Zekun Wu commited on
Commit
727d404
·
1 Parent(s): 07aabce
Files changed (1) hide show
  1. app.py +27 -67
app.py CHANGED
@@ -190,7 +190,19 @@ def main_app():
190
  # Ask for feedback
191
  st.markdown(st.session_state['analysis'])
192
 
193
- st.markdown("Provide feedback on the report:")
 
 
 
 
 
 
 
 
 
 
 
 
194
 
195
  criteria = {
196
  "Faithfulness": "Are all claims made in the answer inferred from the given context, i.e., not hallucinated?",
@@ -203,12 +215,17 @@ def main_app():
203
 
204
  ratings = {}
205
  for criterion, description in criteria.items():
206
- ratings[criterion] = st.slider(f"{criterion}: {description}", 0, 10, 5,key=f"coach {criterion}")
207
 
208
- feedback = st.text_input("Provide additional feedback on the response:",key=f"coach feedback")
209
 
210
  if st.button('Submit Report Feedback'):
211
- store_feedback(str(generate_prompt_from_profile(profile, version=st.session_state['version'])), st.session_state['analysis'], feedback, str(ratings), "wu981526092/feedback_report")
 
 
 
 
 
212
  st.success("Feedback submitted successfully!")
213
 
214
 
@@ -333,37 +350,13 @@ def sidebar_components():
333
 
334
  if st.sidebar.button('Submit'):
335
  if user_input:
 
336
  if st.session_state['chat_context'] == "profile":
337
  chat_prompt_template = create_chat_prompt_template(get_profile_str(st.session_state['profile']),st.session_state['definition'])
338
  else:
339
  chat_prompt_template = create_chat_prompt_template(st.session_state['analysis'],st.session_state['definition'])
340
- response = execute_query(index, chat_prompt_template, user_input)
341
-
342
- st.sidebar.markdown(response)
343
-
344
- st.markdown("Provide feedback on the response:")
345
-
346
- # Feedback criteria
347
- st.sidebar.markdown("## Feedback Criteria")
348
- criteria = {
349
- "Faithfulness": "Are all claims made in the answer inferred from the given context, i.e., not hallucinated?",
350
- "Answer Relevancy": "Is the answer relevant to the question?",
351
- "Context Relevancy": "Is the context relevant to the question?",
352
- "Correctness": "Is the answer factually correct, based on the context?",
353
- "Clarity": "Is the answer explained clearly without the extensive jargon of the original document?",
354
- "Completeness": "Is the question answered fully, with all parts and subquestions being addressed?",
355
- }
356
- ratings = {}
357
- for criterion, description in criteria.items():
358
- ratings[criterion] = st.sidebar.slider(f"{criterion}: {description}", 0, 10, 5,key=f"report {criterion}")
359
-
360
- # Ask for feedback
361
- feedback = st.sidebar.text_input("Provide additional feedback on the response:",key=f"report feedback")
362
-
363
- if st.sidebar.button('Submit Coach Feedback'):
364
- store_feedback(user_input, response, feedback, str(ratings), "wu981526092/feedback_coach")
365
- time.sleep(10)
366
- st.sidebar.success("Feedback submitted successfully!")
367
 
368
 
369
 
@@ -378,7 +371,9 @@ session_defaults = {
378
  'version': "",
379
  'username': '',
380
  'password': '',
381
- 'authenticated': False
 
 
382
  }
383
 
384
  for key, default in session_defaults.items():
@@ -390,38 +385,3 @@ if st.session_state['authenticated']:
390
  main_app()
391
  else:
392
  login_page()
393
-
394
- # # Display the sidebar components based on the state
395
- # if 'show_chat' not in st.session_state:
396
- # st.session_state['show_chat'] = None
397
- #
398
- # if 'definition' not in st.session_state:
399
- # st.session_state['definition'] = 1
400
- #
401
- # if 'chat_context' not in st.session_state:
402
- # st.session_state['chat_context'] = "analysis"
403
- #
404
- # if 'profile' not in st.session_state:
405
- # st.session_state['profile'] = None
406
- #
407
- # if 'analysis' not in st.session_state:
408
- # st.session_state['analysis'] = None
409
- #
410
- # if 'temperature' not in st.session_state:
411
- # st.session_state['temperature'] = 0
412
- #
413
- # if 'version' not in st.session_state:
414
- # st.session_state['version'] = ""
415
- #
416
- # # Initialize session state for username, password, and authentication
417
- # if 'username' not in st.session_state:
418
- # st.session_state['username'] = ''
419
- # if 'password' not in st.session_state:
420
- # st.session_state['password'] = ''
421
- # if 'authenticated' not in st.session_state:
422
- # st.session_state['authenticated'] = False
423
- # # Show login or main app based on authentication
424
- # if st.session_state['authenticated']:
425
- # main_app()
426
- # else:
427
- # login_page()
 
190
  # Ask for feedback
191
  st.markdown(st.session_state['analysis'])
192
 
193
+ # Ask the user to choose the type of feedback
194
+ feedback_type = st.selectbox(
195
+ "Select the type of feedback:",
196
+ ["Report", "Coach"]
197
+ )
198
+
199
+ # Set the dataset identifier based on feedback type
200
+ if feedback_type == "Report":
201
+ dataset_id = "wu981526092/feedback_report"
202
+ else:
203
+ dataset_id = "wu981526092/feedback_coach"
204
+
205
+ st.markdown(f"Provide feedback on the {feedback_type.lower()}:")
206
 
207
  criteria = {
208
  "Faithfulness": "Are all claims made in the answer inferred from the given context, i.e., not hallucinated?",
 
215
 
216
  ratings = {}
217
  for criterion, description in criteria.items():
218
+ ratings[criterion] = st.slider(f"{criterion}: {description}", 0, 10, 5,key=f"{feedback_type} {criterion}")
219
 
220
+ feedback = st.text_input("Provide additional feedback on the response:",key=f"{feedback_type} feedback")
221
 
222
  if st.button('Submit Report Feedback'):
223
+ if feedback_type == "Report":
224
+ store_feedback(str(generate_prompt_from_profile(profile, version=st.session_state['version'])), st.session_state['analysis'], feedback, str(ratings), dataset_id)
225
+ else:
226
+ store_feedback(st.session_state['coach_query'], st.session_state['coach_response'], feedback, str(ratings), dataset_id)
227
+
228
+
229
  st.success("Feedback submitted successfully!")
230
 
231
 
 
350
 
351
  if st.sidebar.button('Submit'):
352
  if user_input:
353
+ st.session_state['coach_query'] = user_input
354
  if st.session_state['chat_context'] == "profile":
355
  chat_prompt_template = create_chat_prompt_template(get_profile_str(st.session_state['profile']),st.session_state['definition'])
356
  else:
357
  chat_prompt_template = create_chat_prompt_template(st.session_state['analysis'],st.session_state['definition'])
358
+ st.session_state['coach_response'] = execute_query(index, chat_prompt_template, user_input)
359
+ st.sidebar.markdown(st.session_state['coach_response'])
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
360
 
361
 
362
 
 
371
  'version': "",
372
  'username': '',
373
  'password': '',
374
+ 'authenticated': False,
375
+ 'coach_response':"",
376
+ 'coach_query':""
377
  }
378
 
379
  for key, default in session_defaults.items():
 
385
  main_app()
386
  else:
387
  login_page()