The lite version of the prompt is not fully optimized. To achieve better results, it is recommended that users adjust the prompt according to performance!!!
- Create an account on Google AI and get your API key.
- Install the required packages google-generativeai or install the
requirement.txt
with uncommenting the Gemini.
pip install -U google-generativeai==0.7.0
- Add following configuration to
config.yaml
:
{
"API_TYPE": "Gemini" ,
"API_KEY": "YOUR_KEY",
"API_MODEL": "YOUR_MODEL"
}
NOTE: API_MODEL
is the model name of Gemini LLM API.
You can find the model name in the Gemini LLM model list.
If you meet the 429 Resource has been exhausted (e.g. check quota).
, it may because the rate limit of your Gemini API.
- Create an account on Claude and get your API key.
- Install the required packages anthropic or install the
requirement.txt
with uncommenting the Claude.
pip install -U anthropic==0.37.1
- Add following configuration to
config.yaml
:
{
"API_TYPE": "claude" ,
"API_KEY": "YOUR_KEY",
"API_MODEL": "YOUR_MODEL"
}
NOTE: API_MODEL
is the model name of Claude LLM API.
You can find the model name in the Claude LLM model list.
- QWen (Tongyi Qianwen) is a LLM developed by Alibaba. Go to QWen and register an account and get the API key. More details can be found here (in Chinese).
- Install the required packages dashscope or install the
requirement.txt
with uncommenting the Qwen.
pip install dashscope
- Add following configuration to
config.yaml
:
{
"API_TYPE": "Qwen" ,
"API_KEY": "YOUR_KEY",
"API_MODEL": "YOUR_MODEL"
}
NOTE: API_MODEL
is the model name of QWen LLM API.
You can find the model name in the QWen LLM model list.
- Go to Ollama and follow the instructions to serve a LLM model on your local environment. We provide a short example to show how to configure the ollama in the following, which might change if ollama makes updates.
## Install ollama on Linux & WSL2
curl https://ollama.ai/install.sh | sh
## Run the serving
ollama serve
Open another terminal and run:
ollama run YOUR_MODEL
info
When serving LLMs via Ollama, it will by default start a server at http://localhost:11434
, which will later be used as the API base in config.yaml
.
- Add following configuration to
config.yaml
:
{
"API_TYPE": "Ollama" ,
"API_BASE": "YOUR_ENDPOINT",
"API_MODEL": "YOUR_MODEL"
}
NOTE: API_BASE
is the URL started in the Ollama LLM server and API_MODEL
is the model name of Ollama LLM, it should be same as the one you served before. In addition, due to model limitations, you can use lite version of prompt to have a taste on UFO which can be configured in config_dev.yaml
. Attention to the top NOTE.
-
Start a server with your model, which will later be used as the API base in
config.yaml
. -
Add following configuration to
config.yaml
:
{
"API_TYPE": "custom_model" ,
"API_BASE": "YOUR_ENDPOINT",
"API_KEY": "YOUR_KEY",
"API_MODEL": "YOUR_MODEL"
}
NOTE: You should create a new Python script custom_model.py
in the ufo/llm folder like the format of the placeholder.py
, which needs to inherit BaseService
as the parent class, as well as the __init__
and chat_completion
methods. At the same time, you need to add the dynamic import of your file in the get_service
method of BaseService
.
You can use the following code as an example to configure your own model:
def chat_completion(self, messages, n, **kwargs):
retries = 0
while retries < self.max_retry:
try:
# Construct the request payload
payload = {
"messages": messages,
"n": n,
}
# Optionally, you can pass extra parameters through kwargs
payload.update(kwargs)
# Make the actual API request
response = self._make_api_request(payload)
# Process the response (you can adjust this based on your API's format)
return response
except Exception as e:
retries += 1
if retries >= self.max_retry:
raise
raise Exception("Max retries reached. Unable to get response from the API.")
def _make_api_request(self, payload):
# Config as you wished
headers = {
"Authorization": f"Bearer {self.api_key}",
"Content-Type": "application/json"
}
try:
# Send POST request to the API endpoint
response = requests.post(
self.api_base,
headers=headers,
json=payload,
timeout=self.timeout
)
# Check if the request was successful
response.raise_for_status()
# Return the JSON response from the API
return response.json()
except requests.exceptions.RequestException as e:
raise
Also, UFO provides the usage of LLaVA-1.5 and CogAgent as the example.
1.1 Download the essential libs of your custom model.
Please refer to the LLaVA project to download and prepare the LLaVA-1.5 model, for example:
git clone https://github.com/haotian-liu/LLaVA.git
cd LLaVA
conda create -n llava python=3.10 -y
conda activate llava
pip install --upgrade pip # enable PEP 660 support
pip install -e .
Please refer to the CogVLM project to download and prepare the CogAgent model. Download the sat version of the CogAgent weights cogagent-chat.zip
from here, unzip it.
1.2 Start your custom model. You must customize your model to support the interface of the UFO.
For simplicity, you have to configure YOUR_ENDPOINT/chat/completions
.
Add the direct_generate_llava
method and a new post interface /chat/completions
from the custom_model_worker.py
to the into the llava/serve/model_worker.py
And start it with the following command:
python -m llava.serve.llava_model_worker --host YOUR_HOST --port YOUR_POINT --worker YOUR_ENDPOINT --model-path liuhaotian/llava-v1.5-13b --no-register
You can modify the model generate from the basic_demo/cli_demo.py
with a new post interface /chat/completions
to enjoy it with UFO.
- Add following configuration to
config.yaml
:
{
"API_TYPE": "Custom" ,
"API_BASE": "YOUR_ENDPOINT",
"API_MODEL": "YOUR_MODEL"
}
Note: Only LLaVA and CogAgent are supported as open source models for now. If you want to use your own model, remember to modify the dynamic import of your model file in the get_service
method of BaseService
in ufo/llm/base.py
.