Home Assistant custom component for LLM empowerment.
This integration provides:
- HTTP API for available LLM tools to integrate HA LLM Tools with an externally running LLM
- Framework to easily add new LLM tools from other custom integrations, making Home Assistant a platform for LLM tools experimentation.
- Enhanced and experimental versions of core 'Assist' LLM tools
- Selectively Enable/Disable any tool
- Extra LLM tools:
- Web, maps, and news search with Duck Duck Go
- Web scrapping to access the Internet
- Permanent memory tool
- Python code execution
Please feel free to raise an issue if you have an idea of another useful tool!
- Copy
custom_components/powerllm
directory from this repository intocustom_components/
directory in your config directory. Optionally use HACS for this step. - Restart Home Assistant
- Add a config entry by going to Settings -> Device and Services -> Add integration or by pressing here: . If you only need the HTTP API but not the extra tools, then you can just add
powerllm:
into yourconfiguration.yaml
instead. - Configure your LLM integrations, such as OpenAI Conversation or Google Generative AI to use Power LLM API instead of Assist API.
There are following configuration options available:
-
For each interaction with LLM, a system prompt is generated. If this option is enabled, the system prompt will contain the list of all exposed devices. It would allow the LLM to find the devices you refer to more fast and reliable, but also consume input tokens. If your list of exposed entities is really big, you may want to disable this option and rely on other methods, such as explicit querying (see next option) or just guessing by its name from the user prompt (make sure to set up your aliases).
-
Some intents will return the states of affected entities in its response. If this option is enabled, they are also forwarded to the LLM. Usually they are not so important, and a simple response will also do the job. With one exception: the
HassGetState
, this is the intent specifically used to find entities matching certain criteria and return their states in the response. In fact, if this option is disabled, theHassGetState
would not be exposed to the LLM at all.Please keep in mind that the state returned returned using this option contains more information and attributes, than the list in the prompt. So if you want your LLM to be able to answer questions like
how long have the lights been on?
, keep it enabled. -
The server location used for web and news search. You can safely leave it as
No Region
. -
Power LLM includes a tool that allows LLM to write scripts in Home Assistant format and instantly execute them to handle more complex tasks than covered by standard intents. If this option is enabled, Power LLM will make an effort to verify that all entities referenced in this script are exposed. This process however has certain limitations (for example if the entity id is evaluated from template at runtime), so the script might fail this check more often than wanted.
-
These field contain the facts that the LLM chose to remember about the user for each
user_id
. You can also ask LLM to remember something about you. This option is presented here in case you want to delete something.
This is an extension of Home Assistant REST API providing LLM-specific endpoints, such as:
-
GET
/api/powerllm
Returns the list available LLM API, such as 'Assist', 'Power LLM', etc
-
GET
/api/powerllm/<api>
Returns the prompt and the list of tools for a specific api.
-
POST
/api/powerllm/<api>
Same as above, but accepts optional parameters:
user_input
,language
,device_id
-
POST
/api/powerllm/<api>/<tool_name>
Calls the tool and returns the result. Optional parameters:
user_input
,language
,device_id
,tool_args
Other custom integrations can use Power LLM
to add more tools to extend the functionality. Instruct your users to also install the Power LLM integration and add "powerllm" to dependencies in your manifest.json
.
There are two options:
-
Extend the
custom_components.powerllm.PowerLLMTool
class to implement the functionality, then callcustom_components.powerllm.async_register_tool
to register the object of the class. See the memory tool for an example -
Use the
custom_components.powerllm.llm_tool
decorator for any python function. The function is recommended to have type annotations for all parameters. If a parameter name is "hass", "llm_context", or any of thehomeassistant.helpers.llm.LLMContext
attributes, then the value for that parameter will be provided by the conversation agent ("pytest-style"). All other arguments will be provided by the LLM. Refer to the python code tool as an example. A synchronous function should be declared as@callback
, or it will be executed in a separate thread than the main hass loop, while an async function will be run concurrently in the main event loop and therefore is not allowed to use any blocking operations. If using both@llm_tool
and@callback
,@llm_tool
should be the outer decorator.
The tools in this repository use various techniques for demonstration.
- Weather forecast intent
- Ability to talk to other conversation agents (i.e. "Ask expert" for a reasoning model, or NLP conversation (Assist) for device control fallback)
- Your suggestions!