mitulagr2 commited on
Commit
2d12855
·
1 Parent(s): 0bbd828

Migrate to stream generator

Browse files
Files changed (2) hide show
  1. app/main.py +10 -6
  2. app/rag.py +6 -4
app/main.py CHANGED
@@ -22,22 +22,26 @@ app = FastAPI(middleware=middleware)
22
 
23
  files_dir = os.path.expanduser("~/wtp_be_files/")
24
  session_assistant = ChatPDF()
25
- session_messages = []
26
 
27
  @app.get("/query")
28
  def process_input(text: str):
29
  if text and len(text.strip()) > 0:
30
  text = text.strip()
31
- agent_text = session_assistant.ask(text)
32
- session_messages.append((text, True))
33
- session_messages.append((agent_text, False))
34
- return agent_text
 
 
 
 
35
 
36
 
37
  @app.post("/upload")
38
  def upload(files: list[UploadFile]):
39
  session_assistant.clear()
40
- session_messages = []
41
 
42
  try:
43
  os.makedirs(files_dir)
 
22
 
23
  files_dir = os.path.expanduser("~/wtp_be_files/")
24
  session_assistant = ChatPDF()
25
+ # session_messages = []
26
 
27
  @app.get("/query")
28
  def process_input(text: str):
29
  if text and len(text.strip()) > 0:
30
  text = text.strip()
31
+ print("PRINTING STREAM")
32
+ agent_text_stream = session_assistant.ask(text)
33
+ print(stream_gen)
34
+ for text in agent_text_stream:
35
+ print(text)
36
+ # session_messages.append((text, True))
37
+ # session_messages.append((agent_text, False))
38
+ return "Query resolved!"
39
 
40
 
41
  @app.post("/upload")
42
  def upload(files: list[UploadFile]):
43
  session_assistant.clear()
44
+ # session_messages = []
45
 
46
  try:
47
  os.makedirs(files_dir)
app/rag.py CHANGED
@@ -151,7 +151,10 @@ class ChatPDF:
151
  # response_synthesizer=response_synthesizer,
152
  # )
153
 
154
- self.query_engine = index.as_query_engine()
 
 
 
155
 
156
  def ask(self, query: str):
157
  if not self.query_engine:
@@ -159,9 +162,8 @@ class ChatPDF:
159
 
160
  logger.info("retrieving the response to the query")
161
  # response = self.query_engine.query(str_or_query_bundle=query)
162
- response = self.query_engine.query(query)
163
- print(response)
164
- return response
165
 
166
  def clear(self):
167
  self.query_engine = None
 
151
  # response_synthesizer=response_synthesizer,
152
  # )
153
 
154
+ self.query_engine = index.as_query_engine(
155
+ streaming=True,
156
+ # similarity_top_k=6,
157
+ )
158
 
159
  def ask(self, query: str):
160
  if not self.query_engine:
 
162
 
163
  logger.info("retrieving the response to the query")
164
  # response = self.query_engine.query(str_or_query_bundle=query)
165
+ streaming_response = self.query_engine.query(query)
166
+ return streaming_response.response_gen
 
167
 
168
  def clear(self):
169
  self.query_engine = None