Spaces:
Sleeping
Sleeping
Commit
·
329999f
1
Parent(s):
9b93b4d
decision éclairée
Browse files- app.py +2 -2
- pattern_decision.py +133 -72
app.py
CHANGED
@@ -34,7 +34,7 @@ List_prompt = {
|
|
34 |
"<V2 Détection du pattern 'ce qui explique' >": explication_prompt_template(),
|
35 |
"<V2 Détection des adverbes en -ment >": adverbement_prompt_template(),
|
36 |
"<V2 Détection des connecteurs 'cependant' >": connecteur_prompt_template(),
|
37 |
-
"< Détection des decision 'éclairée...' >": decision_prompt_template(),
|
38 |
"< Détection du pattern 'look' >": look_prompt_template(),
|
39 |
"< Détection du pattern 'il existe' >": il_existe_prompt_template(),
|
40 |
"< Détection du pattern 'il faut' >": il_faut_prompt_template(),
|
@@ -152,7 +152,7 @@ if st.button("Lancer l'analyse"):
|
|
152 |
logging.error(f"Error during analysis: {e}")
|
153 |
st.error(f"Une erreur s'est produite lors de l'analyse : {str(e)}")
|
154 |
|
155 |
-
elif option == "< Détection des decision 'éclairée...' >":
|
156 |
try:
|
157 |
# Analyser le texte pour les fautes de style
|
158 |
result = decision(input_text)
|
|
|
34 |
"<V2 Détection du pattern 'ce qui explique' >": explication_prompt_template(),
|
35 |
"<V2 Détection des adverbes en -ment >": adverbement_prompt_template(),
|
36 |
"<V2 Détection des connecteurs 'cependant' >": connecteur_prompt_template(),
|
37 |
+
"<V2 Détection des decision 'éclairée...' >": decision_prompt_template(),
|
38 |
"< Détection du pattern 'look' >": look_prompt_template(),
|
39 |
"< Détection du pattern 'il existe' >": il_existe_prompt_template(),
|
40 |
"< Détection du pattern 'il faut' >": il_faut_prompt_template(),
|
|
|
152 |
logging.error(f"Error during analysis: {e}")
|
153 |
st.error(f"Une erreur s'est produite lors de l'analyse : {str(e)}")
|
154 |
|
155 |
+
elif option == "<V2 Détection des decision 'éclairée...' >":
|
156 |
try:
|
157 |
# Analyser le texte pour les fautes de style
|
158 |
result = decision(input_text)
|
pattern_decision.py
CHANGED
@@ -8,90 +8,151 @@ from langchain.output_parsers import PydanticOutputParser
|
|
8 |
|
9 |
|
10 |
# Modèles Pydantic pour structurer la réponse
|
11 |
-
class
|
12 |
-
|
13 |
-
|
14 |
-
|
15 |
|
16 |
-
class
|
17 |
-
|
18 |
-
|
19 |
-
|
20 |
-
alternative_suggestions: AlternativeSuggestion = Field(..., description="Deux suggestions de reformulation avec justification.")
|
21 |
|
22 |
-
|
23 |
-
|
24 |
-
"pattern": self.pattern,
|
25 |
-
"indices": self.indices,
|
26 |
-
"sentence": self.sentence,
|
27 |
-
"alternative_suggestions": {
|
28 |
-
"suggestion_1": self.alternative_suggestions.suggestion_1,
|
29 |
-
"suggestion_2": self.alternative_suggestions.suggestion_2,
|
30 |
-
"justification": self.alternative_suggestions.justification
|
31 |
-
}
|
32 |
-
}
|
33 |
|
34 |
-
class
|
35 |
-
|
36 |
-
|
37 |
-
|
|
|
38 |
|
39 |
-
|
40 |
-
|
41 |
-
|
42 |
-
|
43 |
-
"occurrences": self.occurrences
|
44 |
-
}
|
45 |
|
46 |
class DetectionResult(BaseModel):
|
47 |
-
|
48 |
-
summary: Summary = Field(..., description="Résumé de la détection
|
49 |
|
50 |
def to_dict(self):
|
51 |
return {
|
52 |
-
"
|
53 |
-
"summary": self.summary.
|
54 |
}
|
55 |
|
56 |
-
def decision_prompt_template():
|
57 |
-
return """
|
58 |
-
Veuillez analyser le texte suivant et identifier toutes les occurrences des expressions liées à la prise de décision comportant des adjectifs tels que "éclairée", "avisée", "judicieuse", "réfléchie", "sage", "pertinente", "optimale", "sensée", etc.
|
59 |
-
|
60 |
-
Pour chaque occurrence trouvée, veuillez :
|
61 |
-
|
62 |
-
- Citer la phrase complète où l'expression apparaît.
|
63 |
-
- Indiquer l'expression exacte utilisée dans le texte.
|
64 |
-
- Proposer deux reformulations de la phrase, en supprimant l'expression ou en la reformulant pour améliorer le style, tout en conservant le sens général.
|
65 |
-
- Assurez-vous que la phrase reformulée est grammaticalement correcte, naturelle et adaptée au contexte.
|
66 |
-
|
67 |
-
Assurez-vous également de respecter les règles suivantes :
|
68 |
-
1. Les expressions comme "crucial", "essentiel", "important", "fondamental", etc., ne doivent pas être utilisées plus d'une fois dans l'introduction.
|
69 |
-
2. Les expressions comme "Il existe", "il faut", "cependant", "de plus", "en revanche", "néanmoins", "toutefois" ne doivent pas être utilisées en début de phrase.
|
70 |
-
3. Les expressions comme "joue un rôle", "il est", ou "est une étape" ne doivent pas être associées à des adjectifs comme "important", "essentiel", etc.
|
71 |
-
4. "En plus" ne doit pas être utilisé seul en début de phrase.
|
72 |
-
|
73 |
-
Le format de sortie doit être un JSON structuré avec les éléments suivants pour chaque pattern détecté :
|
74 |
-
|
75 |
-
- "pattern": "mot ou expression détectée",
|
76 |
-
- "indices": [[index de début, index de fin pour chaque occurrence]],
|
77 |
-
- "sentence": "phrase où l'expression est utilisée",
|
78 |
-
- "alternative_suggestions": ["suggestion 1", "suggestion 2"],
|
79 |
-
- "justification": "justification de la suggestion"
|
80 |
|
81 |
-
|
82 |
-
|
83 |
-
|
84 |
-
|
85 |
-
|
86 |
-
|
87 |
-
|
88 |
-
|
89 |
-
|
90 |
-
|
91 |
-
|
92 |
-
|
93 |
-
|
94 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
95 |
|
96 |
def decision(text):
|
97 |
# Créer le template avec la variable text intégrée directement
|
|
|
8 |
|
9 |
|
10 |
# Modèles Pydantic pour structurer la réponse
|
11 |
+
class Expression(BaseModel):
|
12 |
+
expression: str = Field(..., description="Expression détectée (ex: 'est une étape importante')")
|
13 |
+
indice_debut: int = Field(..., description="Indice de début de l'expression")
|
14 |
+
indice_fin: int = Field(..., description="Indice de fin de l'expression")
|
15 |
|
16 |
+
class Phrase(BaseModel):
|
17 |
+
texte: str = Field(..., description="Phrase complète contenant l'expression ou les expressions détectées")
|
18 |
+
indice_debut: int = Field(..., description="Indice de début de la phrase")
|
19 |
+
indice_fin: int = Field(..., description="Indice de fin de la phrase")
|
|
|
20 |
|
21 |
+
class Reformulation(BaseModel):
|
22 |
+
texte: str = Field(..., description="Texte de la reformulation")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
23 |
|
24 |
+
class PhraseDetectee(BaseModel):
|
25 |
+
phrase: Phrase = Field(..., description="Détails de la phrase")
|
26 |
+
erreurs: List[Expression] = Field(..., description="Liste des expressions détectées dans la phrase")
|
27 |
+
reformulations: List[Reformulation] = Field(..., description="Liste des reformulations proposées")
|
28 |
+
justification: str = Field(..., description="Justification des reformulations proposées")
|
29 |
|
30 |
+
class Summary(BaseModel):
|
31 |
+
total_erreurs: int = Field(..., description="Nombre total d'expressions détectées")
|
32 |
+
total_phrases: int = Field(..., description="Nombre total de phrases contenant des expressions")
|
33 |
+
total_reformulations: int = Field(..., description="Nombre total de reformulations proposées")
|
|
|
|
|
34 |
|
35 |
class DetectionResult(BaseModel):
|
36 |
+
phrases_detectees: List[PhraseDetectee] = Field(..., description="Liste des phrases détectées avec détails")
|
37 |
+
summary: Summary = Field(..., description="Résumé de la détection")
|
38 |
|
39 |
def to_dict(self):
|
40 |
return {
|
41 |
+
"phrases_detectees": [phrase.model_dump() for phrase in self.phrases_detectees],
|
42 |
+
"summary": self.summary.model_dump()
|
43 |
}
|
44 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
45 |
|
46 |
+
def decision_prompt_template():
|
47 |
+
return """En tant que rédacteur web expert, votre mission est d'analyser le texte suivant et d'identifier toutes les occurrences des expressions liées à la prise de décision comportant des adjectifs tels que :
|
48 |
+
"Éclairée"
|
49 |
+
"Avisée"
|
50 |
+
"Judicieuse"
|
51 |
+
"Réfléchie"
|
52 |
+
"Sage"
|
53 |
+
"Pertinente"
|
54 |
+
"Optimale"
|
55 |
+
"Sensée"
|
56 |
+
Incluez également toute autre expression similaire qui reflète la notion de prise de décision de manière positive et prudente.
|
57 |
+
|
58 |
+
Pour chaque phrase où une ou plusieurs occurrences sont trouvées, veuillez :
|
59 |
+
|
60 |
+
1. Citer la phrase complète avec ses indices de début et de fin.
|
61 |
+
2. Identifier l'expression exacte utilisée dans la phrase avec ses indices.
|
62 |
+
3. Proposer cinq reformulations de la phrase, en supprimant l'expression détectée, tout en conservant le sens général de la phrase et en la rendant plus professionnelle.
|
63 |
+
- Assurez-vous que la phrase reformulée soit grammaticalement correcte, naturelle et adaptée au contexte.
|
64 |
+
- Évitez impérativement toute redondance ou répétition de mots.
|
65 |
+
4. Respecter les règles suivantes lors de la reformulation :
|
66 |
+
- Ne pas utiliser : "Crucial", "Essentiel", "Important", "Fondamental", "Le monde de", "Dans l’univers de", "À l’ère de", "Généralement", "Outre", "Cela signifie que", "Ce qui signifie que", "Voici", "Découvrez", "S’avérer être", "Il suffit de", "Permet", "Décision éclairée", "Décision avisée" et leurs variantes.
|
67 |
+
- Ne pas utiliser "Look" et ses variantes dans un contexte de décoration.
|
68 |
+
- Ne pas commencer une phrase par : "Il existe", "Il faut", "Cependant", "De plus", "En revanche", "Néanmoins", "Toutefois", "Imaginez" ou leurs variantes.
|
69 |
+
- Ne pas associer : "Joue un rôle", "Il est", "Est une étape" à des mots tels que "Important", "Essentiel", "Crucial", "Primordial", "Fondamental", "Indispensable", "Déterminant".
|
70 |
+
- Ne pas commencer une phrase par : "En plus" ou ses variantes.
|
71 |
+
5. Justifier les reformulations proposées en expliquant comment elles améliorent le style ou la clarté tout en respectant l'intention originale de la phrase.
|
72 |
+
Exemples d'erreurs à corriger :
|
73 |
+
"La décision éclairée de l'équipe a permis de résoudre le problème", mais on dit "L'équipe a résolu le problème grâce à une décision rapide."
|
74 |
+
"Son jugement judicieux a aidé à avancer dans le projet", mais on dit "Son jugement a permis des avancées importantes dans le projet."
|
75 |
+
"La décision avisée a conduit à des résultats positifs", mais on dit "Cette décision a conduit à des résultats positifs."
|
76 |
+
|
77 |
+
Ton analyse doit être retournée en JSON avec la structure suivante :
|
78 |
+
{{
|
79 |
+
"phrases_detectees": [
|
80 |
+
{{
|
81 |
+
"phrase": {{
|
82 |
+
"texte": "Phrase complète contenant l'expression ou les expressions détectées",
|
83 |
+
"indice_debut": x,
|
84 |
+
"indice_fin": y
|
85 |
+
}},
|
86 |
+
"erreurs": [
|
87 |
+
{{
|
88 |
+
"expression": "Expression détectée",
|
89 |
+
"indice_debut": a,
|
90 |
+
"indice_fin": b
|
91 |
+
}}
|
92 |
+
],
|
93 |
+
"reformulations": [
|
94 |
+
{{ "texte": "Reformulation 1" }},
|
95 |
+
{{ "texte": "Reformulation 2" }},
|
96 |
+
{{ "texte": "Reformulation 3" }},
|
97 |
+
{{ "texte": "Reformulation 4" }},
|
98 |
+
{{ "texte": "Reformulation 5" }}
|
99 |
+
],
|
100 |
+
"justification": "Justification des reformulations proposées en s'il est disponible l'adjectif qualificatif à laquelle c'est associés."
|
101 |
+
}}
|
102 |
+
],
|
103 |
+
"summary": {{
|
104 |
+
"total_erreurs": nombre_total_d_expressions_detectées,
|
105 |
+
"total_phrases": nombre_total_de_phrases_contenant_des_expressions,
|
106 |
+
"total_reformulations": nombre_total_de_reformulations_proposées
|
107 |
+
}}
|
108 |
+
}}
|
109 |
+
|
110 |
+
|
111 |
+
Texte à analyser :
|
112 |
+
{text}
|
113 |
+
|
114 |
+
Assurez-vous que les indices correspondent aux positions exactes dans le texte original et que le JSON est correctement formaté.
|
115 |
+
{format_instruction}"""
|
116 |
+
|
117 |
+
# def decision_prompt_template():
|
118 |
+
# return """
|
119 |
+
# Veuillez analyser le texte suivant et identifier toutes les occurrences des expressions liées à la prise de décision comportant des adjectifs tels que "éclairée", "avisée", "judicieuse", "réfléchie", "sage", "pertinente", "optimale", "sensée", etc.
|
120 |
+
|
121 |
+
# Pour chaque occurrence trouvée, veuillez :
|
122 |
+
|
123 |
+
# - Citer la phrase complète où l'expression apparaît.
|
124 |
+
# - Indiquer l'expression exacte utilisée dans le texte.
|
125 |
+
# - Proposer deux reformulations de la phrase, en supprimant l'expression ou en la reformulant pour améliorer le style, tout en conservant le sens général.
|
126 |
+
# - Assurez-vous que la phrase reformulée est grammaticalement correcte, naturelle et adaptée au contexte.
|
127 |
+
|
128 |
+
# Assurez-vous également de respecter les règles suivantes :
|
129 |
+
# 1. Les expressions comme "crucial", "essentiel", "important", "fondamental", etc., ne doivent pas être utilisées plus d'une fois dans l'introduction.
|
130 |
+
# 2. Les expressions comme "Il existe", "il faut", "cependant", "de plus", "en revanche", "néanmoins", "toutefois" ne doivent pas être utilisées en début de phrase.
|
131 |
+
# 3. Les expressions comme "joue un rôle", "il est", ou "est une étape" ne doivent pas être associées à des adjectifs comme "important", "essentiel", etc.
|
132 |
+
# 4. "En plus" ne doit pas être utilisé seul en début de phrase.
|
133 |
+
|
134 |
+
# Le format de sortie doit être un JSON structuré avec les éléments suivants pour chaque pattern détecté :
|
135 |
+
|
136 |
+
# - "pattern": "mot ou expression détectée",
|
137 |
+
# - "indices": [[index de début, index de fin pour chaque occurrence]],
|
138 |
+
# - "sentence": "phrase où l'expression est utilisée",
|
139 |
+
# - "alternative_suggestions": ["suggestion 1", "suggestion 2"],
|
140 |
+
# - "justification": "justification de la suggestion"
|
141 |
+
|
142 |
+
# Si aucun pattern n'est trouvé, retournez un JSON avec :
|
143 |
+
# - "pattern0": "",
|
144 |
+
# - "occurrences": 0,
|
145 |
+
|
146 |
+
# À la fin, ajoutez un résumé avec :
|
147 |
+
# - "total_patterns_detected": nombre total de patterns détectés,
|
148 |
+
# - "alternative_suggestions_provided": nombre de suggestions données,
|
149 |
+
# - "occurrences": nombre d'occurrences.
|
150 |
+
|
151 |
+
# Voici le texte à analyser :
|
152 |
+
# ```{text}```
|
153 |
+
|
154 |
+
# \n{format_instruction}
|
155 |
+
# """
|
156 |
|
157 |
def decision(text):
|
158 |
# Créer le template avec la variable text intégrée directement
|