discourse-ai/lib/modules/ai_bot
Sam 6282b6d21f
FIX: implement tools framework for Anthropic (#307)
Previous to this changeset we used a custom system for tools/command
support for Anthropic.

We defined commands by using !command as a signal to execute it

Following Anthropic Claude 2.1, there is an official supported syntax (beta)
for tools execution.

eg:

```
+      <function_calls>
+      <invoke>
+      <tool_name>image</tool_name>
+      <parameters>
+      <prompts>
+      [
+      "an oil painting",
+      "a cute fluffy orange",
+      "3 apple's",
+      "a cat"
+      ]
+      </prompts>
+      </parameters>
+      </invoke>
+      </function_calls>
```

This implements the spec per Anthropic, it should be stable enough
to also work on other LLMs.

Keep in mind that OpenAI is not impacted here at all, as it has its
own custom system for function calls.

Additionally:

- Fixes the title system prompt so it works with latest Anthropic
- Uses new spec for "system" messages by Anthropic
- Tweak forum helper persona to guide Anthropic a tiny be better

Overall results are pretty awesome and Anthropic Claude performs
really well now on Discourse
2023-11-24 06:39:56 +11:00
..
commands FIX: implement tools framework for Anthropic (#307) 2023-11-24 06:39:56 +11:00
jobs/regular FEATURE: UI to update ai personas on admin page (#290) 2023-11-21 16:56:43 +11:00
personas FIX: implement tools framework for Anthropic (#307) 2023-11-24 06:39:56 +11:00
anthropic_bot.rb FIX: implement tools framework for Anthropic (#307) 2023-11-24 06:39:56 +11:00
bot.rb FIX: implement tools framework for Anthropic (#307) 2023-11-24 06:39:56 +11:00
entry_point.rb FEATURE: UI to update ai personas on admin page (#290) 2023-11-21 16:56:43 +11:00
open_ai_bot.rb FIX: implement tools framework for Anthropic (#307) 2023-11-24 06:39:56 +11:00
site_settings_extension.rb FEATURE: defer creation of bot users (#258) 2023-10-23 17:00:58 +11:00