nadaaaita commited on
Commit
b1e6513
·
1 Parent(s): 8d810fe

Remove notebooks folder from Git tracking

Browse files
notebooks/01 Basic Chatbot.ipynb DELETED
@@ -1,601 +0,0 @@
1
- {
2
- "cells": [
3
- {
4
- "cell_type": "code",
5
- "execution_count": 8,
6
- "metadata": {},
7
- "outputs": [
8
- {
9
- "name": "stdout",
10
- "output_type": "stream",
11
- "text": [
12
- "srf-chatbot\n",
13
- "The autoreload extension is already loaded. To reload it, use:\n",
14
- " %reload_ext autoreload\n"
15
- ]
16
- }
17
- ],
18
- "source": [
19
- "from dotenv import load_dotenv\n",
20
- "from typing import Annotated\n",
21
- "from typing_extensions import TypedDict\n",
22
- "from langchain.tools import tool\n",
23
- "from langchain.schema import Document\n",
24
- "from langgraph.graph import StateGraph, START, END\n",
25
- "from langgraph.graph.message import add_messages\n",
26
- "from langgraph.prebuilt import ToolNode, tools_condition\n",
27
- "from langgraph.checkpoint.memory import MemorySaver\n",
28
- "from langchain_openai import ChatOpenAI\n",
29
- "from langchain_core.prompts import ChatPromptTemplate, SystemMessagePromptTemplate, AIMessagePromptTemplate, HumanMessagePromptTemplate\n",
30
- "from langchain.schema import SystemMessage, HumanMessage, AIMessage\n",
31
- "\n",
32
- "from IPython.display import Image, display\n",
33
- "import sys\n",
34
- "import os\n",
35
- "\n",
36
- "load_dotenv('/Users/nadaa/Documents/code/langgraph_learning/.env')\n",
37
- "print(os.environ['LANGCHAIN_PROJECT'])\n",
38
- "\n",
39
- "sys.path.append(os.path.abspath('..'))\n",
40
- "%load_ext autoreload\n",
41
- "%autoreload 2\n",
42
- "\n",
43
- "import src.utils.qdrant_manager as qm\n",
44
- "\n",
45
- "\n",
46
- "\n"
47
- ]
48
- },
49
- {
50
- "cell_type": "markdown",
51
- "metadata": {},
52
- "source": [
53
- "# Build a Basic Chatbot"
54
- ]
55
- },
56
- {
57
- "cell_type": "code",
58
- "execution_count": 2,
59
- "metadata": {},
60
- "outputs": [
61
- {
62
- "data": {
63
- "image/jpeg": "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",
64
- "text/plain": [
65
- "<IPython.core.display.Image object>"
66
- ]
67
- },
68
- "metadata": {},
69
- "output_type": "display_data"
70
- }
71
- ],
72
- "source": [
73
- "class State(TypedDict):\n",
74
- " # Messages have the type \"list\". The `add_messages` function\n",
75
- " # in the annotation defines how this state key should be updated\n",
76
- " # (in this case, it appends messages to the list, rather than overwriting them)\n",
77
- " messages: Annotated[list, add_messages]\n",
78
- "\n",
79
- "graph_builder = StateGraph(State)\n",
80
- "\n",
81
- "llm = ChatOpenAI(model='gpt-4o-mini', temperature=0.5)\n",
82
- "\n",
83
- "def chatbot(state: State):\n",
84
- " return {\"messages\": [llm.invoke(state[\"messages\"])]}\n",
85
- "\n",
86
- "# Creating a name for the node and specifying the function.\n",
87
- "# The messages that hte chatbot function returns will be added to the state\n",
88
- "graph_builder.add_node(\"chatbot\", chatbot)\n",
89
- "# Add a starting point\n",
90
- "graph_builder.add_edge(START, \"chatbot\")\n",
91
- "# Add an ending point\n",
92
- "graph_builder.add_edge(\"chatbot\", END)\n",
93
- "# Compile the graph\n",
94
- "graph = graph_builder.compile()\n",
95
- "\n",
96
- "try:\n",
97
- " display(Image(graph.get_graph().draw_mermaid_png()))\n",
98
- "except Exception:\n",
99
- " # This requires some extra dependencies and is optional\n",
100
- " pass\n"
101
- ]
102
- },
103
- {
104
- "cell_type": "code",
105
- "execution_count": 3,
106
- "metadata": {},
107
- "outputs": [
108
- {
109
- "name": "stdout",
110
- "output_type": "stream",
111
- "text": [
112
- "Goodbye!\n"
113
- ]
114
- }
115
- ],
116
- "source": [
117
- "# Use streaming\n",
118
- "while True:\n",
119
- " user_input = input(\"User: \")\n",
120
- " if user_input.lower() in [\"quit\", \"exit\", \"q\"]:\n",
121
- " print(\"Goodbye!\")\n",
122
- " break\n",
123
- " for event in graph.stream({\"messages\": (\"user\", user_input)}):\n",
124
- " for value in event.values():\n",
125
- " print(\"Assistant:\", value[\"messages\"][-1].content)"
126
- ]
127
- },
128
- {
129
- "cell_type": "code",
130
- "execution_count": 17,
131
- "metadata": {},
132
- "outputs": [
133
- {
134
- "data": {
135
- "text/plain": [
136
- "{'messages': [HumanMessage(content='tell me a joke', additional_kwargs={}, response_metadata={}, id='489e1ce6-64eb-4033-af63-f1479d2cb9f8'),\n",
137
- " AIMessage(content='Why did the scarecrow win an award?\\n\\nBecause he was outstanding in his field!', additional_kwargs={'refusal': None}, response_metadata={'token_usage': {'completion_tokens': 17, 'prompt_tokens': 11, 'total_tokens': 28, 'completion_tokens_details': {'reasoning_tokens': 0}}, 'model_name': 'gpt-4o-mini-2024-07-18', 'system_fingerprint': 'fp_483d39d857', 'finish_reason': 'stop', 'logprobs': None}, id='run-29a969e4-b3db-4a7f-ad58-263c2b3be67e-0', usage_metadata={'input_tokens': 11, 'output_tokens': 17, 'total_tokens': 28})]}"
138
- ]
139
- },
140
- "execution_count": 17,
141
- "metadata": {},
142
- "output_type": "execute_result"
143
- }
144
- ],
145
- "source": [
146
- "# Note that when using invoke you must pass a dictionary where the key is messages and the value is a list of dictionaries with the messages and includes role and content\n",
147
- "graph.invoke({'messages':[{'role': 'user', 'content': 'tell me a joke' }]})"
148
- ]
149
- },
150
- {
151
- "cell_type": "markdown",
152
- "metadata": {},
153
- "source": [
154
- "# Chatbot with Vector Look-Up"
155
- ]
156
- },
157
- {
158
- "cell_type": "code",
159
- "execution_count": 9,
160
- "metadata": {},
161
- "outputs": [
162
- {
163
- "name": "stderr",
164
- "output_type": "stream",
165
- "text": [
166
- "/Users/nadaa/Documents/code/py_innovations/srf_chatbot_v2/src/utils/qdrant_manager.py:51: LangChainDeprecationWarning: The class `Qdrant` was deprecated in LangChain 0.1.2 and will be removed in 0.5.0. Use :class:`~QdrantVectorStore` instead.\n",
167
- " self.qdrant = Qdrant(\n"
168
- ]
169
- },
170
- {
171
- "data": {
172
- "image/jpeg": "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",
173
- "text/plain": [
174
- "<IPython.core.display.Image object>"
175
- ]
176
- },
177
- "metadata": {},
178
- "output_type": "display_data"
179
- }
180
- ],
181
- "source": [
182
- "\n",
183
- "chatbot_instructions = \"\"\"You are a helpful assistant for people that want to query and research the teachings of \n",
184
- "Paramhansa Yogananda and the Self-Realization Fellowship. You will only answer questions that are related to the teachings.\n",
185
- "Provide compassionate and insightful responses that are grounded only in the context provided. \n",
186
- "Instructions:\n",
187
- "- Ask follow-up questions if needed to clarify the question\n",
188
- "- Query the vector database multiple times if the user query contains a question or questions that span multiple topics\n",
189
- "- Include direct quotes whenever possible. \n",
190
- "- Provide a list of recommended reading when you output your answer\n",
191
- "- Provide up to three suggestions for followup questions\n",
192
- "\n",
193
- "\"\"\"\n",
194
- "\n",
195
- "# Create the system message\n",
196
- "system_message = SystemMessage(content=chatbot_instructions)\n",
197
- "\n",
198
- "# Modify the LLM initialization\n",
199
- "llm = ChatOpenAI(model='gpt-4o-mini', temperature=0.5)\n",
200
- "\n",
201
- "memory = MemorySaver()\n",
202
- "# Setup the state\n",
203
- "class State(TypedDict):\n",
204
- " # Messages have the type \"list\". The `add_messages` function\n",
205
- " # in the annotation defines how this state key should be updated\n",
206
- " # (in this case, it appends messages to the list, rather than overwriting them)\n",
207
- " messages: Annotated[list, add_messages]\n",
208
- "\n",
209
- "graph_builder = StateGraph(State)\n",
210
- "\n",
211
- "llm = ChatOpenAI(model=\"gpt-4o-mini\", temperature=0.5)\n",
212
- "\n",
213
- "\n",
214
- "# Get vectorstore from qdrant\n",
215
- "qdrant = qm.QdrantManager(collection_name=\"openai_large_chunks_1500char\")\n",
216
- "vectorstore = qdrant.get_vectorstore()\n",
217
- "\n",
218
- "# Create my vector search tool\n",
219
- "@tool\n",
220
- "def vector_search(query: str, k: int = 5) -> list[Document]:\n",
221
- " \"\"\"Search a vector database for passages from the teachings of Paramhansa Yogananda and other publications from the Self Realization Fellowship (SRF).\n",
222
- " The user has the option to specify the number of passages they want the search to return, otherwise the number of passages will be set to the default value.\"\"\"\n",
223
- " retriever = vectorstore.as_retriever(search_kwargs={\"k\": k})\n",
224
- " documents = retriever.invoke(query)\n",
225
- " return documents\n",
226
- "\n",
227
- "# Create a list of tools and bind them to the LLM\n",
228
- "tools=[vector_search]\n",
229
- "llm_with_tools = llm.bind_tools(tools)\n",
230
- "\n",
231
- "# Add the system message onto the llm\n",
232
- "def chatbot(state: State):\n",
233
- " messages = [system_message] + state[\"messages\"]\n",
234
- " return {\"messages\": [llm_with_tools.invoke(messages)]}\n",
235
- "\n",
236
- "# Create and add a tool node\n",
237
- "tool_node = ToolNode(tools)\n",
238
- "graph_builder.add_node(\"tools\", tool_node)\n",
239
- "graph_builder.add_node(\"chatbot\", chatbot)\n",
240
- "\n",
241
- "# Add a conditional edge wherein the chatbot can decide whether or not to go to the tools\n",
242
- "graph_builder.add_conditional_edges(\n",
243
- " \"chatbot\",\n",
244
- " tools_condition,\n",
245
- ")\n",
246
- "\n",
247
- "# Any time a tool is called, we return to the chatbot to decide the next step\n",
248
- "graph_builder.add_edge(\"tools\", \"chatbot\")\n",
249
- "graph_builder.add_edge(START, \"chatbot\")\n",
250
- "\n",
251
- "# Recompile the graph with the new structure\n",
252
- "graph = graph_builder.compile(checkpointer=memory)\n",
253
- "\n",
254
- "# Visualize the updated graph\n",
255
- "try:\n",
256
- " display(Image(graph.get_graph().draw_mermaid_png()))\n",
257
- "except Exception:\n",
258
- " # This requires some extra dependencies and is optional\n",
259
- " pass\n"
260
- ]
261
- },
262
- {
263
- "cell_type": "code",
264
- "execution_count": 5,
265
- "metadata": {},
266
- "outputs": [
267
- {
268
- "name": "stdout",
269
- "output_type": "stream",
270
- "text": [
271
- "Assistant: \n",
272
- "Assistant: [Document(metadata={'split_id_uuid': 'e0d78426-d586-464d-ab83-fa1b4c6d74f1', 'split_id_sequential': 282, 'chapter_name': 'Intuition Develops Through Meditation', 'publication_name': 'Journey to Self-Realization', '_id': '40595e45-e286-43da-adad-fb54de68b614', '_collection_name': 'openai_large_chunks_1500char'}, page_content='A joy and peace will strike your heart. When that comes, you know that you are communing with God. If you make the effort, you shall contact that Power. Give yourself that opportunity. You cannot succeed unless you try. If you spend your life in constant excitement, you will never know true happiness. Live simply and take life more easily. Happiness lies in giving yourself time to think and to introspect. Be alone once in a while, and remain more in silence. If the radio is going all the time, or other stimuli are constantly bombarding the senses, it truly affects the nerves and creates nervousness. And don’t think so much about reforming others; reform yourself first. The greatest field of victory is your own home. If you are an angel at home, you can be an angel everywhere. The sweetness of your voice, the peace of your behaviour, is needed in your own household more than anywhere else.'), Document(metadata={'split_id_sequential': 716, 'publication_name': 'Journey to Self-Realization', 'chapter_name': 'Use Tact; Persons Are Not Unfeeling Stones', 'split_id_uuid': '7b8ee071-2240-4db1-b967-4b3f47bc9933', '_id': '667c9cc7-6f35-4c9f-b8b0-e9b2c6e99fab', '_collection_name': 'openai_large_chunks_1500char'}, page_content='Find your peace by meditating regularly and deeply, and you will be surprised to see how your relationships with others improve. Also develop your power of usefulness. That is love. Think about that. Learn to be serviceful to others—useful with positive thoughts; useful with your speech; useful with constructive suggestions. But do not give advice where it is not wanted; if your suggestions are unwelcome, have the control to remain silent. And when sometimes you do good to others and then can no longer help them in a material way, if they become inimical because they continue to expect from you, never mind; go on doing what is right. Do the best you can and forget it.'), Document(metadata={'split_id_sequential': 75, 'publication_name': 'Journey to Self-Realization', 'split_id_uuid': '1b706451-f27f-4466-8b44-f1fb17c80a69', 'chapter_name': 'Be a Conqueror of Hearts', '_id': '6714c2d3-f32a-42e6-bcf3-49f24cfb3d40', '_collection_name': 'openai_large_chunks_1500char'}, page_content='That is a lesson given to strengthen us, to bring out our hidden powers. But instead, the contradiction of desires causes anger. When desires are thwarted and we are caught in the paroxysm of anger, the mind becomes befogged and we forget our position and lose our discrimination; and when we act without discrimination, errors and unhappiness follow.2 If you never get angry at life’s reverses, or at their human instigators, you can see your way more clearly through whatever is going on around you. That is why your peace is to be guarded above everything else. If you can retain your inner peace, therein lies your supreme victory. No matter how you are situated in life, never feel justified in losing your peace. When that is gone and you cannot think clearly, you have lost the battle. If you never lose your peace, you will find you are always victorious, no matter what the outcome of your problems. That is the way to conquer life. You have nothing to fear. If you have to be afraid at all, be afraid only of yourself. But if you do everything with sincerity and love in your heart, you do not have to fear anybody or anything. As you find your soul-reservoir of peace, less and less controversy will be able to afflict your life. One who loves God lives in the soul, his true Self. He does everything for God, nothing for himself. He loves everybody, because he sees the world as the Lord’s cosmic show.'), Document(metadata={'split_id_uuid': '9f26c821-5e3c-4746-806a-54edd5df5a3a', 'publication_name': 'Journey to Self-Realization', 'chapter_name': 'Use Tact; Persons Are Not Unfeeling Stones', 'split_id_sequential': 715, '_id': 'e066e97f-21a6-446d-be4d-e28f9ca4d20f', '_collection_name': 'openai_large_chunks_1500char'}, page_content='After doing so, I said, “Now, I am not going to shut you out of my classes. But you must promise me that you will not talk against anyone during the class series. Do not think of yourselves as teachers. As long as there is prideful desire to teach, you are not qualified to teach. First you yourself must live it. If you do that, others will follow your example.” And do you know that hour after hour they attended the classes and didn’t once disturb anyone. They were the meekest of students. You see, I got along with them all right because I did not get angry. I used tact to bring them to the sudden realization of their mental weaknesses. But getting along with others cannot be done only by tact. It also requires example, calmness, evenness of mind, sincerity, joy, doing everything in an honourable way; not clinging to pride and egotism; and not governing your actions by what everybody else does, but doing those things that please God. Find your peace by meditating regularly and deeply, and you will be surprised to see how your relationships with others improve. Also develop your power of usefulness. That is love. Think about that. Learn to be serviceful to others—useful with positive thoughts; useful with your speech; useful with constructive suggestions. But do not give advice where it is not wanted; if your suggestions are unwelcome, have the control to remain silent.'), Document(metadata={'chapter_number': 61, 'publication_name': 'The Second Coming of Christ', 'split_id_sequential': 2217, 'split_id_uuid': '7e3cc238-62a7-4ad4-8da2-f26f25e2da99', 'chapter_name': 'Discourse 61 - “The Kingdom Of God Is Within You”', '_id': 'e9c475cd-898c-4368-b502-4bf783a88d9a', '_collection_name': 'openai_large_chunks_1500char'}, page_content='The yogi begins with proper deep breathing, inhaling and tensing the whole body, exhaling and relaxing, several times. With each exhalation all muscular tension and motion should be cast away, until a state of bodily stillness is attained. Then, by concentration techniques, restless motion is removed from the mind. In perfect stillness of body and mind, the yogi enjoys the ineffable peace of the presence of the soul. In the body, life is templed; in the mind, light is templed; in the soul, peace is templed. The deeper one goes into the soul the more that peace is felt; that is superconsciousness. When by deeper meditation the devotee expands that awareness of peace and feels his consciousness spreading with it over the universe, that all beings and all creation are swallowed up in that peace, then he is entering into Cosmic Consciousness. He feels that peace everywhere—in the flowers, in every human being, in the atmosphere. He beholds the earth and all worlds floating like bubbles in that ocean of peace.14 The inner peace first experienced by the devotee in meditation is his own soul; the vaster peace he feels by going deeper is God. The devotee who experiences unity with everything has established God in the temple of his infinite inner perception. In the temple of silence, in the temple of peace, I will meet Thee, I will touch Thee, I will love Thee, And coax Thee to my altar of peace.')]\n",
273
- "Assistant: To cultivate a greater sense of peace in your life, Paramhansa Yogananda's teachings emphasize several key practices and attitudes:\n",
274
- "\n",
275
- "1. **Meditation**: Regular and deep meditation is fundamental. Yogananda teaches that \"Find your peace by meditating regularly and deeply, and you will be surprised to see how your relationships with others improve.\" Meditation helps quiet the mind and connect with a deeper state of peace.\n",
276
- "\n",
277
- "2. **Simplicity and Introspection**: Living simply and allowing time for introspection can lead to happiness. Yogananda advises, \"Happiness lies in giving yourself time to think and to introspect.\" This means taking moments of solitude to reflect and connect with your inner self.\n",
278
- "\n",
279
- "3. **Guarding Your Peace**: It's crucial to maintain your inner peace, regardless of external circumstances. Yogananda states, \"If you never lose your peace, you will find you are always victorious, no matter what the outcome of your problems.\" This involves not allowing anger or frustration to derail your calmness.\n",
280
- "\n",
281
- "4. **Service to Others**: Engaging in acts of kindness and being useful to others fosters love and peace. Yogananda suggests, \"Learn to be serviceful to others—useful with positive thoughts; useful with your speech; useful with constructive suggestions.\" \n",
282
- "\n",
283
- "5. **Breath and Stillness**: Practicing proper deep breathing and achieving bodily stillness can enhance your sense of peace. Yogananda describes, \"In perfect stillness of body and mind, the yogi enjoys the ineffable peace of the presence of the soul.\"\n",
284
- "\n",
285
- "Incorporating these practices into your daily routine can help you cultivate a more peaceful state of being.\n",
286
- "\n",
287
- "### Recommended Reading:\n",
288
- "- **\"Journey to Self-Realization\"** by Paramhansa Yogananda\n",
289
- "- **\"The Second Coming of Christ\"** by Paramhansa Yogananda\n",
290
- "\n",
291
- "### Follow-Up Questions:\n",
292
- "1. What specific challenges do you face that disrupt your peace?\n",
293
- "2. Have you tried meditation before, and if so, what was your experience?\n",
294
- "3. Are there particular areas in your life where you feel you could be more serviceful to others?\n",
295
- "Goodbye!\n"
296
- ]
297
- }
298
- ],
299
- "source": [
300
- "# Use streaming\n",
301
- "config = {\"configurable\": {\"thread_id\": \"1\"}}\n",
302
- "\n",
303
- "while True:\n",
304
- " user_input = input(\"User: \")\n",
305
- " if user_input.lower() in [\"quit\", \"exit\", \"q\"]:\n",
306
- " print(\"Goodbye!\")\n",
307
- " break\n",
308
- " for event in graph.stream({\"messages\": (\"user\", user_input)}, config):\n",
309
- " for value in event.values():\n",
310
- " print(\"Assistant:\", value[\"messages\"][-1].content)"
311
- ]
312
- },
313
- {
314
- "cell_type": "code",
315
- "execution_count": 10,
316
- "metadata": {},
317
- "outputs": [],
318
- "source": [
319
- "config = {\"configurable\": {\"thread_id\": \"1\"}}\n",
320
- "result = graph.invoke({\"messages\":[{\"role\": \"user\", \"content\": \"Search the vector database on the importance of a true guru, return the full passages returned from the vector search verbatim and bold the most important quotes\"}]}, config)\n"
321
- ]
322
- },
323
- {
324
- "cell_type": "code",
325
- "execution_count": 11,
326
- "metadata": {},
327
- "outputs": [
328
- {
329
- "name": "stdout",
330
- "output_type": "stream",
331
- "text": [
332
- "Here are the full passages from the teachings of Paramhansa Yogananda regarding the importance of a true guru, with key quotes emphasized:\n",
333
- "\n",
334
- "1. **\"It is admirable to lecture and teach good principles; but without possessing the qualifications of a real guru a teacher cannot redeem souls, nor should he presume to accept others as disciples until he himself has progressed far in his own Self-realization.\"** True gurus train first their inner selves in the theologically advanced school of intuition and God-communion in meditation. They spiritually baptize themselves in Spirit before they aspire to initiate others. They teach not for mundane gain or glory, but for the singular purpose of leading souls to God. A guru never seeks for himself the devotion and obedience of his disciples, but transfers that reverence to God. It is not necessary for a disciple to be in the company of the guru in order to receive his blessings. What is most important is to be spiritually in tune with the guru, for his help is transferred to the disciple primarily on the inner spiritual plane rather than through material means.\n",
335
- "\n",
336
- "2. **\"A guru is not an ordinary spiritual teacher.\"** One may have many teachers, but only one guru, who is the agent of salvation appointed by God in response to a devotee’s demands for release from the bondage of matter. Ministers in churches and priests in temples are oftentimes chosen only by a set standard of their intellectual knowledge of the scriptures, or by virtue of sacerdotal authority ceremonially conferred on them by a formally higher ecclesiastical superior. No guru can be developed only by years of study in the intellectual factory of a theological seminary, which deems it has attained its ends when it confers B.D. or D.D. degrees. Such titles can be won by men of good memory; but character, self-control, and the wisdom of soul intuition can be cultured only by knowledge and application of advanced methods of deep daily meditation that produce Self-realization and actual experience of God.\n",
337
- "\n",
338
- "3. **\"Discretion and caution are particularly necessary in accepting a guru.\"** One may have many teachers in the beginning of his search, but when one’s heart and soul are confidently settled in a guru-disciple relationship ordained and blessed by God, the disciple has only one guru, and no other teachers thereafter. The devotee remains loyal to such a guru, being spiritually fulfilled by the God-sent messenger. To forsake the guru and his ideals is to spurn the help sent by God, the One Guru of gurus. **\"Unconditional love, loyalty, and obedience are hallmarks of the guru-disciple relationship.\"** The spiritual soul contact between guru and disciple is one of eternal, unconditional divine love and friendship, bearing no taint of any selfish consideration.\n",
339
- "\n",
340
- "4. **\"Of the total requirement to achieve salvation, it is said that 25% is the disciple’s spiritual effort, 25% is the blessing of the guru, and the remaining 50% is the grace of God.\"** The aspirant should not be tempted into complacency, however, waiting to be moved by the spirit of the blessings and grace, for it is the catalyst of the devotee’s effort that makes the formula work. As the devotee’s effort and the guru’s blessings are equally necessary to the disciple’s progress, we are taught in India the first requisite importance on the spiritual path of following faithfully one’s guru.\n",
341
- "\n",
342
- "5. **\"What is most important is to be spiritually in tune with the guru.\"** If the disciple is uncarping, unconditionally reverential and loving to the master, and faithful in following his precepts, his receptivity makes the task of the guru easier. Attunement links the help of the guru with the sincere striving of the disciple, even if the guru is no longer incarnate on earth.\n",
343
- "\n",
344
- "### Recommended Reading:\n",
345
- "- \"The Second Coming of Christ\" by Paramhansa Yogananda\n",
346
- "- \"Autobiography of a Yogi\" by Paramhansa Yogananda\n",
347
- "- \"The Yoga of Jesus\" by Paramhansa Yogananda\n",
348
- "\n",
349
- "### Follow-Up Questions:\n",
350
- "1. What qualities should one look for in a true guru?\n",
351
- "2. How can a disciple cultivate a deeper connection with their guru?\n",
352
- "3. Can the teachings of a guru be accessed without physical presence?\n"
353
- ]
354
- }
355
- ],
356
- "source": [
357
- "print(result['messages'][-1].content)"
358
- ]
359
- },
360
- {
361
- "cell_type": "code",
362
- "execution_count": 15,
363
- "metadata": {},
364
- "outputs": [],
365
- "source": [
366
- "config = {\"configurable\": {\"thread_id\": \"1\"}}\n",
367
- "result = graph.invoke({\"messages\":[{\"role\": \"user\", \"content\": \"Summarize in a nice paragraph format what yogananda says about introspection. At the end of the summary provide supporting quotes and resources.\"}]}, config)\n"
368
- ]
369
- },
370
- {
371
- "cell_type": "code",
372
- "execution_count": 16,
373
- "metadata": {},
374
- "outputs": [
375
- {
376
- "name": "stdout",
377
- "output_type": "stream",
378
- "text": [
379
- "Paramhansa Yogananda emphasizes the significance of introspection as a crucial practice for spiritual development and self-awareness. He describes introspection as a \"wonderful mirror\" that allows individuals to evaluate their thoughts and actions, promoting moral and spiritual growth. By reflecting on oneself, particularly in the light of a guru's wisdom, one can gain deeper insights and clarity. Yogananda advocates for accepting criticism as a sign of spiritual strength, encouraging individuals to learn from feedback and continuously strive for improvement. He also highlights the importance of deep thinking, asserting that concentrated reflection can lead to profound understanding and peace. Ultimately, Yogananda underscores personal responsibility, urging individuals to prioritize self-correction over the tendency to criticize others. This holistic approach to introspection is seen as essential on the path to self-realization and divine connection.\n",
380
- "\n",
381
- "### Supporting Quotes:\n",
382
- "- **\"Introspection is a wonderful mirror in which to judge oneself.\"**\n",
383
- "- **\"Even more accurate than that mirror is one’s reflection in the mirror of a wise man’s mind.\"**\n",
384
- "- **\"To be able humbly to stand the barbs of criticism, just or unjust, and to make continuous effort to improve one’s attitudes and behavior when criticism is justified, will make one a saint.\"**\n",
385
- "- **\"Without deep thinking, concentration of the mind, one will never find the way to God.\"**\n",
386
- "\n",
387
- "### Recommended Resources:\n",
388
- "- **\"The Second Coming of Christ\"** by Paramhansa Yogananda\n",
389
- "- **\"Journey to Self-Realization\"** by Paramhansa Yogananda\n"
390
- ]
391
- }
392
- ],
393
- "source": [
394
- "print(result['messages'][-1].content)"
395
- ]
396
- },
397
- {
398
- "cell_type": "code",
399
- "execution_count": 17,
400
- "metadata": {},
401
- "outputs": [],
402
- "source": [
403
- "config = {\"configurable\": {\"thread_id\": \"1\"}}\n",
404
- "result = graph.invoke({\"messages\":[{\"role\": \"user\", \"content\": \"Find 20 passages on introspection and identify the subtopics that emerge.\"}]}, config)\n"
405
- ]
406
- },
407
- {
408
- "cell_type": "code",
409
- "execution_count": 18,
410
- "metadata": {},
411
- "outputs": [
412
- {
413
- "name": "stdout",
414
- "output_type": "stream",
415
- "text": [
416
- "Here are 20 passages on introspection from the teachings of Paramhansa Yogananda, along with the subtopics that emerge from these reflections:\n",
417
- "\n",
418
- "1. **Introspection as Self-Judgment**: Yogananda describes introspection as a \"wonderful mirror\" for self-assessment, emphasizing the importance of judging oneself rather than others.\n",
419
- "\n",
420
- "2. **Guidance from a Guru**: He highlights the value of seeing oneself through the lens of a wise guru, stating that their insights can lead to spiritual transformation.\n",
421
- "\n",
422
- "3. **Strength in Criticism**: Yogananda notes that the ability to accept criticism is a sign of spiritual strength and encourages individuals to use criticism as a tool for self-improvement.\n",
423
- "\n",
424
- "4. **Deep Thinking**: He advocates for deep thinking as a means to cultivate introspection, suggesting that it allows individuals to dive deeper into their thoughts and gain clarity and peace.\n",
425
- "\n",
426
- "5. **Personal Responsibility**: Yogananda emphasizes the importance of personal responsibility in self-correction, urging individuals to focus on their own flaws rather than criticizing others.\n",
427
- "\n",
428
- "6. **Inner Peace**: He warns against the negative effects of harboring critical thoughts about others, suggesting that such negativity disrupts one's inner peace.\n",
429
- "\n",
430
- "7. **The Role of Intuition**: Yogananda connects introspection to the development of intuition, stating that a calm mind allows for greater intuitive understanding and insight.\n",
431
- "\n",
432
- "8. **Meditation and Introspection**: He stresses that meditation is essential for developing introspection, as it helps clear the mind and facilitates deeper self-examination.\n",
433
- "\n",
434
- "9. **The Nature of Truth**: Yogananda discusses the need for honest self-scrutiny, suggesting that true understanding of one's nature requires confronting uncomfortable truths.\n",
435
- "\n",
436
- "10. **Avoiding Hypocrisy**: He warns against the dangers of hypocrisy, advocating for sincere self-reflection rather than the superficial acknowledgment of faults.\n",
437
- "\n",
438
- "11. **Self-Enquiry**: Yogananda encourages self-enquiry as a means to uncover deeper truths about oneself, promoting questions like \"Who am I?\" and \"What is my purpose?\"\n",
439
- "\n",
440
- "12. **The Importance of Silence**: He suggests that spending time in silence is crucial for introspection, allowing individuals to connect with their inner selves.\n",
441
- "\n",
442
- "13. **Judgment vs. Observation**: Yogananda differentiates between judgment and observation, advocating for a neutral perspective that focuses on understanding rather than criticizing.\n",
443
- "\n",
444
- "14. **Transformation through Introspection**: He believes that introspection leads to personal transformation, enabling individuals to align more closely with their true selves.\n",
445
- "\n",
446
- "15. **The Dangers of External Validation**: Yogananda cautions against seeking validation from others, emphasizing that true worth comes from self-knowledge and inner peace.\n",
447
- "\n",
448
- "16. **The Impact of Environment**: He notes that one's environment can influence thoughts and feelings, highlighting the importance of cultivating a positive inner space.\n",
449
- "\n",
450
- "17. **Self-Reflection as a Path to God**: Yogananda teaches that introspection can lead to a deeper communion with God, as it opens the heart and mind to divine truths.\n",
451
- "\n",
452
- "18. **The Connection between Introspection and Faith**: He connects introspection to the development of faith, suggesting that understanding oneself leads to a stronger connection with the divine.\n",
453
- "\n",
454
- "19. **Ego and Self-Analysis**: Yogananda discusses the role of ego in hindering true self-analysis, urging individuals to confront and transcend their egos.\n",
455
- "\n",
456
- "20. **The Journey of Self-Discovery**: He frames introspection as an ongoing journey of self-discovery, encouraging individuals to continually seek deeper understanding of themselves and their relationship with God.\n",
457
- "\n",
458
- "### Subtopics Identified:\n",
459
- "- Self-Judgment and Self-Assessment\n",
460
- "- Guidance and Influence of a Guru\n",
461
- "- Strength and Growth through Criticism\n",
462
- "- Deep Thinking and Concentration\n",
463
- "- Personal Responsibility in Self-Correction\n",
464
- "- Inner Peace and Mental Clarity\n",
465
- "- Development of Intuition\n",
466
- "- The Role of Meditation in Introspection\n",
467
- "- Honest Self-Enquiry and Truth-Seeking\n",
468
- "- Avoiding Hypocrisy and Sincerity\n",
469
- "- The Importance of Silence for Reflection\n",
470
- "- Observation vs. Judgment\n",
471
- "- Transformation through Self-Reflection\n",
472
- "- The Impact of External Validation\n",
473
- "- The Influence of Environment on Thoughts\n",
474
- "- Introspection as a Path to God\n",
475
- "- Connection between Introspection and Faith\n",
476
- "- Ego and Self-Analysis\n",
477
- "- Ongoing Journey of Self-Discovery\n",
478
- "\n",
479
- "These passages and subtopics provide a comprehensive view of Yogananda's teachings on introspection, highlighting its significance in the spiritual journey. If you have further questions or need more insights, feel free to ask!\n"
480
- ]
481
- }
482
- ],
483
- "source": [
484
- "print(result['messages'][-1].content)"
485
- ]
486
- },
487
- {
488
- "cell_type": "code",
489
- "execution_count": 5,
490
- "metadata": {},
491
- "outputs": [
492
- {
493
- "name": "stdout",
494
- "output_type": "stream",
495
- "text": [
496
- "Running on local URL: http://127.0.0.1:7861\n",
497
- "Running on public URL: https://5c55504e6a49d443ab.gradio.live\n",
498
- "\n",
499
- "This share link expires in 72 hours. For free permanent hosting and GPU upgrades, run `gradio deploy` from Terminal to deploy to Spaces (https://huggingface.co/spaces)\n"
500
- ]
501
- },
502
- {
503
- "data": {
504
- "text/html": [
505
- "<div><iframe src=\"https://5c55504e6a49d443ab.gradio.live\" width=\"100%\" height=\"500\" allow=\"autoplay; camera; microphone; clipboard-read; clipboard-write;\" frameborder=\"0\" allowfullscreen></iframe></div>"
506
- ],
507
- "text/plain": [
508
- "<IPython.core.display.HTML object>"
509
- ]
510
- },
511
- "metadata": {},
512
- "output_type": "display_data"
513
- },
514
- {
515
- "data": {
516
- "text/plain": []
517
- },
518
- "execution_count": 5,
519
- "metadata": {},
520
- "output_type": "execute_result"
521
- }
522
- ],
523
- "source": [
524
- "import gradio as gr\n",
525
- "from langgraph.graph import StateGraph, END\n",
526
- "from langchain_openai import ChatOpenAI\n",
527
- "config = {\"configurable\": {\"thread_id\": \"1\"}}\n",
528
- "\n",
529
- "# Define the chatbot function\n",
530
- "# def chatbot(state):\n",
531
- "# llm = ChatOpenAI()\n",
532
- "# return {\"messages\": state[\"messages\"] + [llm.invoke(state[\"messages\"])]}\n",
533
- "\n",
534
- "# # Create the graph\n",
535
- "# graph = StateGraph()\n",
536
- "\n",
537
- "# # Add the chatbot node\n",
538
- "# graph.add_node(\"chatbot\", chatbot)\n",
539
- "\n",
540
- "# # Define the edges\n",
541
- "# graph.add_edge(graph.START, \"chatbot\")\n",
542
- "# graph.add_edge(\"chatbot\", graph.END)\n",
543
- "\n",
544
- "# # Compile the graph\n",
545
- "# chain = graph.compile()\n",
546
- "\n",
547
- "# Define the Gradio interface\n",
548
- "def respond(message, history):\n",
549
- " # Format the history and new message into the expected structure\n",
550
- " formatted_messages = []\n",
551
- " for human, ai in history:\n",
552
- " formatted_messages.append(HumanMessage(content=human))\n",
553
- " if ai: # AI might not have responded yet\n",
554
- " formatted_messages.append(AIMessage(content=ai))\n",
555
- " \n",
556
- " # Add the new message\n",
557
- " formatted_messages.append(HumanMessage(content=message))\n",
558
- " \n",
559
- " # Invoke the graph with properly formatted input\n",
560
- " result = graph.invoke({\"messages\": formatted_messages}, config)\n",
561
- " \n",
562
- " # Extract the assistant's response\n",
563
- " response = result[\"messages\"][-1].content\n",
564
- " \n",
565
- " return response\n",
566
- "\n",
567
- "# Create and launch the Gradio interface\n",
568
- "gradio = gr.ChatInterface(respond)\n",
569
- "gradio.launch(share=True)\n"
570
- ]
571
- },
572
- {
573
- "cell_type": "code",
574
- "execution_count": null,
575
- "metadata": {},
576
- "outputs": [],
577
- "source": []
578
- }
579
- ],
580
- "metadata": {
581
- "kernelspec": {
582
- "display_name": "srf_chatbot_v2",
583
- "language": "python",
584
- "name": "srf_chatbot_v2"
585
- },
586
- "language_info": {
587
- "codemirror_mode": {
588
- "name": "ipython",
589
- "version": 3
590
- },
591
- "file_extension": ".py",
592
- "mimetype": "text/x-python",
593
- "name": "python",
594
- "nbconvert_exporter": "python",
595
- "pygments_lexer": "ipython3",
596
- "version": "3.11.9"
597
- }
598
- },
599
- "nbformat": 4,
600
- "nbformat_minor": 2
601
- }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
notebooks/02 Chatbot with custom system prompt.ipynb DELETED
@@ -1,287 +0,0 @@
1
- {
2
- "cells": [
3
- {
4
- "cell_type": "code",
5
- "execution_count": 5,
6
- "metadata": {},
7
- "outputs": [
8
- {
9
- "name": "stdout",
10
- "output_type": "stream",
11
- "text": [
12
- "Running on local URL: http://127.0.0.1:7864\n",
13
- "\n",
14
- "To create a public link, set `share=True` in `launch()`.\n"
15
- ]
16
- },
17
- {
18
- "data": {
19
- "text/html": [
20
- "<div><iframe src=\"http://127.0.0.1:7864/\" width=\"100%\" height=\"500\" allow=\"autoplay; camera; microphone; clipboard-read; clipboard-write;\" frameborder=\"0\" allowfullscreen></iframe></div>"
21
- ],
22
- "text/plain": [
23
- "<IPython.core.display.HTML object>"
24
- ]
25
- },
26
- "metadata": {},
27
- "output_type": "display_data"
28
- },
29
- {
30
- "data": {
31
- "text/plain": []
32
- },
33
- "execution_count": 5,
34
- "metadata": {},
35
- "output_type": "execute_result"
36
- }
37
- ],
38
- "source": [
39
- "import gradio as gr\n",
40
- "\n",
41
- "# Define some pre-written templates\n",
42
- "templates = {\n",
43
- " \"Friendly Chatbot\": \"You are a helpful, friendly chatbot that engages in light-hearted conversations.\",\n",
44
- " \"Technical Assistant\": \"You are a technical assistant specialized in answering questions related to Python programming.\",\n",
45
- " \"Nutrition Advisor\": \"You provide evidence-based advice on nutrition and healthy eating habits.\",\n",
46
- "}\n",
47
- "\n",
48
- "# Chatbot logic: Takes system instructions and user query, returns a response\n",
49
- "def chatbot_response(system_instructions, user_query):\n",
50
- " if \"friendly\" in system_instructions.lower():\n",
51
- " return f\"Friendly Chatbot says: Hi there! 😊 How can I assist you today?\"\n",
52
- " elif \"technical\" in system_instructions.lower():\n",
53
- " return f\"Technical Assistant says: Sure! Here's some information on Python: {user_query}\"\n",
54
- " elif \"nutrition\" in system_instructions.lower():\n",
55
- " return f\"Nutrition Advisor says: Here's some advice about healthy eating: {user_query}\"\n",
56
- " else:\n",
57
- " return f\"Custom Chatbot says: {user_query}\"\n",
58
- "\n",
59
- "# Function to update the interface when a selection is made from the dropdown\n",
60
- "def update_interface(template_name, custom_instructions):\n",
61
- " if template_name == \"Custom Instructions\":\n",
62
- " return gr.update(visible=True), gr.update(visible(False))\n",
63
- " else:\n",
64
- " template_content = templates.get(template_name, \"\")\n",
65
- " return gr.update(visible=False), gr.update(visible=True, value=template_content)\n",
66
- "\n",
67
- "# Chatbot conversation function\n",
68
- "def chatbot_conversation(system_instructions, chat_history, user_query):\n",
69
- " response = chatbot_response(system_instructions, user_query)\n",
70
- " chat_history.append((user_query, response))\n",
71
- " return chat_history, \"\"\n",
72
- "\n",
73
- "# Build the Gradio interface\n",
74
- "with gr.Blocks() as demo:\n",
75
- " \n",
76
- " # Add the title and description\n",
77
- " gr.Markdown(\"# **SRF Innovation Labs - AI Chatbot Use Case Explorer**\")\n",
78
- " gr.Markdown(\"\"\"\n",
79
- " Welcome to the SRF Innovation Labs AI Chatbot Use Case Explorer! \n",
80
- " This tool allows you to experiment with different system prompts, \n",
81
- " giving you control over how the chatbot behaves. You can either use pre-defined templates or write your own custom instructions.\n",
82
- " \n",
83
- " Additionally, the chatbot has access to a vector database where it can look up and retrieve learnings for various queries. \n",
84
- " This makes it an excellent platform for exploring potential AI use cases in real-time.\n",
85
- " \"\"\")\n",
86
- "\n",
87
- " # Section to select system instructions from dropdown\n",
88
- " gr.Markdown(\"## **Chatbot Setup**\")\n",
89
- "\n",
90
- " # Dropdown for selecting a pre-written template or custom instructions\n",
91
- " template_name = gr.Dropdown(choices=[\"Custom Instructions\"] + list(templates.keys()), label=\"Choose Instructions\", value=\"Friendly Chatbot\")\n",
92
- " \n",
93
- " # Textbox for custom chatbot instructions (only shown when \"Custom Instructions\" is selected)\n",
94
- " custom_instructions = gr.Textbox(label=\"Custom Instructions\", visible=False, placeholder=\"Write your own instructions here...\")\n",
95
- " \n",
96
- " # Output field to display the selected pre-written template (not shown when Custom Instructions is selected)\n",
97
- " template_display = gr.Textbox(label=\"Template Content\", interactive=False, visible=True)\n",
98
- " \n",
99
- " # Section for chat interface\n",
100
- " gr.Markdown(\"## **Chatbot Interaction**\")\n",
101
- "\n",
102
- " # Chatbot interface with chat history\n",
103
- " chatbot = gr.Chatbot(label=\"Chatbot Conversation\")\n",
104
- " user_query = gr.Textbox(label=\"Your Query\", placeholder=\"Ask a question or say something to the chatbot...\")\n",
105
- "\n",
106
- " # Button to submit the query\n",
107
- " submit_button = gr.Button(\"Send\")\n",
108
- "\n",
109
- " # Update logic to control the display based on the dropdown selection\n",
110
- " template_name.change(fn=update_interface, \n",
111
- " inputs=[template_name, custom_instructions], \n",
112
- " outputs=[custom_instructions, template_display])\n",
113
- "\n",
114
- " # Chatbot interaction logic\n",
115
- " submit_button.click(fn=chatbot_conversation, \n",
116
- " inputs=[custom_instructions if template_name == \"Custom Instructions\" else template_display, chatbot, user_query], \n",
117
- " outputs=[chatbot, user_query])\n",
118
- "\n",
119
- "# Launch the app\n",
120
- "demo.launch()\n"
121
- ]
122
- },
123
- {
124
- "cell_type": "code",
125
- "execution_count": 6,
126
- "metadata": {},
127
- "outputs": [
128
- {
129
- "name": "stdout",
130
- "output_type": "stream",
131
- "text": [
132
- "Running on local URL: http://127.0.0.1:7865\n",
133
- "\n",
134
- "To create a public link, set `share=True` in `launch()`.\n"
135
- ]
136
- },
137
- {
138
- "data": {
139
- "text/html": [
140
- "<div><iframe src=\"http://127.0.0.1:7865/\" width=\"100%\" height=\"500\" allow=\"autoplay; camera; microphone; clipboard-read; clipboard-write;\" frameborder=\"0\" allowfullscreen></iframe></div>"
141
- ],
142
- "text/plain": [
143
- "<IPython.core.display.HTML object>"
144
- ]
145
- },
146
- "metadata": {},
147
- "output_type": "display_data"
148
- },
149
- {
150
- "data": {
151
- "text/plain": []
152
- },
153
- "execution_count": 6,
154
- "metadata": {},
155
- "output_type": "execute_result"
156
- }
157
- ],
158
- "source": [
159
- "import gradio as gr\n",
160
- "\n",
161
- "# Define some pre-written templates for Tab 1\n",
162
- "templates = {\n",
163
- " \"Friendly Chatbot\": \"You are a helpful, friendly chatbot that engages in light-hearted conversations.\",\n",
164
- " \"Technical Assistant\": \"You are a technical assistant specialized in answering questions related to Python programming.\",\n",
165
- " \"Nutrition Advisor\": \"You provide evidence-based advice on nutrition and healthy eating habits.\",\n",
166
- "}\n",
167
- "\n",
168
- "# Define some agentic workflows for Tab 2\n",
169
- "agentic_workflows = {\n",
170
- " \"Blog Post Generator\": \"This agent is designed to help generate a blog post based on user input.\",\n",
171
- " \"Document Summarizer\": \"This agent summarizes long documents by extracting key points.\",\n",
172
- " \"Task Manager\": \"This agent helps you organize tasks and provides step-by-step guidance.\"\n",
173
- "}\n",
174
- "\n",
175
- "# Chatbot logic for custom instructions or pre-written templates\n",
176
- "def chatbot_response(system_instructions, user_query):\n",
177
- " if \"friendly\" in system_instructions.lower():\n",
178
- " return f\"Friendly Chatbot says: Hi there! 😊 How can I assist you today?\"\n",
179
- " elif \"technical\" in system_instructions.lower():\n",
180
- " return f\"Technical Assistant says: Sure! Here's some information on Python: {user_query}\"\n",
181
- " elif \"nutrition\" in system_instructions.lower():\n",
182
- " return f\"Nutrition Advisor says: Here's some advice about healthy eating: {user_query}\"\n",
183
- " else:\n",
184
- " return f\"Custom Chatbot says: {user_query}\"\n",
185
- "\n",
186
- "# Chatbot conversation function\n",
187
- "def chatbot_conversation(system_instructions, chat_history, user_query):\n",
188
- " response = chatbot_response(system_instructions, user_query)\n",
189
- " chat_history.append((user_query, response))\n",
190
- " return chat_history, \"\"\n",
191
- "\n",
192
- "# Chatbot conversation for predefined agentic workflows\n",
193
- "def agentic_chatbot_conversation(workflow_instructions, chat_history, user_query):\n",
194
- " response = f\"Agent Workflow ({workflow_instructions}) says: {user_query}\"\n",
195
- " chat_history.append((user_query, response))\n",
196
- " return chat_history, \"\"\n",
197
- "\n",
198
- "# Function to update the interface when a selection is made from the dropdown (Tab 1)\n",
199
- "def update_interface(template_name, custom_instructions):\n",
200
- " if template_name == \"Custom Instructions\":\n",
201
- " return gr.update(visible=True), gr.update(visible=False)\n",
202
- " else:\n",
203
- " template_content = templates.get(template_name, \"\")\n",
204
- " return gr.update(visible=False), gr.update(visible=True, value=template_content)\n",
205
- "\n",
206
- "# Build the Gradio interface with Tabs\n",
207
- "with gr.Blocks() as demo:\n",
208
- " \n",
209
- " # Add Tabs\n",
210
- " with gr.Tabs():\n",
211
- " \n",
212
- " # Tab 1: Custom Instructions or Pre-Written Templates\n",
213
- " with gr.Tab(\"Custom Instructions Chatbot\"):\n",
214
- " gr.Markdown(\"# **SRF Innovation Labs - AI Chatbot Use Case Explorer**\")\n",
215
- " gr.Markdown(\"\"\"\n",
216
- " This tool allows you to experiment with different system prompts, \n",
217
- " giving you control over how the chatbot behaves. You can either use pre-defined templates or write your own custom instructions.\n",
218
- " \"\"\")\n",
219
- "\n",
220
- " # Section to select system instructions from dropdown\n",
221
- " gr.Markdown(\"## **Chatbot Setup**\")\n",
222
- " template_name = gr.Dropdown(choices=[\"Custom Instructions\"] + list(templates.keys()), label=\"Choose Instructions\", value=\"Friendly Chatbot\")\n",
223
- " custom_instructions = gr.Textbox(label=\"Custom Instructions\", visible=False, placeholder=\"Write your own instructions here...\")\n",
224
- " template_display = gr.Textbox(label=\"Template Content\", interactive=False, visible=True)\n",
225
- "\n",
226
- " # Chatbot interface\n",
227
- " gr.Markdown(\"## **Chatbot Interaction**\")\n",
228
- " chatbot = gr.Chatbot(label=\"Chatbot Conversation\")\n",
229
- " user_query = gr.Textbox(label=\"Your Query\", placeholder=\"Ask a question or say something to the chatbot...\")\n",
230
- " submit_button = gr.Button(\"Send\")\n",
231
- "\n",
232
- " # Update logic for Tab 1\n",
233
- " template_name.change(fn=update_interface, inputs=[template_name, custom_instructions], outputs=[custom_instructions, template_display])\n",
234
- " submit_button.click(fn=chatbot_conversation, inputs=[custom_instructions if template_name == \"Custom Instructions\" else template_display, chatbot, user_query], outputs=[chatbot, user_query])\n",
235
- "\n",
236
- " # Tab 2: Predefined Agentic Workflows\n",
237
- " with gr.Tab(\"Agentic Workflow Chatbots\"):\n",
238
- " gr.Markdown(\"# **Agentic Workflow Explorer**\")\n",
239
- " gr.Markdown(\"\"\"\n",
240
- " This tab allows you to experiment with different agentic workflows that are predefined. \n",
241
- " Each workflow executes a specific task, such as generating blog posts, summarizing documents, or managing tasks.\n",
242
- " \"\"\")\n",
243
- "\n",
244
- " # Dropdown for selecting agentic workflows\n",
245
- " workflow_name = gr.Dropdown(choices=list(agentic_workflows.keys()), label=\"Choose Agent Workflow\", value=\"Blog Post Generator\")\n",
246
- " workflow_display = gr.Textbox(label=\"Workflow Description\", interactive=False, visible=True)\n",
247
- " workflow_chatbot = gr.Chatbot(label=\"Agent Workflow Conversation\")\n",
248
- " workflow_user_query = gr.Textbox(label=\"Your Query\", placeholder=\"Ask the agent to perform a task...\")\n",
249
- " workflow_submit_button = gr.Button(\"Send\")\n",
250
- "\n",
251
- " # Chatbot interaction for agentic workflows\n",
252
- " workflow_submit_button.click(fn=agentic_chatbot_conversation, inputs=[workflow_name, workflow_chatbot, workflow_user_query], outputs=[workflow_chatbot, workflow_user_query])\n",
253
- "\n",
254
- "# Launch the app\n",
255
- "demo.launch()\n"
256
- ]
257
- },
258
- {
259
- "cell_type": "code",
260
- "execution_count": null,
261
- "metadata": {},
262
- "outputs": [],
263
- "source": []
264
- }
265
- ],
266
- "metadata": {
267
- "kernelspec": {
268
- "display_name": "srf_chatbot_v2",
269
- "language": "python",
270
- "name": "srf_chatbot_v2"
271
- },
272
- "language_info": {
273
- "codemirror_mode": {
274
- "name": "ipython",
275
- "version": 3
276
- },
277
- "file_extension": ".py",
278
- "mimetype": "text/x-python",
279
- "name": "python",
280
- "nbconvert_exporter": "python",
281
- "pygments_lexer": "ipython3",
282
- "version": "3.11.9"
283
- }
284
- },
285
- "nbformat": 4,
286
- "nbformat_minor": 2
287
- }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
notebooks/03 Experimentation Chatbot.ipynb DELETED
@@ -1,697 +0,0 @@
1
- {
2
- "cells": [
3
- {
4
- "cell_type": "code",
5
- "execution_count": 30,
6
- "metadata": {},
7
- "outputs": [
8
- {
9
- "name": "stdout",
10
- "output_type": "stream",
11
- "text": [
12
- "The autoreload extension is already loaded. To reload it, use:\n",
13
- " %reload_ext autoreload\n"
14
- ]
15
- }
16
- ],
17
- "source": [
18
- "from dotenv import load_dotenv\n",
19
- "from typing import Annotated, List, Tuple\n",
20
- "from typing_extensions import TypedDict\n",
21
- "from langchain.tools import tool, BaseTool\n",
22
- "from langchain.schema import Document\n",
23
- "from langgraph.graph import StateGraph, START, END, MessagesState\n",
24
- "from langgraph.graph.message import add_messages\n",
25
- "from langgraph.prebuilt import ToolNode, tools_condition\n",
26
- "from langgraph.checkpoint.memory import MemorySaver\n",
27
- "from langchain_openai import ChatOpenAI\n",
28
- "from langchain_core.prompts import ChatPromptTemplate, SystemMessagePromptTemplate, AIMessagePromptTemplate, HumanMessagePromptTemplate\n",
29
- "from langchain.schema import SystemMessage, HumanMessage, AIMessage\n",
30
- "from langchain.retrievers.multi_query import MultiQueryRetriever\n",
31
- "import gradio as gr\n",
32
- "\n",
33
- "from IPython.display import Image, display\n",
34
- "import sys\n",
35
- "import os\n",
36
- "import uuid\n",
37
- "\n",
38
- "\n",
39
- "load_dotenv('/Users/nadaa/Documents/code/py_innovations/srf_chatbot_v2/.env')\n",
40
- "\n",
41
- "sys.path.append(os.path.abspath('..'))\n",
42
- "%load_ext autoreload\n",
43
- "%autoreload 2\n",
44
- "\n",
45
- "import src.utils.qdrant_manager as qm\n",
46
- "import prompts.system_prompts as sp\n",
47
- "\n",
48
- "\n",
49
- "\n"
50
- ]
51
- },
52
- {
53
- "cell_type": "code",
54
- "execution_count": 31,
55
- "metadata": {},
56
- "outputs": [],
57
- "source": [
58
- "class ToolManager:\n",
59
- " def __init__(self, collection_name=\"openai_large_chunks_1500char\"):\n",
60
- " self.tools = []\n",
61
- " self.qdrant = qm.QdrantManager(collection_name=collection_name)\n",
62
- " self.vectorstore = self.qdrant.get_vectorstore()\n",
63
- " self.add_vector_search_tool()\n",
64
- "\n",
65
- " def get_tools(self):\n",
66
- " return self.tools\n",
67
- "\n",
68
- " def add_vector_search_tool(self):\n",
69
- " @tool\n",
70
- " def vector_search(query: str, k: int = 5) -> list[Document]:\n",
71
- " \"\"\"Useful for simple queries. This tool will search a vector database for passages from the teachings of Paramhansa Yogananda and other publications from the Self Realization Fellowship (SRF).\n",
72
- " The user has the option to specify the number of passages they want the search to return, otherwise the number of passages will be set to the default value.\"\"\"\n",
73
- " retriever = self.vectorstore.as_retriever(search_kwargs={\"k\": k})\n",
74
- " documents = retriever.invoke(query)\n",
75
- " return documents\n",
76
- " \n",
77
- " \n",
78
- " @tool\n",
79
- " def multiple_query_vector_search(query: str, k: int = 5) -> list[Document]:\n",
80
- " \"\"\"Useful when the user's query is vague, complex, or involves multiple concepts. \n",
81
- " This tool will write multiple versions of the user's query and search the vector database for relevant passages. \n",
82
- " Returns a list of relevant passages.\"\"\"\n",
83
- " \n",
84
- " llm = ChatOpenAI(model=\"gpt-4o-mini\", temperature=0.5)\n",
85
- " retriever_from_llm = MultiQueryRetriever.from_llm(retriever=self.vectorstore.as_retriever(), llm=llm)\n",
86
- " documents = retriever_from_llm.invoke(query)\n",
87
- " return documents\n",
88
- " \n",
89
- " \n",
90
- " self.tools.append(vector_search)\n",
91
- " self.tools.append(multiple_query_vector_search)"
92
- ]
93
- },
94
- {
95
- "cell_type": "code",
96
- "execution_count": 32,
97
- "metadata": {},
98
- "outputs": [],
99
- "source": [
100
- "\n",
101
- "class SRFChatbot:\n",
102
- " def __init__(\n",
103
- " self,\n",
104
- " chatbot_instructions: str = sp.system_prompt_templates['Open-Ended Bot'],\n",
105
- " model: str = 'gpt-4o-mini',\n",
106
- " temperature: float = 0,\n",
107
- " ):\n",
108
- " # Initialize the LLM and the system message\n",
109
- " self.llm = ChatOpenAI(model=model, temperature=temperature)\n",
110
- " self.system_message = SystemMessage(content=chatbot_instructions)\n",
111
- " self.tools = ToolManager().get_tools()\n",
112
- " self.llm_with_tools = self.llm.bind_tools(self.tools)\n",
113
- "\n",
114
- " # Build the graph\n",
115
- " self.graph = self.build_graph()\n",
116
- " # Get the configurable\n",
117
- " self.config = self.get_configurable()\n",
118
- " \n",
119
- " def reset_system_prompt(self, chatbot_instructions_dropdown: str):\n",
120
- " # Get chatbot instructions\n",
121
- " chatbot_instructions = sp.system_prompt_templates[chatbot_instructions_dropdown]\n",
122
- " # Reset the system prompt\n",
123
- " self.system_message = SystemMessage(content=chatbot_instructions)\n",
124
- " # Reset the configurable\n",
125
- " self.config = self.get_configurable()\n",
126
- "\n",
127
- " return chatbot_instructions\n",
128
- "\n",
129
- " def get_configurable(self):\n",
130
- " # This thread id is used to keep track of the chatbot's conversation\n",
131
- " self.thread_id = str(uuid.uuid4())\n",
132
- " return {\"configurable\": {\"thread_id\": self.thread_id}}\n",
133
- " \n",
134
- " # Add the system message onto the llm\n",
135
- " def chatbot(self, state: MessagesState):\n",
136
- " messages = [self.system_message] + state[\"messages\"]\n",
137
- " return {\"messages\": [self.llm_with_tools.invoke(messages)]}\n",
138
- " \n",
139
- " def build_graph(self):\n",
140
- "\n",
141
- " # Add chatbot state\n",
142
- " graph_builder = StateGraph(MessagesState)\n",
143
- "\n",
144
- " # Add nodes\n",
145
- " tool_node = ToolNode(self.tools)\n",
146
- " graph_builder.add_node(\"tools\", tool_node)\n",
147
- " graph_builder.add_node(\"chatbot\", self.chatbot)\n",
148
- "\n",
149
- " # Add a conditional edge wherein the chatbot can decide whether or not to go to the tools\n",
150
- " graph_builder.add_conditional_edges(\n",
151
- " \"chatbot\",\n",
152
- " tools_condition,\n",
153
- " )\n",
154
- "\n",
155
- " # Add fixed edges\n",
156
- " graph_builder.add_edge(START, \"chatbot\")\n",
157
- " graph_builder.add_edge(\"tools\", \"chatbot\")\n",
158
- "\n",
159
- " # Instantiate the memory saver\n",
160
- " memory = MemorySaver()\n",
161
- "\n",
162
- " # Compile the graph\n",
163
- " return graph_builder.compile(checkpointer=memory)\n",
164
- "\n",
165
- "\n",
166
- "\n",
167
- "\n"
168
- ]
169
- },
170
- {
171
- "cell_type": "code",
172
- "execution_count": 33,
173
- "metadata": {},
174
- "outputs": [],
175
- "source": [
176
- "chatbot = SRFChatbot()\n"
177
- ]
178
- },
179
- {
180
- "cell_type": "code",
181
- "execution_count": 15,
182
- "metadata": {},
183
- "outputs": [],
184
- "source": [
185
- "query = \"Tell me more about reducing nervousness to improve sleep\"\n",
186
- "results = chatbot.graph.invoke({\"messages\": [HumanMessage(content=query)]}, chatbot.config)"
187
- ]
188
- },
189
- {
190
- "cell_type": "code",
191
- "execution_count": 16,
192
- "metadata": {},
193
- "outputs": [
194
- {
195
- "name": "stdout",
196
- "output_type": "stream",
197
- "text": [
198
- "To reduce nervousness and improve sleep, it is essential to recognize that much of our nervousness stems from our own reactions and emotional states. Paramhansa Yogananda emphasizes that restlessness and emotional excitement can overload the nervous system, leading to fatigue and anxiety. Engaging in deep meditation can help calm the nerves, as it allows the body to rest and rejuvenate. Additionally, dietary choices play a significant role; consuming calming foods such as whole grains, fruits, and avoiding stimulants like caffeine and alcohol can support a healthier nervous system. Practicing silence and reducing exposure to noise can also alleviate nervousness, creating a more peaceful environment conducive to sleep.\n",
199
- "\n",
200
- "**Quotes:**\n",
201
- "1. \"You always blame other things for making you nervous, but never accuse yourself. Yet it is you who make yourself nervous; ninety-nine percent is your own fault.\" - *Journey to Self-Realization, Probing the Core of Nervousness*\n",
202
- "2. \"When you stop overloading the nervous system, as when you are in deep sleep or a state of calmness in meditation, you are not nervous at all.\" - *Journey to Self-Realization, Probing the Core of Nervousness*\n",
203
- "3. \"Learn to enjoy silence; don’t listen to the radio or television for hours on end, or have them blaring mindlessly in the background all the time.\" - *Journey to Self-Realization, Examine Yourself to See What Makes You Nervous*\n",
204
- "4. \"The greatest healing of nervousness takes place when we attune our lives to God.\" - *Journey to Self-Realization, Attunement With God: Greatest Cure for Nervousness*\n",
205
- "\n",
206
- "**Recommended Reading:**\n",
207
- "- *Journey to Self-Realization* by Paramhansa Yogananda\n",
208
- "\n",
209
- "**Follow-up Questions:**\n",
210
- "1. What specific techniques can I use in meditation to calm my nerves?\n",
211
- "2. Are there particular foods or drinks that are especially beneficial for reducing nervousness?\n",
212
- "3. How can I create a more peaceful environment at home to improve my sleep?\n"
213
- ]
214
- }
215
- ],
216
- "source": [
217
- "print(results['messages'][-1].content)"
218
- ]
219
- },
220
- {
221
- "cell_type": "code",
222
- "execution_count": 17,
223
- "metadata": {},
224
- "outputs": [
225
- {
226
- "data": {
227
- "text/plain": [
228
- "[HumanMessage(content='Tell me more about reducing nervousness to improve sleep', additional_kwargs={}, response_metadata={}, id='c1d3f9ba-0e06-4a6a-b38c-3dcd3be78bbf'),\n",
229
- " AIMessage(content='', additional_kwargs={'tool_calls': [{'id': 'call_fjyQpF0pjUQZ8gobl2SAozXV', 'function': {'arguments': '{\"query\":\"reducing nervousness improve sleep\"}', 'name': 'vector_search'}, 'type': 'function'}], 'refusal': None}, response_metadata={'token_usage': {'completion_tokens': 19, 'prompt_tokens': 433, 'total_tokens': 452, 'completion_tokens_details': {'reasoning_tokens': 0}}, 'model_name': 'gpt-4o-mini-2024-07-18', 'system_fingerprint': 'fp_1bb46167f9', 'finish_reason': 'tool_calls', 'logprobs': None}, id='run-4a39fe1a-6413-4ba3-8aa3-290dc31a27bb-0', tool_calls=[{'name': 'vector_search', 'args': {'query': 'reducing nervousness improve sleep'}, 'id': 'call_fjyQpF0pjUQZ8gobl2SAozXV', 'type': 'tool_call'}], usage_metadata={'input_tokens': 433, 'output_tokens': 19, 'total_tokens': 452}),\n",
230
- " ToolMessage(content=\"[Document(metadata={'chapter_name': 'Probing the Core of Nervousness', 'split_id_sequential': 418, 'split_id_uuid': '5ca2777d-c2a0-4e32-96b7-e43ed71c3aa2', 'publication_name': 'Journey to Self-Realization', '_id': '2151431e-7e07-44b6-8f33-7c8e277993c8', '_collection_name': 'openai_large_chunks_1500char'}, page_content='Probing the Core of Nervousness Self-Realization Fellowship Temple, San Diego, California, June 15, 1947 Everyone has at times been nervous, more or less, without knowing why. I may shake this piece of cloth and say it is nervous, but what is making the cloth move? When I cease moving my hand, the cloth lies limp. You always blame other things for making you nervous, but never accuse yourself. Yet it is you who make yourself nervous; ninety-nine percent is your own fault. Restlessness, emotional excitement, concentrates too much energy in the nerves so that they begin to wear out. After years and years, the adverse effects of that nervousness begin to show. The nerves are very tough—God made them so, because they have to last a lifetime—but it is necessary to give them proper care. When you stop overloading the nervous system, as when you are in deep sleep or a state of calmness in meditation, you are not nervous at all. In meditative ecstasy the nerves become highly rested and rejuvenated.'), Document(metadata={'split_id_sequential': 526, 'publication_name': 'Journey to Self-Realization', 'split_id_uuid': '2cecd1d8-68bf-4831-a6d2-de6028ff5fc5', 'chapter_name': 'The Best Diet for the Nerves', '_id': 'ff7b43a1-b42d-4983-8472-6eaeed695f4b', '_collection_name': 'openai_large_chunks_1500char'}, page_content='A yogic drink that is very good for the nervous system is made by adding crushed rock candy and fresh lime juice to a glass of water. It should be thoroughly mixed and evenly blended so that the taste is equally sweet and sour. I have recommended this to many people with excellent results. Another beneficial practice when you are very nervous is to take a cold bath. I once told this to a newspaperman. He said, “Well, if I did that every time I was nervous, I would have to carry a bathtub with me all the time!” I said, “Not necessary. Take a large piece of ice and rub it all over the body, especially over all the openings of the body. With this yoga technique, you will find that your nerves will become much calmer.”'), Document(metadata={'split_id_sequential': 525, 'publication_name': 'Journey to Self-Realization', 'chapter_name': 'The Best Diet for the Nerves', 'split_id_uuid': '5b366387-d311-486a-bc74-0559cb45d041', '_id': 'e2a33e74-64d8-47f4-9edd-41eebe277585', '_collection_name': 'openai_large_chunks_1500char'}, page_content='The Best Diet for the Nerves Even foods, which also are material condensations of astral rays of life, have effects that are correlated to their colour. Various kinds of natural white foods are good for the nervous system; they benefit the white matter of the brain. Berries are good for the gray matter of the brain—that is, blueberries or blackberries (which are really purple). Most fruits are gold in colour (or variants of gold, such as red and orange). As gold is the colour of the creative vibratory energy in matter, such fruits help the muscles, the blood, and the tissues. Goat’s milk, unbleached almonds, and raisins are very good for the nervous system. But all forms of meat of higher animals, especially beef and pork, are harmful to the nervous system; they are hyperstimulating and cause aggressiveness. Avoid too much starch, especially foods made from refined flour. Eat whole grains, cottage cheese, and plenty of fruits, fruit juices, and fresh vegetables—these are important. Needless to say, alcoholic beverages and drugs destroy the nervous system; stay away from them. A yogic drink that is very good for the nervous system is made by adding crushed rock candy and fresh lime juice to a glass of water. It should be thoroughly mixed and evenly blended so that the taste is equally sweet and sour. I have recommended this to many people with excellent results. Another beneficial practice when you are very nervous is to take a cold bath. I once told this to a newspaperman.'), Document(metadata={'chapter_name': 'Examine Yourself to See What Makes You Nervous', 'publication_name': 'Journey to Self-Realization', 'split_id_sequential': 160, 'split_id_uuid': '0900b6ab-2a48-48db-a66b-2ca0e80f9c70', '_id': 'de7f20d2-d3ac-45b6-8588-1a0b568e2ec9', '_collection_name': 'openai_large_chunks_1500char'}, page_content='Other cars were speeding past us on the steep, winding grade. I thought they were hurrying to get to the mountaintop in time to see the sunrise. To my great amazement, when we arrived we were the only ones outside to enjoy the view. All the others were in the restaurant drinking coffee and eating doughnuts. Imagine! They rushed to the top and then rushed back, just for the thrill of being able to say when they got home that they had been there, and had coffee and doughnuts on Pikes Peak. That is what nervousness does. We should take time to enjoy things—the beauties of God’s creation, the many blessings of life—but avoid undue excitement, restlessness, and sudden emotions, which burn up the nervous system. Talking too much, including the habit of engaging in long conversations on the telephone, creates nervousness. Habitual twitching—such as drumming the fingers or moving the toes—burns energy in the nerves. Another cause of nervousness, though you may not be aware of it, is the noise of the radio or television going on for hours at a time. All sounds cause the nerves to react.1 A study conducted in the police department in Chicago showed that if human beings were not subjected to the bombardment of the sounds of modern living, which are especially harsh in cities, they could live years longer. Learn to enjoy silence; don’t listen to the radio or television for hours on end, or have them blaring mindlessly in the background all the time.'), Document(metadata={'chapter_name': 'Attunement With God: Greatest Cure for Nervousness', 'split_id_sequential': 33, 'split_id_uuid': '28716ee9-dae2-46e5-80e6-f53bffa190c1', 'publication_name': 'Journey to Self-Realization', '_id': 'b079c905-181b-42ef-8c5f-849c0ba81f9b', '_collection_name': 'openai_large_chunks_1500char'}, page_content='Attunement With God: Greatest Cure for Nervousness Remember that the greatest healing of nervousness takes place when we attune our lives to God. The highest commandments given to man are to love God with all your heart, and with all your soul, and with all your mind, and with all your strength; and secondly, to love your neighbour as yourself.13 If you follow these, everything will come in its own way, and in the right way. It is not enough just to be a strict moralist—stones and goats do not break moral laws; still, they do not know God. But when you love God deeply enough, even if you are the greatest of sinners, you will be transformed and redeemed. The great saint Mirabai14 said, “To find the Divine One, the only indispensable is love.” That truth touched me deeply. All the prophets observe these two foremost commandments. Loving God with all your heart means to love Him with the love that you feel for the person who is dearest to you—with the love of the mother or father for the child, or the lover for the beloved. Give that kind of unconditional love to God. Loving God with all your soul means you can truly love Him when through deep meditation you know yourself as a soul, a child of God, made in His image. Loving God with all your mind means that when you are praying, your whole attention is on Him, not distracted by restless thoughts. In meditation, think only of God; don’t let the mind wander to everything else but God.')]\", name='vector_search', id='34f93038-5940-4a3b-bfd2-7f595ee69775', tool_call_id='call_fjyQpF0pjUQZ8gobl2SAozXV'),\n",
231
- " AIMessage(content='To reduce nervousness and improve sleep, it is essential to recognize that much of our nervousness stems from our own reactions and emotional states. Paramhansa Yogananda emphasizes that restlessness and emotional excitement can overload the nervous system, leading to fatigue and anxiety. Engaging in deep meditation can help calm the nerves, as it allows the body to rest and rejuvenate. Additionally, dietary choices play a significant role; consuming calming foods such as whole grains, fruits, and avoiding stimulants like caffeine and alcohol can support a healthier nervous system. Practicing silence and reducing exposure to noise can also alleviate nervousness, creating a more peaceful environment conducive to sleep.\\n\\n**Quotes:**\\n1. \"You always blame other things for making you nervous, but never accuse yourself. Yet it is you who make yourself nervous; ninety-nine percent is your own fault.\" - *Journey to Self-Realization, Probing the Core of Nervousness*\\n2. \"When you stop overloading the nervous system, as when you are in deep sleep or a state of calmness in meditation, you are not nervous at all.\" - *Journey to Self-Realization, Probing the Core of Nervousness*\\n3. \"Learn to enjoy silence; don’t listen to the radio or television for hours on end, or have them blaring mindlessly in the background all the time.\" - *Journey to Self-Realization, Examine Yourself to See What Makes You Nervous*\\n4. \"The greatest healing of nervousness takes place when we attune our lives to God.\" - *Journey to Self-Realization, Attunement With God: Greatest Cure for Nervousness*\\n\\n**Recommended Reading:**\\n- *Journey to Self-Realization* by Paramhansa Yogananda\\n\\n**Follow-up Questions:**\\n1. What specific techniques can I use in meditation to calm my nerves?\\n2. Are there particular foods or drinks that are especially beneficial for reducing nervousness?\\n3. How can I create a more peaceful environment at home to improve my sleep?', additional_kwargs={'refusal': None}, response_metadata={'token_usage': {'completion_tokens': 416, 'prompt_tokens': 2347, 'total_tokens': 2763, 'completion_tokens_details': {'reasoning_tokens': 0}}, 'model_name': 'gpt-4o-mini-2024-07-18', 'system_fingerprint': 'fp_1bb46167f9', 'finish_reason': 'stop', 'logprobs': None}, id='run-0814edcd-020f-4ae0-bab2-b696f9948fec-0', usage_metadata={'input_tokens': 2347, 'output_tokens': 416, 'total_tokens': 2763})]"
232
- ]
233
- },
234
- "execution_count": 17,
235
- "metadata": {},
236
- "output_type": "execute_result"
237
- }
238
- ],
239
- "source": [
240
- "\n",
241
- "chatbot.graph.get_state(chatbot.config)[0]['messages']"
242
- ]
243
- },
244
- {
245
- "cell_type": "code",
246
- "execution_count": 20,
247
- "metadata": {},
248
- "outputs": [],
249
- "source": []
250
- },
251
- {
252
- "cell_type": "code",
253
- "execution_count": 35,
254
- "metadata": {},
255
- "outputs": [
256
- {
257
- "name": "stdout",
258
- "output_type": "stream",
259
- "text": [
260
- "Running on local URL: http://127.0.0.1:7875\n",
261
- "\n",
262
- "To create a public link, set `share=True` in `launch()`.\n"
263
- ]
264
- },
265
- {
266
- "data": {
267
- "text/html": [
268
- "<div><iframe src=\"http://127.0.0.1:7875/\" width=\"100%\" height=\"500\" allow=\"autoplay; camera; microphone; clipboard-read; clipboard-write;\" frameborder=\"0\" allowfullscreen></iframe></div>"
269
- ],
270
- "text/plain": [
271
- "<IPython.core.display.HTML object>"
272
- ]
273
- },
274
- "metadata": {},
275
- "output_type": "display_data"
276
- },
277
- {
278
- "data": {
279
- "text/plain": []
280
- },
281
- "execution_count": 35,
282
- "metadata": {},
283
- "output_type": "execute_result"
284
- }
285
- ],
286
- "source": [
287
- "\n",
288
- "def respond(query, history):\n",
289
- "\n",
290
- " formatted_query = [HumanMessage(content=query)]\n",
291
- " # Invoke the graph with properly formatted input\n",
292
- " result = chatbot.graph.invoke({\"messages\": formatted_query}, chatbot.config)\n",
293
- " \n",
294
- " # Extract the assistant's response\n",
295
- " response = result[\"messages\"][-1].content\n",
296
- "\n",
297
- " history.append((query, response))\n",
298
- "\n",
299
- " \n",
300
- " return history\n",
301
- "\n",
302
- "chatbot = SRFChatbot()\n",
303
- "\n",
304
- "# Gradio interface with responsive layout\n",
305
- "with gr.Blocks(css=\"\"\"\n",
306
- " @media (max-width: 600px) {\n",
307
- " .gr-row { flex-direction: column !important; }\n",
308
- " .gr-column { width: 100% !important; }\n",
309
- " }\n",
310
- "\"\"\") as demo:\n",
311
- " gr.Markdown(\"# SRF Chatbot\")\n",
312
- " \n",
313
- " with gr.Row(elem_classes=\"gr-row\"):\n",
314
- " with gr.Column(scale=4, elem_classes=\"gr-column\"):\n",
315
- " chatbot_output = gr.Chatbot()\n",
316
- " user_input = gr.Textbox(placeholder=\"Type your question here...\")\n",
317
- " submit_button = gr.Button(\"Submit\")\n",
318
- " \n",
319
- " with gr.Column(scale=1, elem_classes=\"gr-column\"):\n",
320
- " system_prompt_dropdown = gr.Dropdown(\n",
321
- " choices=list(sp.system_prompt_templates.keys()),\n",
322
- " label=\"Select Chatbot Instructions\",\n",
323
- " value=list(sp.system_prompt_templates.keys())[0]\n",
324
- " )\n",
325
- " system_prompt_display = gr.Textbox(\n",
326
- " value=sp.system_prompt_templates[list(sp.system_prompt_templates.keys())[0]],\n",
327
- " label=\"Current Chatbot Instructions\",\n",
328
- " lines=5,\n",
329
- " interactive=False\n",
330
- " )\n",
331
- " \n",
332
- " # Update system prompt display when a new prompt is selected\n",
333
- " system_prompt_dropdown.change(\n",
334
- " fn=chatbot.reset_system_prompt,\n",
335
- " inputs=[system_prompt_dropdown],\n",
336
- " outputs=[system_prompt_display]\n",
337
- " )\n",
338
- " \n",
339
- " # Submit button logic to handle chatbot conversation\n",
340
- " submit_button.click(\n",
341
- " fn=respond,\n",
342
- " inputs=[user_input, chatbot_output],\n",
343
- " outputs=[chatbot_output]\n",
344
- " )\n",
345
- "\n",
346
- "\n",
347
- "demo.launch()\n"
348
- ]
349
- },
350
- {
351
- "cell_type": "code",
352
- "execution_count": 43,
353
- "metadata": {},
354
- "outputs": [
355
- {
356
- "name": "stdout",
357
- "output_type": "stream",
358
- "text": [
359
- "Running on local URL: http://127.0.0.1:7883\n",
360
- "\n",
361
- "To create a public link, set `share=True` in `launch()`.\n"
362
- ]
363
- },
364
- {
365
- "data": {
366
- "text/html": [
367
- "<div><iframe src=\"http://127.0.0.1:7883/\" width=\"100%\" height=\"500\" allow=\"autoplay; camera; microphone; clipboard-read; clipboard-write;\" frameborder=\"0\" allowfullscreen></iframe></div>"
368
- ],
369
- "text/plain": [
370
- "<IPython.core.display.HTML object>"
371
- ]
372
- },
373
- "metadata": {},
374
- "output_type": "display_data"
375
- },
376
- {
377
- "data": {
378
- "text/plain": []
379
- },
380
- "execution_count": 43,
381
- "metadata": {},
382
- "output_type": "execute_result"
383
- }
384
- ],
385
- "source": [
386
- "import gradio as gr\n",
387
- "\n",
388
- "# Define the respond function\n",
389
- "def respond(query, history):\n",
390
- " formatted_query = [HumanMessage(content=query)]\n",
391
- " # Invoke the graph with properly formatted input\n",
392
- " result = chatbot.graph.invoke({\"messages\": formatted_query}, chatbot.config)\n",
393
- " \n",
394
- " # Extract the assistant's response\n",
395
- " response = result[\"messages\"][-1].content\n",
396
- "\n",
397
- " history.append((query, response))\n",
398
- "\n",
399
- " return history, \"\"\n",
400
- "\n",
401
- "# Initialize chatbot\n",
402
- "chatbot = SRFChatbot()\n",
403
- "\n",
404
- "# Gradio interface with black and grey color scheme\n",
405
- "with gr.Blocks(css=\"\"\"\n",
406
- " .gradio-container {\n",
407
- " background-color: #F0F0F0; \n",
408
- " font-family: 'Arial', sans-serif;\n",
409
- " }\n",
410
- " h1, h2, p {\n",
411
- " color: black;\n",
412
- " }\n",
413
- " h1 {\n",
414
- " font-size: 32px;\n",
415
- " text-align: left;\n",
416
- " }\n",
417
- " h2 {\n",
418
- " font-size: 24px;\n",
419
- " }\n",
420
- " p {\n",
421
- " font-size: 18px;\n",
422
- " margin-bottom: 15px;\n",
423
- " }\n",
424
- " .gr-button {\n",
425
- " background-color: #333333; \n",
426
- " color: white;\n",
427
- " font-size: 18px;\n",
428
- " padding: 10px;\n",
429
- " }\n",
430
- " .gr-textbox textarea {\n",
431
- " font-size: 18px;\n",
432
- " color: black;\n",
433
- " }\n",
434
- " .gr-dropdown {\n",
435
- " font-size: 18px;\n",
436
- " color: black;\n",
437
- " }\n",
438
- " .source-box {\n",
439
- " background-color: #D0D0D0; \n",
440
- " padding: 10px; \n",
441
- " border-radius: 8px; \n",
442
- " margin-top: 20px;\n",
443
- " color: black;\n",
444
- " }\n",
445
- " @media (max-width: 600px) {\n",
446
- " .gr-row { flex-direction: column !important; }\n",
447
- " .gr-column { width: 100% !important; }\n",
448
- " }\n",
449
- "\"\"\") as demo:\n",
450
- " \n",
451
- " # Title\n",
452
- " gr.Markdown(\"# SRF Chatbot\")\n",
453
- " \n",
454
- " with gr.Row(elem_classes=\"gr-row\"):\n",
455
- " with gr.Column(scale=4, elem_classes=\"gr-column\"):\n",
456
- " # Chatbot interface\n",
457
- " chatbot_output = gr.Chatbot()\n",
458
- " user_input = gr.Textbox(placeholder=\"Type your question here...\", label=\"Your Question\")\n",
459
- " submit_button = gr.Button(\"Submit\")\n",
460
- " \n",
461
- " with gr.Column(scale=1, elem_classes=\"gr-column\"):\n",
462
- " # Dropdown to select system prompts\n",
463
- " system_prompt_dropdown = gr.Dropdown(\n",
464
- " choices=list(sp.system_prompt_templates.keys()),\n",
465
- " label=\"Select Chatbot Instructions\",\n",
466
- " value=list(sp.system_prompt_templates.keys())[0],\n",
467
- " elem_classes=\"gr-dropdown\"\n",
468
- " )\n",
469
- " # Display the selected system prompt\n",
470
- " system_prompt_display = gr.Textbox(\n",
471
- " value=sp.system_prompt_templates[list(sp.system_prompt_templates.keys())[0]],\n",
472
- " label=\"Current Chatbot Instructions\",\n",
473
- " lines=5,\n",
474
- " interactive=False\n",
475
- " )\n",
476
- " \n",
477
- " # Sources box\n",
478
- " gr.Markdown(\"\"\"\n",
479
- " <div class=\"source-box\">\n",
480
- " <strong>Available sources:</strong>\n",
481
- " <ul>\n",
482
- " <li>Journey to Self-Realization</li>\n",
483
- " <li>The Second Coming of Christ</li>\n",
484
- " <li>Autobiography of a Yogi</li>\n",
485
- " </ul>\n",
486
- " </div>\n",
487
- " \"\"\")\n",
488
- " \n",
489
- " # Update system prompt display when a new prompt is selected\n",
490
- " system_prompt_dropdown.change(\n",
491
- " fn=chatbot.reset_system_prompt,\n",
492
- " inputs=[system_prompt_dropdown],\n",
493
- " outputs=[system_prompt_display]\n",
494
- " )\n",
495
- " \n",
496
- " # Submit button logic to handle chatbot conversation\n",
497
- " submit_button.click(\n",
498
- " fn=respond,\n",
499
- " inputs=[user_input, chatbot_output],\n",
500
- " outputs=[chatbot_output, user_input]\n",
501
- " )\n",
502
- "\n",
503
- "# Launch the interface\n",
504
- "demo.launch()\n"
505
- ]
506
- },
507
- {
508
- "cell_type": "code",
509
- "execution_count": 44,
510
- "metadata": {},
511
- "outputs": [
512
- {
513
- "name": "stdout",
514
- "output_type": "stream",
515
- "text": [
516
- "Running on local URL: http://127.0.0.1:7885\n",
517
- "\n",
518
- "To create a public link, set `share=True` in `launch()`.\n"
519
- ]
520
- },
521
- {
522
- "data": {
523
- "text/html": [
524
- "<div><iframe src=\"http://127.0.0.1:7885/\" width=\"100%\" height=\"500\" allow=\"autoplay; camera; microphone; clipboard-read; clipboard-write;\" frameborder=\"0\" allowfullscreen></iframe></div>"
525
- ],
526
- "text/plain": [
527
- "<IPython.core.display.HTML object>"
528
- ]
529
- },
530
- "metadata": {},
531
- "output_type": "display_data"
532
- },
533
- {
534
- "data": {
535
- "text/plain": []
536
- },
537
- "execution_count": 44,
538
- "metadata": {},
539
- "output_type": "execute_result"
540
- }
541
- ],
542
- "source": [
543
- "import gradio as gr\n",
544
- "import src.srf_bot as sb\n",
545
- "import prompts.system_prompts as sp\n",
546
- "from langchain_core.messages import HumanMessage \n",
547
- "\n",
548
- "# Define the respond function\n",
549
- "def respond(query, history):\n",
550
- " formatted_query = [HumanMessage(content=query)]\n",
551
- " # Invoke the graph with properly formatted input\n",
552
- " result = chatbot.graph.invoke({\"messages\": formatted_query}, chatbot.config)\n",
553
- " \n",
554
- " # Extract the assistant's response\n",
555
- " response = result[\"messages\"][-1].content\n",
556
- "\n",
557
- " history.append((query, response))\n",
558
- "\n",
559
- " return history, \"\"\n",
560
- "\n",
561
- "# Initialize chatbot\n",
562
- "chatbot = sb.SRFChatbot()\n",
563
- "\n",
564
- "# Gradio interface with black and grey color scheme\n",
565
- "with gr.Blocks(css=\"\"\"\n",
566
- " .gradio-container {\n",
567
- " background-color: #F0F0F0; \n",
568
- " font-family: 'Arial', sans-serif;\n",
569
- " }\n",
570
- " h1, h2, p {\n",
571
- " color: black;\n",
572
- " }\n",
573
- " h1 {\n",
574
- " font-size: 32px;\n",
575
- " text-align: left;\n",
576
- " }\n",
577
- " h2 {\n",
578
- " font-size: 24px;\n",
579
- " }\n",
580
- " p {\n",
581
- " font-size: 18px;\n",
582
- " margin-bottom: 15px;\n",
583
- " }\n",
584
- " .gr-button {\n",
585
- " background-color: #333333; \n",
586
- " color: white;\n",
587
- " font-size: 18px;\n",
588
- " padding: 10px;\n",
589
- " }\n",
590
- " .gr-textbox textarea {\n",
591
- " font-size: 18px;\n",
592
- " color: black;\n",
593
- " }\n",
594
- " .gr-dropdown {\n",
595
- " font-size: 18px;\n",
596
- " color: black;\n",
597
- " }\n",
598
- " .source-box {\n",
599
- " background-color: white; \n",
600
- " padding: 10px; \n",
601
- " border-radius: 8px; \n",
602
- " margin-top: 20px;\n",
603
- " color: black;\n",
604
- " border: 1px solid #D0D0D0;\n",
605
- " }\n",
606
- " @media (max-width: 600px) {\n",
607
- " .gr-row { flex-direction: column !important; }\n",
608
- " .gr-column { width: 100% !important; }\n",
609
- " }\n",
610
- "\"\"\") as demo:\n",
611
- " \n",
612
- " # Title\n",
613
- " gr.Markdown(\"# SRF Chatbot\")\n",
614
- " \n",
615
- " with gr.Row(elem_classes=\"gr-row\"):\n",
616
- " with gr.Column(scale=4, elem_classes=\"gr-column\"):\n",
617
- " # Chatbot interface\n",
618
- " chatbot_output = gr.Chatbot(height=600) # Increased height for longer chat interface\n",
619
- " user_input = gr.Textbox(placeholder=\"Type your question here...\", label=\"Your Question\")\n",
620
- " submit_button = gr.Button(\"Submit\")\n",
621
- " \n",
622
- " with gr.Column(scale=1, elem_classes=\"gr-column\"):\n",
623
- " # Dropdown to select system prompts\n",
624
- " system_prompt_dropdown = gr.Dropdown(\n",
625
- " choices=list(sp.system_prompt_templates.keys()),\n",
626
- " label=\"Select Chatbot Instructions\",\n",
627
- " value=list(sp.system_prompt_templates.keys())[0],\n",
628
- " elem_classes=\"gr-dropdown\"\n",
629
- " )\n",
630
- " # Display the selected system prompt\n",
631
- " system_prompt_display = gr.Textbox(\n",
632
- " value=sp.system_prompt_templates[list(sp.system_prompt_templates.keys())[0]],\n",
633
- " label=\"Current Chatbot Instructions\",\n",
634
- " lines=5,\n",
635
- " interactive=False\n",
636
- " )\n",
637
- " \n",
638
- " # Sources box (Now white, matching the other boxes)\n",
639
- " gr.Markdown(\"\"\"\n",
640
- " <div class=\"source-box\">\n",
641
- " <strong>Available sources:</strong>\n",
642
- " <ul>\n",
643
- " <li>Journey to Self-Realization</li>\n",
644
- " <li>The Second Coming of Christ</li>\n",
645
- " <li>Autobiography of a Yogi</li>\n",
646
- " </ul>\n",
647
- " </div>\n",
648
- " \"\"\")\n",
649
- " \n",
650
- " # Update system prompt display when a new prompt is selected\n",
651
- " system_prompt_dropdown.change(\n",
652
- " fn=chatbot.reset_system_prompt,\n",
653
- " inputs=[system_prompt_dropdown],\n",
654
- " outputs=[system_prompt_display]\n",
655
- " )\n",
656
- " \n",
657
- " # Submit button logic to handle chatbot conversation\n",
658
- " submit_button.click(\n",
659
- " fn=respond,\n",
660
- " inputs=[user_input, chatbot_output],\n",
661
- " outputs=[chatbot_output, user_input]\n",
662
- " )\n",
663
- "\n",
664
- "# Launch the interface\n",
665
- "demo.launch()\n"
666
- ]
667
- },
668
- {
669
- "cell_type": "code",
670
- "execution_count": null,
671
- "metadata": {},
672
- "outputs": [],
673
- "source": []
674
- }
675
- ],
676
- "metadata": {
677
- "kernelspec": {
678
- "display_name": "srf_chatbot_v2",
679
- "language": "python",
680
- "name": "srf_chatbot_v2"
681
- },
682
- "language_info": {
683
- "codemirror_mode": {
684
- "name": "ipython",
685
- "version": 3
686
- },
687
- "file_extension": ".py",
688
- "mimetype": "text/x-python",
689
- "name": "python",
690
- "nbconvert_exporter": "python",
691
- "pygments_lexer": "ipython3",
692
- "version": "3.11.9"
693
- }
694
- },
695
- "nbformat": 4,
696
- "nbformat_minor": 2
697
- }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
notebooks/04 Return Passages.ipynb DELETED
File without changes
notebooks/05 Scratch.ipynb DELETED
File without changes