Text Generation
Transformers
Safetensors
mistral
function-call
conversational
text-generation-inference
Instructions to use InterSync/Mistral-7B-Instruct-v0.2-Function-Calling with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- Transformers
How to use InterSync/Mistral-7B-Instruct-v0.2-Function-Calling with Transformers:
# Use a pipeline as a high-level helper from transformers import pipeline pipe = pipeline("text-generation", model="InterSync/Mistral-7B-Instruct-v0.2-Function-Calling") messages = [ {"role": "user", "content": "Who are you?"}, ] pipe(messages)# Load model directly from transformers import AutoTokenizer, AutoModelForCausalLM tokenizer = AutoTokenizer.from_pretrained("InterSync/Mistral-7B-Instruct-v0.2-Function-Calling") model = AutoModelForCausalLM.from_pretrained("InterSync/Mistral-7B-Instruct-v0.2-Function-Calling") messages = [ {"role": "user", "content": "Who are you?"}, ] inputs = tokenizer.apply_chat_template( messages, add_generation_prompt=True, tokenize=True, return_dict=True, return_tensors="pt", ).to(model.device) outputs = model.generate(**inputs, max_new_tokens=40) print(tokenizer.decode(outputs[0][inputs["input_ids"].shape[-1]:])) - Notebooks
- Google Colab
- Kaggle
- Local Apps
- vLLM
How to use InterSync/Mistral-7B-Instruct-v0.2-Function-Calling with vLLM:
Install from pip and serve model
# Install vLLM from pip: pip install vllm # Start the vLLM server: vllm serve "InterSync/Mistral-7B-Instruct-v0.2-Function-Calling" # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "InterSync/Mistral-7B-Instruct-v0.2-Function-Calling", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }'Use Docker
docker model run hf.co/InterSync/Mistral-7B-Instruct-v0.2-Function-Calling
- SGLang
How to use InterSync/Mistral-7B-Instruct-v0.2-Function-Calling with SGLang:
Install from pip and serve model
# Install SGLang from pip: pip install sglang # Start the SGLang server: python3 -m sglang.launch_server \ --model-path "InterSync/Mistral-7B-Instruct-v0.2-Function-Calling" \ --host 0.0.0.0 \ --port 30000 # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:30000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "InterSync/Mistral-7B-Instruct-v0.2-Function-Calling", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }'Use Docker images
docker run --gpus all \ --shm-size 32g \ -p 30000:30000 \ -v ~/.cache/huggingface:/root/.cache/huggingface \ --env "HF_TOKEN=<secret>" \ --ipc=host \ lmsysorg/sglang:latest \ python3 -m sglang.launch_server \ --model-path "InterSync/Mistral-7B-Instruct-v0.2-Function-Calling" \ --host 0.0.0.0 \ --port 30000 # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:30000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "InterSync/Mistral-7B-Instruct-v0.2-Function-Calling", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }' - Docker Model Runner
How to use InterSync/Mistral-7B-Instruct-v0.2-Function-Calling with Docker Model Runner:
docker model run hf.co/InterSync/Mistral-7B-Instruct-v0.2-Function-Calling
How to use from
vLLMUse Docker
docker model run hf.co/InterSync/Mistral-7B-Instruct-v0.2-Function-CallingQuick Links
Fine-tuned Mistral 7B Instruct v0.2 with OpenAI Function Call Support
Finetuned version of Mistral-7B-Instruct-v0.2 to support direct function calling. This new capability aligns with the functionality seen in OpenAI's models, enabling Mistral 7B Instruct v0.2 to interact with external data sources and perform more complex tasks, such as fetching real-time information or integrating with custom databases for enriched AI-powered applications.
Features
- Direct Function Calls: Mistral 7B Instruct v0.2 now supports structured function calls, allowing for the integration of external APIs and databases directly into the conversational flow. This makes it possible to execute custom searches, retrieve data from the web or specific databases, and even summarize or explain content in depth.
Usage
Importing Libraries
from transformers import AutoModelForCausalLM, AutoTokenizer, TextStreamer
Initializing Model and Tokenizer
device = "cuda"
model = AutoModelForCausalLM.from_pretrained("InterSync/Mistral-7B-Instruct-v0.2-Function-Calling")
tokenizer = AutoTokenizer.from_pretrained("InterSync/Mistral-7B-Instruct-v0.2-Function-Calling")
Creating the Text Streamer
streamer = TextStreamer(tokenizer, skip_prompt=True, skip_special_tokens=True)
Defining Tools
tools = [
{
"type": "function",
"function": {
"name": "get_current_weather",
"description": "Get the current weather",
"parameters": {
"type": "object",
"properties": {
"location": {
"type": "string",
"description": "The city and state, e.g. San Francisco, CA",
},
"format": {
"type": "string",
"enum": ["celsius", "fahrenheit"],
"description": "The temperature unit to use. Infer this from the user's location.",
},
},
"required": ["location", "format"],
},
}
}
]
Setting up the Messages
messages = [
{
"role": "user",
"content": (
"You are Mistral with function-calling supported. You are provided with function signatures within <tools></tools> XML tags. "
"You may call one or more functions to assist with the user query. Don't make assumptions about what values to plug into functions. "
"Here are the available tools:\n"
"<tools>\n"
f"{tools}\n"
"</tools>\n\n"
"For each function call, return a JSON object with the function name and arguments within <tool_call></tool_call> XML tags as follows:\n"
"<tool_call>\n"
"{'arguments': <args-dict>, 'name': <function-name>}\n"
"</tool_call>"
)
},
{
"role": "assistant",
"content": "How can I help you today?"
},
{
"role": "user",
"content": "What is the current weather in San Francisco?"
},
]
Preparing Model Inputs
inputs = tokenizer.apply_chat_template(messages, tokenize=True, add_generation_prompt=True, return_tensors="pt")
model_inputs = inputs.to(device)
Generating the Response
model.to(device)
generate_ids = model.generate(model_inputs, streamer=streamer, do_sample=True, max_length=4096)
decoded = tokenizer.batch_decode(generate_ids)
Expected Output
<tool_call>
{"arguments": {"location": "San Francisco, CA", "format": "celsius"}, "name": "get_current_weather"}
</tool_call>
- Downloads last month
- 6
Install from pip and serve model
# Install vLLM from pip: pip install vllm# Start the vLLM server: vllm serve "InterSync/Mistral-7B-Instruct-v0.2-Function-Calling"# Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "InterSync/Mistral-7B-Instruct-v0.2-Function-Calling", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }'