LLMs#
ragbits.core.llms.LLM
#
Bases: ConfigurableComponent[LLMClientOptionsT]
, ABC
Abstract class for interaction with Large Language Model.
Constructs a new LLM instance.
PARAMETER | DESCRIPTION |
---|---|
model_name |
Name of the model to be used.
TYPE:
|
default_options |
Default options to be used.
TYPE:
|
RAISES | DESCRIPTION |
---|---|
TypeError
|
If the subclass is missing the 'options_cls' attribute. |
Source code in packages/ragbits-core/src/ragbits/core/llms/base.py
subclass_from_config
classmethod
#
Initializes the class with the provided configuration. May return a subclass of the class, if requested by the configuration.
PARAMETER | DESCRIPTION |
---|---|
config |
A model containing configuration details for the class.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
Self
|
An instance of the class initialized with the provided configuration. |
RAISES | DESCRIPTION |
---|---|
InvalidConfigError
|
The class can't be found or is not a subclass of the current class. |
Source code in packages/ragbits-core/src/ragbits/core/utils/config_handling.py
subclass_from_factory
classmethod
#
Creates the class using the provided factory function. May return a subclass of the class, if requested by the factory.
PARAMETER | DESCRIPTION |
---|---|
factory_path |
A string representing the path to the factory function in the format of "module.submodule:factory_name".
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
Self
|
An instance of the class initialized with the provided factory function. |
RAISES | DESCRIPTION |
---|---|
InvalidConfigError
|
The factory can't be found or the object returned is not a subclass of the current class. |
Source code in packages/ragbits-core/src/ragbits/core/utils/config_handling.py
subclass_from_defaults
classmethod
#
subclass_from_defaults(defaults: CoreConfig, factory_path_override: str | None = None, yaml_path_override: Path | None = None) -> Self
Tries to create an instance by looking at default configuration file, and default factory function. Takes optional overrides for both, which takes a higher precedence.
PARAMETER | DESCRIPTION |
---|---|
defaults |
The CoreConfig instance containing default factory and configuration details.
TYPE:
|
factory_path_override |
A string representing the path to the factory function in the format of "module.submodule:factory_name".
TYPE:
|
yaml_path_override |
A string representing the path to the YAML file containing the Ragstack instance configuration.
TYPE:
|
RAISES | DESCRIPTION |
---|---|
InvalidConfigError
|
If the default factory or configuration can't be found. |
Source code in packages/ragbits-core/src/ragbits/core/utils/config_handling.py
from_config
classmethod
#
Initializes the class with the provided configuration.
PARAMETER | DESCRIPTION |
---|---|
config |
A dictionary containing configuration details for the class.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
ConfigurableComponent
|
An instance of the class initialized with the provided configuration. |
Source code in packages/ragbits-core/src/ragbits/core/utils/config_handling.py
count_tokens
#
Counts tokens in the prompt.
PARAMETER | DESCRIPTION |
---|---|
prompt |
Formatted prompt template with conversation and response parsing configuration.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
int
|
Number of tokens in the prompt. |
Source code in packages/ragbits-core/src/ragbits/core/llms/base.py
generate_raw
async
#
Prepares and sends a prompt to the LLM and returns the raw response (without parsing).
PARAMETER | DESCRIPTION |
---|---|
prompt |
Formatted prompt template with conversation.
TYPE:
|
options |
Options to use for the LLM client.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
str
|
Raw text response from LLM. |
Source code in packages/ragbits-core/src/ragbits/core/llms/base.py
generate
async
#
Prepares and sends a prompt to the LLM and returns response parsed to the output type of the prompt (if available).
PARAMETER | DESCRIPTION |
---|---|
prompt |
Formatted prompt template with conversation and optional response parsing configuration.
TYPE:
|
options |
Options to use for the LLM client.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
OutputT
|
Text response from LLM. |
Source code in packages/ragbits-core/src/ragbits/core/llms/base.py
generate_streaming
async
#
generate_streaming(prompt: BasePrompt, *, options: LLMClientOptionsT | None = None) -> AsyncGenerator[str, None]
Prepares and sends a prompt to the LLM and streams the results.
PARAMETER | DESCRIPTION |
---|---|
prompt |
Formatted prompt template with conversation.
TYPE:
|
options |
Options to use for the LLM client.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
AsyncGenerator[str, None]
|
Response stream from LLM. |
Source code in packages/ragbits-core/src/ragbits/core/llms/base.py
ragbits.core.llms.local.LocalLLM
#
LocalLLM(model_name: str, default_options: LocalLLMOptions | None = None, *, api_key: str | None = None)
Bases: LLM[LocalLLMOptions]
Class for interaction with any LLM available in HuggingFace.
Constructs a new local LLM instance.
PARAMETER | DESCRIPTION |
---|---|
model_name |
Name of the model to use. This should be a model from the CausalLM class.
TYPE:
|
default_options |
Default options for the LLM.
TYPE:
|
api_key |
The API key for Hugging Face authentication.
TYPE:
|
RAISES | DESCRIPTION |
---|---|
ImportError
|
If the 'local' extra requirements are not installed. |
Source code in packages/ragbits-core/src/ragbits/core/llms/local.py
client
cached
property
#
Client for the LLM.
RETURNS | DESCRIPTION |
---|---|
LocalLLMClient
|
The client used to interact with the LLM. |
subclass_from_config
classmethod
#
Initializes the class with the provided configuration. May return a subclass of the class, if requested by the configuration.
PARAMETER | DESCRIPTION |
---|---|
config |
A model containing configuration details for the class.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
Self
|
An instance of the class initialized with the provided configuration. |
RAISES | DESCRIPTION |
---|---|
InvalidConfigError
|
The class can't be found or is not a subclass of the current class. |
Source code in packages/ragbits-core/src/ragbits/core/utils/config_handling.py
subclass_from_factory
classmethod
#
Creates the class using the provided factory function. May return a subclass of the class, if requested by the factory.
PARAMETER | DESCRIPTION |
---|---|
factory_path |
A string representing the path to the factory function in the format of "module.submodule:factory_name".
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
Self
|
An instance of the class initialized with the provided factory function. |
RAISES | DESCRIPTION |
---|---|
InvalidConfigError
|
The factory can't be found or the object returned is not a subclass of the current class. |
Source code in packages/ragbits-core/src/ragbits/core/utils/config_handling.py
subclass_from_defaults
classmethod
#
subclass_from_defaults(defaults: CoreConfig, factory_path_override: str | None = None, yaml_path_override: Path | None = None) -> Self
Tries to create an instance by looking at default configuration file, and default factory function. Takes optional overrides for both, which takes a higher precedence.
PARAMETER | DESCRIPTION |
---|---|
defaults |
The CoreConfig instance containing default factory and configuration details.
TYPE:
|
factory_path_override |
A string representing the path to the factory function in the format of "module.submodule:factory_name".
TYPE:
|
yaml_path_override |
A string representing the path to the YAML file containing the Ragstack instance configuration.
TYPE:
|
RAISES | DESCRIPTION |
---|---|
InvalidConfigError
|
If the default factory or configuration can't be found. |
Source code in packages/ragbits-core/src/ragbits/core/utils/config_handling.py
from_config
classmethod
#
Initializes the class with the provided configuration.
PARAMETER | DESCRIPTION |
---|---|
config |
A dictionary containing configuration details for the class.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
ConfigurableComponent
|
An instance of the class initialized with the provided configuration. |
Source code in packages/ragbits-core/src/ragbits/core/utils/config_handling.py
generate_raw
async
#
Prepares and sends a prompt to the LLM and returns the raw response (without parsing).
PARAMETER | DESCRIPTION |
---|---|
prompt |
Formatted prompt template with conversation.
TYPE:
|
options |
Options to use for the LLM client.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
str
|
Raw text response from LLM. |
Source code in packages/ragbits-core/src/ragbits/core/llms/base.py
generate
async
#
Prepares and sends a prompt to the LLM and returns response parsed to the output type of the prompt (if available).
PARAMETER | DESCRIPTION |
---|---|
prompt |
Formatted prompt template with conversation and optional response parsing configuration.
TYPE:
|
options |
Options to use for the LLM client.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
OutputT
|
Text response from LLM. |
Source code in packages/ragbits-core/src/ragbits/core/llms/base.py
generate_streaming
async
#
generate_streaming(prompt: BasePrompt, *, options: LLMClientOptionsT | None = None) -> AsyncGenerator[str, None]
Prepares and sends a prompt to the LLM and streams the results.
PARAMETER | DESCRIPTION |
---|---|
prompt |
Formatted prompt template with conversation.
TYPE:
|
options |
Options to use for the LLM client.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
AsyncGenerator[str, None]
|
Response stream from LLM. |
Source code in packages/ragbits-core/src/ragbits/core/llms/base.py
count_tokens
#
Counts tokens in the messages.
PARAMETER | DESCRIPTION |
---|---|
prompt |
Messages to count tokens for.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
int
|
Number of tokens in the messages. |
Source code in packages/ragbits-core/src/ragbits/core/llms/local.py
ragbits.core.llms.litellm.LiteLLM
#
LiteLLM(model_name: str = 'gpt-3.5-turbo', default_options: LiteLLMOptions | None = None, *, base_url: str | None = None, api_key: str | None = None, api_version: str | None = None, use_structured_output: bool = False, router: Router | None = None)
Bases: LLM[LiteLLMOptions]
Class for interaction with any LLM supported by LiteLLM API.
Constructs a new LiteLLM instance.
PARAMETER | DESCRIPTION |
---|---|
model_name |
Name of the LiteLLM supported model to be used. Default is "gpt-3.5-turbo".
TYPE:
|
default_options |
Default options to be used.
TYPE:
|
base_url |
Base URL of the LLM API.
TYPE:
|
api_key |
API key to be used. API key to be used. If not specified, an environment variable will be used, for more information, follow the instructions for your specific vendor in the LiteLLM documentation.
TYPE:
|
api_version |
API version to be used. If not specified, the default version will be used.
TYPE:
|
use_structured_output |
Whether to request a structured output from the model. Default is False. Can only be combined with models that support structured output.
TYPE:
|
router |
Router to be used to route requests to different models.
TYPE:
|
Source code in packages/ragbits-core/src/ragbits/core/llms/litellm.py
subclass_from_config
classmethod
#
Initializes the class with the provided configuration. May return a subclass of the class, if requested by the configuration.
PARAMETER | DESCRIPTION |
---|---|
config |
A model containing configuration details for the class.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
Self
|
An instance of the class initialized with the provided configuration. |
RAISES | DESCRIPTION |
---|---|
InvalidConfigError
|
The class can't be found or is not a subclass of the current class. |
Source code in packages/ragbits-core/src/ragbits/core/utils/config_handling.py
subclass_from_factory
classmethod
#
Creates the class using the provided factory function. May return a subclass of the class, if requested by the factory.
PARAMETER | DESCRIPTION |
---|---|
factory_path |
A string representing the path to the factory function in the format of "module.submodule:factory_name".
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
Self
|
An instance of the class initialized with the provided factory function. |
RAISES | DESCRIPTION |
---|---|
InvalidConfigError
|
The factory can't be found or the object returned is not a subclass of the current class. |
Source code in packages/ragbits-core/src/ragbits/core/utils/config_handling.py
subclass_from_defaults
classmethod
#
subclass_from_defaults(defaults: CoreConfig, factory_path_override: str | None = None, yaml_path_override: Path | None = None) -> Self
Tries to create an instance by looking at default configuration file, and default factory function. Takes optional overrides for both, which takes a higher precedence.
PARAMETER | DESCRIPTION |
---|---|
defaults |
The CoreConfig instance containing default factory and configuration details.
TYPE:
|
factory_path_override |
A string representing the path to the factory function in the format of "module.submodule:factory_name".
TYPE:
|
yaml_path_override |
A string representing the path to the YAML file containing the Ragstack instance configuration.
TYPE:
|
RAISES | DESCRIPTION |
---|---|
InvalidConfigError
|
If the default factory or configuration can't be found. |
Source code in packages/ragbits-core/src/ragbits/core/utils/config_handling.py
from_config
classmethod
#
Initializes the class with the provided configuration.
PARAMETER | DESCRIPTION |
---|---|
config |
A dictionary containing configuration details for the class.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
ConfigurableComponent
|
An instance of the class initialized with the provided configuration. |
Source code in packages/ragbits-core/src/ragbits/core/utils/config_handling.py
generate_raw
async
#
Prepares and sends a prompt to the LLM and returns the raw response (without parsing).
PARAMETER | DESCRIPTION |
---|---|
prompt |
Formatted prompt template with conversation.
TYPE:
|
options |
Options to use for the LLM client.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
str
|
Raw text response from LLM. |
Source code in packages/ragbits-core/src/ragbits/core/llms/base.py
generate
async
#
Prepares and sends a prompt to the LLM and returns response parsed to the output type of the prompt (if available).
PARAMETER | DESCRIPTION |
---|---|
prompt |
Formatted prompt template with conversation and optional response parsing configuration.
TYPE:
|
options |
Options to use for the LLM client.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
OutputT
|
Text response from LLM. |
Source code in packages/ragbits-core/src/ragbits/core/llms/base.py
generate_streaming
async
#
generate_streaming(prompt: BasePrompt, *, options: LLMClientOptionsT | None = None) -> AsyncGenerator[str, None]
Prepares and sends a prompt to the LLM and streams the results.
PARAMETER | DESCRIPTION |
---|---|
prompt |
Formatted prompt template with conversation.
TYPE:
|
options |
Options to use for the LLM client.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
AsyncGenerator[str, None]
|
Response stream from LLM. |
Source code in packages/ragbits-core/src/ragbits/core/llms/base.py
count_tokens
#
Counts tokens in the prompt.
PARAMETER | DESCRIPTION |
---|---|
prompt |
Formatted prompt template with conversation and response parsing configuration.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
int
|
Number of tokens in the prompt. |