upgraded template

This commit is contained in:
Saifeddine ALOUI 2024-06-28 00:39:36 +02:00
parent 8b4aac2a1b
commit 9cbcfbb282
3 changed files with 60 additions and 63 deletions

View File

@ -1,5 +1,5 @@
# =================== Lord Of Large Language Multimodal Systems Configuration file =========================== # =================== Lord Of Large Language Multimodal Systems Configuration file ===========================
version: 121 version: 122
binding_name: null binding_name: null
model_name: null model_name: null
model_variant: null model_variant: null
@ -76,6 +76,9 @@ discussion_db_name: default
# Automatic updates # Automatic updates
debug: false debug: false
debug_show_final_full_prompt: false
debug_show_chunks: false
debug_log_file_path: "" debug_log_file_path: ""
auto_update: true auto_update: true
auto_sync_personalities: true auto_sync_personalities: true
@ -253,6 +256,7 @@ rag_activate_multi_hops: false #if true, we use multi hops algorithm to do multi
rag_min_nb_tokens_in_chunk: 10 #this removed any useless junk ith less than x tokens rag_min_nb_tokens_in_chunk: 10 #this removed any useless junk ith less than x tokens
rag_max_n_hops: 3 #We set the maximum number of hop in multi hops rag rag_max_n_hops: 3 #We set the maximum number of hop in multi hops rag
activate_skills_lib: false # Activate vectorizing previous conversations activate_skills_lib: false # Activate vectorizing previous conversations
skills_lib_database_name: "default" # Default skills database skills_lib_database_name: "default" # Default skills database

View File

