From 6439b7a21390b45ab427ad1db94e16f82a1e1f95 Mon Sep 17 00:00:00 2001 From: Daniel McKnight <34697904+NeonDaniel@users.noreply.github.com> Date: Thu, 28 Dec 2023 11:26:43 -0800 Subject: [PATCH] Add default persona config (#14) * Minor logging and formatting changes Add default `llm_bots` configuration to Docker Implement persona support from https://github.com/NeonGeckoCom/neon-llm-core/pull/3 * Update neon-llm-core dependency for chatbot support Update default configuration and document llm bots * Resolve license test failures --------- Co-authored-by: Daniel McKnight --- .github/workflows/license_tests.yml | 2 +- Dockerfile | 4 ++- README.md | 16 +++++++++++ docker_overlay/etc/neon/diana.yaml | 42 ++++++++++++++++++++++++++--- neon_llm_chatgpt/__main__.py | 2 ++ neon_llm_chatgpt/chatgpt.py | 7 ++--- neon_llm_chatgpt/rmq.py | 11 +++++--- requirements/requirements.txt | 3 ++- 8 files changed, 75 insertions(+), 12 deletions(-) diff --git a/.github/workflows/license_tests.yml b/.github/workflows/license_tests.yml index 1404a33..b8217ea 100644 --- a/.github/workflows/license_tests.yml +++ b/.github/workflows/license_tests.yml @@ -9,4 +9,4 @@ jobs: license_tests: uses: neongeckocom/.github/.github/workflows/license_tests.yml@master with: - packages-exclude: '^(neon-llm-chatgpt|tqdm).*' \ No newline at end of file + packages-exclude: '^(neon-llm-chatgpt|tqdm|klat-connector|neon-chatbot|dnspython).*' \ No newline at end of file diff --git a/Dockerfile b/Dockerfile index 822d628..af2ef09 100644 --- a/Dockerfile +++ b/Dockerfile @@ -6,8 +6,10 @@ LABEL vendor=neon.ai \ ENV OVOS_CONFIG_BASE_FOLDER neon ENV OVOS_CONFIG_FILENAME diana.yaml ENV XDG_CONFIG_HOME /config -COPY docker_overlay/ / +ENV CHATBOT_VERSION v2 +COPY docker_overlay/ / +RUN apt update && apt install -y git WORKDIR /app COPY . /app RUN pip install /app diff --git a/README.md b/README.md index ce20d97..b7e677e 100644 --- a/README.md +++ b/README.md @@ -37,6 +37,22 @@ LLM_CHAT_GPT: num_parallel_processes: 2 ``` +To add support for Chatbotsforum personas, a list of names and prompts can be added +to configuration: +```yaml +llm_bots: + chat_gpt: + - name: tutor + description: | + You are an AI bot that specializes in tutoring and guiding learners. + Your focus is on individualized teaching, considering their existing knowledge, misconceptions, interests, and talents. + Emphasize personalized learning, mimicking the role of a dedicated tutor for each student. + You're attempting to provide a concise response within a 40-word limit. +``` +> `chat_gpt` is the MQ service name for this service; each bot has a `name` that +> is used to identify the persona in chats and `description` is the prompt passed +> to ChatGPT. + For example, if your configuration resides in `~/.config`: ```shell export CONFIG_PATH="/home/${USER}/.config" diff --git a/docker_overlay/etc/neon/diana.yaml b/docker_overlay/etc/neon/diana.yaml index 3c0fa01..0a422e7 100644 --- a/docker_overlay/etc/neon/diana.yaml +++ b/docker_overlay/etc/neon/diana.yaml @@ -5,10 +5,11 @@ logs: - pika warning: - filelock - info: [] + info: + - openai debug: [] MQ: - server: api.neon.ai + server: neon-rabbitmq port: 5672 users: mq_handler: @@ -19,4 +20,39 @@ LLM_CHAT_GPT: role: "You are trying to give a short answer in less than 40 words." context_depth: 3 max_tokens: 100 - num_parallel_processes: 2 \ No newline at end of file + num_parallel_processes: 2 +#llm_bots: +# chat_gpt: +# - name: urban_logic +# description: | +# You are an AI bot that specializes in smart city planning. +# Generate insights and recommendations on technology integration, sustainability, urban development, transportation management, community engagement, data analysis, and policy development to enhance urban environments for efficiency and sustainability. +# You're attempting to provide a concise response within a 40-word limit. +# - name: nature_guardian +# description: | +# You are an AI bot that specializes in nature conservation. +# Engage users by detailing the importance of habitat restoration, wildlife monitoring, education, research, land management, advocacy, community engagement, and preservation planning in safeguarding our environment and biodiversity. +# You're attempting to provide a concise response within a 40-word limit. +# - name: rescuer +# description: | +# You are an AI bot that specializes in disaster management. +# Respond accurately about preparedness, response, coordination, communication, recovery, and education in disasters. +# Aim to inform, guide, and assist in minimizing disaster impact. +# You're attempting to provide a concise response within a 40-word limit. +# - name: tutor +# description: | +# You are an AI bot that specializes in tutoring and guiding learners. +# Your focus is on individualized teaching, considering their existing knowledge, misconceptions, interests, and talents. +# Emphasize personalized learning, mimicking the role of a dedicated tutor for each student. +# You're attempting to provide a concise response within a 40-word limit. +# - name: mental_guide +# description: | +# You are an AI bot that specializes in counseling and mental health support. +# Provide guidance on assessments, therapy sessions, crisis intervention, goal setting, referrals, advocacy, education, documentation, and adherence to ethical standards, fostering positive changes in clients' lives. +# You're attempting to provide a concise response within a 40-word limit. +# - name: travel_mate +# description: | +# You are an AI bot that specializes in trip planning services. +# Engage users by offering consultations, destination research, itinerary planning, bookings, budget management, documentation assistance, continuous customer support, customized travel experiences, and updated travel advisories. +# Enhance their travel journey and save their time. +# You're attempting to provide a concise response within a 40-word limit. diff --git a/neon_llm_chatgpt/__main__.py b/neon_llm_chatgpt/__main__.py index e98ff45..55ac1ae 100644 --- a/neon_llm_chatgpt/__main__.py +++ b/neon_llm_chatgpt/__main__.py @@ -25,9 +25,11 @@ # SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. from neon_llm_chatgpt.rmq import ChatgptMQ +from neon_utils.log_utils import init_log def main(): + init_log(log_name="chatgpt") # Run RabbitMQ chatgptMQ = ChatgptMQ() chatgptMQ.run(run_sync=False, run_consumers=True, diff --git a/neon_llm_chatgpt/chatgpt.py b/neon_llm_chatgpt/chatgpt.py index fe378bf..21de273 100644 --- a/neon_llm_chatgpt/chatgpt.py +++ b/neon_llm_chatgpt/chatgpt.py @@ -29,6 +29,7 @@ from typing import List, Dict from neon_llm_core.llm import NeonLLM +from ovos_utils.log import LOG class ChatGPT(NeonLLM): @@ -71,7 +72,7 @@ def _system_prompt(self) -> str: return self.role def warmup(self): - self.model + _ = self.model def get_sorted_answer_indexes(self, question: str, answers: List[str], persona: dict) -> List[int]: """ @@ -102,7 +103,7 @@ def _call_model(self, prompt: List[Dict[str, str]]) -> str: max_tokens=self.max_tokens, ) text = response.choices[0].message['content'] - + LOG.debug(text) return text def _assemble_prompt(self, message: str, chat_history: List[List[str]], persona: dict) -> List[Dict[str, str]]: @@ -153,4 +154,4 @@ def _embeddings(self, question: str, answers: List[str], persona: dict) -> (List embeddings = get_embeddings(texts, engine="text-embedding-ada-002") question_embeddings = embeddings[0] answers_embeddings = embeddings[1:] - return question_embeddings, answers_embeddings \ No newline at end of file + return question_embeddings, answers_embeddings diff --git a/neon_llm_chatgpt/rmq.py b/neon_llm_chatgpt/rmq.py index 3409a95..117b202 100644 --- a/neon_llm_chatgpt/rmq.py +++ b/neon_llm_chatgpt/rmq.py @@ -48,8 +48,13 @@ def model(self): return self._model def warmup(self): - self.model + """ + Initialize this LLM to be ready to provide responses + """ + _ = self.model @staticmethod - def compose_opinion_prompt(respondent_nick: str, question: str, answer: str) -> str: - return f'Why Answer "{answer}" to the Question "{question}" generated by Bot named "{respondent_nick}" is good?' + def compose_opinion_prompt(respondent_nick: str, question: str, + answer: str) -> str: + return (f'Why Answer "{answer}" to the Question "{question}" ' + f'generated by Bot named "{respondent_nick}" is good?') diff --git a/requirements/requirements.txt b/requirements/requirements.txt index e08541f..00f0334 100644 --- a/requirements/requirements.txt +++ b/requirements/requirements.txt @@ -1,4 +1,5 @@ # model openai[embeddings]~=0.27 # networking -neon_llm_core~=0.1.0 \ No newline at end of file +neon_llm_core[chatbots]~=0.1.0,>=0.1.1a1 +ovos-utils~=0.0.32 \ No newline at end of file