Compare commits
No commits in common. "8b33ed2214ec8f98d6878c4575128e0523a8e004" and "5c5581e2719ee107469c46bdf709d98c70755097" have entirely different histories.
8b33ed2214
...
5c5581e271
@ -21,10 +21,6 @@ examples = [
|
|||||||
"input": "Donne moi une information.",
|
"input": "Donne moi une information.",
|
||||||
"output": "Désolé je n'ai pas assez d'information pour vous aider. Merci de fournir le type de contrat et de travail que vous occupez.",
|
"output": "Désolé je n'ai pas assez d'information pour vous aider. Merci de fournir le type de contrat et de travail que vous occupez.",
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"input": "Pouvez-vous m'aider sur le droit des freelances ?",
|
|
||||||
"output": "Pour mieux comprendre votre situation, pourriez-vous me donner plus de détails sur votre contexte spécifique en tant que freelance ? Par exemple, quel est votre domaine d'activité, votre statut juridique, etc. Cela me permettra de vous fournir des informations plus précises et adaptées à votre situation."
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"input": "Mon patron est méchant avec moi.",
|
"input": "Mon patron est méchant avec moi.",
|
||||||
"output": "Désolé je n'ai pas assez d'information pour vous aider. Merci de fournir le type de contrat et de travail que vous occupez.",
|
"output": "Désolé je n'ai pas assez d'information pour vous aider. Merci de fournir le type de contrat et de travail que vous occupez.",
|
||||||
|
51
web-ui.py
51
web-ui.py
@ -1,12 +1,5 @@
|
|||||||
from __future__ import annotations
|
|
||||||
|
|
||||||
import copy
|
|
||||||
import random
|
import random
|
||||||
from typing import Iterable
|
|
||||||
|
|
||||||
import gradio as gr
|
import gradio as gr
|
||||||
from gradio.themes.base import Base
|
|
||||||
from gradio.themes.utils import colors, fonts, sizes
|
|
||||||
|
|
||||||
__import__('pysqlite3')
|
__import__('pysqlite3')
|
||||||
import sys
|
import sys
|
||||||
@ -46,7 +39,7 @@ few_shot_prompt = FewShotChatMessagePromptTemplate(
|
|||||||
final_prompt = ChatPromptTemplate.from_messages(
|
final_prompt = ChatPromptTemplate.from_messages(
|
||||||
[
|
[
|
||||||
("system",
|
("system",
|
||||||
"You are a lawyer specialized in French Labour laws that promotes Unions and regulation authorities. You want to help but not misguide the user. If you don't know the answer, just say that you don't know. Don't hesitate to reformulate and think about the issues. Cite law articles as much as possible."),
|
"You are a lawyer specialized in French Labour laws and promting Unions. You want to help but not misguide the user. If you don't know the answer, just say that you don't know. Don't hesitate to reformulate and think about the issues. Cite law articles as much as possible."),
|
||||||
few_shot_prompt,
|
few_shot_prompt,
|
||||||
("human", """
|
("human", """
|
||||||
Question: {question}
|
Question: {question}
|
||||||
@ -60,49 +53,17 @@ Answer:
|
|||||||
|
|
||||||
llm = ChatOpenAI(model_name="gpt-3.5-turbo", temperature=0.33)
|
llm = ChatOpenAI(model_name="gpt-3.5-turbo", temperature=0.33)
|
||||||
rag_chain = (
|
rag_chain = (
|
||||||
{"context": retriever, "question": RunnablePassthrough(), "input": RunnablePassthrough()}
|
{"context": retriever, "question": RunnablePassthrough(), "input" : RunnablePassthrough()}
|
||||||
| final_prompt
|
| final_prompt
|
||||||
| llm
|
| llm
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def random_response(message, history):
|
||||||
def merge_history(message: str, reversed_history: list) -> str:
|
res = rag_chain.invoke(message)
|
||||||
max_words = 1499
|
|
||||||
merged_message = []
|
|
||||||
if len(reversed_history) == 0:
|
|
||||||
return message
|
|
||||||
merged_message.extend(
|
|
||||||
f"Ma question est: <question>{message}</question>. L'historique de la discussion est <history>".split())
|
|
||||||
|
|
||||||
for msg,response in reversed_history:
|
|
||||||
if len(merged_message) >= max_words:
|
|
||||||
break
|
|
||||||
words = msg.split(" ")
|
|
||||||
merged_message.extend(words[0:(max_words - len(merged_message))])
|
|
||||||
merged_message.append("</history>")
|
|
||||||
return " ".join(merged_message)
|
|
||||||
|
|
||||||
|
|
||||||
def llm_response(message, history):
|
|
||||||
reversed_history = copy.deepcopy(history)
|
|
||||||
reversed_history.reverse()
|
|
||||||
merged_message = merge_history(message, reversed_history)
|
|
||||||
res = rag_chain.invoke(merged_message)
|
|
||||||
return res.content
|
return res.content
|
||||||
|
|
||||||
|
|
||||||
demo = gr.ChatInterface(
|
demo = gr.ChatInterface(random_response)
|
||||||
llm_response,
|
|
||||||
examples=[
|
|
||||||
"J'ai été embauchée en Contrat à Durée Déterminée d'une durée de 3 mois pour un poste de vendeuse dans un supermarché. J'ai déjà fait 2 semaines mais le poste ne me convient pas. Comment rompre ma période d’essai?",
|
|
||||||
"Je suis dans la fonction publique territoriale, plus précisément agent de maîtrise pour une commune. Est-ce que mon employeur peut modifier mes dates de départ en congé alors qu'elles étaient définies depuis plus d'un mois? "
|
|
||||||
],
|
|
||||||
theme=gr.themes.Soft(),
|
|
||||||
analytics_enabled=False
|
|
||||||
)
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
demo.launch(
|
demo.launch()
|
||||||
show_error=True,
|
|
||||||
|
|
||||||
)
|
|
||||||
|
Loading…
Reference in New Issue
Block a user