-
Notifications
You must be signed in to change notification settings - Fork 43
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #170 from NimbleBoxAI/fury
CF-1.6.2
- Loading branch information
Showing
46 changed files
with
837 additions
and
1,690 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -149,5 +149,5 @@ private.sh | |
api_docs/_build/ | ||
api_docs/_static/ | ||
cf | ||
locust_file.py | ||
demo/ | ||
demo/ | ||
logs.py |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
Fury Agents Manifesto | ||
===================== | ||
|
||
**Starting date: 21st October, 2023** | ||
|
||
|
||
ChainFury's `first commit`_ was on 7th April, 2023. It has been about 6 months since then and it has undergone lot of | ||
production usage. With multiple API changes and engines, we are now at a stable place. This is also a good time to check | ||
up on the things that have released in the wild till now. | ||
|
||
tl;dr | ||
----- | ||
|
||
Predictable automated chains as agents, that use tree searching algorithms to find solution to a problem with given set | ||
of actions. Has ability to create new actions and learn from feedback. | ||
|
||
Agents | ||
------ | ||
|
||
There have been several "agent like" systems that have been released. Some can create code, others can perform advanced | ||
searching. Ultimately all of them can be modelled as a Chain and use different algorithms. ``chainfury`` can support | ||
all algorithms and has a type-based robust chaining engine. This means building agents is the next logical step. There | ||
is a lot of theory and academic research done on the topic of agents. All of them have different tradeoffs. But first | ||
let's start with the requirements of an agent. | ||
|
||
* Agent should be able to execute task without human intervention | ||
* Agent should stop when it can't proceed | ||
* Agent should be interruptible to take in feedback | ||
* Agent should take inputs from it's environment | ||
* Agent should be able to remember things over time | ||
* Agent should be predictable in its behaviour, debuggable | ||
|
||
Von-Neumann machine | ||
~~~~~~~~~~~~~~~~~~~ | ||
|
||
We are followers of the agent as a `Von-Neumann machine`_, which means each chain has a complete I/O mechanism where | ||
each input and output can be accessed independently. ``chainfury`` can use different memory systems like VectorDB, etc. | ||
meaning that it can persist data over time. For the CPU analogy we have :py:mod:`chainfury.base.Chain` which models the | ||
execution as a DAG of :py:class:`chainfury.base.Node` objects. Each node contains the unit step of the chain. We can | ||
parallellise and speed up executions by using :py:mod:`chainfury.utils.threaded_map`. | ||
|
||
``chainfury`` is already being used in production and thus with the infrastructure layer sorted we can then think about | ||
what to build on top of it. | ||
|
||
Automated | ||
~~~~~~~~~ | ||
|
||
One of the most important things is that these agents be automated and run without human in the loop. | ||
|
||
Edits | ||
----- | ||
|
||
.. all the links here | ||
.. _first commit: https://github.com/NimbleBoxAI/ChainFury/commit/64a5f7b0fcf3d8bcce0cde6ee974b659ebe01b68 | ||
.. _Von-Neumann machine: https://blog.nimblebox.ai/new-flow-engine-from-scratch |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
Components List | ||
=============== | ||
|
||
.. this is a jinja template document, run scripts/list_builtins.py to generate components-list.rst | ||
There are several components that are shipped with the ``chainfury``. You can find how to access the underlying function | ||
via the `components page`_. | ||
|
||
.. code-block::python | ||
# load the registries you can do these imports | ||
from chainfury import programatic_actions_registry, ai_actions_registry | ||
Programatic Actions | ||
------------------- | ||
|
||
Programatic means that these are generally not an LLM call rather something more standard like calling an API, | ||
transforming the data, etc. | ||
|
||
|
||
* `serper-api` - Search the web with Serper. Copy: ``programatic_actions_registry.get("serper-api")`` | ||
|
||
* `call_api_requests` - Call an API using the requests library. Copy: ``programatic_actions_registry.get("call_api_requests")`` | ||
|
||
* `regex_search` - Perform a regex search on the text and get items in an array. Copy: ``programatic_actions_registry.get("regex_search")`` | ||
|
||
* `regex_substitute` - Perform a regex substitution on the text and get the result. Copy: ``programatic_actions_registry.get("regex_substitute")`` | ||
|
||
* `json_translator` - Extract a value from a JSON object using a list of keys. Copy: ``programatic_actions_registry.get("json_translator")`` | ||
|
||
|
||
AI Action Components | ||
-------------------- | ||
|
||
These actions generally take the input, create a custom prompt, call the Model and respond back with the result. | ||
|
||
|
||
* `hello-world` - Python function loaded from a file used as an AI action. Copy: ``ai_actions_registry.get("hello-world")`` | ||
|
||
* `deep-rap-quote` - J-type action will write a deep poem in the style of a character. Copy: ``ai_actions_registry.get("deep-rap-quote")`` | ||
|
||
|
||
Memory Components | ||
----------------- | ||
|
||
Memory components are used to store data, which can be a Vector DB or Redis, etc. | ||
|
||
|
||
* `qdrant-write` - Write to the Qdrant DB using the Qdrant client. Copy: ``memory_registry.get_write("qdrant-write")`` | ||
|
||
* `qdrant-read` - Function to read from the Qdrant DB using the Qdrant client. Copy: ``memory_registry.get_read("qdrant-read")`` | ||
|
||
|
||
Model Components | ||
---------------- | ||
|
||
Model are the different GenAI models that can be used from the ``chainfury``. | ||
|
||
|
||
* `stability-text-to-image` - Generate a new image from a text prompt. Copy: ``model_registry.get("stability-text-to-image")`` | ||
|
||
* `chatnbx` - Chat with the ChatNBX API with OpenAI compatability, see more at https://chat.nbox.ai/. Copy: ``model_registry.get("chatnbx")`` | ||
|
||
* `nbx-deploy` - Call NimbleBox LLMOps deploy API. Copy: ``model_registry.get("nbx-deploy")`` | ||
|
||
* `openai-completion` - Given a prompt, the model will return one or more predicted completions, and can also return the probabilities of alternative tokens at each position. Copy: ``model_registry.get("openai-completion")`` | ||
|
||
* `openai-chat` - Given a list of messages describing a conversation, the model will return a response. Copy: ``model_registry.get("openai-chat")`` | ||
|
||
* `openai-embedding` - Given a list of messages create embeddings for each message. Copy: ``model_registry.get("openai-embedding")`` | ||
|
||
|
||
.. all the links are here | ||
.. _components page: https://qdrant.tech/documentation/tutorials/bulk-upload/#upload-directly-to-disk |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
Components List | ||
=============== | ||
|
||
.. this is a jinja template document, run scripts/list_builtins.py to generate components-list.rst | ||
There are several components that are shipped with the ``chainfury``. You can find how to access the underlying function | ||
via the `components page`_. | ||
|
||
.. code-block::python | ||
# load the registries you can do these imports | ||
from chainfury import programatic_actions_registry, ai_actions_registry | ||
Programatic Actions | ||
------------------- | ||
|
||
Programatic means that these are generally not an LLM call rather something more standard like calling an API, | ||
transforming the data, etc. | ||
|
||
{% for component in pc %} | ||
* `{{ component.id }}` - {{ component.description }} | ||
{% endfor %} | ||
|
||
AI Action Components | ||
-------------------- | ||
|
||
These actions generally take the input, create a custom prompt, call the Model and respond back with the result. | ||
|
||
{% for component in ac %} | ||
* `{{ component.id }}` - {{ component.description }} | ||
{% endfor %} | ||
|
||
Memory Components | ||
----------------- | ||
|
||
Memory components are used to store data, which can be a Vector DB or Redis, etc. | ||
|
||
{% for component in mc %} | ||
* `{{ component.id }}` - {{ component.description }} | ||
{% endfor %} | ||
|
||
Model Components | ||
---------------- | ||
|
||
Model are the different GenAI models that can be used from the ``chainfury``. | ||
|
||
{% for component in moc %} | ||
* `{{ component.id }}` - {{ component.description }} | ||
{% endfor %} | ||
|
||
.. all the links are here | ||
.. _components page: https://qdrant.tech/documentation/tutorials/bulk-upload/#upload-directly-to-disk | ||
|
Submodule cf_internal
updated
from be5b37 to 7f44e7
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.