Text Generation
Transformers
TensorBoard
Safetensors
gemma3_text
Generated from Trainer
sft
trl
conversational
text-generation-inference
Instructions to use talha970/function-gemma-boost with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- Transformers
How to use talha970/function-gemma-boost with Transformers:
# Use a pipeline as a high-level helper from transformers import pipeline pipe = pipeline("text-generation", model="talha970/function-gemma-boost") messages = [ {"role": "user", "content": "Who are you?"}, ] pipe(messages)# Load model directly from transformers import AutoTokenizer, AutoModelForCausalLM tokenizer = AutoTokenizer.from_pretrained("talha970/function-gemma-boost") model = AutoModelForCausalLM.from_pretrained("talha970/function-gemma-boost") 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 talha970/function-gemma-boost with vLLM:
Install from pip and serve model
# Install vLLM from pip: pip install vllm # Start the vLLM server: vllm serve "talha970/function-gemma-boost" # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/chat/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "talha970/function-gemma-boost", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }'Use Docker
docker model run hf.co/talha970/function-gemma-boost
- SGLang
How to use talha970/function-gemma-boost 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 "talha970/function-gemma-boost" \ --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": "talha970/function-gemma-boost", "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 "talha970/function-gemma-boost" \ --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": "talha970/function-gemma-boost", "messages": [ { "role": "user", "content": "What is the capital of France?" } ] }' - Docker Model Runner
How to use talha970/function-gemma-boost with Docker Model Runner:
docker model run hf.co/talha970/function-gemma-boost
| {%- macro format_parameters(properties, required) -%} | |
| {%- set standard_keys = ['description', 'type', 'properties', 'required', 'nullable'] -%} | |
| {%- set ns = namespace(found_first=false) -%} | |
| {%- for key, value in properties | dictsort -%} | |
| {%- if key not in standard_keys -%} | |
| {%- if ns.found_first %},{% endif -%} | |
| {%- set ns.found_first = true -%} | |
| {{- key }}:{description:<escape>{{ value['description'] }}<escape> | |
| {%- if value['type'] | upper == 'STRING' -%} | |
| {%- if value['enum'] -%} | |
| ,enum:{{ format_argument(value['enum']) }} | |
| {%- endif -%} | |
| {%- elif value['type'] | upper == 'OBJECT' -%} | |
| ,properties:{ | |
| {%- if value['properties'] is defined and value['properties'] is mapping -%} | |
| {{- format_parameters(value['properties'], value['required'] | default([])) -}} | |
| {%- elif value is mapping -%} | |
| {{- format_parameters(value, value['required'] | default([])) -}} | |
| {%- endif -%} | |
| } | |
| {%- if value['required'] -%} | |
| ,required:[ | |
| {%- for item in value['required'] | default([]) -%} | |
| <escape>{{- item -}}<escape> | |
| {%- if not loop.last %},{% endif -%} | |
| {%- endfor -%} | |
| ] | |
| {%- endif -%} | |
| {%- elif value['type'] | upper == 'ARRAY' -%} | |
| {%- if value['items'] is mapping and value['items'] -%} | |
| ,items:{ | |
| {%- set ns_items = namespace(found_first=false) -%} | |
| {%- for item_key, item_value in value['items'] | dictsort -%} | |
| {%- if item_value is not none -%} | |
| {%- if ns_items.found_first %},{% endif -%} | |
| {%- set ns_items.found_first = true -%} | |
| {%- if item_key == 'properties' -%} | |
| properties:{ | |
| {%- if item_value is mapping -%} | |
| {{- format_parameters(item_value, value['items']['required'] | default([])) -}} | |
| {%- endif -%} | |
| } | |
| {%- elif item_key == 'required' -%} | |
| required:[ | |
| {%- for req_item in item_value -%} | |
| <escape>{{- req_item -}}<escape> | |
| {%- if not loop.last %},{% endif -%} | |
| {%- endfor -%} | |
| ] | |
| {%- elif item_key == 'type' -%} | |
| {%- if item_value is string -%} | |
| type:{{ format_argument(item_value | upper) }} | |
| {%- else -%} | |
| type:{{ format_argument(item_value | map('upper') | list) }} | |
| {%- endif -%} | |
| {%- else -%} | |
| {{ item_key }}:{{ format_argument(item_value) }} | |
| {%- endif -%} | |
| {%- endif -%} | |
| {%- endfor -%} | |
| } | |
| {%- endif -%} | |
| {%- endif -%} | |
| ,type:<escape>{{ value['type'] | upper }}<escape>} | |
| {%- endif -%} | |
| {%- endfor -%} | |
| {%- endmacro -%} | |
| {% macro format_function_declaration(tool_data) -%} | |
| declaration:{{- tool_data['function']['name'] -}} | |
| {description:<escape>{{- tool_data['function']['description'] -}}<escape> | |
| {%- set params = tool_data['function']['parameters'] -%} | |
| {%- if params -%} | |
| ,parameters:{ | |
| {%- if params['properties'] -%} | |
| properties:{ {{- format_parameters(params['properties'], params['required']) -}} }, | |
| {%- endif -%} | |
| {%- if params['required'] -%} | |
| required:[ | |
| {%- for item in params['required'] -%} | |
| <escape>{{- item -}}<escape> | |
| {{- ',' if not loop.last -}} | |
| {%- endfor -%} | |
| ], | |
| {%- endif -%} | |
| {%- if params['type'] -%} | |
| type:<escape>{{- params['type'] | upper -}}<escape>} | |
| {%- endif -%} | |
| {%- endif -%} | |
| } | |
| {%- endmacro -%} | |
| {% macro format_argument(argument, escape_keys=True) -%} | |
| {%- if argument is string -%} | |
| {{- '<escape>' + argument + '<escape>' -}} | |
| {%- elif argument is boolean -%} | |
| {%- if argument -%} | |
| {{- 'true' -}} | |
| {%- else -%} | |
| {{- 'false' -}} | |
| {%- endif -%} | |
| {%- elif argument is mapping -%} | |
| {{- '{' -}} | |
| {%- set ns = namespace(found_first=false) -%} | |
| {%- for key, value in argument | dictsort -%} | |
| {%- if ns.found_first %},{% endif -%} | |
| {%- set ns.found_first = true -%} | |
| {%- if escape_keys -%} | |
| {{- '<escape>' + key + '<escape>' -}} | |
| {%- else -%} | |
| {{- key -}} | |
| {%- endif -%} | |
| :{{- format_argument(value, escape_keys=escape_keys) -}} | |
| {%- endfor -%} | |
| {{- '}' -}} | |
| {%- elif argument is sequence -%} | |
| {{- '[' -}} | |
| {%- for item in argument -%} | |
| {{- format_argument(item, escape_keys=escape_keys) -}} | |
| {%- if not loop.last %},{% endif -%} | |
| {%- endfor -%} | |
| {{- ']' -}} | |
| {%- else -%} | |
| {{- argument -}} | |
| {%- endif -%} | |
| {%- endmacro -%} | |
| {{ bos_token }} | |
| {%- set ns = namespace(prev_message_type=None) -%} | |
| {#- Tool Declarations -#} | |
| {%- set loop_messages = messages -%} | |
| {%- if tools or messages[0]['role'] == 'system' or messages[0]['role'] == 'developer' -%} | |
| {{- '<start_of_turn>developer\n' -}} | |
| {%- if messages[0]['role'] == 'system' or messages[0]['role'] == 'developer' -%} | |
| {%- if messages[0]['content'] is string -%} | |
| {{- messages[0]['content'] | trim -}} | |
| {%- elif messages[0]['content'] is sequence -%} | |
| {%- for item in messages[0]['content'] -%} | |
| {%- if item['type'] == 'text' -%} | |
| {{- item['text'] | trim -}} | |
| {%- endif -%} | |
| {%- endfor -%} | |
| {%- endif -%} | |
| {%- set loop_messages = messages[1:] -%} | |
| {%- endif -%} | |
| {%- if tools -%} | |
| {%- for tool in tools %} | |
| {{- '<start_function_declaration>' -}} | |
| {{- format_function_declaration(tool) | trim }} | |
| {{- '<end_function_declaration>' -}} | |
| {%- endfor %} | |
| {%- endif -%} | |
| {{- '<end_of_turn>\n' }} | |
| {%- endif %} | |
| {#- Loop through messages. -#} | |
| {%- for message in loop_messages -%} | |
| {%- if (message['role'] == 'assistant') -%} | |
| {#- Rename "assistant" to "model". -#} | |
| {%- set role = "model" -%} | |
| {%- else -%} | |
| {%- set role = message['role'] -%} | |
| {%- endif -%} | |
| {%- if role != 'tool' -%} | |
| {%- if ns.prev_message_type != 'tool_response' -%} | |
| {{- '<start_of_turn>' + role + '\n' }} | |
| {%- endif -%} | |
| {%- set ns.prev_message_type = None -%} | |
| {%- if 'content' in message and message['content'] is not none -%} | |
| {%- if message['content'] is string -%} | |
| {{ message['content'] | trim }} | |
| {%- elif message['content'] is sequence -%} | |
| {%- for item in message['content'] -%} | |
| {%- if item['type'] == 'image' -%} | |
| {{ '<start_of_image>' }} | |
| {%- elif item['type'] == 'text' -%} | |
| {{ item['text'] | trim }} | |
| {%- endif -%} | |
| {%- endfor -%} | |
| {%- else -%} | |
| {{ raise_exception("Invalid content type in user/assistant message") }} | |
| {%- endif -%} | |
| {%- set ns.prev_message_type = 'content' -%} | |
| {%- endif -%} | |
| {%- if 'tool_calls' in message and message['tool_calls'] and message['tool_calls'] is iterable -%} | |
| {#- Tool Calls -#} | |
| {%- for tool_call in message['tool_calls'] -%} | |
| {% set function = tool_call['function'] %} | |
| {{- '<start_function_call>call:' + function['name'] + '{' -}} | |
| {%- if 'arguments' in function -%} | |
| {%- if function['arguments'] is mapping -%} | |
| {%- set ns = namespace(found_first=false) -%} | |
| {%- for key, value in function['arguments'] | dictsort -%} | |
| {%- if ns.found_first %},{% endif -%} | |
| {%- set ns.found_first = true -%} | |
| {{- key -}}:{{- format_argument(value, escape_keys=False) -}} | |
| {%- endfor -%} | |
| {%- elif function['arguments'] is string -%} | |
| {# This handles string-JSON, just in case #} | |
| {{ function['arguments'] }} | |
| {%- endif %} | |
| {%- endif -%} | |
| {{- '}<end_function_call>' -}} | |
| {%- endfor -%} | |
| {%- if loop.last -%} | |
| {{ '<start_function_response>' }} | |
| {%- endif -%} | |
| {%- set ns.prev_message_type = 'tool_call' -%} | |
| {%- endif -%} | |
| {%- else -%} | |
| {#- Tool Responses -#} | |
| {%- if 'content' in message and message['content'] -%} | |
| {%- if message['content'] is mapping -%} | |
| {%- if 'name' in message['content'] and 'response' in message['content'] -%} | |
| {{ '<start_function_response>response:' + message['content']['name'] | trim + '{' }} | |
| {%- set response_ns = namespace(found_first=false) -%} | |
| {%- for key, value in message['content']['response'] | dictsort -%} | |
| {%- if response_ns.found_first %},{% endif -%} | |
| {%- set response_ns.found_first = true -%} | |
| {{- key -}}:{{- format_argument(value, escape_keys=False) -}} | |
| {%- endfor -%} | |
| {{- '}<end_function_response>' -}} | |
| {%- elif 'name' in message -%} | |
| {{ '<start_function_response>response:' + message['name'] | trim + '{' }} | |
| {%- set response_ns = namespace(found_first=false) -%} | |
| {%- for key, value in message['content'] | dictsort -%} | |
| {%- if response_ns.found_first %},{% endif -%} | |
| {%- set response_ns.found_first = true -%} | |
| {{- key -}}:{{- format_argument(value, escape_keys=False) -}} | |
| {%- endfor -%} | |
| {{- '}<end_function_response>' -}} | |
| {%- else -%} | |
| {{ raise_exception("Invalid tool response mapping: must contain 'name' and 'response' keys, or 'name' must be in the message.") }} | |
| {%- endif -%} | |
| {%- elif message['content'] is string -%} | |
| {%- if 'name' in message -%} | |
| {{ '<start_function_response>response:' + message['name'] | trim + '{value:' + format_argument(message['content'], escape_keys=False) + '}<end_function_response>' }} | |
| {%- else -%} | |
| {{ raise_exception("Invalid tool response: 'name' must be provided.") }} | |
| {%- endif -%} | |
| {%- elif message['content'] is sequence -%} | |
| {%- for item in message['content'] -%} | |
| {%- if item is mapping -%} | |
| {%- if 'name' in item and 'response' in item -%} | |
| {{ '<start_function_response>response:' + item['name'] | trim + '{' }} | |
| {%- set response_ns = namespace(found_first=false) -%} | |
| {%- for key, value in item['response'] | dictsort -%} | |
| {%- if response_ns.found_first %},{% endif -%} | |
| {%- set response_ns.found_first = true -%} | |
| {{- key -}}:{{- format_argument(value, escape_keys=False) -}} | |
| {%- endfor -%} | |
| {{- '}<end_function_response>' -}} | |
| {%- elif 'name' in message -%} | |
| {{ '<start_function_response>response:' + message['name'] | trim + '{' }} | |
| {%- set response_ns = namespace(found_first=false) -%} | |
| {%- for key, value in item | dictsort -%} | |
| {%- if response_ns.found_first %},{% endif -%} | |
| {%- set response_ns.found_first = true -%} | |
| {{- key -}}:{{- format_argument(value, escape_keys=False) -}} | |
| {%- endfor -%} | |
| {{- '}<end_function_response>' -}} | |
| {%- else -%} | |
| {{ raise_exception("Invalid tool response mapping: must contain 'name' and 'response' keys, or 'name' must be in the message.") }} | |
| {%- endif -%} | |
| {%- else -%} | |
| {{ raise_exception("Invalid tool response message: multiple responses must all be mappings") }} | |
| {%- endif -%} | |
| {%- endfor -%} | |
| {%- else -%} | |
| {{ raise_exception("Invalid content type in tool message: must be mapping, sequence of mappings, or string.") }} | |
| {%- endif -%} | |
| {%- endif -%} | |
| {%- set ns.prev_message_type = 'tool_response' -%} | |
| {%- endif -%} | |
| {%- if ns.prev_message_type not in ['tool_call', 'tool_response'] -%} | |
| {{ '<end_of_turn>\n' }} | |
| {%- endif -%} | |
| {%- endfor -%} | |
| {%- if add_generation_prompt -%} | |
| {%- if ns.prev_message_type != 'tool_response' -%} | |
| {{- '<start_of_turn>model\n' -}} | |
| {%- endif -%} | |
| {%- endif -%} | |