Spaces:
Sleeping
Sleeping
Update app.py
Browse files
app.py
CHANGED
@@ -5,53 +5,61 @@ import logging
|
|
5 |
import warnings
|
6 |
from typing import List, Tuple, Dict
|
7 |
import random
|
|
|
8 |
|
9 |
logging.basicConfig(level=logging.INFO)
|
10 |
logger = logging.getLogger(__name__)
|
11 |
warnings.filterwarnings('ignore')
|
12 |
|
13 |
-
#
|
14 |
-
|
15 |
"casamento": [
|
16 |
{
|
17 |
-
"
|
18 |
-
"
|
19 |
-
"
|
20 |
-
"
|
21 |
-
"
|
22 |
},
|
23 |
{
|
24 |
-
"
|
25 |
-
"
|
26 |
-
"
|
27 |
-
"
|
28 |
-
"
|
29 |
-
}
|
30 |
-
],
|
31 |
-
"criacao_filhos": [
|
32 |
{
|
33 |
-
"
|
34 |
-
"
|
35 |
-
"
|
36 |
-
"
|
37 |
-
"
|
38 |
},
|
39 |
{
|
40 |
-
"
|
41 |
-
"
|
42 |
-
"
|
43 |
-
"
|
44 |
-
"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
45 |
}
|
|
|
|
|
|
|
46 |
]
|
47 |
}
|
48 |
|
49 |
-
class
|
50 |
def __init__(self):
|
51 |
-
logger.info("Inicializando conselheiro bíblico
|
52 |
self.device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
|
53 |
self.model_name = "pierreguillou/bert-base-cased-squad-v1.1-portuguese"
|
54 |
-
self.max_length = 512 # Máximo de tokens
|
55 |
|
56 |
try:
|
57 |
self.tokenizer = AutoTokenizer.from_pretrained(self.model_name)
|
@@ -62,135 +70,130 @@ class EnhancedBiblicalCounselor:
|
|
62 |
logger.error(f"Erro ao carregar modelo: {str(e)}")
|
63 |
raise
|
64 |
|
65 |
-
def
|
66 |
-
"""
|
67 |
|
68 |
-
|
69 |
-
|
70 |
-
|
71 |
-
|
72 |
-
|
73 |
-
|
74 |
-
|
75 |
-
|
76 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
77 |
|
78 |
-
|
79 |
-
|
|
|
|
|
80 |
|
81 |
-
|
82 |
-
|
83 |
|
84 |
-
|
85 |
-
|
86 |
-
"""
|
87 |
-
return response_template
|
88 |
|
89 |
-
|
90 |
-
|
91 |
-
|
92 |
-
return "Tema não encontrado em nossa base.", "Sem referências disponíveis."
|
93 |
-
|
94 |
-
# Seleciona uma passagem relevante
|
95 |
-
passage = BIBLICAL_PASSAGES[theme][0] # Poderia ser randomizado entre as disponíveis
|
96 |
-
context = passage["texto"]
|
97 |
-
|
98 |
-
# Prepara o input com máximo de tokens
|
99 |
-
inputs = self.tokenizer.encode_plus(
|
100 |
-
question,
|
101 |
-
context,
|
102 |
-
return_tensors="pt",
|
103 |
-
max_length=self.max_length,
|
104 |
-
truncation=True,
|
105 |
-
padding="max_length"
|
106 |
-
).to(self.device)
|
107 |
-
|
108 |
-
# Gera a resposta
|
109 |
-
with torch.no_grad():
|
110 |
-
outputs = self.model(**inputs)
|
111 |
-
|
112 |
-
answer_start = torch.argmax(outputs.start_logits)
|
113 |
-
answer_end = torch.argmax(outputs.end_logits)
|
114 |
-
|
115 |
-
tokens = self.tokenizer.convert_ids_to_tokens(inputs["input_ids"][0])
|
116 |
-
answer = tokens[answer_start:answer_end + 1]
|
117 |
-
answer = self.tokenizer.convert_tokens_to_string(answer)
|
118 |
|
119 |
-
|
120 |
-
|
121 |
-
|
122 |
-
|
123 |
-
|
124 |
-
📚 Referências Adicionais:
|
125 |
-
• Passagem Principal: {passage['passagem']}
|
126 |
-
• Tema: {theme.replace('_', ' ').title()}
|
127 |
-
• Contexto: {passage['contexto']}
|
128 |
-
"""
|
129 |
|
130 |
-
|
131 |
|
132 |
-
|
133 |
-
|
134 |
-
return "Perdoe-nos, ocorreu um erro ao processar sua pergunta.", "Erro no processamento"
|
135 |
|
136 |
-
def create_enhanced_interface():
|
137 |
-
counselor = EnhancedBiblicalCounselor()
|
138 |
-
|
139 |
with gr.Blocks(theme=gr.themes.Soft()) as demo:
|
140 |
gr.Markdown("""
|
141 |
-
# 🕊️ Conselheiro Bíblico
|
142 |
-
### Orientação Bíblica
|
143 |
""")
|
144 |
|
145 |
with gr.Row():
|
146 |
with gr.Column():
|
147 |
theme = gr.Dropdown(
|
148 |
-
choices=list(
|
149 |
-
label="Tema
|
150 |
value="casamento"
|
151 |
)
|
152 |
question = gr.Textbox(
|
153 |
label="Sua Pergunta",
|
154 |
-
placeholder="
|
155 |
lines=3
|
156 |
)
|
157 |
-
submit_btn = gr.Button("🙏 Buscar Orientação
|
158 |
|
159 |
with gr.Column():
|
160 |
answer_output = gr.Textbox(
|
161 |
-
label="
|
162 |
-
lines=
|
163 |
)
|
164 |
-
|
165 |
-
label="Referências
|
166 |
-
lines=
|
167 |
)
|
168 |
|
169 |
-
|
170 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
171 |
inputs=[theme, question],
|
172 |
-
outputs=[answer_output,
|
|
|
|
|
173 |
)
|
174 |
|
175 |
-
|
176 |
-
|
177 |
-
|
178 |
-
|
179 |
-
|
180 |
-
1. Escolha o tema específico de sua dúvida
|
181 |
-
2. Faça uma pergunta clara e específica
|
182 |
-
3. Leia atentamente a resposta contextualizada
|
183 |
-
4. Medite nas passagens bíblicas fornecidas
|
184 |
-
5. Ore pedindo sabedoria para aplicar os princípios
|
185 |
-
""")
|
186 |
|
187 |
return demo
|
188 |
|
189 |
if __name__ == "__main__":
|
190 |
try:
|
191 |
-
logger.info("Iniciando aplicação
|
192 |
-
demo =
|
193 |
-
demo.launch(
|
|
|
|
|
|
|
|
|
194 |
except Exception as e:
|
195 |
logger.error(f"Erro ao iniciar aplicação: {str(e)}")
|
196 |
raise
|
|
|
5 |
import warnings
|
6 |
from typing import List, Tuple, Dict
|
7 |
import random
|
8 |
+
import hashlib
|
9 |
|
10 |
logging.basicConfig(level=logging.INFO)
|
11 |
logger = logging.getLogger(__name__)
|
12 |
warnings.filterwarnings('ignore')
|
13 |
|
14 |
+
# Banco de exemplos e respostas pré-definidas
|
15 |
+
BIBLICAL_EXAMPLES = {
|
16 |
"casamento": [
|
17 |
{
|
18 |
+
"pergunta": "Como resolver conflitos no casamento?",
|
19 |
+
"passagem": "Efésios 4:26-32",
|
20 |
+
"texto": """Não se ponha o sol sobre a vossa ira. Não deis lugar ao diabo. Toda amargura, cólera, ira, gritaria e blasfêmia sejam tiradas dentre vós, bem como toda malícia. Antes, sede bondosos uns para com os outros, compassivos, perdoando uns aos outros, como também Deus vos perdoou em Cristo.""",
|
21 |
+
"resposta_base": """O princípio bíblico para resolução de conflitos no casamento envolve três aspectos fundamentais: não deixar a ira se prolongar, comunicar-se com amor e praticar o perdão mútuo. A Palavra nos ensina que devemos resolver os conflitos rapidamente, não permitindo que o sol se ponha sobre nossa ira.""",
|
22 |
+
"aplicacao": "Resolução diária de conflitos, perdão e reconciliação"
|
23 |
},
|
24 |
{
|
25 |
+
"pergunta": "Como manter um casamento forte espiritualmente?",
|
26 |
+
"passagem": "Eclesiastes 4:9-12",
|
27 |
+
"texto": """É melhor serem dois do que um, porque têm melhor paga do seu trabalho. Porque se um cair, o outro levanta o seu companheiro; mas ai do que estiver só; pois, caindo, não haverá outro que o levante. Também, se dois dormirem juntos, eles se aquentarão; mas um só, como se aquentará? E, se alguém prevalecer contra um, os dois lhe resistirão; e o cordão de três dobras não se quebra tão depressa.""",
|
28 |
+
"resposta_base": """A força espiritual do casamento vem da união em três dimensões: o marido, a esposa e Deus. Como um cordão de três dobras, esta união proporciona apoio mútuo, fortalecimento espiritual e resistência nas adversidades.""",
|
29 |
+
"aplicacao": "Desenvolvimento espiritual conjunto e oração em casal"
|
30 |
+
},
|
|
|
|
|
31 |
{
|
32 |
+
"pergunta": "Qual o papel do perdão no casamento?",
|
33 |
+
"passagem": "Colossenses 3:13-14",
|
34 |
+
"texto": """Suportando-vos uns aos outros, e perdoando-vos uns aos outros, se alguém tiver queixa contra outro; assim como Cristo vos perdoou, assim fazei vós também. E, sobre tudo isto, revesti-vos de amor, que é o vínculo da perfeição.""",
|
35 |
+
"resposta_base": """O perdão no casamento reflete o perdão que recebemos de Cristo. É um ato contínuo de amor que fortalece o vínculo conjugal e promove a cura emocional. Devemos perdoar assim como fomos perdoados.""",
|
36 |
+
"aplicacao": "Prática do perdão e cultivo do amor sacrificial"
|
37 |
},
|
38 |
{
|
39 |
+
"pergunta": "Como manter a fidelidade no casamento?",
|
40 |
+
"passagem": "Hebreus 13:4",
|
41 |
+
"texto": """Venerado seja entre todos o matrimônio e o leito sem mácula; porém aos que se dão à prostituição e aos adúlteros, Deus os julgará.""",
|
42 |
+
"resposta_base": """A fidelidade no casamento é um mandamento divino que requer compromisso, respeito mútuo e temor a Deus. O matrimônio deve ser honrado por todos, mantendo a pureza e a santidade da união conjugal.""",
|
43 |
+
"aplicacao": "Compromisso com a fidelidade e pureza conjugal"
|
44 |
+
},
|
45 |
+
{
|
46 |
+
"pergunta": "Como lidar com diferenças no casamento?",
|
47 |
+
"passagem": "1 Pedro 3:8-9",
|
48 |
+
"texto": """Finalmente, sede todos de um mesmo sentimento, compassivos, amando os irmãos, entranhavelmente misericordiosos e humildes. Não tornando mal por mal, ou injúria por injúria; antes, pelo contrário, bendizendo.""",
|
49 |
+
"resposta_base": """As diferenças no casamento devem ser tratadas com compreensão, humildade e respeito mútuo. A unidade não significa uniformidade, mas harmonia nas diferenças através do amor e da compaixão.""",
|
50 |
+
"aplicacao": "Respeito às diferenças e busca da harmonia"
|
51 |
}
|
52 |
+
],
|
53 |
+
"criacao_filhos": [
|
54 |
+
# [Exemplos similares para outros temas...]
|
55 |
]
|
56 |
}
|
57 |
|
58 |
+
class DiverseBiblicalCounselor:
|
59 |
def __init__(self):
|
60 |
+
logger.info("Inicializando conselheiro bíblico...")
|
61 |
self.device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
|
62 |
self.model_name = "pierreguillou/bert-base-cased-squad-v1.1-portuguese"
|
|
|
63 |
|
64 |
try:
|
65 |
self.tokenizer = AutoTokenizer.from_pretrained(self.model_name)
|
|
|
70 |
logger.error(f"Erro ao carregar modelo: {str(e)}")
|
71 |
raise
|
72 |
|
73 |
+
def get_unique_response(self, question: str, theme: str) -> Tuple[str, Dict]:
|
74 |
+
"""Gera uma resposta única baseada na pergunta e tema"""
|
75 |
|
76 |
+
# Gera um hash da pergunta para garantir consistência
|
77 |
+
question_hash = hashlib.md5(question.lower().encode()).hexdigest()
|
78 |
+
|
79 |
+
# Seleciona exemplo baseado no hash
|
80 |
+
examples = BIBLICAL_EXAMPLES.get(theme, [])
|
81 |
+
if not examples:
|
82 |
+
return "Tema não encontrado", {}
|
83 |
+
|
84 |
+
# Usa o hash para selecionar um exemplo de forma determinística
|
85 |
+
selected_index = int(question_hash, 16) % len(examples)
|
86 |
+
example = examples[selected_index]
|
87 |
+
|
88 |
+
# Prepara o contexto para o modelo
|
89 |
+
inputs = self.tokenizer.encode_plus(
|
90 |
+
question,
|
91 |
+
example["texto"],
|
92 |
+
return_tensors="pt",
|
93 |
+
max_length=512,
|
94 |
+
truncation=True,
|
95 |
+
padding="max_length"
|
96 |
+
).to(self.device)
|
97 |
+
|
98 |
+
# Gera a resposta
|
99 |
+
with torch.no_grad():
|
100 |
+
outputs = self.model(**inputs)
|
101 |
+
|
102 |
+
answer_start = torch.argmax(outputs.start_logits)
|
103 |
+
answer_end = torch.argmax(outputs.end_logits)
|
104 |
+
|
105 |
+
tokens = self.tokenizer.convert_ids_to_tokens(inputs["input_ids"][0])
|
106 |
+
model_answer = tokens[answer_start:answer_end + 1]
|
107 |
+
model_answer = self.tokenizer.convert_tokens_to_string(model_answer)
|
108 |
|
109 |
+
# Formata a resposta final
|
110 |
+
response = f"""
|
111 |
+
🕊️ Conselho Bíblico:
|
112 |
+
{example['resposta_base']}
|
113 |
|
114 |
+
📖 Passagem Bíblica:
|
115 |
+
{example['passagem']}: {example['texto']}
|
116 |
|
117 |
+
✝️ Aplicação Prática:
|
118 |
+
{example['aplicacao']}
|
|
|
|
|
119 |
|
120 |
+
💭 Reflexão Adicional:
|
121 |
+
{model_answer}
|
122 |
+
"""
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
123 |
|
124 |
+
metadata = {
|
125 |
+
"passagem": example['passagem'],
|
126 |
+
"contexto": "Baseado em princípios bíblicos para " + theme.replace('_', ' '),
|
127 |
+
"aplicacao": example['aplicacao']
|
128 |
+
}
|
|
|
|
|
|
|
|
|
|
|
129 |
|
130 |
+
return response, metadata
|
131 |
|
132 |
+
def create_interface():
|
133 |
+
counselor = DiverseBiblicalCounselor()
|
|
|
134 |
|
|
|
|
|
|
|
135 |
with gr.Blocks(theme=gr.themes.Soft()) as demo:
|
136 |
gr.Markdown("""
|
137 |
+
# 🕊️ Conselheiro Bíblico
|
138 |
+
### Orientação Bíblica Personalizada
|
139 |
""")
|
140 |
|
141 |
with gr.Row():
|
142 |
with gr.Column():
|
143 |
theme = gr.Dropdown(
|
144 |
+
choices=list(BIBLICAL_EXAMPLES.keys()),
|
145 |
+
label="Tema",
|
146 |
value="casamento"
|
147 |
)
|
148 |
question = gr.Textbox(
|
149 |
label="Sua Pergunta",
|
150 |
+
placeholder="Digite sua pergunta...",
|
151 |
lines=3
|
152 |
)
|
153 |
+
submit_btn = gr.Button("🙏 Buscar Orientação")
|
154 |
|
155 |
with gr.Column():
|
156 |
answer_output = gr.Textbox(
|
157 |
+
label="Resposta",
|
158 |
+
lines=10
|
159 |
)
|
160 |
+
metadata_output = gr.Textbox(
|
161 |
+
label="Referências",
|
162 |
+
lines=3
|
163 |
)
|
164 |
|
165 |
+
# Exemplos
|
166 |
+
gr.Examples(
|
167 |
+
examples=[
|
168 |
+
["casamento", "Como resolver conflitos no casamento?"],
|
169 |
+
["casamento", "Como manter um casamento forte espiritualmente?"],
|
170 |
+
["casamento", "Qual o papel do perdão no casamento?"],
|
171 |
+
["casamento", "Como manter a fidelidade no casamento?"],
|
172 |
+
["casamento", "Como lidar com diferenças no casamento?"]
|
173 |
+
],
|
174 |
inputs=[theme, question],
|
175 |
+
outputs=[answer_output, metadata_output],
|
176 |
+
fn=lambda t, q: counselor.get_unique_response(q, t),
|
177 |
+
label="Exemplos de Perguntas"
|
178 |
)
|
179 |
|
180 |
+
submit_btn.click(
|
181 |
+
fn=lambda t, q: counselor.get_unique_response(q, t),
|
182 |
+
inputs=[theme, question],
|
183 |
+
outputs=[answer_output, metadata_output]
|
184 |
+
)
|
|
|
|
|
|
|
|
|
|
|
|
|
185 |
|
186 |
return demo
|
187 |
|
188 |
if __name__ == "__main__":
|
189 |
try:
|
190 |
+
logger.info("Iniciando aplicação...")
|
191 |
+
demo = create_interface()
|
192 |
+
demo.launch(
|
193 |
+
server_name="0.0.0.0",
|
194 |
+
share=True,
|
195 |
+
show_error=True
|
196 |
+
)
|
197 |
except Exception as e:
|
198 |
logger.error(f"Erro ao iniciar aplicação: {str(e)}")
|
199 |
raise
|