Spaces:
Running
Running
File size: 11,235 Bytes
12aabae 91e94f1 12aabae 91e94f1 c9b80e5 12aabae 91e94f1 c9b80e5 91e94f1 c9b80e5 12aabae c9b80e5 12aabae c9b80e5 91e94f1 c9b80e5 91e94f1 c9b80e5 12aabae 91e94f1 12aabae c9b80e5 91e94f1 12aabae 91e94f1 12aabae c9b80e5 12aabae 91e94f1 12aabae 91e94f1 12aabae 91e94f1 12aabae c9b80e5 12aabae c9b80e5 91e94f1 12aabae 91e94f1 12aabae 91e94f1 12aabae 91e94f1 12aabae 91e94f1 12aabae 91e94f1 12aabae b70c257 466dbe3 c9b80e5 e232de0 c9b80e5 466dbe3 b70c257 466dbe3 e232de0 91e94f1 c9b80e5 e232de0 b70c257 91e94f1 e232de0 466dbe3 c9b80e5 466dbe3 91e94f1 e232de0 91e94f1 e232de0 91e94f1 e232de0 91e94f1 e232de0 91e94f1 12aabae e232de0 12aabae 91e94f1 c9b80e5 12aabae 91e94f1 |
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 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 |
import os
import re
import cohere
import gradio as gr
from typing import Iterator, List, Tuple
# Configuration Constants
DEFAULT_SYSTEM_PROMPT = """
أنت مترجم ثنائي اللغة متخصص في الترجمة بين العربية والإنجليزية. هدفك هو تقديم ترجمات دقيقة، ملائمة للسياق، ومتسقة من الناحية الأسلوبية، مع الالتزام بالإرشادات التالية:
أسلوب الكتابة:
1. الدقة النحوية: احرص دائمًا على أن تكون الترجمة صحيحة نحويًا.
2. الملاءمة السياقية: قم بتكييف الترجمة مع السياق والجمهور المستهدف:
استخدم جملًا موجزة وواضحة في المحتوى الطبي والقانوني.
اعتمد لغة جذابة وخيالية في المواد التسويقية.
حافظ على الرسمية والبلاغة في المحتوى القانوني.
3. البنية السليمة: احترم تراكيب الجمل العربية وتجنب النسخ المباشر لقواعد لغة المصدر. فضل استخدام "الجملة الفعلية" إلا إذا كانت "الجملة الاسمية" أكثر ملاءمة (مثلًا في العناوين أو التنويهات).
الخيارات الأسلوبية:
استخدم التشكيل فقط عند الضرورة لتوضيح المعنى.
تعامل مع الأسماء والأحرف المختصرة حسب السياق:
قم بتعريب الأسماء وأسماء الأدوية إلا إذا وُجدت لها مرادفات عربية.
ترجم أسماء البرامج والإدارات والهيئات عندما يكون ذلك مفيدًا.
استخدم الأرقام العربية وتأكد من التعامل الصحيح مع الوحدات والعناوين والمراجع.
علامات الترقيم:
طبق قواعد الترقيم العربية لضمان وضوح النص.
استخدم الفاصلة العربية (،) والفاصلة المنقوطة (؛) حسب الأعراف.
تجنب الإفراط في استخدام علامات الاقتباس واحرص على وضع النقطتين (:) بشكل منطقي.
الأخطاء الشائعة التي يجب تجنبها:
تجنب ترجمة "is" بـ "يُعتبر" إلا إذا كان ذلك مناسبًا للسياق.
استخدم حروف الجر والعطف بشكل صحيح لضمان تدفق الجمل بسلاسة.
قلل من التكرار واستخدم الضمائر حيثما أمكن.
تجنب الإفراط في استخدام تراكيب مثل "(قام + الفعل)" و"الخاص بـ."
المصطلحات المحددة:
في الترجمات القانونية، حافظ على النبرة الرسمية وتأكد من دقة المصطلحات.
في الترجمات الطبية، بسّط المصطلحات التقنية للجمهور العام مع الاحتفاظ بالتعقيد عند مخاطبة المتخصصين.
في الترجمات التسويقية، ركّز على الإبداع بدلًا من الترجمة الحرفية، مع الحفاظ على الرسالة الأساسية.
إرشادات التنسيق:
التزم بمعايير الطباعة العربية بشكل متسق.
حافظ على تنسيق البيانات المهمة (مثل التواريخ، والقياسات، والاستشهادات القانونية).
عند الشك:
قدم الأولوية للوضوح، والتناسق، والملاءمة مع احتياجات الجمهور المستهدف. قم دائمًا بموازنة التعليمات الخاصة بالمشروع مع هذه الإرشادات، مع إعطاء الأولوية لمتطلبات العميل عند وجود أي تعارض.
""" # Full prompt maintained as original
TITLE = "<h1><center>Mawared T Assistant</center></h1>"
PLACEHOLDER = "Ask me anything! I'll think through it step by step."
CSS = """
duplicate-button {
margin: auto !important;
color: white !important;
background: black !important;
border-radius: 100vh !important;
}
h3 {
text-align: center;
}
.message-wrap {
overflow-x: auto;
}
.message-wrap p {
margin-bottom: 1em;
}
.message-wrap pre {
background-color: #f6f8fa;
border-radius: 3px;
padding: 16px;
overflow-x: auto;
}
.message-wrap code {
background-color: rgba(175,184,193,0.2);
border-radius: 3px;
padding: 0.2em 0.4em;
font-family: monospace;
}
.custom-tag {
color: #0066cc;
font-weight: bold;
}
.chat-area {
height: 500px !important;
overflow-y: auto !important;
}
"""
# Precompile regex patterns for better performance
TAG_PATTERNS = [
(re.compile(r'<Thinking>'), '\n<Thinking>\n'),
(re.compile(r'</Thinking>'), '\n</Thinking>\n'),
(re.compile(r'<Critique>'), '\n<Critique>\n'),
(re.compile(r'</Critique>'), '\n</Critique>\n'),
(re.compile(r'<Revising>'), '\n<Revising>\n'),
(re.compile(r'</Revising>'), '\n</Revising>\n'),
(re.compile(r'<Final>'), '\n<Final>\n'),
(re.compile(r'</Final>'), '\n</Final>\n')
]
def format_text(text: str) -> str:
"""Format text with proper spacing and tag highlighting"""
formatted = text
for pattern, replacement in TAG_PATTERNS:
formatted = pattern.sub(replacement, formatted)
return '\n'.join(line for line in formatted.split('\n') if line.strip())
def format_chat_history(history: List[List[str]]) -> str:
"""Format chat history for display"""
return "\n\n".join(
f"User: {user_msg}\nAssistant: {assistant_msg}"
for user_msg, assistant_msg in history if user_msg
)
def convert_history_to_cohere_format(history: List[List[str]]) -> List[dict]:
"""Convert chat history to Cohere's format with proper roles"""
cohere_history = []
for user_msg, assistant_msg in history:
if user_msg:
cohere_history.append({"role": "USER", "message": user_msg})
if assistant_msg:
cohere_history.append({"role": "CHATBOT", "message": assistant_msg})
return cohere_history
def chat_response(
message: str,
history: List[List[str]],
chat_display: str,
system_prompt: str,
temperature: float = 0.2,
max_new_tokens: int = 8192,
top_p: float = 0.8,
top_k: int = 40,
penalty: float = 1.2,
api_key: str = os.getenv("COHERE_API_KEY")
) -> Iterator[Tuple[List[List[str]], str]]:
"""Generate chat responses using Cohere API with error handling"""
if not api_key:
error_message = "Error: COHERE_API_KEY environment variable not set."
history.append([message, error_message])
yield history, format_chat_history(history)
return
co = cohere.Client(api_key=api_key)
chat_history = convert_history_to_cohere_format(history)
buffer = ""
history.append([message, ""])
try:
stream = co.chat_stream(
model='c4ai-aya-expanse-32b',
message=message,
temperature=temperature,
max_tokens=max_new_tokens,
p=top_p,
k=top_k,
frequency_penalty=penalty,
chat_history=chat_history,
prompt_truncation='AUTO',
preamble=system_prompt
)
for event in stream:
if event.event_type == "text-generation":
buffer += event.text
history[-1][1] = format_text(buffer)
yield history, format_chat_history(history)
except Exception as e:
error_message = f"Error: {str(e)}"
history[-1][1] = error_message
yield history, format_chat_history(history)
def main():
"""Main function to set up and launch the Gradio interface"""
with gr.Blocks(css=CSS, theme="soft") as demo:
gr.HTML(TITLE)
gr.DuplicateButton(
value="Duplicate Space for private use",
elem_classes="duplicate-button"
)
with gr.Row():
with gr.Column():
chat_history = gr.State([])
chat_display = gr.TextArea(
value="",
label="Chat History",
interactive=False,
elem_classes=["chat-area"],
)
message = gr.TextArea(
placeholder=PLACEHOLDER,
label="Your message",
lines=3,
elem_id="message_input"
)
with gr.Row():
submit = gr.Button("Send", elem_id="submit_btn")
clear = gr.Button("Clear")
with gr.Accordion("⚙️ Advanced Settings", open=False):
system_prompt = gr.TextArea(
value=DEFAULT_SYSTEM_PROMPT,
label="System Prompt",
lines=5,
)
temperature = gr.Slider(
minimum=0,
maximum=1,
step=0.1,
value=0.2,
label="Temperature",
)
max_tokens = gr.Slider(
minimum=128,
maximum=32000,
step=128,
value=8192,
label="Max Tokens",
)
top_p = gr.Slider(
minimum=0.1,
maximum=1.0,
step=0.1,
value=0.8,
label="Top-p",
)
top_k = gr.Slider(
minimum=1,
maximum=100,
step=1,
value=40,
label="Top-k",
)
penalty = gr.Slider(
minimum=1.0,
maximum=2.0,
step=0.1,
value=1.2,
label="Repetition Penalty",
)
# Event handlers
submit.click(
chat_response,
inputs=[message, chat_history, chat_display, system_prompt,
temperature, max_tokens, top_p, top_k, penalty],
outputs=[chat_history, chat_display],
show_progress=True,
).then(lambda: "", outputs=message)
message.submit(
chat_response,
inputs=[message, chat_history, chat_display, system_prompt,
temperature, max_tokens, top_p, top_k, penalty],
outputs=[chat_history, chat_display],
show_progress=True,
).then(lambda: "", outputs=message)
clear.click(
lambda: ([], ""),
outputs=[chat_history, chat_display],
show_progress=True,
)
# Add JavaScript for Enter key handling
if __name__ == "__main__":
demo = main()
demo.launch() |