mirror of
https://github.com/camel-ai/owl.git
synced 2026-03-22 05:57:17 +08:00
add deepseek example
This commit is contained in:
@@ -8,6 +8,8 @@ HF_TOKEN=""
|
|||||||
# Qwen API (https://help.aliyun.com/zh/model-studio/developer-reference/get-api-key)
|
# Qwen API (https://help.aliyun.com/zh/model-studio/developer-reference/get-api-key)
|
||||||
QWEN_API_KEY=""
|
QWEN_API_KEY=""
|
||||||
|
|
||||||
|
# DeepSeek API (https://platform.deepseek.com/api_keys)
|
||||||
|
DEEPSEEK_API_KEY="
|
||||||
|
|
||||||
#===========================================
|
#===========================================
|
||||||
# Tools & Services API
|
# Tools & Services API
|
||||||
|
|||||||
84
owl/run_deepseek_example.py
Normal file
84
owl/run_deepseek_example.py
Normal file
@@ -0,0 +1,84 @@
|
|||||||
|
from camel.models import ModelFactory
|
||||||
|
from camel.toolkits import *
|
||||||
|
from camel.types import ModelPlatformType, ModelType
|
||||||
|
from camel.configs import DeepSeekConfig
|
||||||
|
|
||||||
|
from typing import List, Dict
|
||||||
|
from dotenv import load_dotenv
|
||||||
|
from retry import retry
|
||||||
|
from loguru import logger
|
||||||
|
|
||||||
|
from utils import OwlRolePlaying, run_society
|
||||||
|
import os
|
||||||
|
|
||||||
|
|
||||||
|
load_dotenv()
|
||||||
|
|
||||||
|
|
||||||
|
def construct_society(question: str) -> OwlRolePlaying:
|
||||||
|
r"""Construct the society based on the question."""
|
||||||
|
|
||||||
|
user_role_name = "user"
|
||||||
|
assistant_role_name = "assistant"
|
||||||
|
|
||||||
|
user_model = ModelFactory.create(
|
||||||
|
model_platform=ModelPlatformType.DEEPSEEK,
|
||||||
|
model_type=ModelType.DEEPSEEK_CHAT,
|
||||||
|
model_config_dict=DeepSeekConfig(temperature=0, top_p=1).as_dict(), # [Optional] the config for model
|
||||||
|
)
|
||||||
|
|
||||||
|
assistant_model = ModelFactory.create(
|
||||||
|
model_platform=ModelPlatformType.DEEPSEEK,
|
||||||
|
model_type=ModelType.DEEPSEEK_CHAT,
|
||||||
|
model_config_dict=DeepSeekConfig(temperature=0, top_p=1).as_dict(), # [Optional] the config for model
|
||||||
|
)
|
||||||
|
|
||||||
|
tools_list = [
|
||||||
|
*WebToolkit(
|
||||||
|
headless=False,
|
||||||
|
web_agent_model=assistant_model,
|
||||||
|
planning_agent_model=assistant_model
|
||||||
|
).get_tools(),
|
||||||
|
*DocumentProcessingToolkit().get_tools(),
|
||||||
|
*VideoAnalysisToolkit().get_tools(), # This requires OpenAI and Qwen Key
|
||||||
|
*CodeExecutionToolkit().get_tools(),
|
||||||
|
*ImageAnalysisToolkit(model=assistant_model).get_tools(),
|
||||||
|
*AudioAnalysisToolkit().get_tools(), # This requires OpenAI Key
|
||||||
|
*SearchToolkit(model=assistant_model).get_tools(),
|
||||||
|
*ExcelToolkit().get_tools()
|
||||||
|
]
|
||||||
|
|
||||||
|
user_role_name = 'user'
|
||||||
|
user_agent_kwargs = dict(model=user_model)
|
||||||
|
assistant_role_name = 'assistant'
|
||||||
|
assistant_agent_kwargs = dict(model=assistant_model,
|
||||||
|
tools=tools_list)
|
||||||
|
|
||||||
|
task_kwargs = {
|
||||||
|
'task_prompt': question,
|
||||||
|
'with_task_specify': False,
|
||||||
|
}
|
||||||
|
|
||||||
|
society = OwlRolePlaying(
|
||||||
|
**task_kwargs,
|
||||||
|
user_role_name=user_role_name,
|
||||||
|
user_agent_kwargs=user_agent_kwargs,
|
||||||
|
assistant_role_name=assistant_role_name,
|
||||||
|
assistant_agent_kwargs=assistant_agent_kwargs,
|
||||||
|
)
|
||||||
|
|
||||||
|
return society
|
||||||
|
|
||||||
|
|
||||||
|
# Example case
|
||||||
|
question = "What was the volume in m^3 of the fish bag that was calculated in the University of Leicester paper `Can Hiccup Supply Enough Fish to Maintain a Dragon’s Diet?` "
|
||||||
|
|
||||||
|
society = construct_society(question)
|
||||||
|
answer, chat_history, token_count = run_society(society)
|
||||||
|
|
||||||
|
logger.success(f"Answer: {answer}")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Reference in New Issue
Block a user