File size: 7,124 Bytes
ee96e07
 
 
 
 
 
 
 
 
 
 
 
 
b177ad3
 
 
 
 
ee96e07
 
 
b177ad3
 
ee96e07
b177ad3
 
 
 
 
 
 
 
 
 
 
 
ee96e07
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
b177ad3
ee96e07
 
 
 
 
 
 
 
 
 
 
 
 
b177ad3
 
 
 
 
 
 
 
 
ee96e07
b177ad3
 
 
 
 
 
 
ee96e07
 
 
 
 
 
 
b177ad3
 
ee96e07
b177ad3
 
 
 
 
ee96e07
 
 
 
 
 
b177ad3
 
 
 
ee96e07
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
b177ad3
ee96e07
 
 
 
 
 
 
 
 
 
 
b177ad3
 
 
 
 
 
 
 
ee96e07
b177ad3
 
 
 
 
ee96e07
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
import os
import streamlit as st
from datetime import datetime
import json
import requests
import uuid
from datetime import date, datetime
import requests
from pydantic import BaseModel, Field
from typing import Optional



placeHolderPersona1 = """## Mission Statement
My mission is to utilize my expertise to aid in the medical triaging process by providing a clear, concise, and accurate assessment of potential arthritis related conditions.
 
# Triaging process 
Ensure you stay on the topic of asking questions to triage the potential of Rheumatoid arthritis.
Ask only one question at a time.
Provide some context or clarification around the follow-up questions you ask.
Do not converse with the customer.
Be as concise as possible.
Do not give a diagnosis """

placeHolderPersona2 = """## Mission
To analyse a clinical triaging discussion between a patient and AI doctor interactions with a focus on Immunology symptoms, medical history, and test results to deduce the most probable Immunology diagnosis.

## Diagnostic Process
Upon receipt of the clinical notes, I will follow a systematic approach to arrive at a diagnosis:
1. Review the patient's presenting symptoms and consider their relevance to immunopathology.
2. Cross-reference the gathered information with my knowledge base of immunology to identify patterns or indicators of specific immune disorders.
3. Formulate a diagnosis from the potential conditions.
4. Determine the most likely diagnosis and assign a confidence score from 1-100, with 100 being absolute certainty.

# Limitations
While I am specialized in immunology, I understand that not all cases will fall neatly within my domain. In instances where the clinical notes point to a condition outside of my expertise, I will provide the best possible diagnosis with the acknowledgment that my confidence score will reflect the limitations of my specialization in those cases"""



class ChatRequestClient(BaseModel):
    user_id: str
    user_input: str
    numberOfQuestions: int
    welcomeMessage: str
    llm1: str
    tokens1: int
    temperature1: float
    persona1SystemMessage: str
    persona2SystemMessage: str
    userMessage2: str
    llm2: str
    tokens2: int
    temperature2: float

def call_chat_api(data: ChatRequestClient):
    url = "http://127.0.0.1:8000/chat/"
    # Validate and convert the data to a dictionary
    validated_data = data.dict()
    
    # Make the POST request to the FastAPI server
    response = requests.post(url, json=validated_data)
    
    if response.status_code == 200:
        return response.json()  # Return the JSON response if successful
    else:
        return "An error occured"  # Return the raw response text if not successful

def genuuid ():
    return uuid.uuid4()

def format_elapsed_time(time):
    # Format the elapsed time to two decimal places
    return "{:.2f}".format(time)

def update_history(response):
    # Initialize the history list if it doesn't exist
    if 'history' not in st.session_state:
        st.session_state.history = []
    
    # Append the agent's response to the history
    st.session_state.history.append("Agent: " + response['content'])
def display_history():
    # Display each item in the history
    for item in st.session_state.history:
        st.text_area(label="", value=item, height=75) 

# Title of the application
# st.image('agentBuilderLogo.png')
st.title('LLM-Powered Agent Interaction')

# Sidebar for inputting personas
st.sidebar.image('agentBuilderLogo.png')
st.sidebar.header("Agent Personas Design")
# st.sidebar.subheader("Welcome Message")
# welcomeMessage = st.sidebar.text_area("Define Triaging Persona", value=welcomeMessage, height=150)
st.sidebar.subheader("Personas 1 Settings")
numberOfQuestions = st.sidebar.slider("Number of Questions", min_value=0, max_value=10, step=1, value=5, key='persona1_questions')
persona1SystemMessage = st.sidebar.text_area("Define Triaging Persona", value=placeHolderPersona1, height=150)
with st.sidebar.expander("See explanation"):
    st.write("Personas: the individual members of the business function / agent equivalent to employee’s. They have job or personality specific design and are crafted to think, and reason based on this job or personality specific design. They have free reign to feedback to the task however they see most appropriate ")
    st.image("agentPersona1.png")
llm1 = st.sidebar.selectbox("Model Selection", ['GPT-4', 'GPT3.5'], key='persona1_size')
temp1 = st.sidebar.slider("Tempreature", min_value=0.0, max_value=1.0, step=0.1, value=0.6, key='persona1_temp')
tokens1 = st.sidebar.slider("Tokens", min_value=0, max_value=4000, step=100, value=500, key='persona1_tokens')

# Persona 2
st.sidebar.subheader("Personas 2 Settings")
persona2SystemMessage = st.sidebar.text_area("Define Selection Persona", value=placeHolderPersona2, height=150)
with st.sidebar.expander("See explanation"):
    st.write("Personas: the individual members of the business function / agent equivalent to employee’s. They have job or personality specific design and are crafted to think, and reason based on this job or personality specific design. They have free reign to feedback to the task however they see most appropriate ")
    st.image("agentPersona2.png")
llm2 = st.sidebar.selectbox("Model Selection", ['GPT-4', 'GPT3.5'], key='persona2_size')
temp2 = st.sidebar.slider("Tempreature", min_value=0.0, max_value=1.0, step=0.1, value=0.5, key='persona2_temp')
tokens2 = st.sidebar.slider("Tokens", min_value=0, max_value=4000, step=100, value=500, key='persona2_tokens')
userMessage2 = st.sidebar.text_area("Define User Message", value="This is the conversation todate, ", height=150)
st.sidebar.caption(f"Session ID: {genuuid()}")
# Main chat interface
st.header("Chat with the Agents")
user_id = st.text_input("User ID:", key="user_id")
user_input = st.text_input("Write your message here:", key="user_input")

if 'history' not in st.session_state:
    st.session_state.history = []

if st.button("Send"):
    # Placeholder for processing the input and generating a response
    data = ChatRequestClient(
        user_id=user_id,
        user_input=user_input,
        numberOfQuestions=numberOfQuestions,
        welcomeMessage="",
        llm1=llm1,
        tokens1=tokens1,
        temperature1=temp1,
        persona1SystemMessage=persona1SystemMessage,
        persona2SystemMessage=persona2SystemMessage,
        userMessage2=userMessage2,
        llm2=llm2,
        tokens2=tokens2,
        temperature2=temp2
    )
    response = call_chat_api(data)
    
    
    st.markdown(f"##### Time take: {format_elapsed_time(response['elapsed_time'])}")
    st.markdown(f"##### Question Count : {response['count']} of {numberOfQuestions}")
    
    
    # {"count":count, "user_id":user_id,"time_stamp":time_stamp, "elapsed_time":elapsed_time, "content":content}

    st.session_state.history.append("You: " + user_input)
                
    st.session_state.history.append("Agent: " + response['content'])  # Using 'response' after it's defined
    for message in st.session_state.history:
        st.write(message)