DHEIVER commited on
Commit
8183430
·
verified ·
1 Parent(s): 1048b9c

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +28 -13
app.py CHANGED
@@ -6,25 +6,40 @@ client = InferenceClient("mistralai/Mixtral-8x7B-Instruct-v0.1")
6
 
7
  # Função para formatar o prompt de entrada com o histórico de diálogo
8
  def formatar_prompt(mensagem, historico):
9
- prompt = "<s>" + "".join(f"[INST] {prompt_usuario} [/INST] {resposta_bot}" for prompt_usuario, resposta_bot in historico) + f"[INST] {mensagem} [/INST]"
 
 
 
 
10
  return prompt
11
 
12
  # Função para gerar resposta do modelo
13
  def gerar(prompt, historico, prompt_sistema, temperatura=0.9, max_tokens_novos=256, top_p=0.95, penalidade_repeticao=1.0):
 
 
 
14
  kwargs_geracao = dict(
15
- temperature=float(temperatura),
16
- max_new_tokens=int(max_tokens_novos),
17
- top_p=float(top_p),
18
- repetition_penalty=float(penalidade_repeticao),
19
  do_sample=True,
20
  seed=42,
21
  )
 
 
22
  prompt_formatada = formatar_prompt(f"{prompt_sistema}, {prompt}", historico)
 
 
23
  stream = client.text_generation(prompt_formatada, **kwargs_geracao, stream=True, details=True, return_full_text=False)
 
 
24
  for resposta in stream:
25
- yield resposta.token.text
 
 
26
 
27
- # Inputs adicionais para o modelo
28
  inputs_adicionais = [
29
  gr.Textbox(label="Prompt do Sistema", max_lines=1, interactive=True),
30
  gr.Slider(label="Temperatura", value=0.9, minimum=0.0, maximum=1.0, step=0.05, interactive=True, info="Valores mais altos produzem saídas mais diversas"),
@@ -35,11 +50,11 @@ inputs_adicionais = [
35
 
36
  # Exemplos de prompts
37
  exemplos = [
38
- ["Paciente de 55 anos, história familiar de doença cardíaca. Colesterol total: 260 mg/dL, HDL: 40 mg/dL, LDL: 180 mg/dL, triglicerídeos: 200 mg/dL. Interpretar resultados e sugerir intervenções.", None, None, None, None, None],
39
- ["Ecocardiograma em paciente de 70 anos, dispneia aos esforços. Fração de ejeção: 40%, espessamento do septo interventricular, dilatação atrial esquerda. Propor tratamento para insuficiência cardíaca.", None, None, None, None, None],
40
- ["Teste de esforço em esteira, paciente de 45 anos, dor torácica atípica. 10 METs atingidos, depressão do segmento ST de 2 mm no pós-exercício. Recomendar próximos passos diagnósticos e terapêuticos.", None, None, None, None, None],
41
- ["Holter de 24 horas, paciente de 60 anos, síncope recorrente. Episódios de pausas sinusais de até 5 segundos, arritmia sinusal respiratória. Formular plano para bradicardia sintomática.", None, None, None, None, None],
42
- ["Cateterismo cardíaco em paciente de 65 anos, angina instável. Angiografia revela lesões significativas em duas artérias coronárias principais, FFR: 0,68. Recomendar opções de revascularização.", None, None, None, None, None]
43
  ]
44
 
45
  # Interface do Chat
@@ -50,4 +65,4 @@ gr.ChatInterface(
50
  title="Medchat | Automação Inteligente de Saúde",
51
  examples=exemplos,
52
  concurrency_limit=20,
53
- ).launch(show_api=False)
 
6
 
7
  # Função para formatar o prompt de entrada com o histórico de diálogo
8
  def formatar_prompt(mensagem, historico):
9
+ prompt = "<s>"
10
+ for prompt_usuario, resposta_bot in historico:
11
+ prompt += f"[INST] {prompt_usuario} [/INST]"
12
+ prompt += f" {resposta_bot}</s> "
13
+ prompt += f"[INST] {mensagem} [/INST]"
14
  return prompt
15
 
16
  # Função para gerar resposta do modelo
17
  def gerar(prompt, historico, prompt_sistema, temperatura=0.9, max_tokens_novos=256, top_p=0.95, penalidade_repeticao=1.0):
18
+ temperatura = max(0.01, float(temperatura)) # Garante que a temperatura seja pelo menos 0.01
19
+ top_p = float(top_p)
20
+
21
  kwargs_geracao = dict(
22
+ temperature=temperatura,
23
+ max_new_tokens=max_tokens_novos,
24
+ top_p=top_p,
25
+ repetition_penalty=penalidade_repeticao,
26
  do_sample=True,
27
  seed=42,
28
  )
29
+
30
+ # Formata o prompt
31
  prompt_formatada = formatar_prompt(f"{prompt_sistema}, {prompt}", historico)
32
+
33
+ # Geração de texto com stream
34
  stream = client.text_generation(prompt_formatada, **kwargs_geracao, stream=True, details=True, return_full_text=False)
35
+ output = ""
36
+
37
  for resposta in stream:
38
+ output += resposta.token.text
39
+ yield output
40
+ return output
41
 
42
+ # Criação dos widgets de entrada adicionais
43
  inputs_adicionais = [
44
  gr.Textbox(label="Prompt do Sistema", max_lines=1, interactive=True),
45
  gr.Slider(label="Temperatura", value=0.9, minimum=0.0, maximum=1.0, step=0.05, interactive=True, info="Valores mais altos produzem saídas mais diversas"),
 
50
 
51
  # Exemplos de prompts
52
  exemplos = [
53
+ ["Analise o caso de um paciente de 55 anos com histórico familiar de doença cardíaca. Ele apresenta um colesterol total de 260 mg/dL, HDL de 40 mg/dL, LDL de 180 mg/dL e triglicerídeos de 200 mg/dL. Interpretar os resultados e sugerir intervenções dietéticas e farmacológicas.", None, None, None, None, None],
54
+ ["Examine os resultados de um ecocardiograma em um paciente de 70 anos que se queixa de dispneia aos esforços. O exame revela uma fração de ejeção de 40%, espessamento do septo interventricular e dilatação atrial esquerda. Propor um plano de tratamento e acompanhamento para insuficiência cardíaca.", None, None, None, None, None],
55
+ ["Avalie os achados de um teste de esforço em esteira em um paciente de 45 anos com dor torácica atípica. Ele atingiu 10 METs, mas desenvolveu depressão do segmento ST de 2 mm no pós-exercício. Recomendar próximos passos diagnósticos e terapêuticos.", None, None, None, None, None],
56
+ ["Interpretar os resultados de um Holter de 24 horas em um paciente de 60 anos com síncope recorrente. O registro mostra episódios de pausas sinusais de até 5 segundos e arritmia sinusal respiratória. Formular um plano de monitoramento e tratamento para bradicardia sintomática.", None, None, None, None, None],
57
+ ["Analise os resultados de um cateterismo cardíaco em um paciente de 65 anos com angina instável. A angiografia revela lesões significativas em duas artérias coronárias principais, com uma fração de fluxo fracionada (FFR) de 0,68. Recomendar opções de revascularização e manejo da doença coronariana.", None, None, None, None, None]
58
  ]
59
 
60
  # Interface do Chat
 
65
  title="Medchat | Automação Inteligente de Saúde",
66
  examples=exemplos,
67
  concurrency_limit=20,
68
+ ).launch(show_api=False)