From cbe10e34e0b5c3f1ce71edcfa2f5299cc5618c97 Mon Sep 17 00:00:00 2001 From: Dmitrii Cherkasov Date: Thu, 12 Dec 2024 13:42:36 -0800 Subject: [PATCH] Adds LlamaIndex integration docs. --- docs/source/conf.py | 11 +- .../user_guide/large_language_model/index.rst | 1 + .../llamaindex_integration.rst | 362 ++++++++++++++++++ 3 files changed, 370 insertions(+), 4 deletions(-) create mode 100644 docs/source/user_guide/large_language_model/llamaindex_integration.rst diff --git a/docs/source/conf.py b/docs/source/conf.py index 4939c3d6a..d2ce56302 100644 --- a/docs/source/conf.py +++ b/docs/source/conf.py @@ -31,7 +31,7 @@ "sphinx.ext.autodoc", "sphinx.ext.todo", "sphinx.ext.extlinks", - "sphinx.ext.intersphinx", + "sphinx.ext.intersphinx", "sphinx.ext.graphviz", "nbsphinx", "sphinx_code_tabs", @@ -80,12 +80,12 @@ html_use_index = False # html_css_files = [ -# 'pied-piper-admonition.css', +# 'pied-piper-admonition.css', # ] html_theme_options = { "light_logo": "logo-light-mode.png", - "dark_logo": "logo-dark-mode.png", + "dark_logo": "logo-dark-mode.png", } @@ -165,7 +165,10 @@ # -- Options for intersphinx extension --------------------------------------- # Example configuration for intersphinx: refer to the Python standard library. -intersphinx_mapping = {"https://docs.python.org/": None} +intersphinx_mapping = { + "python": ("https://docs.python.org/3/", None), + "sphinx": ("https://www.sphinx-doc.org/en/master/", None), +} # -- Options for todo extension ---------------------------------------------- diff --git a/docs/source/user_guide/large_language_model/index.rst b/docs/source/user_guide/large_language_model/index.rst index 9b9a2d07a..2ba43655c 100644 --- a/docs/source/user_guide/large_language_model/index.rst +++ b/docs/source/user_guide/large_language_model/index.rst @@ -40,6 +40,7 @@ ADS is designed to work with LangChain, enabling developers to incorporate vario training_llm langchain_models autogen_integration + llamaindex_integration deploy_langchain_application retrieval guardrails diff --git a/docs/source/user_guide/large_language_model/llamaindex_integration.rst b/docs/source/user_guide/large_language_model/llamaindex_integration.rst new file mode 100644 index 000000000..05a61a232 --- /dev/null +++ b/docs/source/user_guide/large_language_model/llamaindex_integration.rst @@ -0,0 +1,362 @@ +LlamaIndex Integration +********************** + +.. versionadded:: 2.12.8 + +The integrations for LlamaIndex described here allow you to invoke LLMs deployed on OCI Data Science model deployments. With `AI Quick Actions `_, deploying and serving large language models becomes straightforward. + +For comprehensive guidance on deploying LLM models in OCI Data Science using AI Quick Actions, refer to the detailed documentation available `here `_ and `here `_. + + +.. admonition:: Requirements + :class: note + + The LlamaIndex LLM integration requires ``python>=3.9`` and a suitable LLM endpoint deployed on OCI Data Science. + Ensure you have installed ``llama-index-llms-oci-data-science``, ``llama-index-core`` and ``oracle-ads`` libraries. + +.. code-block:: bash + + pip install llama-index-llms-oci-data-science + + +Authentication +============== + +The authentication methods supported for LlamaIndex are equivalent to those used with other OCI services and follow standard SDK authentication methods, including API Key, session token, instance principal, and resource principal. More details can be found `here `_. Ensure you have the required `policies `_ to access the OCI Data Science Model Deployment endpoint. +By default, the integration uses the same authentication method configured with ``ads.set_auth()``. Optionally, you can also pass the ``auth`` keyword argument when initializing the model to use specific authentication method for the model. + +Basic Usage +=========== + +Using LLMs offered by OCI Data Science AI with LlamaIndex only requires you to initialize the ``OCIDataScience`` interface with your Data Science Model Deployment endpoint and model ID. By default, all deployed models in AI Quick Actions get ``odsc-model`` as an ID, but this can be changed during deployment. + +Call ``complete`` with a prompt +----------------------------- + +.. code-block:: python3 + + import ads + from llama_index.llms.oci_data_science import OCIDataScience + + ads.set_auth(auth="resource_principal") + + llm = OCIDataScience( + # auth=ads.auth.security_token(profile=""), + model="odsc-llm", + endpoint="https:///predict", + temperature=0.2, + max_tokens=500, + timeout=120, + ) + response = llm.complete("Tell me a joke") + + print(response) + +Call ``chat`` with a list of messages +----------------------------------- + +.. code-block:: python3 + + import ads + from llama_index.llms.oci_data_science import OCIDataScience + from llama_index.core.base.llms.types import ChatMessage + + ads.set_auth(auth="security_token", profile="") + + llm = OCIDataScience( + model="odsc-llm", + endpoint="https:///predict", + ) + response = llm.chat( + [ + ChatMessage(role="user", content="Tell me a joke"), + ChatMessage(role="assistant", content="Why did the chicken cross the road?"), + ChatMessage(role="user", content="I don't know, why?"), + ] + ) + + print(response) + +Streaming +========= + +Using ``stream_complete`` endpoint +------------------------------- + +.. code-block:: python3 + + import ads + from llama_index.llms.oci_data_science import OCIDataScience + + ads.set_auth(auth="security_token", profile="") + + llm = OCIDataScience( + model="odsc-llm", + endpoint="https:///predict", + ) + + for chunk in llm.stream_complete("Tell me a joke"): + print(chunk.delta, end="") + +Using ``stream_chat`` endpoint +---------------------------- + +.. code-block:: python3 + + import ads + from llama_index.llms.oci_data_science import OCIDataScience + from llama_index.core.base.llms.types import ChatMessage + + ads.set_auth(auth="security_token", profile="") + + llm = OCIDataScience( + model="odsc-llm", + endpoint="https:///predict", + ) + response = llm.stream_chat( + [ + ChatMessage(role="user", content="Tell me a joke"), + ChatMessage(role="assistant", content="Why did the chicken cross the road?"), + ChatMessage(role="user", content="I don't know, why?"), + ] + ) + + for chunk in response: + print(chunk.delta, end="") + +Async +===== + +Call ``acomplete`` with a prompt +------------------------------ + +.. code-block:: python3 + + import ads + from llama_index.llms.oci_data_science import OCIDataScience + + ads.set_auth(auth="security_token", profile="") + + llm = OCIDataScience( + model="odsc-llm", + endpoint="https:///predict", + ) + response = await llm.acomplete("Tell me a joke") + + print(response) + +Call ``achat`` with a list of messages +------------------------------------ + +.. code-block:: python3 + + import ads + from llama_index.llms.oci_data_science import OCIDataScience + from llama_index.core.base.llms.types import ChatMessage + + ads.set_auth(auth="security_token", profile="") + + llm = OCIDataScience( + model="odsc-llm", + endpoint="https:///predict", + ) + response = await llm.achat( + [ + ChatMessage(role="user", content="Tell me a joke"), + ChatMessage(role="assistant", content="Why did the chicken cross the road?"), + ChatMessage(role="user", content="I don't know, why?"), + ] + ) + + print(response) + +Async Streaming +=============== + +Using ``astream_complete`` endpoint +--------------------------------- + +.. code-block:: python3 + + import ads + from llama_index.llms.oci_data_science import OCIDataScience + + ads.set_auth(auth="security_token", profile="") + + llm = OCIDataScience( + model="odsc-llm", + endpoint="https:///predict", + ) + + async for chunk in await llm.astream_complete("Tell me a joke"): + print(chunk.delta, end="") + +Using ``astream_chat`` endpoint +----------------------------- + +.. code-block:: python3 + + import ads + from llama_index.llms.oci_data_science import OCIDataScience + from llama_index.core.base.llms.types import ChatMessage + + ads.set_auth(auth="security_token", profile="") + + llm = OCIDataScience( + model="odsc-llm", + endpoint="https:///predict", + ) + response = await llm.stream_chat( + [ + ChatMessage(role="user", content="Tell me a joke"), + ChatMessage(role="assistant", content="Why did the chicken cross the road?"), + ChatMessage(role="user", content="I don't know, why?"), + ] + ) + + async for chunk in response: + print(chunk.delta, end="") + +Configure Model +=============== + +.. code-block:: python3 + + import ads + from llama_index.llms.oci_data_science import OCIDataScience + + ads.set_auth(auth="security_token", profile="") + + llm = OCIDataScience( + model="odsc-llm", + endpoint="https:///predict", + temperature=0.2, + max_tokens=500, + timeout=120, + context_window=2500, + additional_kwargs={ + "top_p": 0.75, + "logprobs": True, + "top_logprobs": 3, + }, + ) + response = llm.chat( + [ + ChatMessage(role="user", content="Tell me a joke"), + ] + ) + print(response) + +Function Calling +================ + +If the deployed model supports function calling, integration with LlamaIndex tools through ``predict_and_call`` allows the LLM to decide which tools to call. + +.. code-block:: python3 + + import ads + from llama_index.llms.oci_data_science import OCIDataScience + from llama_index.core.tools import FunctionTool + + ads.set_auth(auth="security_token", profile="") + + llm = OCIDataScience( + model="odsc-llm", + endpoint="https:///predict", + temperature=0.2, + max_tokens=500, + timeout=120, + context_window=2500, + additional_kwargs={ + "top_p": 0.75, + "logprobs": True, + "top_logprobs": 3, + }, + ) + + def multiply(a: float, b: float) -> float: + print(f"---> {a} * {b}") + return a * b + + def add(a: float, b: float) -> float: + print(f"---> {a} + {b}") + return a + b + + def subtract(a: float, b: float) -> float: + print(f"---> {a} - {b}") + return a - b + + def divide(a: float, b: float) -> float: + print(f"---> {a} / {b}") + return a / b + + multiply_tool = FunctionTool.from_defaults(fn=multiply) + add_tool = FunctionTool.from_defaults(fn=add) + sub_tool = FunctionTool.from_defaults(fn=subtract) + divide_tool = FunctionTool.from_defaults(fn=divide) + + response = llm.predict_and_call( + [multiply_tool, add_tool, sub_tool, divide_tool], + user_msg="Calculate the result of `8 + 2`.", + verbose=True, + ) + + print(response) + +Using ``FunctionCallingAgent`` +------------------------------ + +.. code-block:: python3 + + import ads + from llama_index.llms.oci_data_science import OCIDataScience + from llama_index.core.tools import FunctionTool + from llama_index.core.agent import FunctionCallingAgent + + ads.set_auth(auth="security_token", profile="") + + llm = OCIDataScience( + model="odsc-llm", + endpoint="https:///predict", + temperature=0.2, + max_tokens=500, + timeout=120, + context_window=2500, + additional_kwargs={ + "top_p": 0.75, + "logprobs": True, + "top_logprobs": 3, + }, + ) + + def multiply(a: float, b: float) -> float: + print(f"---> {a} * {b}") + return a * b + + def add(a: float, b: float) -> float: + print(f"---> {a} + {b}") + return a + b + + def subtract(a: float, b: float) -> float: + print(f"---> {a} - {b}") + return a - b + + def divide(a: float, b: float) -> float: + print(f"---> {a} / {b}") + return a / b + + multiply_tool = FunctionTool.from_defaults(fn=multiply) + add_tool = FunctionTool.from_defaults(fn=add) + sub_tool = FunctionTool.from_defaults(fn=subtract) + divide_tool = FunctionTool.from_defaults(fn=divide) + + agent = FunctionCallingAgent.from_tools( + tools=[multiply_tool, add_tool, sub_tool, divide_tool], + llm=llm, + verbose=True, + ) + response = agent.chat( + "Calculate the result of `8 + 2 - 6`. Use tools. Return the calculated result." + ) + + print(response)