@ -204,7 +204,6 @@ class LollmsApplication(LoLLMsCom):
return False return False
def add_discussion_to_skills_library(self, client: Client): def add_discussion_to_skills_library(self, client: Client):
start_header_id_template = self.config.start_header_id_template
end_header_id_template = self.config.end_header_id_template end_header_id_template = self.config.end_header_id_template
separator_template = self.config.separator_template separator_template = self.config.separator_template
system_message_template = self.config.system_message_template system_message_template = self.config.system_message_template
@ -223,19 +222,19 @@ class LollmsApplication(LoLLMsCom):
# Generate title # Generate title
title_prompt = f"{separator_template}".join([ title_prompt = f"{separator_template}".join([
f"{start_header_id_template}{system_message_template}{end_header_id_template}Generate a concise and descriptive title for the following content.", f"{self.start_header_id_template}{system_message_template}{end_header_id_template}Generate a concise and descriptive title for the following content.",
"The title should summarize the main topic or subject of the content.", "The title should summarize the main topic or subject of the content.",
"Do not mention the format of the content (e.g., bullet points, discussion, etc.) in the title.", "Do not mention the format of the content (e.g., bullet points, discussion, etc.) in the title.",
"Provide only the title without any additional explanations or context.", "Provide only the title without any additional explanations or context.",
f"{start_header_id_template}content{end_header_id_template}", f"{self.start_header_id_template}content{end_header_id_template}",
f"{content}", f"{content}",
f"{start_header_id_template}title{end_header_id_template}" f"{self.start_header_id_template}title{end_header_id_template}"
]) ])
title = self._generate_text(title_prompt) title = self._generate_text(title_prompt)
# Determine category # Determine category
category_prompt = f"{start_header_id_template}{system_message_template}{end_header_id_template}Analyze the following title, and determine the most appropriate generic category that encompasses the main subject or theme. The category should be broad enough to include multiple related skill entries. Provide only the category name without any additional explanations or context:\n\nTitle:\n{title}\n{separator_template}{start_header_id_template}Category:\n" category_prompt = f"{self.start_header_id_template}{system_message_template}{end_header_id_template}Analyze the following title, and determine the most appropriate generic category that encompasses the main subject or theme. The category should be broad enough to include multiple related skill entries. Provide only the category name without any additional explanations or context:\n\nTitle:\n{title}\n{separator_template}{self.start_header_id_template}Category:\n"
category = self._generate_text(category_prompt) category = self._generate_text(category_prompt)
# Add entry to skills library # Add entry to skills library
@ -861,18 +860,8 @@ class LollmsApplication(LoLLMsCom):
Tuple[str, str, List[str]]: The prepared query, original message content, and tokenized query. Tuple[str, str, List[str]]: The prepared query, original message content, and tokenized query.
""" """
documentation_entries = [] documentation_entries = []
start_header_id_template = self.config.start_header_id_template
end_header_id_template = self.config.end_header_id_template
separator_template = self.config.separator_template
start_user_header_id_template = self.config.start_user_header_id_template
end_user_header_id_template = self.config.end_user_header_id_template
end_user_message_id_template = self.config.end_user_message_id_template
start_ai_header_id_template = self.config.start_ai_header_id_template start_ai_header_id_template = self.config.start_ai_header_id_template
end_ai_header_id_template = self.config.end_ai_header_id_template end_ai_header_id_template = self.config.end_ai_header_id_template
end_ai_message_id_template = self.config.end_ai_message_id_template
system_message_template = self.config.system_message_template system_message_template = self.config.system_message_template
@ -915,7 +904,7 @@ class LollmsApplication(LoLLMsCom):
conditionning = self.personality._personality_conditioning conditionning = self.personality._personality_conditioning
if len(conditionning)>0: if len(conditionning)>0:
conditionning = start_header_id_template + system_message_template + end_header_id_template + self.personality.replace_keys(conditionning, self.personality.conditionning_commands) + ("" if conditionning[-1]==separator_template else separator_template) conditionning = self.start_header_id_template + system_message_template + self.end_header_id_template + self.personality.replace_keys(conditionning, self.personality.conditionning_commands) + ("" if conditionning[-1]==self.separator_template else self.separator_template)
# Check if there are document files to add to the prompt # Check if there are document files to add to the prompt
internet_search_results = "" internet_search_results = ""
@ -927,21 +916,21 @@ class LollmsApplication(LoLLMsCom):
# boosting information # boosting information
if self.config.positive_boost: if self.config.positive_boost:
positive_boost=f"{separator_template}{start_header_id_template}important information: "+self.config.positive_boost+"\n" positive_boost=f"{self.separator_template}{self.start_header_id_template}important information: "+self.config.positive_boost+"\n"
n_positive_boost = len(self.model.tokenize(positive_boost)) n_positive_boost = len(self.model.tokenize(positive_boost))
else: else:
positive_boost="" positive_boost=""
n_positive_boost = 0 n_positive_boost = 0
if self.config.negative_boost: if self.config.negative_boost:
negative_boost=f"{separator_template}{start_header_id_template}important information: "+self.config.negative_boost+"\n" negative_boost=f"{self.separator_template}{self.start_header_id_template}important information: "+self.config.negative_boost+"\n"
n_negative_boost = len(self.model.tokenize(negative_boost)) n_negative_boost = len(self.model.tokenize(negative_boost))
else: else:
negative_boost="" negative_boost=""
n_negative_boost = 0 n_negative_boost = 0
if self.config.fun_mode: if self.config.fun_mode:
fun_mode=f"{separator_template}{start_header_id_template}important information: Fun mode activated. In this mode you must answer in a funny playful way. Do not be serious in your answers. Each answer needs to make the user laugh.\n" fun_mode=f"{self.separator_template}{self.start_header_id_template}important information: Fun mode activated. In this mode you must answer in a funny playful way. Do not be serious in your answers. Each answer needs to make the user laugh.\n"
n_fun_mode = len(self.model.tokenize(positive_boost)) n_fun_mode = len(self.model.tokenize(positive_boost))
else: else:
fun_mode="" fun_mode=""
@ -955,10 +944,10 @@ class LollmsApplication(LoLLMsCom):
discussion = self.recover_discussion(client_id) discussion = self.recover_discussion(client_id)
if self.config.internet_activate_search_decision: if self.config.internet_activate_search_decision:
self.personality.step_start(f"Requesting if {self.personality.name} needs to search internet to answer the user") self.personality.step_start(f"Requesting if {self.personality.name} needs to search internet to answer the user")
q = f"{separator_template}".join([ q = f"{self.separator_template}".join([
f"{start_header_id_template}{system_message_template}{end_header_id_template}", f"{self.start_header_id_template}{system_message_template}{self.end_header_id_template}",
f"Answer the question with yes or no. Don't add any extra explanation.", f"Answer the question with yes or no. Don't add any extra explanation.",
f"{start_user_header_id_template}user{end_user_header_id_template}", f"{self.start_user_header_id_template}user{self.end_user_header_id_template}",
f"Do you have enough information to give a satisfactory answer to {self.config.user_name}'s request without internet search?", f"Do you have enough information to give a satisfactory answer to {self.config.user_name}'s request without internet search?",
"(If you do not know or you can't answer the question, return 0 (no)" "(If you do not know or you can't answer the question, return 0 (no)"
]) ])
@ -969,13 +958,13 @@ class LollmsApplication(LoLLMsCom):
need=True need=True
if need: if need:
self.personality.step_start("Crafting internet search query") self.personality.step_start("Crafting internet search query")
q = f"{separator_template}".join([ q = f"{self.separator_template}".join([
f"{start_header_id_template}discussion{end_header_id_template}", f"{self.start_header_id_template}discussion{self.end_header_id_template}",
f"{discussion[-2048:]}{start_header_id_template}system{end_header_id_template}", f"{discussion[-2048:]}{self.start_header_id_template}system{self.end_header_id_template}",
f"Read the discussion and craft a web search query suited to recover needed information to reply to last {self.config.user_name} message.", f"Read the discussion and craft a web search query suited to recover needed information to reply to last {self.config.user_name} message.",
f"Do not answer the prompt. Do not add explanations.", f"Do not answer the prompt. Do not add explanations.",
f"{start_header_id_template}current date{end_header_id_template}{datetime.now()}", f"{self.start_header_id_template}current date{self.end_header_id_template}{datetime.now()}",
f"{start_header_id_template}websearch query{end_header_id_template}" f"{self.start_header_id_template}websearch query{self.end_header_id_template}"
]) ])
query = self.personality.fast_gen(q, max_generation_size=256, show_progress=True, callback=self.personality.sink) query = self.personality.fast_gen(q, max_generation_size=256, show_progress=True, callback=self.personality.sink)
self.personality.step_end("Crafting internet search query") self.personality.step_end("Crafting internet search query")
@ -986,14 +975,14 @@ class LollmsApplication(LoLLMsCom):
else: else:
self.personality.step_start("Performing Internet search (advanced mode: slower but more advanced)") self.personality.step_start("Performing Internet search (advanced mode: slower but more advanced)")
internet_search_results=f"{start_header_id_template}{system_message_template}{end_header_id_template}Use the web search results data to answer {self.config.user_name}. Try to extract information from the web search and use it to perform the requested task or answer the question. Do not come up with information that is not in the websearch results. Try to stick to the websearch results and clarify if your answer was based on the resuts or on your own culture. If you don't know how to perform the task, then tell the user politely that you need more data inputs.{separator_template}{start_header_id_template}Web search results{end_header_id_template}\n" internet_search_results=f"{self.start_header_id_template}{system_message_template}{self.end_header_id_template}Use the web search results data to answer {self.config.user_name}. Try to extract information from the web search and use it to perform the requested task or answer the question. Do not come up with information that is not in the websearch results. Try to stick to the websearch results and clarify if your answer was based on the resuts or on your own culture. If you don't know how to perform the task, then tell the user politely that you need more data inputs.{self.separator_template}{self.start_header_id_template}Web search results{self.end_header_id_template}\n"
docs, sorted_similarities, document_ids = self.personality.internet_search_with_vectorization(query, self.config.internet_quick_search, asses_using_llm=self.config.activate_internet_pages_judgement) docs, sorted_similarities, document_ids = self.personality.internet_search_with_vectorization(query, self.config.internet_quick_search, asses_using_llm=self.config.activate_internet_pages_judgement)
if len(docs)>0: if len(docs)>0:
for doc, infos,document_id in zip(docs, sorted_similarities, document_ids): for doc, infos,document_id in zip(docs, sorted_similarities, document_ids):
internet_search_infos.append(document_id) internet_search_infos.append(document_id)
internet_search_results += f"{start_header_id_template}search result chunk{end_header_id_template}\nchunk_infos:{document_id['url']}\nchunk_title:{document_id['title']}\ncontent:{doc}\n" internet_search_results += f"{self.start_header_id_template}search result chunk{self.end_header_id_template}\nchunk_infos:{document_id['url']}\nchunk_title:{document_id['title']}\ncontent:{doc}\n"
else: else:
internet_search_results += "The search response was empty!\nFailed to recover useful information from the search engine.\n" internet_search_results += "The search response was empty!\nFailed to recover useful information from the search engine.\n"
if self.config.internet_quick_search: if self.config.internet_quick_search:
@ -1003,12 +992,12 @@ class LollmsApplication(LoLLMsCom):
if self.personality.persona_data_vectorizer: if self.personality.persona_data_vectorizer:
if documentation=="": if documentation=="":
documentation=f"{separator_template}{start_header_id_template}Documentation:\n" documentation=f"{self.separator_template}{self.start_header_id_template}Documentation:\n"
if self.config.data_vectorization_build_keys_words: if self.config.data_vectorization_build_keys_words:
if discussion is None: if discussion is None:
discussion = self.recover_discussion(client_id) discussion = self.recover_discussion(client_id)
query = self.personality.fast_gen(f"{separator_template}{start_header_id_template}instruction: Read the discussion and rewrite the last prompt for someone who didn't read the entire discussion.\nDo not answer the prompt. Do not add explanations.{separator_template}{start_header_id_template}discussion:\n{discussion[-2048:]}{separator_template}{start_header_id_template}enhanced query: ", max_generation_size=256, show_progress=True) query = self.personality.fast_gen(f"{self.separator_template}{self.start_header_id_template}instruction: Read the discussion and rewrite the last prompt for someone who didn't read the entire discussion.\nDo not answer the prompt. Do not add explanations.{self.separator_template}{self.start_header_id_template}discussion:\n{discussion[-2048:]}{self.separator_template}{self.start_header_id_template}enhanced query: ", max_generation_size=256, show_progress=True)
ASCIIColors.cyan(f"Query:{query}") ASCIIColors.cyan(f"Query:{query}")
else: else:
query = current_message.content query = current_message.content
@ -1016,9 +1005,9 @@ class LollmsApplication(LoLLMsCom):
docs, sorted_similarities, document_ids = self.personality.persona_data_vectorizer.recover_text(query, top_k=int(self.config.data_vectorization_nb_chunks)) docs, sorted_similarities, document_ids = self.personality.persona_data_vectorizer.recover_text(query, top_k=int(self.config.data_vectorization_nb_chunks))
for doc, infos, doc_id in zip(docs, sorted_similarities, document_ids): for doc, infos, doc_id in zip(docs, sorted_similarities, document_ids):
if self.config.data_vectorization_put_chunk_informations_into_context: if self.config.data_vectorization_put_chunk_informations_into_context:
documentation += f"{start_header_id_template}document chunk{end_header_id_template}\nchunk_infos:{infos}\ncontent:{doc}\n" documentation += f"{self.start_header_id_template}document chunk{self.end_header_id_template}\nchunk_infos:{infos}\ncontent:{doc}\n"
else: else:
documentation += f"{start_header_id_template}chunk{end_header_id_template}\n{doc}\n" documentation += f"{self.start_header_id_template}chunk{self.end_header_id_template}\n{doc}\n"
except Exception as ex: except Exception as ex:
trace_exception(ex) trace_exception(ex)
@ -1031,12 +1020,12 @@ class LollmsApplication(LoLLMsCom):
if self.config.data_vectorization_build_keys_words: if self.config.data_vectorization_build_keys_words:
self.personality.step_start("Building vector store query") self.personality.step_start("Building vector store query")
q = f"{separator_template}".join([ q = f"{self.separator_template}".join([
f"{start_header_id_template}instruction{end_header_id_template}Read the entire discussion and rewrite the last prompt for someone who hasn't read the discussion.", f"{self.start_header_id_template}instruction{self.end_header_id_template}Read the entire discussion and rewrite the last prompt for someone who hasn't read the discussion.",
"Do not answer the prompt. Do not provide any explanations.", "Do not answer the prompt. Do not provide any explanations.",
f"{start_header_id_template}discussion{end_header_id_template}", f"{self.start_header_id_template}discussion{self.end_header_id_template}",
f"{discussion[-2048:]}", f"{discussion[-2048:]}",
f"{start_header_id_template}enhanced_query{end_header_id_template}" f"{self.start_header_id_template}enhanced_query{self.end_header_id_template}"
]) ])
query = self.personality.fast_gen(q, max_generation_size=256, show_progress=True, callback=self.personality.sink) query = self.personality.fast_gen(q, max_generation_size=256, show_progress=True, callback=self.personality.sink)
self.personality.step_end("Building vector store query") self.personality.step_end("Building vector store query")
@ -1045,13 +1034,13 @@ class LollmsApplication(LoLLMsCom):
else: else:
query = current_message.content query = current_message.content
if documentation=="": if documentation=="":
documentation=f"{separator_template}".join([ documentation=f"{self.separator_template}".join([
f"{separator_template}{start_header_id_template}important information{end_header_id_template}Utilize Documentation Data: Always refer to the provided documentation to answer user questions accurately.", f"{self.separator_template}{self.start_header_id_template}important information{self.end_header_id_template}Utilize Documentation Data: Always refer to the provided documentation to answer user questions accurately.",
"Absence of Information: If the required information is not available in the documentation, inform the user that the requested information is not present in the documentation section.", "Absence of Information: If the required information is not available in the documentation, inform the user that the requested information is not present in the documentation section.",
"Strict Adherence to Documentation: It is strictly prohibited to provide answers without concrete evidence from the documentation.", "Strict Adherence to Documentation: It is strictly prohibited to provide answers without concrete evidence from the documentation.",
"Cite Your Sources: After providing an answer, include the full path to the document where the information was found.", "Cite Your Sources: After providing an answer, include the full path to the document where the information was found.",
f"{start_header_id_template}Documentation{end_header_id_template}"]) f"{self.start_header_id_template}Documentation{self.end_header_id_template}"])
documentation += f"{separator_template}" documentation += f"{self.separator_template}"
results = [] results = []
recovered_ids=[[]*len(self.active_rag_dbs)] recovered_ids=[[]*len(self.active_rag_dbs)]
i=0 i=0
@ -1072,8 +1061,8 @@ class LollmsApplication(LoLLMsCom):
sorted_results = sorted(results, key=lambda x: x.distance)[:n_neighbors] sorted_results = sorted(results, key=lambda x: x.distance)[:n_neighbors]
for chunk in sorted_results: for chunk in sorted_results:
document_infos = f"{separator_template}".join([ document_infos = f"{self.separator_template}".join([
f"{start_header_id_template}document chunk{end_header_id_template}", f"{self.start_header_id_template}document chunk{self.end_header_id_template}",
f"source_document_title:{chunk.doc.title}", f"source_document_title:{chunk.doc.title}",
f"source_document_path:{chunk.doc.path}", f"source_document_path:{chunk.doc.path}",
f"content:\n{chunk.text}\n" f"content:\n{chunk.text}\n"
@ -1092,12 +1081,12 @@ class LollmsApplication(LoLLMsCom):
discussion = self.recover_discussion(client_id) discussion = self.recover_discussion(client_id)
if documentation=="": if documentation=="":
documentation=f"{separator_template}{start_header_id_template}important information: Use the documentation data to answer the user questions. If the data is not present in the documentation, please tell the user that the information he is asking for does not exist in the documentation section. It is strictly forbidden to give the user an answer without having actual proof from the documentation.{separator_template}{start_header_id_template}Documentation:\n" documentation=f"{self.separator_template}{self.start_header_id_template}important information: Use the documentation data to answer the user questions. If the data is not present in the documentation, please tell the user that the information he is asking for does not exist in the documentation section. It is strictly forbidden to give the user an answer without having actual proof from the documentation.{self.separator_template}{self.start_header_id_template}Documentation:\n"
if query is None: if query is None:
if self.config.data_vectorization_build_keys_words: if self.config.data_vectorization_build_keys_words:
self.personality.step_start("Building vector store query") self.personality.step_start("Building vector store query")
query = self.personality.fast_gen(f"{separator_template}{start_header_id_template}instruction: Read the discussion and rewrite the last prompt for someone who didn't read the entire discussion.\nDo not answer the prompt. Do not add explanations.{separator_template}{start_header_id_template}discussion:\n{discussion[-2048:]}{separator_template}{start_header_id_template}enhanced query: ", max_generation_size=256, show_progress=True, callback=self.personality.sink) query = self.personality.fast_gen(f"{self.separator_template}{self.start_header_id_template}instruction: Read the discussion and rewrite the last prompt for someone who didn't read the entire discussion.\nDo not answer the prompt. Do not add explanations.{self.separator_template}{self.start_header_id_template}discussion:\n{discussion[-2048:]}{self.separator_template}{self.start_header_id_template}enhanced query: ", max_generation_size=256, show_progress=True, callback=self.personality.sink)
self.personality.step_end("Building vector store query") self.personality.step_end("Building vector store query")
ASCIIColors.cyan(f"Query: {query}") ASCIIColors.cyan(f"Query: {query}")
else: else:
@ -1111,20 +1100,20 @@ class LollmsApplication(LoLLMsCom):
content = client.discussion.vectorizer.chunks[doc_index]['chunk_text'] content = client.discussion.vectorizer.chunks[doc_index]['chunk_text']
if self.config.data_vectorization_put_chunk_informations_into_context: if self.config.data_vectorization_put_chunk_informations_into_context:
documentation += f"{start_header_id_template}document chunk{end_header_id_template}\nchunk_infos:{doc_id}\ncontent:{content}\n" documentation += f"{self.start_header_id_template}document chunk{self.end_header_id_template}\nchunk_infos:{doc_id}\ncontent:{content}\n"
else: else:
documentation += f"{start_header_id_template}chunk{end_header_id_template}\n{content}\n" documentation += f"{self.start_header_id_template}chunk{self.end_header_id_template}\n{content}\n"
docs, sorted_similarities, document_ids = client.discussion.vectorizer.recover_text(query, top_k=int(self.config.data_vectorization_nb_chunks)) docs, sorted_similarities, document_ids = client.discussion.vectorizer.recover_text(query, top_k=int(self.config.data_vectorization_nb_chunks))
for doc, infos in zip(docs, sorted_similarities): for doc, infos in zip(docs, sorted_similarities):
if self.config.data_vectorization_force_first_chunk and len(client.discussion.vectorizer.chunks)>0 and infos[0]==doc_id: if self.config.data_vectorization_force_first_chunk and len(client.discussion.vectorizer.chunks)>0 and infos[0]==doc_id:
continue continue
if self.config.data_vectorization_put_chunk_informations_into_context: if self.config.data_vectorization_put_chunk_informations_into_context:
documentation += f"{start_header_id_template}document chunk{end_header_id_template}\nchunk path: {infos[0]}\nchunk content:\n{doc}\n" documentation += f"{self.start_header_id_template}document chunk{self.end_header_id_template}\nchunk path: {infos[0]}\nchunk content:\n{doc}\n"
else: else:
documentation += f"{start_header_id_template}chunk{end_header_id_template}\n{doc}\n" documentation += f"{self.start_header_id_template}chunk{self.end_header_id_template}\n{doc}\n"
documentation += f"{separator_template}{start_header_id_template}important information: Use the documentation data to answer the user questions. If the data is not present in the documentation, please tell the user that the information he is asking for does not exist in the documentation section. It is strictly forbidden to give the user an answer without having actual proof from the documentation.\n" documentation += f"{self.separator_template}{self.start_header_id_template}important information: Use the documentation data to answer the user questions. If the data is not present in the documentation, please tell the user that the information he is asking for does not exist in the documentation section. It is strictly forbidden to give the user an answer without having actual proof from the documentation.\n"
except Exception as ex: except Exception as ex:
trace_exception(ex) trace_exception(ex)
self.warning("Couldn't add documentation to the context. Please verify the vector database") self.warning("Couldn't add documentation to the context. Please verify the vector database")
@ -1135,7 +1124,7 @@ class LollmsApplication(LoLLMsCom):
if discussion is None: if discussion is None:
discussion = self.recover_discussion(client_id) discussion = self.recover_discussion(client_id)
self.personality.step_start("Building query") self.personality.step_start("Building query")
query = self.personality.fast_gen(f"{start_header_id_template}{system_message_template}{end_header_id_template}Your task is to carefully read the provided discussion and reformulate {self.config.user_name}'s request concisely. Return only the reformulated request without any additional explanations, commentary, or output.{separator_template}{start_header_id_template}discussion:\n{discussion[-2048:]}{separator_template}{start_header_id_template}search query: ", max_generation_size=256, show_progress=True, callback=self.personality.sink) query = self.personality.fast_gen(f"{self.start_header_id_template}{system_message_template}{self.end_header_id_template}Your task is to carefully read the provided discussion and reformulate {self.config.user_name}'s request concisely. Return only the reformulated request without any additional explanations, commentary, or output.{self.separator_template}{self.start_header_id_template}discussion:\n{discussion[-2048:]}{self.separator_template}{self.start_header_id_template}search query: ", max_generation_size=256, show_progress=True, callback=self.personality.sink)
self.personality.step_end("Building query") self.personality.step_end("Building query")
# skills = self.skills_library.query_entry(query) # skills = self.skills_library.query_entry(query)
self.personality.step_start("Adding skills") self.personality.step_start("Adding skills")
@ -1145,9 +1134,9 @@ class LollmsApplication(LoLLMsCom):
knowledge_infos={"titles":skill_titles,"contents":skills} knowledge_infos={"titles":skill_titles,"contents":skills}
if len(skills)>0: if len(skills)>0:
if knowledge=="": if knowledge=="":
knowledge=f"{start_header_id_template}knowledge{end_header_id_template}\n" knowledge=f"{self.start_header_id_template}knowledge{self.end_header_id_template}\n"
for i,(title, content) in enumerate(zip(skill_titles,skills)): for i,(title, content) in enumerate(zip(skill_titles,skills)):
knowledge += f"{start_header_id_template}knowledge {i}{end_header_id_template}\ntitle:\n{title}\ncontent:\n{content}\n" knowledge += f"{self.start_header_id_template}knowledge {i}{self.end_header_id_template}\ntitle:\n{title}\ncontent:\n{content}\n"
self.personality.step_end("Adding skills") self.personality.step_end("Adding skills")
self.personality.step_end("Querying skills library") self.personality.step_end("Querying skills library")
except Exception as ex: except Exception as ex:
@ -1157,7 +1146,7 @@ class LollmsApplication(LoLLMsCom):
self.personality.step_end("Querying skills library",False) self.personality.step_end("Querying skills library",False)
user_description="" user_description=""
if self.config.use_user_informations_in_discussion: if self.config.use_user_informations_in_discussion:
user_description=f"{start_header_id_template}User description{end_header_id_template}\n"+self.config.user_description+"\n" user_description=f"{self.start_header_id_template}User description{self.end_header_id_template}\n"+self.config.user_description+"\n"
# Tokenize the conditionning text and calculate its number of tokens # Tokenize the conditionning text and calculate its number of tokens
@ -1250,12 +1239,12 @@ class LollmsApplication(LoLLMsCom):
# Tokenize the message content # Tokenize the message content
if self.config.use_model_name_in_discussions: if self.config.use_model_name_in_discussions:
if message.model: if message.model:
msg = f"{separator_template}{start_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else start_user_header_id_template}{message.sender}({message.model}){end_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else end_user_header_id_template}" + message.content.strip() msg = f"{start_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else self.start_user_header_id_template}{message.sender}({message.model}){end_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else self.end_user_header_id_template}" + message.content.strip() + f"{self.separator_template}"
else: else:
msg = f"{separator_template}{start_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else start_user_header_id_template}{message.sender}{end_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else end_user_header_id_template}" + message.content.strip() msg = f"{start_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else self.start_user_header_id_template}{message.sender}{end_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else self.end_user_header_id_template}" + message.content.strip() + f"{self.separator_template}"
message_tokenized = self.model.tokenize(msg) message_tokenized = self.model.tokenize(msg)
else: else:
msg_value= f"{separator_template}{start_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else start_user_header_id_template}{message.sender}{end_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else end_user_header_id_template}" + message.content.strip() msg_value= f"{start_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else self.start_user_header_id_template}{message.sender}{end_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else self.end_user_header_id_template}" + message.content.strip() + f"{self.separator_template}"
message_tokenized = self.model.tokenize( message_tokenized = self.model.tokenize(
msg_value msg_value
) )
@ -1281,13 +1270,13 @@ class LollmsApplication(LoLLMsCom):
if self.config.use_model_name_in_discussions: if self.config.use_model_name_in_discussions:
if message.model: if message.model:
msg = f"{separator_template}{start_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else start_user_header_id_template}{message.sender}({message.model}){end_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else end_user_header_id_template}" + message.content.strip() msg = f"{self.separator_template}{start_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else self.start_user_header_id_template}{message.sender}({message.model}){end_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else self.end_user_header_id_template}" + message.content.strip()
else: else:
msg = f"{separator_template}{start_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else start_user_header_id_template}{message.sender}{end_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else end_user_header_id_template}" + message.content.strip() msg = f"{self.separator_template}{start_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else self.start_user_header_id_template}{message.sender}{end_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else self.end_user_header_id_template}" + message.content.strip()
message_tokenized = self.model.tokenize(msg) message_tokenized = self.model.tokenize(msg)
else: else:
message_tokenized = self.model.tokenize( message_tokenized = self.model.tokenize(
f"{separator_template}{start_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else start_user_header_id_template}{message.sender}{end_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else end_user_header_id_template}" + message.content.strip() f"{self.separator_template}{start_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else self.start_user_header_id_template}{message.sender}{end_ai_header_id_template if message.sender_type == SENDER_TYPES.SENDER_TYPES_AI else self.end_user_header_id_template}" + message.content.strip()
) )
# Add the tokenized message to the full_message_list # Add the tokenized message to the full_message_list

View File

@ -1,5 +1,5 @@
# =================== Lord Of Large Language Multimodal Systems Configuration file =========================== # =================== Lord Of Large Language Multimodal Systems Configuration file ===========================
version: 121 version: 122
binding_name: null binding_name: null
model_name: null model_name: null
model_variant: null model_variant: null
@ -76,6 +76,9 @@ discussion_db_name: default
# Automatic updates # Automatic updates
debug: false debug: false
debug_show_final_full_prompt: false
debug_show_chunks: false
debug_log_file_path: "" debug_log_file_path: ""
auto_update: true auto_update: true
auto_sync_personalities: true auto_sync_personalities: true
@ -253,6 +256,7 @@ rag_activate_multi_hops: false #if true, we use multi hops algorithm to do multi
rag_min_nb_tokens_in_chunk: 10 #this removed any useless junk ith less than x tokens rag_min_nb_tokens_in_chunk: 10 #this removed any useless junk ith less than x tokens
rag_max_n_hops: 3 #We set the maximum number of hop in multi hops rag rag_max_n_hops: 3 #We set the maximum number of hop in multi hops rag
activate_skills_lib: false # Activate vectorizing previous conversations activate_skills_lib: false # Activate vectorizing previous conversations
skills_lib_database_name: "default" # Default skills database skills_lib_database_name: "default" # Default skills database