|
import os |
|
|
|
os.environ['CUDA_VISIBLE_DEVICES'] = '0,1,2,3' |
|
os.environ['SWIFT_DEBUG'] = '1' |
|
|
|
tools = [{ |
|
'name': 'get_current_weather', |
|
'description': 'Get the current weather in a given location', |
|
'parameters': { |
|
'type': 'object', |
|
'properties': { |
|
'location': { |
|
'type': 'string', |
|
'description': 'The city and state, e.g. San Francisco, CA' |
|
}, |
|
'unit': { |
|
'type': 'string', |
|
'enum': ['celsius', 'fahrenheit'] |
|
} |
|
}, |
|
'required': ['location'] |
|
} |
|
}] |
|
|
|
|
|
def _test_tool(pt_engine, system=None): |
|
messages = [ |
|
{ |
|
'role': 'user', |
|
'content': "How's the weather in Beijing today?" |
|
}, |
|
{ |
|
'role': |
|
'assistant', |
|
'content': ('<tool_call>\n{"name": "get_current_weather", "arguments": ' |
|
'{"location": "Beijing, China", "unit": "celsius"}}\n</tool_call>') |
|
}, |
|
{ |
|
'role': 'tool', |
|
'content': "{'temp': 25, 'description': 'Partly cloudy', 'status': 'success'}" |
|
}, |
|
] |
|
request_config = RequestConfig(max_tokens=512, temperature=0) |
|
response = pt_engine.infer([InferRequest(messages=messages, tools=tools)], request_config=request_config) |
|
return response[0].choices[0].message.content |
|
|
|
|
|
def test_qwen2_5(): |
|
pt_engine = PtEngine('Qwen/Qwen2.5-7B-Instruct') |
|
response = _test_tool(pt_engine) |
|
assert response == 'Today in Beijing, the temperature is 25 degrees Celsius with partly cloudy skies.' |
|
|
|
|
|
def test_qwq(): |
|
pt_engine = PtEngine('Qwen/QwQ-32B') |
|
response = _test_tool(pt_engine) |
|
assert response[-100:] == ('weather in Beijing is **25°C** with **partly cloudy** skies. ' |
|
'It looks like a mild day outside—enjoy!') |
|
|
|
|
|
def test_deepseek_r1_distill(): |
|
|
|
pt_engine = PtEngine('deepseek-ai/DeepSeek-R1-Distill-Qwen-7B') |
|
_test_tool(pt_engine, system='') |
|
|
|
|
|
if __name__ == '__main__': |
|
from swift.llm import PtEngine, RequestConfig, InferRequest |
|
from swift.utils import get_logger |
|
logger = get_logger() |
|
|
|
test_qwq() |
|
|
|
|