From af06338d86c6bffddcfbbd0c7347de957909cf98 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 12 Mar 2025 15:12:52 -0300 Subject: [PATCH 01/55] WIP: first bits of Ollama provider, adapted from Gemini --- lib/ruby_llm.rb | 4 +- lib/ruby_llm/configuration.rb | 1 + lib/ruby_llm/providers/ollama.rb | 36 +++++ lib/ruby_llm/providers/ollama/capabilities.rb | 138 ++++++++++++++++++ lib/ruby_llm/providers/ollama/models.rb | 52 +++++++ 5 files changed, 230 insertions(+), 1 deletion(-) create mode 100644 lib/ruby_llm/providers/ollama.rb create mode 100644 lib/ruby_llm/providers/ollama/capabilities.rb create mode 100644 lib/ruby_llm/providers/ollama/models.rb diff --git a/lib/ruby_llm.rb b/lib/ruby_llm.rb index 37dc3b18..80ab4c3c 100644 --- a/lib/ruby_llm.rb +++ b/lib/ruby_llm.rb @@ -15,7 +15,8 @@ 'llm' => 'LLM', 'openai' => 'OpenAI', 'api' => 'API', - 'deepseek' => 'DeepSeek' + 'deepseek' => 'DeepSeek', + 'ollama' => 'Ollama', ) loader.ignore("#{__dir__}/ruby_llm/railtie") loader.ignore("#{__dir__}/ruby_llm/active_record") @@ -70,6 +71,7 @@ def logger RubyLLM::Provider.register :anthropic, RubyLLM::Providers::Anthropic RubyLLM::Provider.register :gemini, RubyLLM::Providers::Gemini RubyLLM::Provider.register :deepseek, RubyLLM::Providers::DeepSeek +RubyLLM::Provider.register :ollama, RubyLLM::Providers::Ollama if defined?(Rails::Railtie) require 'ruby_llm/railtie' diff --git a/lib/ruby_llm/configuration.rb b/lib/ruby_llm/configuration.rb index 72a878aa..22718a79 100644 --- a/lib/ruby_llm/configuration.rb +++ b/lib/ruby_llm/configuration.rb @@ -14,6 +14,7 @@ class Configuration :anthropic_api_key, :gemini_api_key, :deepseek_api_key, + :ollama_api_base_url, :default_model, :default_embedding_model, :default_image_model, diff --git a/lib/ruby_llm/providers/ollama.rb b/lib/ruby_llm/providers/ollama.rb new file mode 100644 index 00000000..35d1a665 --- /dev/null +++ b/lib/ruby_llm/providers/ollama.rb @@ -0,0 +1,36 @@ +# frozen_string_literal: true + +module RubyLLM + module Providers + # Native Ollama API implementation + module Ollama + extend Provider + # extend Ollama::Chat + # extend Ollama::Embeddings + extend Ollama::Models + # extend Ollama::Streaming + + module_function + + def enabled? + !! RubyLLM.config.ollama_api_base_url + end + + def api_base + RubyLLM.config.ollama_api_base_url + end + + def headers + { } + end + + def capabilities + Ollama::Capabilities + end + + def slug + 'ollama' + end + end + end +end diff --git a/lib/ruby_llm/providers/ollama/capabilities.rb b/lib/ruby_llm/providers/ollama/capabilities.rb new file mode 100644 index 00000000..4d5b9d46 --- /dev/null +++ b/lib/ruby_llm/providers/ollama/capabilities.rb @@ -0,0 +1,138 @@ +# frozen_string_literal: true + +module RubyLLM + module Providers + module Ollama + # Determines capabilities for Ollama + module Capabilities # rubocop:disable Metrics/ModuleLength + module_function + + # Returns the context window size (input token limit) for the given model + # @param model_id [String] the model identifier + # @return [Integer] the context window size in tokens + def context_window_for(model_id) + # FIXME: revise + 4_192 # Sensible (and conservative) default for unknown models + end + + # Returns the maximum output tokens for the given model + # @param model_id [String] the model identifier + # @return [Integer] the maximum output tokens + def max_tokens_for(model_id) + # FIXME: revise + 32_768 + end + + # Returns the input price per million tokens for the given model + # @param model_id [String] the model identifier + # @return [Float] the price per million tokens in USD + def input_price_for(model_id) + 0.0 + end + + # Returns the output price per million tokens for the given model + # @param model_id [String] the model identifier + # @return [Float] the price per million tokens in USD + def output_price_for(model_id) + 0.0 + end + + # Determines if the model supports vision (image/video) inputs + # @param model_id [String] the model identifier + # @return [Boolean] true if the model supports vision inputs + def supports_vision?(model_id) + # FIXME: revise + false + end + + # Determines if the model supports function calling + # @param model_id [String] the model identifier + # @return [Boolean] true if the model supports function calling + def supports_functions?(model_id) + # FIXME: revise + false + end + + # Determines if the model supports JSON mode + # @param model_id [String] the model identifier + # @return [Boolean] true if the model supports JSON mode + def supports_json_mode?(model_id) + # FIXME: revise + false + end + + # Formats the model ID into a human-readable display name + # @param model_id [String] the model identifier + # @return [String] the formatted display name + def format_display_name(model_id) + model_id + .delete_prefix('models/') + .split('-') + .map(&:capitalize) + .join(' ') + .gsub(/(\d+\.\d+)/, ' \1') # Add space before version numbers + .gsub(/\s+/, ' ') # Clean up multiple spaces + .strip + end + + # Determines if the model supports context caching + # @param model_id [String] the model identifier + # @return [Boolean] true if the model supports caching + def supports_caching?(model_id) + # FIXME: revise + true + end + + # Determines if the model supports tuning + # @param model_id [String] the model identifier + # @return [Boolean] true if the model supports tuning + def supports_tuning?(model_id) + # FIXME: revise + false + end + + # Determines if the model supports audio inputs + # @param model_id [String] the model identifier + # @return [Boolean] true if the model supports audio inputs + def supports_audio?(model_id) + # FIXME: revise + false + end + + # Returns the type of model (chat, embedding, image) + # @param model_id [String] the model identifier + # @return [String] the model type + def model_type(model_id) + # FIXME: revise + 'chat' + end + + # Returns the model family identifier + # @param model_id [String] the model identifier + # @return [String] the model family identifier + def model_family(model_id) # rubocop:disable Metrics/CyclomaticComplexity,Metrics/MethodLength + 'other' + end + + # Returns the context length for the model + # @param model_id [String] the model identifier + # @return [Integer] the context length in tokens + def context_length(model_id) + context_window_for(model_id) + end + + # Default input price for unknown models + # @return [Float] the default input price per million tokens + def default_input_price + 0.0 + end + + # Default output price for unknown models + # @return [Float] the default output price per million tokens + def default_output_price + 0.0 + end + end + end + end +end diff --git a/lib/ruby_llm/providers/ollama/models.rb b/lib/ruby_llm/providers/ollama/models.rb new file mode 100644 index 00000000..3a62ffc4 --- /dev/null +++ b/lib/ruby_llm/providers/ollama/models.rb @@ -0,0 +1,52 @@ +# frozen_string_literal: true + +module RubyLLM + module Providers + module Ollama + # Models methods for the Ollama API integration + module Models + # Methods needed by Provider - must be public + def models_url + 'api/tags' + end + + def list_models + return [] unless enabled? + + response = connection.get("api/tags") do |req| + req.headers.merge! headers + end + + parse_list_models_response(response, slug, capabilities) + end + + private + + def parse_list_models_response(response, slug, capabilities) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength + (response.body['models'] || []).map do |model| + model_id = model['name'] + + ModelInfo.new( + id: model_id, + # NOTE: this is date pulled into ollama, not quite date of introduction of a model + created_at: model['modified_at'], + display_name: model_id, + provider: slug, + type: capabilities.model_type(model_id), + family: model['family'], + metadata: { + }, + context_window: capabilities.context_window_for(model_id), + max_tokens: capabilities.max_tokens_for(model_id), + supports_vision: capabilities.supports_vision?(model_id), + supports_functions: capabilities.supports_functions?(model_id), + supports_json_mode: capabilities.supports_json_mode?(model_id), + input_price_per_million: capabilities.input_price_for(model_id), + output_price_per_million: capabilities.output_price_for(model_id) + ) + end + end + end + end + end +end From 55151a02bd4a7f88ed2742ec8119577c3b0614b8 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 12 Mar 2025 16:23:24 -0300 Subject: [PATCH 02/55] Basic chat functionality --- lib/ruby_llm/providers/ollama.rb | 2 +- lib/ruby_llm/providers/ollama/chat.rb | 102 ++++++++++++++++++++++++++ 2 files changed, 103 insertions(+), 1 deletion(-) create mode 100644 lib/ruby_llm/providers/ollama/chat.rb diff --git a/lib/ruby_llm/providers/ollama.rb b/lib/ruby_llm/providers/ollama.rb index 35d1a665..228ed385 100644 --- a/lib/ruby_llm/providers/ollama.rb +++ b/lib/ruby_llm/providers/ollama.rb @@ -5,7 +5,7 @@ module Providers # Native Ollama API implementation module Ollama extend Provider - # extend Ollama::Chat + extend Ollama::Chat # extend Ollama::Embeddings extend Ollama::Models # extend Ollama::Streaming diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb new file mode 100644 index 00000000..0ae3d669 --- /dev/null +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -0,0 +1,102 @@ +# frozen_string_literal: true + +module RubyLLM + module Providers + module Ollama + # Chat methods for the Ollama API implementation + module Chat # rubocop:disable Metrics/ModuleLength + # Must be public for Provider to use + def complete(messages, tools:, temperature:, model:, &block) # rubocop:disable Metrics/MethodLength + if tools.any? + raise NotImplementedError.new("tool use not implemented in Ollama at this time") + end + + payload = { + model: model, + messages: format_messages(messages), + options: { + temperature: temperature, + }, + } + + if block_given? + raise NotImplementedError + # stream_completion(model, payload, &block) + else + payload[:stream] = false + generate_completion(model, payload) + end + end + + # Format methods can be private + private + + def generate_completion(model, payload) + url = "api/chat" + response = post(url, payload) + result = parse_completion_response(response) + + result + end + + def format_messages(messages) + messages.map do |msg| + { + role: format_role(msg.role), + content: format_parts(msg), + } + end + end + + def format_role(role) + case role + when :assistant + when :system + when :tool + role.to_s + # FIXME: probably should validate this + else role.to_s + end + end + + def format_parts(msg) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength + if msg.content.is_a?(Array) + # Handle multi-part content (text, images, etc.) + msg.content.map { |part| format_part(part) } + else + # Simple text content + msg.content.to_s + end + end + + def format_part(part) # rubocop:disable Metrics/MethodLength + case part[:type] + when 'text' + { text: part[:text] } + when 'image' + Media.format_image(part) + when 'pdf' + Media.format_pdf(part) + when 'audio' + Media.format_audio(part) + else + { text: part.to_s } + end + end + + def parse_completion_response(response) + data = response.body + message = data['message'] + + Message.new( + role: :assistant, + content: data.dig('message', 'content'), + input_tokens: data['prompt_eval_count'].to_i, + output_tokens: data['eval_count'].to_i, + model_id: data['model'], + ) + end + end + end + end +end From c7b98604eb784bf7455cd90151f938f1bf96295d Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 12 Mar 2025 18:05:56 -0300 Subject: [PATCH 03/55] Basic streaming functionality --- lib/ruby_llm/providers/ollama.rb | 2 +- lib/ruby_llm/providers/ollama/chat.rb | 4 +- lib/ruby_llm/providers/ollama/streaming.rb | 44 ++++++++++++++++++++++ 3 files changed, 47 insertions(+), 3 deletions(-) create mode 100644 lib/ruby_llm/providers/ollama/streaming.rb diff --git a/lib/ruby_llm/providers/ollama.rb b/lib/ruby_llm/providers/ollama.rb index 228ed385..033301dd 100644 --- a/lib/ruby_llm/providers/ollama.rb +++ b/lib/ruby_llm/providers/ollama.rb @@ -8,7 +8,7 @@ module Ollama extend Ollama::Chat # extend Ollama::Embeddings extend Ollama::Models - # extend Ollama::Streaming + extend Ollama::Streaming module_function diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index 0ae3d669..9702e72e 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -20,8 +20,8 @@ def complete(messages, tools:, temperature:, model:, &block) # rubocop:disable M } if block_given? - raise NotImplementedError - # stream_completion(model, payload, &block) + payload[:stream] = true + stream_completion(model, payload, &block) else payload[:stream] = false generate_completion(model, payload) diff --git a/lib/ruby_llm/providers/ollama/streaming.rb b/lib/ruby_llm/providers/ollama/streaming.rb new file mode 100644 index 00000000..3c3641d0 --- /dev/null +++ b/lib/ruby_llm/providers/ollama/streaming.rb @@ -0,0 +1,44 @@ +# frozen_string_literal: true + +module RubyLLM + module Providers + module Ollama + # Streaming methods for the Ollama API implementation + module Streaming + # Need to make stream_completion public for chat.rb to access + def stream_completion(model, payload, &block) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength + url = "api/chat" + accumulator = StreamAccumulator.new + + post(url, payload) do |req| + req.options.on_data = stream_handler(accumulator, &block) + end + + message = accumulator.to_message + + accumulator.to_message + end + + private + + # Handle streaming + def stream_handler(accumulator, &block) # rubocop:disable Metrics/AbcSize,Metrics/CyclomaticComplexity,Metrics/MethodLength,Metrics/PerceivedComplexity + to_json_stream do |data| # rubocop:disable Metrics/BlockLength + chunk = Chunk.new( + role: :assistant, + content: data.dig('message', 'content'), + model_id: data['model'], + + # NOTE: unavailable in the response - https://ollama.readthedocs.io/en/api/#streaming-responses + input_tokens: nil, + output_tokens: nil, + ) + + accumulator.add(chunk) + block.call(chunk) + end + end + end + end + end +end From f294070d0c25e3d81d566a000886d8d94c85eead Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 12 Mar 2025 18:23:31 -0300 Subject: [PATCH 04/55] Basic embedding functionality --- lib/ruby_llm/providers/ollama.rb | 2 +- lib/ruby_llm/providers/ollama/embeddings.rb | 39 +++++++++++++++++++++ 2 files changed, 40 insertions(+), 1 deletion(-) create mode 100644 lib/ruby_llm/providers/ollama/embeddings.rb diff --git a/lib/ruby_llm/providers/ollama.rb b/lib/ruby_llm/providers/ollama.rb index 033301dd..74467068 100644 --- a/lib/ruby_llm/providers/ollama.rb +++ b/lib/ruby_llm/providers/ollama.rb @@ -6,7 +6,7 @@ module Providers module Ollama extend Provider extend Ollama::Chat - # extend Ollama::Embeddings + extend Ollama::Embeddings extend Ollama::Models extend Ollama::Streaming diff --git a/lib/ruby_llm/providers/ollama/embeddings.rb b/lib/ruby_llm/providers/ollama/embeddings.rb new file mode 100644 index 00000000..1c41dc1f --- /dev/null +++ b/lib/ruby_llm/providers/ollama/embeddings.rb @@ -0,0 +1,39 @@ +# frozen_string_literal: true + +module RubyLLM + module Providers + module Ollama + # Embeddings methods for the Ollama API integration + module Embeddings + # Must be public for Provider module + def embed(text, model:) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength + payload = { + model: model, + input: format_text_for_embedding(text), + } + + url = "api/embed" + response = post(url, payload) + + Embedding.new( + vectors: response.body['embeddings'], + model: model, + # only available when passing a single string input + input_tokens: response.body['prompt_eval_count'] || 0, + ) + end + + private + + def format_text_for_embedding(text) + if text.is_a?(Array) || text.is_a?(String) + # Ollama supports either a string or a string array here + text + else + raise NotImplementedException.new("unsupported argument for Ollama embedding: #{text.class}") + end + end + end + end + end +end From 8b9899f6ac86d592be16c9c93496a8b70514bf09 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 12 Mar 2025 19:17:15 -0300 Subject: [PATCH 05/55] Mention Ollama in getting-started.md --- docs/guides/getting-started.md | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/docs/guides/getting-started.md b/docs/guides/getting-started.md index ff6cb1c0..960a414d 100644 --- a/docs/guides/getting-started.md +++ b/docs/guides/getting-started.md @@ -33,6 +33,16 @@ RubyLLM.configure do |config| end ``` +Alternatively, you can point to an Ollama instance; here it is configured to the most common address when Ollama is installed locally: +``` +RubyLLM.configure do |config| + config.ollama_api_base_url = 'http://localhost:11434' +end + +# Needs to be called to populate Ollama models before using any +RubyLLM.models.refresh! +``` + ## Your First Chat Let's start with a simple chat interaction: @@ -64,6 +74,10 @@ claude_chat.ask "Tell me about Ruby programming language" # Use Gemini gemini_chat = RubyLLM.chat(model: 'gemini-2.0-flash') gemini_chat.ask "What are the best Ruby gems for machine learning?" + +# Use an Ollama model (pull it into the server first; consult Ollama docs): +ollama_chat = RubyLLM.chat(model: 'gemma3:latest') +ollama_chat.ask "What is Alphabet?" ``` ## Exploring Available Models @@ -161,4 +175,4 @@ Now that you've got the basics down, you're ready to explore more advanced featu - [Chatting with AI]({% link guides/chat.md %}) - Learn more about chat capabilities - [Using Tools]({% link guides/tools.md %}) - Let AI use your Ruby code -- [Rails Integration]({% link guides/rails.md %}) - Persist chats in your Rails apps \ No newline at end of file +- [Rails Integration]({% link guides/rails.md %}) - Persist chats in your Rails apps From a0617fe38b5ee4698c3930c5d5c0472dcdc7ae04 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 12 Mar 2025 20:10:55 -0300 Subject: [PATCH 06/55] Rubocop autocorrects --- lib/ruby_llm.rb | 2 +- lib/ruby_llm/providers/ollama.rb | 4 ++-- lib/ruby_llm/providers/ollama/chat.rb | 21 ++++++++------------- lib/ruby_llm/providers/ollama/embeddings.rb | 13 ++++++------- lib/ruby_llm/providers/ollama/models.rb | 5 ++--- lib/ruby_llm/providers/ollama/streaming.rb | 6 ++---- 6 files changed, 21 insertions(+), 30 deletions(-) diff --git a/lib/ruby_llm.rb b/lib/ruby_llm.rb index 80ab4c3c..94861ce4 100644 --- a/lib/ruby_llm.rb +++ b/lib/ruby_llm.rb @@ -16,7 +16,7 @@ 'openai' => 'OpenAI', 'api' => 'API', 'deepseek' => 'DeepSeek', - 'ollama' => 'Ollama', + 'ollama' => 'Ollama' ) loader.ignore("#{__dir__}/ruby_llm/railtie") loader.ignore("#{__dir__}/ruby_llm/active_record") diff --git a/lib/ruby_llm/providers/ollama.rb b/lib/ruby_llm/providers/ollama.rb index 74467068..254ca821 100644 --- a/lib/ruby_llm/providers/ollama.rb +++ b/lib/ruby_llm/providers/ollama.rb @@ -13,7 +13,7 @@ module Ollama module_function def enabled? - !! RubyLLM.config.ollama_api_base_url + !!RubyLLM.config.ollama_api_base_url end def api_base @@ -21,7 +21,7 @@ def api_base end def headers - { } + {} end def capabilities diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index 9702e72e..1a9aa8f6 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -7,16 +7,14 @@ module Ollama module Chat # rubocop:disable Metrics/ModuleLength # Must be public for Provider to use def complete(messages, tools:, temperature:, model:, &block) # rubocop:disable Metrics/MethodLength - if tools.any? - raise NotImplementedError.new("tool use not implemented in Ollama at this time") - end + raise NotImplementedError.new('tool use not implemented in Ollama at this time') if tools.any? payload = { model: model, messages: format_messages(messages), options: { - temperature: temperature, - }, + temperature: temperature + } } if block_given? @@ -31,19 +29,17 @@ def complete(messages, tools:, temperature:, model:, &block) # rubocop:disable M # Format methods can be private private - def generate_completion(model, payload) - url = "api/chat" + def generate_completion(_model, payload) + url = 'api/chat' response = post(url, payload) - result = parse_completion_response(response) - - result + parse_completion_response(response) end def format_messages(messages) messages.map do |msg| { role: format_role(msg.role), - content: format_parts(msg), + content: format_parts(msg) } end end @@ -86,14 +82,13 @@ def format_part(part) # rubocop:disable Metrics/MethodLength def parse_completion_response(response) data = response.body - message = data['message'] Message.new( role: :assistant, content: data.dig('message', 'content'), input_tokens: data['prompt_eval_count'].to_i, output_tokens: data['eval_count'].to_i, - model_id: data['model'], + model_id: data['model'] ) end end diff --git a/lib/ruby_llm/providers/ollama/embeddings.rb b/lib/ruby_llm/providers/ollama/embeddings.rb index 1c41dc1f..ecac1876 100644 --- a/lib/ruby_llm/providers/ollama/embeddings.rb +++ b/lib/ruby_llm/providers/ollama/embeddings.rb @@ -9,29 +9,28 @@ module Embeddings def embed(text, model:) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength payload = { model: model, - input: format_text_for_embedding(text), + input: format_text_for_embedding(text) } - url = "api/embed" + url = 'api/embed' response = post(url, payload) Embedding.new( vectors: response.body['embeddings'], model: model, # only available when passing a single string input - input_tokens: response.body['prompt_eval_count'] || 0, + input_tokens: response.body['prompt_eval_count'] || 0 ) end private def format_text_for_embedding(text) - if text.is_a?(Array) || text.is_a?(String) - # Ollama supports either a string or a string array here - text - else + # Ollama supports either a string or a string array here + unless text.is_a?(Array) || text.is_a?(String) raise NotImplementedException.new("unsupported argument for Ollama embedding: #{text.class}") end + text end end end diff --git a/lib/ruby_llm/providers/ollama/models.rb b/lib/ruby_llm/providers/ollama/models.rb index 3a62ffc4..28c4f32d 100644 --- a/lib/ruby_llm/providers/ollama/models.rb +++ b/lib/ruby_llm/providers/ollama/models.rb @@ -13,7 +13,7 @@ def models_url def list_models return [] unless enabled? - response = connection.get("api/tags") do |req| + response = connection.get('api/tags') do |req| req.headers.merge! headers end @@ -34,8 +34,7 @@ def parse_list_models_response(response, slug, capabilities) # rubocop:disable M provider: slug, type: capabilities.model_type(model_id), family: model['family'], - metadata: { - }, + metadata: {}, context_window: capabilities.context_window_for(model_id), max_tokens: capabilities.max_tokens_for(model_id), supports_vision: capabilities.supports_vision?(model_id), diff --git a/lib/ruby_llm/providers/ollama/streaming.rb b/lib/ruby_llm/providers/ollama/streaming.rb index 3c3641d0..a6fd1218 100644 --- a/lib/ruby_llm/providers/ollama/streaming.rb +++ b/lib/ruby_llm/providers/ollama/streaming.rb @@ -7,15 +7,13 @@ module Ollama module Streaming # Need to make stream_completion public for chat.rb to access def stream_completion(model, payload, &block) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength - url = "api/chat" + url = 'api/chat' accumulator = StreamAccumulator.new post(url, payload) do |req| req.options.on_data = stream_handler(accumulator, &block) end - message = accumulator.to_message - accumulator.to_message end @@ -31,7 +29,7 @@ def stream_handler(accumulator, &block) # rubocop:disable Metrics/AbcSize,Metric # NOTE: unavailable in the response - https://ollama.readthedocs.io/en/api/#streaming-responses input_tokens: nil, - output_tokens: nil, + output_tokens: nil ) accumulator.add(chunk) From b65132e45771b263108c2039ffb3f1d659da2fb8 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 12 Mar 2025 20:19:47 -0300 Subject: [PATCH 07/55] More rubocop appeasement --- lib/ruby_llm/providers/ollama/chat.rb | 10 ++-------- lib/ruby_llm/providers/ollama/embeddings.rb | 3 ++- 2 files changed, 4 insertions(+), 9 deletions(-) diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index 1a9aa8f6..b9a0209f 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -7,7 +7,7 @@ module Ollama module Chat # rubocop:disable Metrics/ModuleLength # Must be public for Provider to use def complete(messages, tools:, temperature:, model:, &block) # rubocop:disable Metrics/MethodLength - raise NotImplementedError.new('tool use not implemented in Ollama at this time') if tools.any? + raise NotImplementedError, 'tool use not implemented in Ollama at this time' if tools.any? payload = { model: model, @@ -45,14 +45,8 @@ def format_messages(messages) end def format_role(role) - case role - when :assistant - when :system - when :tool - role.to_s # FIXME: probably should validate this - else role.to_s - end + role.to_s end def format_parts(msg) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength diff --git a/lib/ruby_llm/providers/ollama/embeddings.rb b/lib/ruby_llm/providers/ollama/embeddings.rb index ecac1876..a6aa736f 100644 --- a/lib/ruby_llm/providers/ollama/embeddings.rb +++ b/lib/ruby_llm/providers/ollama/embeddings.rb @@ -28,8 +28,9 @@ def embed(text, model:) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength def format_text_for_embedding(text) # Ollama supports either a string or a string array here unless text.is_a?(Array) || text.is_a?(String) - raise NotImplementedException.new("unsupported argument for Ollama embedding: #{text.class}") + raise NotImplementedException, "unsupported argument for Ollama embedding: #{text.class}" end + text end end From 88cffc382ab847e2d274a8d2cf527440f75c0b26 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Mon, 24 Mar 2025 19:46:47 -0300 Subject: [PATCH 08/55] WIP: start adding Ollama provider tests --- lib/ruby_llm/providers/ollama.rb | 4 + lib/ruby_llm/providers/ollama/models.rb | 7 ++ lib/tasks/ollama.rake | 32 +++++++ spec/ruby_llm/providers/ollama/ollama_spec.rb | 92 +++++++++++++++++++ spec/spec_helper.rb | 3 + 5 files changed, 138 insertions(+) create mode 100644 lib/tasks/ollama.rake create mode 100644 spec/ruby_llm/providers/ollama/ollama_spec.rb diff --git a/lib/ruby_llm/providers/ollama.rb b/lib/ruby_llm/providers/ollama.rb index 254ca821..3cef062c 100644 --- a/lib/ruby_llm/providers/ollama.rb +++ b/lib/ruby_llm/providers/ollama.rb @@ -31,6 +31,10 @@ def capabilities def slug 'ollama' end + + def configuration_requirements + %i[ollama_api_base_url] + end end end end diff --git a/lib/ruby_llm/providers/ollama/models.rb b/lib/ruby_llm/providers/ollama/models.rb index 28c4f32d..5e394cb7 100644 --- a/lib/ruby_llm/providers/ollama/models.rb +++ b/lib/ruby_llm/providers/ollama/models.rb @@ -10,6 +10,13 @@ def models_url 'api/tags' end + # FIXME: include aliases for tags with the format \d+m or \d+b + # ie. given these models in the server, + # - gemma3:27b + # - gemma3:9b + # + # create an alias gemma3 for gemma3:27b + def list_models return [] unless enabled? diff --git a/lib/tasks/ollama.rake b/lib/tasks/ollama.rake new file mode 100644 index 00000000..b80f9fad --- /dev/null +++ b/lib/tasks/ollama.rake @@ -0,0 +1,32 @@ +# frozen_string_literal: true + +require 'ruby_llm' + +def pull_model(ollama_library_model_spec, description) + warn "+ pulling #{ollama_library_model_spec} from Ollama library (#{description})" + payload = { + model: ollama_library_model_spec, + insecure: false, + stream: false + } + + # ugly but effective + # FIXME: possibly needs timeout adjustment since it downloads models + response = RubyLLM::Providers::Ollama.send :post, '/api/pull', payload + + unless response.body['status'] == 'success' + raise 'non-successful response when pulling model; check Ollama server logs' + end + + warn '+ done' +end + +namespace :ollama do + desc 'Install some tiny models required for running Ollama specs (downloads about 150 MB into your Ollama server)' + task :install_models_for_specs do + RubyLLM.config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL') + + pull_model('smollm:135m', '92MiB chat model') + pull_model('snowflake-arctic-embed:22m', '46MiB embedding model') + end +end diff --git a/spec/ruby_llm/providers/ollama/ollama_spec.rb b/spec/ruby_llm/providers/ollama/ollama_spec.rb new file mode 100644 index 00000000..0fb4ccd1 --- /dev/null +++ b/spec/ruby_llm/providers/ollama/ollama_spec.rb @@ -0,0 +1,92 @@ +# frozen_string_literal: true + +require 'spec_helper' +require 'dotenv/load' + +RSpec.shared_context 'with configured local Ollama server' do + before :all do + RubyLLM.configure do |config| + config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL', 'http://localhost:11434') + + # FIXME: need a sane internal API to do this, like RubyLLM.disable_all_providers() + # FIXME: this will break other tests depending on run order + config.openai_api_key = nil + config.anthropic_api_key = nil + config.gemini_api_key = nil + config.deepseek_api_key = nil + end + end +end + +RSpec.describe RubyLLM::Providers::Ollama do # rubocop:disable RSpec/SpecFilePathFormat + include_context 'with configured local Ollama server' + + describe '.models' do + it 'fetches models from the server at runtime' do # rubocop:disable RSpec/MultipleExpectations + RubyLLM.models.refresh! + + # NOTE: to ensure relevant models are pulled into your local server, do + # bundle exec rake ollama:install_models_for_specs + + expect(RubyLLM.models).to include( + an_object_having_attributes(provider: 'ollama', id: 'smollm:135m') + ) + expect(RubyLLM.models).to include( + an_object_having_attributes(provider: 'ollama', id: 'snowflake-arctic-embed:22m') + ) + end + end + + describe '.chat' do + let(:chat) { RubyLLM.chat(model: 'smollm:135m', provider: 'ollama') } + + it 'works' do + response = chat.ask('Count from 1 to 3') + expect(response.content).to be_present + end + end + + describe 'streaming' do + let(:chat) { RubyLLM.chat(model: 'smollm:135m', provider: 'ollama') } + + it 'works' do + chunks = [] + + chat.ask('Count from 1 to 3') do |chunk| + chunks << chunk + end + + expect(chunks).not_to be_empty + expect(chunks.first).to be_a(RubyLLM::Chunk) + end + end + + describe 'embeddings' do + let(:test_text) { "Ruby is a programmer's best friend" } + let(:test_texts) { %w[Ruby Python JavaScript] } + let(:model) { 'snowflake-arctic-embed:22m' } + + it 'can handle a single text' do # rubocop:disable RSpec/MultipleExpectations + # FIXME: need a provider: param just like in chat() + # embedding = RubyLLM.embed(test_text, model: model, provider: 'ollama') + + embedding = RubyLLM.embed(test_text, model: model) + expect(embedding.vectors).to be_an(Array) + expect(embedding.vectors.first).to be_a(Float) + expect(embedding.model).to eq(model) + expect(embedding.input_tokens).to be >= 0 + end + + it 'can handle multiple texts' do # rubocop:disable RSpec/ExampleLength,RSpec/MultipleExpectations + # FIXME: need a provider: param just like in chat() + # embeddings = RubyLLM.embed(test_texts, model: model, provider: 'ollama') + + embeddings = RubyLLM.embed(test_texts, model: model) + expect(embeddings.vectors).to be_an(Array) + expect(embeddings.vectors.size).to eq(3) + expect(embeddings.vectors.first).to be_an(Array) + expect(embeddings.model).to eq(model) + expect(embeddings.input_tokens).to be >= 0 + end + end +end diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index 26aea5df..2e05f5ce 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -46,6 +46,9 @@ config.filter_sensitive_data('') { ENV.fetch('GEMINI_API_KEY', nil) } config.filter_sensitive_data('') { ENV.fetch('DEEPSEEK_API_KEY', nil) } + # Pretend this is the same for everyone + config.filter_sensitive_data('http://localhost:11434') { ENV.fetch('OLLAMA_API_BASE_URL', nil) } + # Filter sensitive response headers config.filter_sensitive_data('') do |interaction| interaction.response.headers['Openai-Organization']&.first From 836e96140ed71ec2b33f458ce8b8c3df722c51db Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Mon, 24 Mar 2025 20:07:32 -0300 Subject: [PATCH 09/55] Fix embeddings return value --- lib/ruby_llm/providers/ollama/embeddings.rb | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/lib/ruby_llm/providers/ollama/embeddings.rb b/lib/ruby_llm/providers/ollama/embeddings.rb index a6aa736f..3a20b6af 100644 --- a/lib/ruby_llm/providers/ollama/embeddings.rb +++ b/lib/ruby_llm/providers/ollama/embeddings.rb @@ -14,9 +14,10 @@ def embed(text, model:) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength url = 'api/embed' response = post(url, payload) + vectors = response.body['embeddings'] Embedding.new( - vectors: response.body['embeddings'], + vectors: text.is_a?(String) ? vectors.first : vectors, model: model, # only available when passing a single string input input_tokens: response.body['prompt_eval_count'] || 0 From 4d8151d969fb50b763520167fce7368d454ac919 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Mon, 24 Mar 2025 22:45:25 -0300 Subject: [PATCH 10/55] Rubocop appeasement --- lib/ruby_llm/providers/ollama/capabilities.rb | 26 +++++++++---------- lib/ruby_llm/providers/ollama/chat.rb | 4 +-- lib/ruby_llm/providers/ollama/embeddings.rb | 2 +- lib/ruby_llm/providers/ollama/models.rb | 2 +- lib/ruby_llm/providers/ollama/streaming.rb | 6 ++--- spec/ruby_llm/providers/ollama/ollama_spec.rb | 8 +++--- 6 files changed, 24 insertions(+), 24 deletions(-) diff --git a/lib/ruby_llm/providers/ollama/capabilities.rb b/lib/ruby_llm/providers/ollama/capabilities.rb index 4d5b9d46..be144b47 100644 --- a/lib/ruby_llm/providers/ollama/capabilities.rb +++ b/lib/ruby_llm/providers/ollama/capabilities.rb @@ -4,13 +4,13 @@ module RubyLLM module Providers module Ollama # Determines capabilities for Ollama - module Capabilities # rubocop:disable Metrics/ModuleLength + module Capabilities module_function # Returns the context window size (input token limit) for the given model # @param model_id [String] the model identifier # @return [Integer] the context window size in tokens - def context_window_for(model_id) + def context_window_for(_model_id) # FIXME: revise 4_192 # Sensible (and conservative) default for unknown models end @@ -18,7 +18,7 @@ def context_window_for(model_id) # Returns the maximum output tokens for the given model # @param model_id [String] the model identifier # @return [Integer] the maximum output tokens - def max_tokens_for(model_id) + def max_tokens_for(_model_id) # FIXME: revise 32_768 end @@ -26,21 +26,21 @@ def max_tokens_for(model_id) # Returns the input price per million tokens for the given model # @param model_id [String] the model identifier # @return [Float] the price per million tokens in USD - def input_price_for(model_id) + def input_price_for(_model_id) 0.0 end # Returns the output price per million tokens for the given model # @param model_id [String] the model identifier # @return [Float] the price per million tokens in USD - def output_price_for(model_id) + def output_price_for(_model_id) 0.0 end # Determines if the model supports vision (image/video) inputs # @param model_id [String] the model identifier # @return [Boolean] true if the model supports vision inputs - def supports_vision?(model_id) + def supports_vision?(_model_id) # FIXME: revise false end @@ -48,7 +48,7 @@ def supports_vision?(model_id) # Determines if the model supports function calling # @param model_id [String] the model identifier # @return [Boolean] true if the model supports function calling - def supports_functions?(model_id) + def supports_functions?(_model_id) # FIXME: revise false end @@ -56,7 +56,7 @@ def supports_functions?(model_id) # Determines if the model supports JSON mode # @param model_id [String] the model identifier # @return [Boolean] true if the model supports JSON mode - def supports_json_mode?(model_id) + def supports_json_mode?(_model_id) # FIXME: revise false end @@ -78,7 +78,7 @@ def format_display_name(model_id) # Determines if the model supports context caching # @param model_id [String] the model identifier # @return [Boolean] true if the model supports caching - def supports_caching?(model_id) + def supports_caching?(_model_id) # FIXME: revise true end @@ -86,7 +86,7 @@ def supports_caching?(model_id) # Determines if the model supports tuning # @param model_id [String] the model identifier # @return [Boolean] true if the model supports tuning - def supports_tuning?(model_id) + def supports_tuning?(_model_id) # FIXME: revise false end @@ -94,7 +94,7 @@ def supports_tuning?(model_id) # Determines if the model supports audio inputs # @param model_id [String] the model identifier # @return [Boolean] true if the model supports audio inputs - def supports_audio?(model_id) + def supports_audio?(_model_id) # FIXME: revise false end @@ -102,7 +102,7 @@ def supports_audio?(model_id) # Returns the type of model (chat, embedding, image) # @param model_id [String] the model identifier # @return [String] the model type - def model_type(model_id) + def model_type(_model_id) # FIXME: revise 'chat' end @@ -110,7 +110,7 @@ def model_type(model_id) # Returns the model family identifier # @param model_id [String] the model identifier # @return [String] the model family identifier - def model_family(model_id) # rubocop:disable Metrics/CyclomaticComplexity,Metrics/MethodLength + def model_family(_model_id) 'other' end diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index b9a0209f..d86d12c4 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -4,7 +4,7 @@ module RubyLLM module Providers module Ollama # Chat methods for the Ollama API implementation - module Chat # rubocop:disable Metrics/ModuleLength + module Chat # Must be public for Provider to use def complete(messages, tools:, temperature:, model:, &block) # rubocop:disable Metrics/MethodLength raise NotImplementedError, 'tool use not implemented in Ollama at this time' if tools.any? @@ -49,7 +49,7 @@ def format_role(role) role.to_s end - def format_parts(msg) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength + def format_parts(msg) if msg.content.is_a?(Array) # Handle multi-part content (text, images, etc.) msg.content.map { |part| format_part(part) } diff --git a/lib/ruby_llm/providers/ollama/embeddings.rb b/lib/ruby_llm/providers/ollama/embeddings.rb index 3a20b6af..8d2eb722 100644 --- a/lib/ruby_llm/providers/ollama/embeddings.rb +++ b/lib/ruby_llm/providers/ollama/embeddings.rb @@ -6,7 +6,7 @@ module Ollama # Embeddings methods for the Ollama API integration module Embeddings # Must be public for Provider module - def embed(text, model:) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength + def embed(text, model:) # rubocop:disable Metrics/MethodLength payload = { model: model, input: format_text_for_embedding(text) diff --git a/lib/ruby_llm/providers/ollama/models.rb b/lib/ruby_llm/providers/ollama/models.rb index 5e394cb7..136414fc 100644 --- a/lib/ruby_llm/providers/ollama/models.rb +++ b/lib/ruby_llm/providers/ollama/models.rb @@ -29,7 +29,7 @@ def list_models private - def parse_list_models_response(response, slug, capabilities) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength + def parse_list_models_response(response, slug, capabilities) # rubocop:disable Metrics/MethodLength (response.body['models'] || []).map do |model| model_id = model['name'] diff --git a/lib/ruby_llm/providers/ollama/streaming.rb b/lib/ruby_llm/providers/ollama/streaming.rb index a6fd1218..b268ee01 100644 --- a/lib/ruby_llm/providers/ollama/streaming.rb +++ b/lib/ruby_llm/providers/ollama/streaming.rb @@ -6,7 +6,7 @@ module Ollama # Streaming methods for the Ollama API implementation module Streaming # Need to make stream_completion public for chat.rb to access - def stream_completion(model, payload, &block) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength + def stream_completion(_model, payload, &block) url = 'api/chat' accumulator = StreamAccumulator.new @@ -20,8 +20,8 @@ def stream_completion(model, payload, &block) # rubocop:disable Metrics/AbcSize, private # Handle streaming - def stream_handler(accumulator, &block) # rubocop:disable Metrics/AbcSize,Metrics/CyclomaticComplexity,Metrics/MethodLength,Metrics/PerceivedComplexity - to_json_stream do |data| # rubocop:disable Metrics/BlockLength + def stream_handler(accumulator, &block) # rubocop:disable Metrics/MethodLength + to_json_stream do |data| chunk = Chunk.new( role: :assistant, content: data.dig('message', 'content'), diff --git a/spec/ruby_llm/providers/ollama/ollama_spec.rb b/spec/ruby_llm/providers/ollama/ollama_spec.rb index 0fb4ccd1..56ea89b2 100644 --- a/spec/ruby_llm/providers/ollama/ollama_spec.rb +++ b/spec/ruby_llm/providers/ollama/ollama_spec.rb @@ -18,11 +18,11 @@ end end -RSpec.describe RubyLLM::Providers::Ollama do # rubocop:disable RSpec/SpecFilePathFormat +RSpec.describe RubyLLM::Providers::Ollama do include_context 'with configured local Ollama server' describe '.models' do - it 'fetches models from the server at runtime' do # rubocop:disable RSpec/MultipleExpectations + it 'fetches models from the server at runtime' do # rubocop:disable RSpec/MultipleExpectations,RSpec/ExampleLength RubyLLM.models.refresh! # NOTE: to ensure relevant models are pulled into your local server, do @@ -40,7 +40,7 @@ describe '.chat' do let(:chat) { RubyLLM.chat(model: 'smollm:135m', provider: 'ollama') } - it 'works' do + it 'ask works' do response = chat.ask('Count from 1 to 3') expect(response.content).to be_present end @@ -49,7 +49,7 @@ describe 'streaming' do let(:chat) { RubyLLM.chat(model: 'smollm:135m', provider: 'ollama') } - it 'works' do + it 'ask with streaming works' do # rubocop:disable RSpec/MultipleExpectations,RSpec/ExampleLength chunks = [] chat.ask('Count from 1 to 3') do |chunk| From fb9697c9a4c1efb7a4f7e4c320a7b2636ad9677b Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Mon, 24 Mar 2025 22:21:22 -0300 Subject: [PATCH 11/55] Add VCR cassettes --- .../providers_ollama_chat_ask_works.yml | 45 ++++++++ ...ma_embeddings_can_handle_a_single_text.yml | 38 +++++++ ...a_embeddings_can_handle_multiple_texts.yml | 37 +++++++ ...ches_models_from_the_server_at_runtime.yml | 35 ++++++ ...ama_streaming_ask_with_streaming_works.yml | 101 ++++++++++++++++++ 5 files changed, 256 insertions(+) create mode 100644 spec/fixtures/vcr_cassettes/providers_ollama_chat_ask_works.yml create mode 100644 spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_a_single_text.yml create mode 100644 spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_multiple_texts.yml create mode 100644 spec/fixtures/vcr_cassettes/providers_ollama_models_fetches_models_from_the_server_at_runtime.yml create mode 100644 spec/fixtures/vcr_cassettes/providers_ollama_streaming_ask_with_streaming_works.yml diff --git a/spec/fixtures/vcr_cassettes/providers_ollama_chat_ask_works.yml b/spec/fixtures/vcr_cassettes/providers_ollama_chat_ask_works.yml new file mode 100644 index 00000000..8ca26bdb --- /dev/null +++ b/spec/fixtures/vcr_cassettes/providers_ollama_chat_ask_works.yml @@ -0,0 +1,45 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"smollm:135m","messages":[{"role":"user","content":"Count + from 1 to 3"}],"options":{"temperature":0.7},"stream":false}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Tue, 25 Mar 2025 11:42:35 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '812' + body: + encoding: ASCII-8BIT + string: '{"model":"smollm:135m","created_at":"2025-03-25T11:42:35.763421821Z","message":{"role":"assistant","content":"To + count the number of numbers in a list, you can use the `count()` method on + an iterable object like a list or tuple. The `count()` method returns the + number of occurrences of each item in the iterable and its position in the + list. To find the first occurrence of an element, you can access it using + indexing and then return the value obtained by that index:\n\n```python\nnumbers + = [1, 2, 3]\nresult = numbers[0] == 1 or numbers[1] == 3\nassert result == + True\n# ... (approximate count of numbers in list)\n```"},"done_reason":"stop","done":true,"total_duration":1783007537,"load_duration":1218168782,"prompt_eval_count":16,"prompt_eval_duration":186161937,"eval_count":132,"eval_duration":376576424}' + recorded_at: Tue, 25 Mar 2025 11:42:31 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_a_single_text.yml b/spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_a_single_text.yml new file mode 100644 index 00000000..bd9fa5d5 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_a_single_text.yml @@ -0,0 +1,38 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/embed + body: + encoding: UTF-8 + string: '{"model":"snowflake-arctic-embed:22m","input":"Ruby is a programmer''s + best friend"}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Tue, 25 Mar 2025 11:42:36 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Transfer-Encoding: + - chunked + body: + encoding: ASCII-8BIT + string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.025825415,-0.023176115,-0.052045297,-0.023625664,0.0006673469,0.009949714,-0.04538417,-0.06849524,-0.019409077,0.0010184002,-0.054927465,0.04728714,0.032690506,0.030963264,-0.028091758,-0.05092271,0.00021566867,0.023615433,-0.12640688,0.015840458,0.012315658,0.087370574,0.011073331,0.0090212375,0.007156342,-0.0052327104,0.021913407,-0.020346882,-0.03459649,-0.20068292,0.021031896,0.07291515,0.031049531,-0.04963502,0.023327535,-0.06476457,0.0131773045,0.004342761,-0.05204616,-0.03947274,0.0122103775,0.003776148,-0.050048206,-0.017586641,-0.029104842,-0.016230974,0.021660762,-0.017151477,0.0865443,0.01920734,-0.042871486,-0.0089291595,-0.02822964,-0.04884569,-0.018680912,-0.01892585,0.015438859,0.0065737013,-0.021804608,0.00633415,0.0343607,0.0017093703,-0.34944108,-0.06468269,0.0478818,-0.00246448,0.046574403,0.02243261,-0.024708489,-0.016602987,-0.011909359,0.014165576,-0.07424154,-0.03776865,0.032787047,-0.05530688,0.013535443,0.042380534,0.038827997,-0.033742167,0.015697544,0.009775907,0.0042203693,0.0011168025,0.023423292,0.04484947,-0.043061797,-0.05383481,-0.028867329,-0.0033860689,0.018773982,-0.018347567,0.03903167,-0.029658085,-0.06440208,0.040508885,-0.0017985007,0.049720276,0.033716165,0.31325525,0.04386892,0.0048334296,0.050675593,-0.056929454,0.0518016,-0.004611103,-0.0029309082,-0.028916717,0.0060408665,-0.004141483,0.01923389,-0.031655706,0.01768319,0.02311225,0.045390822,-0.024344986,-0.039786555,0.024944702,0.005075094,0.056426894,-0.0009737753,0.0037892968,-0.032363605,-0.012793344,-0.041841026,-0.014850747,-0.06273983,0.033704888,0.031475354,0.011834117,0.05125323,-0.011774348,-0.06885821,-0.014935385,-0.0006414335,0.017715653,-0.008953341,-0.097899854,-0.036503628,-0.084191576,0.023606507,-0.1339018,0.1330882,0.007957225,0.01985772,0.00030814653,0.021941159,0.05639211,-0.043463834,-0.045274723,0.011725757,-0.003486319,0.003375221,0.0074666464,0.06974618,-0.0006389784,-0.038667206,0.07041848,-0.02421246,0.03300245,-0.011266481,0.035639856,0.040018253,0.09069596,0.08246825,-0.009912788,0.012884513,-0.022981415,0.03470591,-0.022104705,0.0043493398,0.013083702,0.035951313,0.03946172,-0.038252268,0.030231304,-0.036359355,0.01005223,0.0025720727,0.0013707506,0.034241233,0.088925935,-0.051440887,-0.050102297,-0.0016456994,-0.009496842,0.062487546,0.040939905,0.07381002,0.078291304,-0.038428534,0.1316706,-0.0055638882,0.008280254,-0.021145111,0.04876571,0.040031683,0.04628573,0.046338666,-0.017028602,-0.007903445,0.007545737,-0.07565534,0.064689994,-0.022149073,-0.046088018,0.014704514,-0.040415496,0.00550196,0.006901969,0.00089305703,0.006521102,0.0366565,0.0074207284,0.039539423,0.005592426,-0.003989626,0.008083243,0.033852484,0.052595314,-0.015218367,0.03131478,0.0040506576,-0.048098013,-0.027468681,-0.024048975,-0.04536876,-0.05319465,-0.027298115,-0.01941297,0.010558779,0.06863464,0.04396793,0.08020219,0.033566475,-0.009056651,-0.014715962,0.04780099,0.05536488,-0.06740807,0.002055909,0.013943318,-0.05024147,-0.035200298,0.027621565,-0.040184192,-0.007491963,-0.06297288,-0.022879997,0.093055375,0.04880813,-0.012168053,0.019717308,0.064516716,0.020201867,0.012079503,-0.17798914,-0.027345736,-0.0612433,0.038101118,-0.06641872,-0.00939703,0.052195832,-0.03770301,-0.022270007,0.012196051,-0.041005902,-0.06945124,-0.027733557,-0.009639078,-0.059247572,0.04474978,0.00042829235,0.010153207,0.02728113,0.029422356,0.049308695,-0.038985588,-0.017589854,-0.02842523,-0.027386962,0.042216763,0.061242577,0.003747581,-0.024338258,-0.050467186,-0.013143215,0.0031099522,0.010997509,0.026045857,0.01815751,-0.027380131,0.01929404,-0.0022469186,0.111852795,0.07823112,0.024928685,0.059756078,-0.008221097,0.016979527,-0.039244134,-0.0019415446,0.011487329,-0.03280691,-0.08006135,-0.026343029,0.026450884,-0.053655412,-0.005154362,0.01307755,0.053237017,0.04086586,-0.0019484188,0.011518151,0.08618621,-0.041709326,0.047144253,0.077645905,-0.044002645,-0.16881582,-0.02115599,-0.011150404,-0.029005526,-0.022859793,-0.0107934745,0.009013299,0.0037840477,-0.023908136,-0.041892353,0.13362311,0.05498781,-0.0010903508,-0.027582854,0.02074264,0.08133009,-0.016295228,0.046583474,-0.012219358,-0.07110713,-0.031505097,0.04635908,0.13795494,0.004750067,0.044614047,0.018176915,0.020094909,-0.08733446,-0.14297998,0.045279857,0.0077459584,-0.019933412,0.059806284,0.0053598317,0.005684153,0.01267696,0.06831267,-0.03196309,0.0056615137,-0.023855256,0.14950311,0.028314097,0.0012290949,-0.034989975,0.014838987,-0.0043164054,-0.0380489,-0.002994491,-0.04658432,-0.023052199,0.009330306,0.019073954,-0.0048254183,0.039711606,0.026755748,0.05285787,0.005976852,-0.02769884,0.03918166,0.022543069,0.035913944,-0.030974701,-0.033151094,-0.061393328,0.012922418]],"total_duration":926343313,"load_duration":836913075,"prompt_eval_count":8}' + recorded_at: Tue, 25 Mar 2025 11:42:32 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_multiple_texts.yml b/spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_multiple_texts.yml new file mode 100644 index 00000000..d5dcdb36 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_multiple_texts.yml @@ -0,0 +1,37 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/embed + body: + encoding: UTF-8 + string: '{"model":"snowflake-arctic-embed:22m","input":["Ruby","Python","JavaScript"]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Tue, 25 Mar 2025 11:42:36 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Transfer-Encoding: + - chunked + body: + encoding: ASCII-8BIT + string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.038980126,0.020101948,-0.067413226,0.007685114,-0.021361317,0.028405204,-0.05964908,-0.09178641,-0.032397546,0.008366828,-0.05523459,0.014637846,0.0298761,0.03387804,-0.016674861,-0.044479024,0.008276525,-0.0022477629,-0.12195336,-0.008178106,0.008199949,0.07350191,0.01897805,0.013661541,-0.003947917,0.00030909953,0.006917925,-0.012626692,-0.09616951,-0.17709318,0.01293276,0.031847943,0.025997223,-0.042996813,0.03192809,-0.048060544,-0.0017395425,0.029812165,-0.026901668,-0.030327402,-0.0068094945,0.023497479,-0.019625092,-0.003110331,0.010590182,-0.027034454,0.04182794,-0.009884578,0.09661056,0.043840215,-0.037773125,-0.033335246,0.009626258,-0.013944384,-0.040054895,-0.0026200123,0.046114273,0.0049590026,-0.008846017,0.034012534,0.038100995,0.0013456035,-0.34869465,-0.06399822,0.06681992,-0.007770172,0.03451249,0.006695025,0.0016939766,-0.005725403,-0.059506737,-0.0011312707,-0.034694858,-0.0070268526,0.033973437,-0.07178208,0.0019529031,0.050796922,0.033150885,-0.04453945,-0.010778929,-0.01298108,0.01772847,0.027397834,0.017516151,0.05094088,-0.045374986,-0.031055674,0.0034364148,0.017342873,0.03724968,-0.020449797,0.03487508,-0.023868825,-0.0705106,0.045591667,0.0014132301,0.04102965,0.0082013225,0.3076015,0.041163538,-0.0075212517,0.0632507,-0.07494113,0.054058343,-0.013692275,-0.018088195,0.0039990763,-0.016607765,-0.00915819,0.03353369,-0.017990997,-0.008927891,0.018497262,0.04622437,-0.028729072,-0.0070351255,-0.005821854,0.0063457754,0.044443272,-0.03001723,0.014840464,-0.03265875,-0.017414864,-0.014599514,-0.022385433,-0.06727593,0.03655243,0.009642398,0.04557801,0.028509801,0.011939836,-0.062560804,-0.015390183,-0.0050801174,0.011868977,0.00253459,-0.07341563,-0.004279252,-0.07461656,-0.0006562158,-0.16768059,0.13006905,0.03295397,0.0145061985,0.000511846,0.009465702,0.037566304,-0.012595248,-0.042188045,0.015753305,0.02033451,-0.026321119,0.020434551,0.09113539,-0.014463864,-0.04273769,0.05132384,-0.007610653,0.036329918,0.010425151,0.0075439727,0.042681746,0.060391378,0.053032257,0.0071610347,0.018304583,-0.0199126,0.008234456,-0.026586238,-0.00048163044,0.018455869,0.012418799,0.061977547,-0.014351739,0.019218396,0.010331768,0.033490002,0.0102368975,-0.031620093,0.015966186,0.10022163,-0.03886677,-0.058662754,-0.010719046,0.011613407,0.055317454,0.021442259,0.041051246,0.05395217,-0.031625535,0.1561225,-0.04847817,0.012704446,-0.017351678,-0.005412353,0.05782586,0.063770935,0.028648905,-0.0010758642,-0.03315512,0.011804742,-0.054954775,0.034165937,-0.027770827,-0.040539972,0.01901002,-0.008845964,-0.009943114,-0.00007340114,0.008205162,0.014036151,0.015788715,0.013589957,0.040579043,-0.015481178,0.0013020202,-0.019863069,0.044024546,0.054241393,-0.019910982,0.019316196,-0.009067846,-0.06370655,-0.038542934,-0.005822525,-0.05564244,-0.020892167,-0.04894251,-0.012727646,0.05143602,0.06270096,0.022492254,0.11401925,0.014643738,0.0030262705,-0.036580373,0.05074049,0.04994587,-0.06580306,0.008364971,0.0012129012,-0.034641,-0.0046832887,0.012338395,-0.032140378,-0.045876123,-0.048861995,-0.019786038,0.12485802,0.06277426,-0.033950374,0.036432575,0.06035506,0.014863595,0.0047113854,-0.19050083,-0.032735668,-0.077262625,0.044320498,-0.059189577,-0.014459053,0.03718649,-0.0026039602,0.004493112,-0.011763187,-0.05504196,-0.025533773,-0.02048363,-0.023919607,-0.015506923,0.061790027,0.01816571,0.0130165955,0.04316555,0.020895818,0.034394037,-0.00560091,0.011984886,-0.06372637,0.02781977,0.020621277,0.06389801,0.0032279587,-0.064306036,-0.07160552,-0.05394653,0.032840647,-0.0021832213,0.030553438,0.0039347326,-0.026431374,-0.026453791,-0.024773262,0.14158836,0.00027325953,-0.003358694,0.031054376,0.005467873,-0.000014875217,-0.05249387,0.05296582,-0.013941867,-0.031785127,-0.07282081,-0.029387616,-0.0076221772,-0.032214306,0.008221592,0.01732765,0.01000591,0.015568096,-0.005231348,-0.012036904,0.07718011,-0.045315113,0.008787361,0.02417641,-0.015230668,-0.15053827,-0.0037556684,-0.01667005,-0.0013223562,-0.02209581,0.016655259,0.019694244,0.015031552,-0.037394483,-0.057655845,0.12982553,0.04818329,0.0077882116,-0.015061786,0.004192891,0.08628084,0.027619699,0.044403546,0.00034237612,-0.044426452,0.00096744276,0.06186224,0.16129373,0.024928987,-0.0073914034,0.0040016263,0.039090827,-0.08990263,-0.118701264,0.04410862,-0.03954887,-0.030827247,0.112970345,0.04363939,-0.021480395,0.03728192,0.044834364,-0.0009248547,0.032832358,-0.035760213,0.15535384,-0.0009505413,-0.0034093896,-0.029711511,0.008248596,-0.051867787,-0.012275803,0.012434058,-0.04902186,-0.011476671,0.0133925,-0.03379115,-0.0151935695,0.010195133,0.031876706,0.025932532,0.036986034,-0.01739396,0.017166032,0.05808856,0.030131826,-0.0008843879,-0.06526332,-0.09222386,-0.0049838475],[-0.007225496,0.037155706,-0.016906068,-0.030758644,-0.020417303,0.011231278,-0.06530078,-0.061754078,-0.020577524,-0.024164986,-0.035808578,0.015893035,0.061571326,0.020668881,0.016767306,-0.023883428,-0.01099219,0.025237663,-0.15266667,-0.013051586,-0.010288909,0.029873036,0.017107742,0.0315594,0.021337744,0.0034486242,0.013156374,-0.037249252,-0.13094991,-0.15867794,0.024068367,0.005509016,-0.0056714285,-0.042848945,-0.0045933733,-0.04299176,0.0020768172,0.04483032,-0.03212172,-0.027772011,-0.0036520734,-0.0075447895,-0.013391376,0.0045278594,0.04607957,0.0027125278,0.049626715,-0.021857744,0.06873977,0.04173157,-0.04370165,0.014249006,-0.0373972,-0.05551407,-0.045433797,-0.0011728521,0.044487648,-0.0074436087,-0.00975718,0.008799588,0.0073077497,0.024823438,-0.35174075,-0.012705645,0.04136241,0.047284245,0.0020329098,0.04765345,-0.02604234,-0.02548834,-0.02704063,0.017578213,0.01482943,0.0055936393,0.023184825,-0.041498873,-0.003050582,0.012843925,0.05516694,-0.03866418,0.02621437,0.032198943,0.01935349,-0.018680874,-0.013953387,0.0451372,-0.018057078,-0.012344732,0.04716202,0.0010259423,-0.028411478,0.04075236,0.024121404,0.0006758823,-0.0674563,0.009551461,-0.01973488,0.05264174,0.04568158,0.29859018,0.030333413,-0.04152799,0.016276676,-0.037692044,0.053379524,-0.029166088,-0.008381986,-0.03611233,0.021734668,-0.02926269,0.01770523,-0.021257408,-0.0026680147,0.0033788746,0.03192171,-0.02859868,-0.050017837,0.007628301,-0.005211484,0.055639394,-0.04813225,-0.00062740705,-0.023975527,-0.05272858,0.0012510746,-0.016620526,-0.05937839,0.014596674,-0.007940771,-0.0060859257,0.03417475,-0.020669967,-0.09361984,-0.019438276,-0.012983339,0.022100516,0.03252378,-0.052587945,0.016381664,-0.047060754,0.015694086,-0.1377361,0.10544033,0.0026725356,0.01146019,0.026346128,-0.025007993,0.004997534,-0.053778246,-0.038643032,0.023108022,0.016371924,-0.015227947,0.0020684898,0.124686636,0.02065184,-0.0070788977,0.031109046,-0.011467157,0.0051159468,0.0174688,0.019905413,-0.0069136377,0.032805618,0.029705629,-0.038734376,0.032078113,-0.01761205,0.01944323,-0.0030690655,0.018461121,0.018608272,-0.012803209,0.017234804,-0.05453963,-0.0014086623,-0.032340996,0.0010491384,0.038566574,-0.03347248,-0.015357926,0.08070545,-0.028756669,-0.046844523,-0.01529485,0.052366853,0.059635386,0.03260225,0.05999529,0.06562162,-0.025594424,0.19492106,-0.09446214,-0.02200547,0.021350436,-0.0047113174,0.03170546,0.032968767,-0.017730163,-0.023518713,-0.024787944,-0.014301349,-0.00028776744,0.015872791,0.015544321,-0.079372294,-0.005725175,0.017331447,-0.0056501715,-0.012182198,-0.009767331,-0.05171092,0.038543854,0.034115233,0.07627104,0.032627165,0.016347326,0.012965246,0.024923127,0.02650983,-0.0040691686,0.04411213,-0.02981039,-0.06744219,-0.030292222,-0.0021420228,-0.06861754,-0.0020280352,-0.08233997,-0.0059836525,0.037955742,0.039244626,0.034866735,0.11366857,0.02521095,0.018243132,0.024956543,0.027358694,0.011940862,-0.061406422,0.0018358993,0.015471496,-0.0400448,-0.024514355,0.020818526,-0.078023,-0.019798901,-0.046464335,-0.03319194,0.16930555,0.050408904,-0.013528864,0.007027566,0.0381429,0.0010658541,-0.011183001,-0.18296444,-0.025517514,-0.028616475,0.044594944,-0.002806602,-0.00036968052,0.040348303,0.022882342,-0.0099050915,-0.029638626,-0.009392766,-0.035751175,-0.02882233,-0.05017968,-0.031793848,0.104784735,0.026196804,0.025192862,0.0053355214,-0.009864406,0.07273947,0.029665705,-0.030834008,0.005743688,0.0130977845,0.027437972,0.042631894,0.02490531,-0.031600703,-0.055224583,-0.04933041,-0.0008777641,-0.002849928,0.06742398,-0.041109774,0.00045421268,-0.008093842,-0.026830377,0.18975478,0.0022353292,0.016124677,0.03874153,-0.01676804,0.0016409162,0.0022479978,0.039468583,-0.03589011,-0.005279329,-0.031004557,-0.014081007,0.058285933,-0.03845023,-0.022855511,0.008495943,-0.013061212,0.029775871,0.024829257,-0.015684903,0.09160675,-0.057623718,0.035138898,0.037533384,0.02173393,-0.20164658,-0.034627892,-0.013216875,0.04897353,-0.058580056,0.018308442,0.028224163,-0.011080451,0.020418232,-0.026639828,0.1152522,0.05399439,-0.017088734,-0.0043683355,0.04675239,0.055089362,0.01442295,0.019836834,-0.013131093,-0.040812545,0.0028349068,0.06096238,0.15055773,-0.0047997017,0.04041006,0.023423078,0.0068679894,-0.036161505,-0.11227965,0.027264446,-0.032434683,-0.033046544,0.05816228,0.019367868,-0.035861887,0.023473343,0.07127074,-0.036597442,0.00892375,-0.03424332,0.15918937,-0.028045062,0.01727863,-0.016116075,-0.033897277,-0.04147993,0.000102095604,0.0054549514,-0.054227076,-0.014035331,0.022229984,-0.0101330625,0.0061006444,0.031121459,0.034375396,0.027529038,0.02083103,-0.01970649,0.01220227,0.048865896,0.04224607,0.034099545,-0.018085487,-0.035159428,-0.057188712],[0.010182182,0.01467856,0.02307528,-0.031243263,-0.019379467,0.018989552,-0.04283347,-0.065710135,0.037127666,-0.00186089,-0.043939225,0.02675395,0.017098242,0.01003573,0.016530303,-0.07529927,-0.0045888554,-0.00783502,-0.16103624,-0.018049028,-0.023261337,0.0726829,0.03554955,0.007101789,-0.03776669,0.03965637,0.010605459,-0.034077637,-0.1356997,-0.17605451,0.017438654,0.021631619,-0.00033740848,-0.05291991,-0.021556789,-0.020458516,-0.035007652,0.015351501,-0.013426498,-0.03958441,0.007752372,-0.016570576,-0.046401996,-0.011264202,0.05016379,-0.013889148,0.023654828,-0.030822476,0.024557399,0.041917533,-0.057632543,-0.032482482,0.00036849198,-0.038682386,-0.046676703,0.050744284,-0.010942368,-0.031797383,0.010470975,0.016948372,0.0055663995,0.058688268,-0.36635372,0.025145743,0.07269215,0.019211076,-0.018371176,-0.007865585,-0.00085583143,0.015894871,0.038337328,-0.014794488,-0.012541673,0.01718971,0.02693935,-0.045785226,0.0036220509,0.021907976,0.06554055,-0.04263025,0.0019336614,0.020152396,0.016324878,0.030021766,-0.015724592,0.06523936,0.0062361993,-0.028796729,0.038781464,0.00485937,-0.04877486,0.035066955,0.003006257,-0.0022367106,-0.04857364,0.001250449,0.0014392686,0.034671582,0.018141782,0.30240846,0.018054346,0.003062208,0.040367432,-0.07040852,0.052332688,-0.0028175337,-0.028020458,-0.021599045,0.031913813,-0.03909125,0.0028893205,-0.017719263,0.0052999025,-0.0061596422,0.054935843,-0.0012574365,-0.016914988,-0.009276138,0.023673639,0.043957185,-0.027961437,0.025381606,-0.04037111,-0.0053644218,-0.01048436,0.0035398034,-0.06366181,0.025020782,-0.046017863,-0.011454832,0.055446308,0.00011163922,-0.09325482,0.019621197,0.022895223,0.03182137,0.0010375826,-0.03117694,0.025362851,-0.031175531,-0.018045994,-0.13010256,0.10690098,-0.010491627,0.025534678,-0.0049998793,-0.028496867,0.043118607,-0.026229834,-0.01440331,0.024678908,0.033322413,-0.04394492,-0.005047783,0.0846922,0.022463208,0.0030116427,-0.003502701,-0.006854317,0.029395698,0.026690561,0.02559026,0.059080407,0.08340788,0.032878075,-0.0951223,0.05720357,0.02495402,0.014070283,-0.0042589814,0.018304987,-0.024781907,-0.041739304,-0.025803747,-0.012889254,-0.008009496,-0.028856821,-0.0005779219,0.028763987,-0.051368624,0.0027247544,0.06316944,-0.026757175,-0.08121664,-0.010547304,0.025082018,0.03702747,0.012908532,0.03141585,0.06318691,-0.027946094,0.17676711,-0.082001895,-0.036393072,-0.034927875,0.021505699,0.015366971,0.043793295,-0.0021506813,0.011197076,-0.04681245,-0.07142668,0.009581391,0.035224073,-0.04230499,-0.03571502,0.044728618,0.013419941,0.04271971,-0.008869499,-0.03126791,-0.0022953814,0.09043066,0.02422671,0.031988394,-0.005063331,-0.01025437,0.028456746,0.005116802,0.047064006,0.006069893,0.018045707,-0.022872277,-0.04572793,0.009827904,0.0069014616,-0.040622003,-0.013080576,-0.04777706,0.0012043755,0.07896354,0.043710608,0.040280547,0.073466524,0.06464221,0.014187437,-0.04872054,0.031972423,0.012510081,-0.038348954,0.016539646,0.006683025,-0.040044174,-0.056529168,0.04949601,-0.09106357,-0.030466262,0.010563386,-0.029358381,0.18323456,0.092901036,0.0274177,0.015892414,0.03165387,-0.06160097,0.0015103974,-0.11125003,0.010338306,-0.04025745,0.03327973,-0.025003629,-0.03141167,0.06007851,-0.029752823,-0.025986204,-0.0014932271,-0.00599316,-0.021954508,-0.005476444,-0.029271869,-0.040407516,0.09515277,0.019253343,0.04248291,0.00067515706,-0.009261151,0.025339367,-0.014061599,-0.0580183,-0.020854905,0.018436473,-0.0027048623,0.05364179,0.03416436,-0.009260716,-0.0785917,-0.023255466,0.03542782,0.07159498,0.0069388812,-0.038117178,-0.012323471,-0.009949083,-0.005902662,0.1273025,0.0014150682,0.018899381,0.022011757,-0.048523538,-0.03720841,-0.009601104,0.0547053,0.013078509,-0.013740014,-0.047507983,-0.018159833,0.017327625,-0.028147077,-0.030314941,-0.0028794382,-0.045816995,0.0028496154,0.015196548,-0.007854572,0.10382276,-0.01617453,0.017708423,0.037362352,0.002230973,-0.17829818,-0.036029417,-0.0006612718,-0.014223209,-0.06350168,-0.030032892,0.023901368,-0.00077770976,0.02510791,-0.04697416,0.15435414,0.08471184,-0.018154247,-0.030085038,0.03331496,0.09898532,0.016086424,0.010282825,-0.018388266,-0.006998348,0.017570151,0.0994389,0.12580456,0.023195932,0.008063885,0.003250409,-0.005355925,-0.047599785,-0.13378266,-0.0018643751,-0.045305796,-0.020819422,0.06300365,0.00095856196,0.005435208,0.0057721534,0.031151773,-0.03753951,0.016918143,-0.044961866,0.13784775,-0.016061982,-0.00000515642,-0.008715281,-0.01241248,-0.0021270465,0.022557234,0.05173467,-0.04232277,0.008206349,0.012508353,-0.004212918,-0.01315854,0.048109457,0.00035447034,-0.0082567325,0.012337424,0.0065427353,0.036199752,0.030513138,0.039167494,-0.028987426,-0.016657345,-0.07125146,-0.020769335]],"total_duration":11837394,"load_duration":2672695,"prompt_eval_count":4}' + recorded_at: Tue, 25 Mar 2025 11:42:32 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/providers_ollama_models_fetches_models_from_the_server_at_runtime.yml b/spec/fixtures/vcr_cassettes/providers_ollama_models_fetches_models_from_the_server_at_runtime.yml new file mode 100644 index 00000000..b719a3eb --- /dev/null +++ b/spec/fixtures/vcr_cassettes/providers_ollama_models_fetches_models_from_the_server_at_runtime.yml @@ -0,0 +1,35 @@ +--- +http_interactions: +- request: + method: get + uri: http://localhost:11434/api/tags + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.12.2 + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Tue, 25 Mar 2025 11:42:33 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Transfer-Encoding: + - chunked + body: + encoding: ASCII-8BIT + string: '{ "models": [ { "details": { "families": [ "bert" ], "family": "bert", "format": "gguf", "parameter_size": "23M", "parent_model": "", "quantization_level": "F16" }, "digest": "bf75350e17522c7dfe63e98f50457b27fadcfee62f0c0767c1c86053407c2abb", "model": "snowflake-arctic-embed:22m", "modified_at": "2025-03-25T01:16:44.503745925Z", "name": "snowflake-arctic-embed:22m", "size": 45838698 }, { "details": { "families": [ "llama" ], "family": "llama", "format": "gguf", "parameter_size": "134.52M", "parent_model": "", "quantization_level": "Q4_0" }, "digest": "b0b2a46174385c0adcaa77ff245ffeced5fc4a61447b6f221b2beb5c5a760133", "model": "smollm:135m", "modified_at": "2025-03-25T01:16:43.495760964Z", "name": "smollm:135m", "size": 91739413 } ] }' + recorded_at: Tue, 25 Mar 2025 11:42:29 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/providers_ollama_streaming_ask_with_streaming_works.yml b/spec/fixtures/vcr_cassettes/providers_ollama_streaming_ask_with_streaming_works.yml new file mode 100644 index 00000000..a70a2ebb --- /dev/null +++ b/spec/fixtures/vcr_cassettes/providers_ollama_streaming_ask_with_streaming_works.yml @@ -0,0 +1,101 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"smollm:135m","messages":[{"role":"user","content":"Count + from 1 to 3"}],"options":{"temperature":0.7},"stream":true}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Tue, 25 Mar 2025 11:42:35 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: | + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.7830333Z","message":{"role":"assistant","content":"Here"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.785646727Z","message":{"role":"assistant","content":" is"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.78827431Z","message":{"role":"assistant","content":" a"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.790801785Z","message":{"role":"assistant","content":" Python"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.793274065Z","message":{"role":"assistant","content":" function"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.795874434Z","message":{"role":"assistant","content":" that"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.7984565Z","message":{"role":"assistant","content":" counts"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.801031415Z","message":{"role":"assistant","content":" the"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.803573893Z","message":{"role":"assistant","content":" number"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.806231278Z","message":{"role":"assistant","content":" of"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.808821071Z","message":{"role":"assistant","content":" digits"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.81137248Z","message":{"role":"assistant","content":" in"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.813966219Z","message":{"role":"assistant","content":" a"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.816573617Z","message":{"role":"assistant","content":" string"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.81917068Z","message":{"role":"assistant","content":" and"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.821770818Z","message":{"role":"assistant","content":" returns"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.824417413Z","message":{"role":"assistant","content":" the"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.828470856Z","message":{"role":"assistant","content":" corresponding"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.831226755Z","message":{"role":"assistant","content":" integer"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.834009618Z","message":{"role":"assistant","content":" value"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.83662707Z","message":{"role":"assistant","content":":"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.839237899Z","message":{"role":"assistant","content":"\n"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.841888936Z","message":{"role":"assistant","content":"\n"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.844437076Z","message":{"role":"assistant","content":"```"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.847064226Z","message":{"role":"assistant","content":"python"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.849627235Z","message":{"role":"assistant","content":"\n"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.852219701Z","message":{"role":"assistant","content":"def"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.854814973Z","message":{"role":"assistant","content":" count"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.857436203Z","message":{"role":"assistant","content":"_"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.860108144Z","message":{"role":"assistant","content":"digits"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.862759224Z","message":{"role":"assistant","content":"("},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.865434499Z","message":{"role":"assistant","content":"s"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.868125297Z","message":{"role":"assistant","content":"):"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.870760844Z","message":{"role":"assistant","content":"\n "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.873382963Z","message":{"role":"assistant","content":" count"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.875996933Z","message":{"role":"assistant","content":" ="},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.878590201Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.881191519Z","message":{"role":"assistant","content":"0"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.883832365Z","message":{"role":"assistant","content":"\n "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.886564727Z","message":{"role":"assistant","content":" for"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.889166207Z","message":{"role":"assistant","content":" digit"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.891879215Z","message":{"role":"assistant","content":" in"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.894548894Z","message":{"role":"assistant","content":" s"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.897207567Z","message":{"role":"assistant","content":":"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.899841625Z","message":{"role":"assistant","content":"\n "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.902498196Z","message":{"role":"assistant","content":" if"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.905107832Z","message":{"role":"assistant","content":" digit"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.907789586Z","message":{"role":"assistant","content":"."},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.910502793Z","message":{"role":"assistant","content":"is"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.9143673Z","message":{"role":"assistant","content":"digit"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.917111538Z","message":{"role":"assistant","content":"():"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.919863033Z","message":{"role":"assistant","content":"\n "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.922599882Z","message":{"role":"assistant","content":" count"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.925334577Z","message":{"role":"assistant","content":" +="},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.928067663Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.930770166Z","message":{"role":"assistant","content":"1"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.933410933Z","message":{"role":"assistant","content":"\n "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.936033812Z","message":{"role":"assistant","content":" return"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.938684522Z","message":{"role":"assistant","content":" int"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.941285311Z","message":{"role":"assistant","content":"("},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.943928387Z","message":{"role":"assistant","content":"count"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.946601129Z","message":{"role":"assistant","content":")"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.94925745Z","message":{"role":"assistant","content":"\n"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.951855253Z","message":{"role":"assistant","content":"```"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.954468729Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":181710972,"load_duration":5399447,"prompt_eval_count":16,"prompt_eval_duration":2211058,"eval_count":65,"eval_duration":173901215} + recorded_at: Tue, 25 Mar 2025 11:42:31 GMT +recorded_with: VCR 6.3.1 From 1298c19363ebb298637b61fe36151c80eedc28a3 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Tue, 25 Mar 2025 08:56:21 -0300 Subject: [PATCH 12/55] Resolve FIXMEs --- lib/ruby_llm/provider.rb | 8 ++++++++ lib/ruby_llm/providers/ollama/chat.rb | 7 +------ lib/tasks/ollama.rake | 14 +++++++------- spec/ruby_llm/providers/ollama/ollama_spec.rb | 14 +++++--------- 4 files changed, 21 insertions(+), 22 deletions(-) diff --git a/lib/ruby_llm/provider.rb b/lib/ruby_llm/provider.rb index c3b3c491..6f76711e 100644 --- a/lib/ruby_llm/provider.rb +++ b/lib/ruby_llm/provider.rb @@ -188,6 +188,14 @@ def providers def configured_providers providers.select { |_name, provider| provider.configured? }.values end + + def disable_all_providers + providers.each_value do |provider| + provider.configuration_requirements.each do |key| + RubyLLM.config.send "#{key}=", nil + end + end + end end end end diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index d86d12c4..cacfbf46 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -38,17 +38,12 @@ def generate_completion(_model, payload) def format_messages(messages) messages.map do |msg| { - role: format_role(msg.role), + role: msg.role.to_s, content: format_parts(msg) } end end - def format_role(role) - # FIXME: probably should validate this - role.to_s - end - def format_parts(msg) if msg.content.is_a?(Array) # Handle multi-part content (text, images, etc.) diff --git a/lib/tasks/ollama.rake b/lib/tasks/ollama.rake index b80f9fad..ac454932 100644 --- a/lib/tasks/ollama.rake +++ b/lib/tasks/ollama.rake @@ -4,15 +4,15 @@ require 'ruby_llm' def pull_model(ollama_library_model_spec, description) warn "+ pulling #{ollama_library_model_spec} from Ollama library (#{description})" - payload = { - model: ollama_library_model_spec, - insecure: false, - stream: false - } # ugly but effective - # FIXME: possibly needs timeout adjustment since it downloads models - response = RubyLLM::Providers::Ollama.send :post, '/api/pull', payload + response = RubyLLM::Providers::Ollama.send( + :post, '/api/pull', { + model: ollama_library_model_spec, + insecure: false, + stream: false + } + ) unless response.body['status'] == 'success' raise 'non-successful response when pulling model; check Ollama server logs' diff --git a/spec/ruby_llm/providers/ollama/ollama_spec.rb b/spec/ruby_llm/providers/ollama/ollama_spec.rb index 56ea89b2..306957df 100644 --- a/spec/ruby_llm/providers/ollama/ollama_spec.rb +++ b/spec/ruby_llm/providers/ollama/ollama_spec.rb @@ -3,23 +3,19 @@ require 'spec_helper' require 'dotenv/load' -RSpec.shared_context 'with configured local Ollama server' do +RSpec.shared_context 'with configured local Ollama server as sole provider' do before :all do RubyLLM.configure do |config| - config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL', 'http://localhost:11434') + # NOTE: other tests will need to ensure relevant providers are enabled as needed + RubyLLM::Provider.disable_all_providers - # FIXME: need a sane internal API to do this, like RubyLLM.disable_all_providers() - # FIXME: this will break other tests depending on run order - config.openai_api_key = nil - config.anthropic_api_key = nil - config.gemini_api_key = nil - config.deepseek_api_key = nil + config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL', 'http://localhost:11434') end end end RSpec.describe RubyLLM::Providers::Ollama do - include_context 'with configured local Ollama server' + include_context 'with configured local Ollama server as sole provider' describe '.models' do it 'fetches models from the server at runtime' do # rubocop:disable RSpec/MultipleExpectations,RSpec/ExampleLength From 88ca59e246113a4596053c1100bc8ea10788b471 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Mon, 24 Mar 2025 23:31:01 -0300 Subject: [PATCH 13/55] Hint about need for models.refresh! --- lib/ruby_llm/providers/ollama/models.rb | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/lib/ruby_llm/providers/ollama/models.rb b/lib/ruby_llm/providers/ollama/models.rb index 136414fc..0b81a49c 100644 --- a/lib/ruby_llm/providers/ollama/models.rb +++ b/lib/ruby_llm/providers/ollama/models.rb @@ -17,6 +17,14 @@ def models_url # # create an alias gemma3 for gemma3:27b + # NOTE: Unlike other providers for well known APIs with stable model + # offerings, the Ollama provider deals with local servers which + # might have arbitrarily named models or even zero models installed. + # + # Thus, this provider can't ship hardcoded assumptions in models.json + # and thus no Ollama models will be known at runtime, so you'll need a + # `RubyLLM.models.refresh!` to populate your instance's models. + def list_models return [] unless enabled? From 5dac2bc227418454bc9f9ee3f03d3ea5fec3d229 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Tue, 25 Mar 2025 09:35:44 -0300 Subject: [PATCH 14/55] Expose more model metadata --- lib/ruby_llm/providers/ollama/models.rb | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/lib/ruby_llm/providers/ollama/models.rb b/lib/ruby_llm/providers/ollama/models.rb index 0b81a49c..cc6a97f4 100644 --- a/lib/ruby_llm/providers/ollama/models.rb +++ b/lib/ruby_llm/providers/ollama/models.rb @@ -49,14 +49,20 @@ def parse_list_models_response(response, slug, capabilities) # rubocop:disable M provider: slug, type: capabilities.model_type(model_id), family: model['family'], - metadata: {}, context_window: capabilities.context_window_for(model_id), max_tokens: capabilities.max_tokens_for(model_id), supports_vision: capabilities.supports_vision?(model_id), supports_functions: capabilities.supports_functions?(model_id), supports_json_mode: capabilities.supports_json_mode?(model_id), input_price_per_million: capabilities.input_price_for(model_id), - output_price_per_million: capabilities.output_price_for(model_id) + output_price_per_million: capabilities.output_price_for(model_id), + metadata: { + byte_size: model['size']&.to_i, + parameter_size: model.dig('details', 'parameter_size'), + quantization_level: model.dig('details', 'quantization_level'), + format: model.dig('details', 'format'), + parent_model: model.dig('details', 'parent_model') + } ) end end From 099978e53c3d4e5f8551521a9aff0e7f9b5681d5 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 26 Mar 2025 09:05:20 -0300 Subject: [PATCH 15/55] Streamline usage in docs --- docs/guides/getting-started.md | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/docs/guides/getting-started.md b/docs/guides/getting-started.md index 960a414d..5fad91b6 100644 --- a/docs/guides/getting-started.md +++ b/docs/guides/getting-started.md @@ -30,17 +30,12 @@ RubyLLM.configure do |config| config.anthropic_api_key = ENV['ANTHROPIC_API_KEY'] config.gemini_api_key = ENV['GEMINI_API_KEY'] config.deepseek_api_key = ENV['DEEPSEEK_API_KEY'] + config.ollama_api_base_url = 'http://localhost:11434' end ``` Alternatively, you can point to an Ollama instance; here it is configured to the most common address when Ollama is installed locally: ``` -RubyLLM.configure do |config| - config.ollama_api_base_url = 'http://localhost:11434' -end - -# Needs to be called to populate Ollama models before using any -RubyLLM.models.refresh! ``` ## Your First Chat @@ -75,7 +70,8 @@ claude_chat.ask "Tell me about Ruby programming language" gemini_chat = RubyLLM.chat(model: 'gemini-2.0-flash') gemini_chat.ask "What are the best Ruby gems for machine learning?" -# Use an Ollama model (pull it into the server first; consult Ollama docs): +# Use an Ollama model - pull it to the server first (consult Ollama docs) and then do models.refresh! before using it: +RubyLLM.models.refresh! # Needs to be called to populate Ollama models before using any ollama_chat = RubyLLM.chat(model: 'gemma3:latest') ollama_chat.ask "What is Alphabet?" ``` From d668c75f7b6551f70770c26ad5f5e01c9e90b922 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 26 Mar 2025 09:13:30 -0300 Subject: [PATCH 16/55] Remove leftovers --- lib/ruby_llm/providers/ollama.rb | 4 ---- lib/ruby_llm/providers/ollama/models.rb | 2 -- 2 files changed, 6 deletions(-) diff --git a/lib/ruby_llm/providers/ollama.rb b/lib/ruby_llm/providers/ollama.rb index 3cef062c..dd56f6d5 100644 --- a/lib/ruby_llm/providers/ollama.rb +++ b/lib/ruby_llm/providers/ollama.rb @@ -12,10 +12,6 @@ module Ollama module_function - def enabled? - !!RubyLLM.config.ollama_api_base_url - end - def api_base RubyLLM.config.ollama_api_base_url end diff --git a/lib/ruby_llm/providers/ollama/models.rb b/lib/ruby_llm/providers/ollama/models.rb index cc6a97f4..0e8dfab5 100644 --- a/lib/ruby_llm/providers/ollama/models.rb +++ b/lib/ruby_llm/providers/ollama/models.rb @@ -26,8 +26,6 @@ def models_url # `RubyLLM.models.refresh!` to populate your instance's models. def list_models - return [] unless enabled? - response = connection.get('api/tags') do |req| req.headers.merge! headers end From ad7ce33476e53a2d5e0c04c018e3a49f5f5bf76b Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 26 Mar 2025 09:38:07 -0300 Subject: [PATCH 17/55] Streamline provider to be more like OpenAI's --- lib/ruby_llm/providers/ollama/chat.rb | 56 ++++--------------- lib/ruby_llm/providers/ollama/embeddings.rb | 24 +++++--- lib/ruby_llm/providers/ollama/streaming.rb | 61 +++++++++++++-------- 3 files changed, 64 insertions(+), 77 deletions(-) diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index cacfbf46..b681fa50 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -5,8 +5,13 @@ module Providers module Ollama # Chat methods for the Ollama API implementation module Chat - # Must be public for Provider to use - def complete(messages, tools:, temperature:, model:, &block) # rubocop:disable Metrics/MethodLength + module_function + + def completion_url + 'api/chat' + end + + def render_payload(messages, tools:, temperature:, model:, stream: false) # rubocop:disable Metrics/MethodLength raise NotImplementedError, 'tool use not implemented in Ollama at this time' if tools.any? payload = { @@ -14,61 +19,20 @@ def complete(messages, tools:, temperature:, model:, &block) # rubocop:disable M messages: format_messages(messages), options: { temperature: temperature - } + }, + stream: stream } - - if block_given? - payload[:stream] = true - stream_completion(model, payload, &block) - else - payload[:stream] = false - generate_completion(model, payload) - end - end - - # Format methods can be private - private - - def generate_completion(_model, payload) - url = 'api/chat' - response = post(url, payload) - parse_completion_response(response) end def format_messages(messages) messages.map do |msg| { role: msg.role.to_s, - content: format_parts(msg) + content: msg.content.to_s } end end - def format_parts(msg) - if msg.content.is_a?(Array) - # Handle multi-part content (text, images, etc.) - msg.content.map { |part| format_part(part) } - else - # Simple text content - msg.content.to_s - end - end - - def format_part(part) # rubocop:disable Metrics/MethodLength - case part[:type] - when 'text' - { text: part[:text] } - when 'image' - Media.format_image(part) - when 'pdf' - Media.format_pdf(part) - when 'audio' - Media.format_audio(part) - else - { text: part.to_s } - end - end - def parse_completion_response(response) data = response.body diff --git a/lib/ruby_llm/providers/ollama/embeddings.rb b/lib/ruby_llm/providers/ollama/embeddings.rb index 8d2eb722..93b02b59 100644 --- a/lib/ruby_llm/providers/ollama/embeddings.rb +++ b/lib/ruby_llm/providers/ollama/embeddings.rb @@ -5,22 +5,30 @@ module Providers module Ollama # Embeddings methods for the Ollama API integration module Embeddings - # Must be public for Provider module - def embed(text, model:) # rubocop:disable Metrics/MethodLength - payload = { + module_function + + def embedding_url + 'api/embed' + end + + def render_embedding_payload(text, model:) + { model: model, input: format_text_for_embedding(text) } + end - url = 'api/embed' - response = post(url, payload) + def parse_embedding_response(response) vectors = response.body['embeddings'] + model_id = response.body['model'] + input_tokens = response.body['prompt_eval_count'] || 0 + vectors = vectors.first if vectors.size == 1 Embedding.new( - vectors: text.is_a?(String) ? vectors.first : vectors, - model: model, + vectors: vectors, + model: model_id, # only available when passing a single string input - input_tokens: response.body['prompt_eval_count'] || 0 + input_tokens: input_tokens ) end diff --git a/lib/ruby_llm/providers/ollama/streaming.rb b/lib/ruby_llm/providers/ollama/streaming.rb index b268ee01..d624e712 100644 --- a/lib/ruby_llm/providers/ollama/streaming.rb +++ b/lib/ruby_llm/providers/ollama/streaming.rb @@ -5,35 +5,50 @@ module Providers module Ollama # Streaming methods for the Ollama API implementation module Streaming - # Need to make stream_completion public for chat.rb to access - def stream_completion(_model, payload, &block) - url = 'api/chat' - accumulator = StreamAccumulator.new + module_function - post(url, payload) do |req| - req.options.on_data = stream_handler(accumulator, &block) + def stream_url + completion_url + end + + def handle_stream(&block) + to_json_stream do |data| + # FIXME: for some reason, there's an unexpected final call + # from on_data with the complete response as an Array. + # + # It is skipped here, but this smells a bit; this method shouldn't + # need to be overridden just for this. Will look into it + done = data.is_a?(Array) || data['done'] + + block.call(build_chunk(data)) if data && !done end + end - accumulator.to_message + def build_chunk(data) + raise 'wtf' if data.is_a?(Array) + + chunk = Chunk.new( + role: :assistant, + content: data.dig('message', 'content'), + model_id: data['model'], + + # NOTE: unavailable in the response - https://ollama.readthedocs.io/en/api/#streaming-responses + input_tokens: nil, + output_tokens: nil + ) end - private + def handle_sse(chunk, parser, env, &block) + # NOTE: Ollama uses NDJSON rather than standard SSE here + content_type = env.response_headers['content-type'] + unless content_type =~ %r{application/x-ndjson} + raise "Unexpected content-type when parsing Ollama streaming response: #{content_type}" + end - # Handle streaming - def stream_handler(accumulator, &block) # rubocop:disable Metrics/MethodLength - to_json_stream do |data| - chunk = Chunk.new( - role: :assistant, - content: data.dig('message', 'content'), - model_id: data['model'], - - # NOTE: unavailable in the response - https://ollama.readthedocs.io/en/api/#streaming-responses - input_tokens: nil, - output_tokens: nil - ) - - accumulator.add(chunk) - block.call(chunk) + chunk.split(/\n+/).each do |line| + next if line.length == 0 + parsed_data = JSON.parse(line) + block.call(parsed_data) end end end From 0f8684c7fdd9c63175ca0fa47d382f095af30f9a Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 26 Mar 2025 12:16:43 -0300 Subject: [PATCH 18/55] Rubocop appeasement --- lib/ruby_llm/providers/ollama/chat.rb | 4 ++-- lib/ruby_llm/providers/ollama/streaming.rb | 7 ++++--- 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index b681fa50..39d64b3e 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -11,10 +11,10 @@ def completion_url 'api/chat' end - def render_payload(messages, tools:, temperature:, model:, stream: false) # rubocop:disable Metrics/MethodLength + def render_payload(messages, tools:, temperature:, model:, stream: false) raise NotImplementedError, 'tool use not implemented in Ollama at this time' if tools.any? - payload = { + { model: model, messages: format_messages(messages), options: { diff --git a/lib/ruby_llm/providers/ollama/streaming.rb b/lib/ruby_llm/providers/ollama/streaming.rb index d624e712..68cddb8e 100644 --- a/lib/ruby_llm/providers/ollama/streaming.rb +++ b/lib/ruby_llm/providers/ollama/streaming.rb @@ -27,7 +27,7 @@ def handle_stream(&block) def build_chunk(data) raise 'wtf' if data.is_a?(Array) - chunk = Chunk.new( + Chunk.new( role: :assistant, content: data.dig('message', 'content'), model_id: data['model'], @@ -38,7 +38,7 @@ def build_chunk(data) ) end - def handle_sse(chunk, parser, env, &block) + def handle_sse(chunk, _parser, env, &block) # NOTE: Ollama uses NDJSON rather than standard SSE here content_type = env.response_headers['content-type'] unless content_type =~ %r{application/x-ndjson} @@ -46,7 +46,8 @@ def handle_sse(chunk, parser, env, &block) end chunk.split(/\n+/).each do |line| - next if line.length == 0 + next if line.empty? + parsed_data = JSON.parse(line) block.call(parsed_data) end From 4cd54fb3fc7c4be476739d954999eff87f484ac0 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 26 Mar 2025 12:13:23 -0300 Subject: [PATCH 19/55] WIP: fold back all ollama specs into existing files Breaks all tests since the `refresh!` call clobbers all known models except those pulled from Ollama's, since only Ollama is configured when it runs (and live API calls go out with the `TEST` key otherwise). --- lib/ruby_llm/provider.rb | 8 -- spec/ruby_llm/chat_spec.rb | 3 +- spec/ruby_llm/chat_streaming_spec.rb | 3 +- spec/ruby_llm/embeddings_spec.rb | 3 +- spec/ruby_llm/providers/ollama/ollama_spec.rb | 88 ------------------- spec/spec_helper.rb | 7 ++ 6 files changed, 13 insertions(+), 99 deletions(-) delete mode 100644 spec/ruby_llm/providers/ollama/ollama_spec.rb diff --git a/lib/ruby_llm/provider.rb b/lib/ruby_llm/provider.rb index 6f76711e..c3b3c491 100644 --- a/lib/ruby_llm/provider.rb +++ b/lib/ruby_llm/provider.rb @@ -188,14 +188,6 @@ def providers def configured_providers providers.select { |_name, provider| provider.configured? }.values end - - def disable_all_providers - providers.each_value do |provider| - provider.configuration_requirements.each do |key| - RubyLLM.config.send "#{key}=", nil - end - end - end end end end diff --git a/spec/ruby_llm/chat_spec.rb b/spec/ruby_llm/chat_spec.rb index 7ced4f95..f35c0cf7 100644 --- a/spec/ruby_llm/chat_spec.rb +++ b/spec/ruby_llm/chat_spec.rb @@ -11,7 +11,8 @@ 'claude-3-5-haiku-20241022', 'gemini-2.0-flash', 'deepseek-chat', - 'gpt-4o-mini' + 'gpt-4o-mini', + 'smollm:135m' ].each do |model| it "#{model} can have a basic conversation" do # rubocop:disable RSpec/ExampleLength,RSpec/MultipleExpectations chat = RubyLLM.chat(model: model) diff --git a/spec/ruby_llm/chat_streaming_spec.rb b/spec/ruby_llm/chat_streaming_spec.rb index a42bf9ca..0f40e121 100644 --- a/spec/ruby_llm/chat_streaming_spec.rb +++ b/spec/ruby_llm/chat_streaming_spec.rb @@ -11,7 +11,8 @@ 'claude-3-5-haiku-20241022', 'gemini-2.0-flash', 'deepseek-chat', - 'gpt-4o-mini' + 'gpt-4o-mini', + 'smollm:135m' ].each do |model| it "#{model} supports streaming responses" do # rubocop:disable RSpec/ExampleLength,RSpec/MultipleExpectations chat = RubyLLM.chat(model: model) diff --git a/spec/ruby_llm/embeddings_spec.rb b/spec/ruby_llm/embeddings_spec.rb index 76a62fbd..6d4813df 100644 --- a/spec/ruby_llm/embeddings_spec.rb +++ b/spec/ruby_llm/embeddings_spec.rb @@ -12,7 +12,8 @@ describe 'basic functionality' do [ 'text-embedding-004', # gemini - 'text-embedding-3-small' # openai + 'text-embedding-3-small', # openai + 'snowflake-arctic-embed:22m' # ollama ].each do |model| it "#{model} can handle a single text" do # rubocop:disable RSpec/MultipleExpectations embedding = RubyLLM.embed(test_text, model: model) diff --git a/spec/ruby_llm/providers/ollama/ollama_spec.rb b/spec/ruby_llm/providers/ollama/ollama_spec.rb deleted file mode 100644 index 306957df..00000000 --- a/spec/ruby_llm/providers/ollama/ollama_spec.rb +++ /dev/null @@ -1,88 +0,0 @@ -# frozen_string_literal: true - -require 'spec_helper' -require 'dotenv/load' - -RSpec.shared_context 'with configured local Ollama server as sole provider' do - before :all do - RubyLLM.configure do |config| - # NOTE: other tests will need to ensure relevant providers are enabled as needed - RubyLLM::Provider.disable_all_providers - - config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL', 'http://localhost:11434') - end - end -end - -RSpec.describe RubyLLM::Providers::Ollama do - include_context 'with configured local Ollama server as sole provider' - - describe '.models' do - it 'fetches models from the server at runtime' do # rubocop:disable RSpec/MultipleExpectations,RSpec/ExampleLength - RubyLLM.models.refresh! - - # NOTE: to ensure relevant models are pulled into your local server, do - # bundle exec rake ollama:install_models_for_specs - - expect(RubyLLM.models).to include( - an_object_having_attributes(provider: 'ollama', id: 'smollm:135m') - ) - expect(RubyLLM.models).to include( - an_object_having_attributes(provider: 'ollama', id: 'snowflake-arctic-embed:22m') - ) - end - end - - describe '.chat' do - let(:chat) { RubyLLM.chat(model: 'smollm:135m', provider: 'ollama') } - - it 'ask works' do - response = chat.ask('Count from 1 to 3') - expect(response.content).to be_present - end - end - - describe 'streaming' do - let(:chat) { RubyLLM.chat(model: 'smollm:135m', provider: 'ollama') } - - it 'ask with streaming works' do # rubocop:disable RSpec/MultipleExpectations,RSpec/ExampleLength - chunks = [] - - chat.ask('Count from 1 to 3') do |chunk| - chunks << chunk - end - - expect(chunks).not_to be_empty - expect(chunks.first).to be_a(RubyLLM::Chunk) - end - end - - describe 'embeddings' do - let(:test_text) { "Ruby is a programmer's best friend" } - let(:test_texts) { %w[Ruby Python JavaScript] } - let(:model) { 'snowflake-arctic-embed:22m' } - - it 'can handle a single text' do # rubocop:disable RSpec/MultipleExpectations - # FIXME: need a provider: param just like in chat() - # embedding = RubyLLM.embed(test_text, model: model, provider: 'ollama') - - embedding = RubyLLM.embed(test_text, model: model) - expect(embedding.vectors).to be_an(Array) - expect(embedding.vectors.first).to be_a(Float) - expect(embedding.model).to eq(model) - expect(embedding.input_tokens).to be >= 0 - end - - it 'can handle multiple texts' do # rubocop:disable RSpec/ExampleLength,RSpec/MultipleExpectations - # FIXME: need a provider: param just like in chat() - # embeddings = RubyLLM.embed(test_texts, model: model, provider: 'ollama') - - embeddings = RubyLLM.embed(test_texts, model: model) - expect(embeddings.vectors).to be_an(Array) - expect(embeddings.vectors.size).to eq(3) - expect(embeddings.vectors.first).to be_an(Array) - expect(embeddings.model).to eq(model) - expect(embeddings.input_tokens).to be >= 0 - end - end -end diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index 2e05f5ce..26df0428 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -87,6 +87,13 @@ RSpec.shared_context 'with configured RubyLLM' do before do RubyLLM.configure do |config| + # NOTE: to ensure relevant models are pulled into your local server, do + # bundle exec rake ollama:install_models_for_specs + config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL', 'http://localhost:11434') + + # FIXME: this clobbers the model list from models.json and results in all tests except for ollama's to fail + RubyLLM.models.refresh! + config.openai_api_key = ENV.fetch('OPENAI_API_KEY', 'test') config.anthropic_api_key = ENV.fetch('ANTHROPIC_API_KEY', 'test') config.gemini_api_key = ENV.fetch('GEMINI_API_KEY', 'test') From af550155beccddacbd42e9bba4c2fd2d6d5f65c3 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 26 Mar 2025 12:43:40 -0300 Subject: [PATCH 20/55] Small fixes --- docs/guides/getting-started.md | 4 ---- 1 file changed, 4 deletions(-) diff --git a/docs/guides/getting-started.md b/docs/guides/getting-started.md index 5fad91b6..cbb25866 100644 --- a/docs/guides/getting-started.md +++ b/docs/guides/getting-started.md @@ -34,10 +34,6 @@ RubyLLM.configure do |config| end ``` -Alternatively, you can point to an Ollama instance; here it is configured to the most common address when Ollama is installed locally: -``` -``` - ## Your First Chat Let's start with a simple chat interaction: From 5cdbd1a445b66a6211d9ab8b32b9f6d0c49be364 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 26 Mar 2025 14:21:40 -0300 Subject: [PATCH 21/55] WIP: closer to a refresh! solution --- ...5m_can_handle_multi-turn_conversations.yml | 61 +++++++++++ ...llm_135m_can_have_a_basic_conversation.yml | 74 +++++++++++++ ...ollm_135m_supports_streaming_responses.yml | 100 +++++++++++++++++ ...tic-embed_22m_can_handle_a_single_text.yml | 34 ++++++ ...ic-embed_22m_can_handle_multiple_texts.yml | 33 ++++++ ...nd_returns_a_chainable_models_instance.yml | 28 +++++ ...ls_refresh_works_as_a_class_method_too.yml | 28 +++++ .../providers_ollama_chat_ask_works.yml | 45 -------- ...ma_embeddings_can_handle_a_single_text.yml | 38 ------- ...a_embeddings_can_handle_multiple_texts.yml | 37 ------- ...ches_models_from_the_server_at_runtime.yml | 35 ------ ...ama_streaming_ask_with_streaming_works.yml | 101 ------------------ spec/ruby_llm/chat_spec.rb | 1 + spec/spec_helper.rb | 15 +-- 14 files changed, 367 insertions(+), 263 deletions(-) create mode 100644 spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_handle_multi-turn_conversations.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_have_a_basic_conversation.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_streaming_responses_smollm_135m_supports_streaming_responses.yml create mode 100644 spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_a_single_text.yml create mode 100644 spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml delete mode 100644 spec/fixtures/vcr_cassettes/providers_ollama_chat_ask_works.yml delete mode 100644 spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_a_single_text.yml delete mode 100644 spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_multiple_texts.yml delete mode 100644 spec/fixtures/vcr_cassettes/providers_ollama_models_fetches_models_from_the_server_at_runtime.yml delete mode 100644 spec/fixtures/vcr_cassettes/providers_ollama_streaming_ask_with_streaming_works.yml diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_handle_multi-turn_conversations.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_handle_multi-turn_conversations.yml new file mode 100644 index 00000000..8326a281 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_handle_multi-turn_conversations.yml @@ -0,0 +1,61 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"smollm:135m","messages":[{"role":"user","content":"Who was + Ruby''s creator?"}],"options":{"temperature":0.7},"stream":false}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Wed, 26 Mar 2025 17:20:39 GMT + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: '{"model":"smollm:135m","created_at":"2025-03-26T17:20:39.40000571Z","message":{"role":"assistant","content":"Ruby''s + creator is unknown, but some theories suggest that she might have been a member + of a team or group of women who worked on the project. Here are a few examples:\n\n1. + **Sophie Couture**: The only person to receive the Ruby Award, a posthumous + honor given to women for outstanding performance in a musical, dance, or other + performance art project. This is a notable exception, as it''s unclear whether + she was a member of a team or a single woman on the project.\n2. **Sitse Selvin**: + A member of a team led by her brother, Robert Selvin, who worked with the + project from 1975 to 1983. He is believed to have been a talented pianist + and composer, but his real role remains unknown.\n3. **Vincent Chesnutt**: + A woman who was a member of a team led by her brother, Vincent Chesnutt, who + worked with the project from 1975 to 2006. She is believed to have been a + talented pianist and composer, but her real role remains unknown.\n4. **Sandra + Lee Cox**: A woman who was a member of a team led by her brother, Sandra Cox, + who worked with the project from 1983 to 2007. She is believed to have been + a talented pianist and composer, but her real role remains unknown.\n5. **Rachel + Vash**: A woman who was a member of a team led by her brother, Rachel Vash, + who worked with the project from 1994 to 2008. She is believed to have been + a talented pianist and composer, but her real role remains unknown.\n6. **Laurie + Lidwell**: A woman who was a member of a team led by her brother, Laurie Lidwell, + who worked with the project from 1994 to 2008. She is believed to have been + a talented pianist and composer, but her real role remains unknown.\n7. **Lindsey + Foyne**: A woman who was a member of a team led by her brother, Lindsey Foyne, + who worked with the project from 1994 to 2008. She is believed to have been + a talented pianist and composer, but her real role remains unknown.\n\nThese + are just a few examples of the many people who might have been involved in + the Ruby Award or on the project. While it''s difficult to provide an exact + count, it''s clear that Rachel Vash was a key part of the project."},"done_reason":"stop","done":true,"total_duration":2071286463,"load_duration":5108714,"prompt_eval_count":15,"prompt_eval_duration":8958877,"eval_count":548,"eval_duration":2056874892}' + recorded_at: Wed, 26 Mar 2025 17:20:39 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_have_a_basic_conversation.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_have_a_basic_conversation.yml new file mode 100644 index 00000000..118d6ebb --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_have_a_basic_conversation.yml @@ -0,0 +1,74 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"smollm:135m","messages":[{"role":"user","content":"What''s + 2 + 2?"}],"options":{"temperature":0.7},"stream":false}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Wed, 26 Mar 2025 17:18:34 GMT + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: '{"model":"smollm:135m","created_at":"2025-03-26T17:18:34.665407999Z","message":{"role":"assistant","content":"What + a great question! The concept of \"1+1\" is a fascinating mathematical operation + that can be understood in various ways. Here are some possible interpretations:\n\n1. + **Counting numbers**: In counting notation (binary, octal, hexadecimal, etc.), + 2 + 2 represents the binary representation of \"1\". This means that it''s + equivalent to adding 1 to itself twice!\n2. **Algebraic operations**: When + two integers are added, they become equivalent by definition. For example, + `a + b = c`, where a is positive and b is negative (i.e., 3+4=7). This equation + shows that 2 + 2 equals 5, which can be considered as \"1+1\" or \"2+2\".\n3. + **Real-world applications**: In some cases, 2 + 2 could represent a real number, + like the sum of two integers: `a + b = c`, where a is positive and b is negative + (i.e., -3). This equation shows that 1 plus 2 equals 5 in this case.\n4. **Fractional + part**: In fractional notation (fractional part), 2+2 could represent the + fractional part of \"1\", like `a/b = 0.2`, where a is positive and b is negative + (i.e., -3). This fraction shows that 2 + 2 equals 5 in this case as well, + albeit with a slightly greater numerator.\n5. **Algebraic expressions**: When + two expressions are algebraic expressions (expression without fractions), + they can be treated similarly to the real-world examples we mentioned earlier: + `a = ab`, where a is positive and b is negative. This expression shows that + 2 + 2 equals 5 in this case, albeit with an extra fraction element added.\n6. + **Symbolic manipulation**: In symbolic manipulation, like in algebra or combinatorics, + the addition of two integers can be represented as `a = ab`, where a is positive + and b is negative. This expression shows that 1 + 2 equals 5 in this case + by definition.\n7. **In mathematics education**: The concept of \"1+1\" has + been part of many mathematical proofs and discussions, often referred to as + \"integral summation\" or \"algebraic summation.\" These ideas can be seen + as a way of representing the summation of two integers that are equivalent + by definition.\n8. **Philosophical significance**: The concept of 2 + 2 raises + fundamental questions about the nature of numbers and their relationship to + reality: What is real, and what is an additive identity? Does zero have a + place in mathematics or can it be treated as a number without being additive + (i.e., 1 cannot equal zero)?\n9. **Mathematical intuition**: The concept of + 2 + 2 can evoke strong mathematical intuitions about the distribution of integers + among positive and negative numbers, which is essential to understanding some + other important properties in mathematics, like the prime number theorem or + the distribution of irrational numbers.\n10. **Philosophical implications**: + The idea of 2 + 2 has been a subject of philosophical debate, with different + interpretations (e.g., \"additive identity\" or \"non-additional\" as an additive + identity) that have challenged our understanding of mathematics and its relationship + to reality.\n\nThese are just a few examples of the many ways in which \"1+1\" + can be understood in various mathematical contexts."},"done_reason":"stop","done":true,"total_duration":3245290565,"load_duration":322808107,"prompt_eval_count":17,"prompt_eval_duration":13628372,"eval_count":733,"eval_duration":2908275176}' + recorded_at: Wed, 26 Mar 2025 17:18:34 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_streaming_responses_smollm_135m_supports_streaming_responses.yml b/spec/fixtures/vcr_cassettes/chat_streaming_responses_smollm_135m_supports_streaming_responses.yml new file mode 100644 index 00000000..390fd1fd --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_streaming_responses_smollm_135m_supports_streaming_responses.yml @@ -0,0 +1,100 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"smollm:135m","messages":[{"role":"user","content":"Count + from 1 to 3"}],"options":{"temperature":0.7},"stream":true}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Wed, 26 Mar 2025 17:18:38 GMT + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: | + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.100562561Z","message":{"role":"assistant","content":"Here"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.104881895Z","message":{"role":"assistant","content":" is"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.109163649Z","message":{"role":"assistant","content":" a"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.113094772Z","message":{"role":"assistant","content":" Python"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.116972445Z","message":{"role":"assistant","content":" function"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.120733929Z","message":{"role":"assistant","content":" that"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.124307882Z","message":{"role":"assistant","content":" counts"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.128387505Z","message":{"role":"assistant","content":" the"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.132135107Z","message":{"role":"assistant","content":" number"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.13578816Z","message":{"role":"assistant","content":" of"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.139146823Z","message":{"role":"assistant","content":" digits"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.142487577Z","message":{"role":"assistant","content":" in"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.145833149Z","message":{"role":"assistant","content":" a"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.149574122Z","message":{"role":"assistant","content":" string"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.153284265Z","message":{"role":"assistant","content":":"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.156734808Z","message":{"role":"assistant","content":"\n"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.160126451Z","message":{"role":"assistant","content":"\n"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.163615804Z","message":{"role":"assistant","content":"```"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.17177554Z","message":{"role":"assistant","content":"python"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.176081914Z","message":{"role":"assistant","content":"\n"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.180185308Z","message":{"role":"assistant","content":"def"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.184394831Z","message":{"role":"assistant","content":" count"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.188109373Z","message":{"role":"assistant","content":"_"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.191586197Z","message":{"role":"assistant","content":"digits"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.19498339Z","message":{"role":"assistant","content":"("},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.198339013Z","message":{"role":"assistant","content":"s"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.201589705Z","message":{"role":"assistant","content":"):"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.205084617Z","message":{"role":"assistant","content":"\n "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.208314251Z","message":{"role":"assistant","content":" result"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.211665804Z","message":{"role":"assistant","content":" ="},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.215361477Z","message":{"role":"assistant","content":" {}"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.219057039Z","message":{"role":"assistant","content":"\n "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.222497532Z","message":{"role":"assistant","content":" for"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.226058135Z","message":{"role":"assistant","content":" char"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.229534369Z","message":{"role":"assistant","content":" in"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.232965531Z","message":{"role":"assistant","content":" s"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.236452504Z","message":{"role":"assistant","content":":"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.240042996Z","message":{"role":"assistant","content":"\n "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.24349197Z","message":{"role":"assistant","content":" if"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.247069563Z","message":{"role":"assistant","content":" char"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.250678586Z","message":{"role":"assistant","content":" not"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.254176448Z","message":{"role":"assistant","content":" in"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.257590831Z","message":{"role":"assistant","content":" result"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.260969383Z","message":{"role":"assistant","content":":"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.264846698Z","message":{"role":"assistant","content":"\n "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.268374811Z","message":{"role":"assistant","content":" result"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.272071133Z","message":{"role":"assistant","content":"["},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.275484896Z","message":{"role":"assistant","content":"char"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.278916879Z","message":{"role":"assistant","content":"]"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.282696043Z","message":{"role":"assistant","content":" ="},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.286494845Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.290218278Z","message":{"role":"assistant","content":"0"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.293935121Z","message":{"role":"assistant","content":"\n "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.297789735Z","message":{"role":"assistant","content":" result"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.301722288Z","message":{"role":"assistant","content":"["},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.305849971Z","message":{"role":"assistant","content":"char"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.309743804Z","message":{"role":"assistant","content":"]"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.313734477Z","message":{"role":"assistant","content":" +="},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.317732522Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.321434594Z","message":{"role":"assistant","content":"1"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.325045267Z","message":{"role":"assistant","content":"\n "},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.32905447Z","message":{"role":"assistant","content":" return"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.332839624Z","message":{"role":"assistant","content":" result"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.336708717Z","message":{"role":"assistant","content":"\n"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.34039667Z","message":{"role":"assistant","content":"```"},"done":false} + {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.343979733Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":261623797,"load_duration":5114494,"prompt_eval_count":16,"prompt_eval_duration":12307330,"eval_count":66,"eval_duration":243867952} + recorded_at: Wed, 26 Mar 2025 17:18:38 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_a_single_text.yml b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_a_single_text.yml new file mode 100644 index 00000000..0ce408e9 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_a_single_text.yml @@ -0,0 +1,34 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/embed + body: + encoding: UTF-8 + string: '{"model":"snowflake-arctic-embed:22m","input":"Ruby is a programmer''s + best friend"}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Wed, 26 Mar 2025 17:18:38 GMT + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.025819365,-0.023147449,-0.05204419,-0.02359659,0.0006516247,0.009969577,-0.0453889,-0.068442866,-0.019442763,0.0009812108,-0.05498037,0.04730593,0.032717418,0.030947946,-0.028105065,-0.05090078,0.00025667102,0.023571288,-0.12629306,0.015917534,0.01231173,0.08733777,0.011108408,0.009003669,0.00718937,-0.0052934815,0.02193917,-0.020292742,-0.03461139,-0.20070425,0.02107215,0.072910964,0.031031353,-0.049616367,0.023306997,-0.06486672,0.013256376,0.0043853885,-0.052061625,-0.039435886,0.012164081,0.003788034,-0.050004035,-0.01751829,-0.029081171,-0.016297124,0.021628456,-0.017189225,0.08650422,0.019240791,-0.04283047,-0.008972946,-0.0282798,-0.048760213,-0.018701227,-0.018923806,0.015387223,0.0066132424,-0.021767087,0.006322427,0.034335203,0.0016922819,-0.3494393,-0.06468288,0.04789346,-0.00242133,0.046571758,0.022469908,-0.024689795,-0.016555127,-0.011920086,0.014217722,-0.074248835,-0.0378238,0.03272102,-0.055375192,0.013477699,0.042363465,0.038778525,-0.033732694,0.015692627,0.009818383,0.004275665,0.0011522578,0.023426272,0.044826716,-0.043028492,-0.05380732,-0.028874718,-0.0033281562,0.018819876,-0.018340344,0.03899947,-0.029625487,-0.064442106,0.04053737,-0.0017892135,0.049774364,0.033641562,0.31321952,0.04387253,0.004834189,0.050648943,-0.056952856,0.051840045,-0.004622082,-0.0029022766,-0.028918024,0.006063617,-0.0041818386,0.019223802,-0.031667218,0.017668251,0.023125196,0.045376316,-0.024328684,-0.03980277,0.024929393,0.0051530804,0.056438677,-0.0009725082,0.0037956084,-0.03239649,-0.012817254,-0.041858695,-0.014856791,-0.06271684,0.033761166,0.031467415,0.011851511,0.051261365,-0.01179492,-0.068899974,-0.014964267,-0.00063179573,0.017690614,-0.009009361,-0.09789638,-0.036439195,-0.0841935,0.023575196,-0.13396092,0.13305002,0.007911912,0.019786658,0.0002827157,0.02192103,0.05638941,-0.043504674,-0.04524754,0.011735054,-0.0035346176,0.0033445251,0.007442268,0.069734655,-0.0006457193,-0.03868659,0.07044447,-0.024192037,0.032955248,-0.011209725,0.03564046,0.039964315,0.09071652,0.08253361,-0.009900468,0.012840352,-0.02295395,0.03471711,-0.022090193,0.0044087064,0.0130827855,0.035907153,0.039426714,-0.03819838,0.030248774,-0.036349647,0.010017172,0.0025868686,0.0013163028,0.03427282,0.08895476,-0.051354308,-0.050073903,-0.0016582799,-0.009518917,0.06254944,0.040961392,0.07374542,0.078283615,-0.038456604,0.13166244,-0.0055810083,0.008324925,-0.021115026,0.04865895,0.040081963,0.04631163,0.04633088,-0.017098077,-0.007893804,0.007607068,-0.07570857,0.064662516,-0.022200007,-0.04613742,0.014698096,-0.040343154,0.0054809875,0.0068689506,0.00092213764,0.006511137,0.036636386,0.0075024543,0.039534982,0.005514188,-0.003920646,0.008136021,0.033838425,0.05254808,-0.015216625,0.031380977,0.0040966547,-0.04814886,-0.027520526,-0.024087062,-0.04536847,-0.05320231,-0.027292114,-0.01939129,0.010507547,0.068630666,0.043998722,0.0801662,0.03348169,-0.009085184,-0.01477701,0.047791857,0.05540584,-0.06736693,0.0020285759,0.013938147,-0.05031106,-0.035206556,0.02761124,-0.04022496,-0.007451326,-0.06296886,-0.022859126,0.09301553,0.048795525,-0.012271036,0.019697173,0.06446396,0.020241095,0.012088095,-0.17798372,-0.027375236,-0.061207205,0.038104277,-0.06642423,-0.009415216,0.052199904,-0.037760843,-0.022187525,0.012181313,-0.041066676,-0.06942215,-0.027730862,-0.009680216,-0.059220828,0.04467606,0.0003948015,0.01014289,0.027306745,0.029429084,0.0493429,-0.039006017,-0.01756003,-0.028417608,-0.027354918,0.042255033,0.061257206,0.0036709877,-0.024329077,-0.050390333,-0.013186946,0.0031478943,0.011040366,0.026129626,0.018130504,-0.027353661,0.019211745,-0.0022117277,0.1118481,0.0782376,0.024995422,0.059711028,-0.008173296,0.017002877,-0.039264616,-0.001962071,0.011470576,-0.032904048,-0.079988904,-0.02629866,0.026457293,-0.053743444,-0.0051814294,0.013066732,0.05321082,0.040862862,-0.0019826875,0.011493213,0.08629233,-0.041718166,0.047269218,0.07769727,-0.044020433,-0.16877456,-0.021221237,-0.011129706,-0.028999822,-0.022866756,-0.010865134,0.009030771,0.003806579,-0.024056332,-0.041828144,0.13366036,0.0550153,-0.0011019756,-0.027688803,0.02077072,0.08133359,-0.016294481,0.046593014,-0.012201837,-0.07112024,-0.03148493,0.046461217,0.13798657,0.004675504,0.04464258,0.018120104,0.020195337,-0.0872914,-0.1429005,0.045251735,0.007702035,-0.019940052,0.0597414,0.0053394698,0.005676257,0.012717743,0.068366244,-0.03198958,0.00562614,-0.023898745,0.14956613,0.028330524,0.0012210672,-0.034995347,0.014900526,-0.0042808442,-0.038005907,-0.0029655711,-0.046612997,-0.023074953,0.0093577355,0.019100675,-0.0048536737,0.03977017,0.02677702,0.05293125,0.005948059,-0.02770206,0.03918424,0.022482652,0.03589692,-0.030975368,-0.03310301,-0.061353248,0.012955803]],"total_duration":282200344,"load_duration":275638829,"prompt_eval_count":8}' + recorded_at: Wed, 26 Mar 2025 17:18:38 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml new file mode 100644 index 00000000..1cbab58b --- /dev/null +++ b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml @@ -0,0 +1,33 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/embed + body: + encoding: UTF-8 + string: '{"model":"snowflake-arctic-embed:22m","input":["Ruby","Python","JavaScript"]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Wed, 26 Mar 2025 17:18:38 GMT + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.0388441,0.020130958,-0.067431964,0.007655712,-0.02143178,0.028401934,-0.059553344,-0.09178961,-0.032458898,0.008410962,-0.055265877,0.014614829,0.029787311,0.03382428,-0.01684954,-0.04444329,0.008301062,-0.0022140234,-0.122114494,-0.008171147,0.008162438,0.07341534,0.018977866,0.013705484,-0.0040139267,0.00035185603,0.0069316016,-0.01251507,-0.09616702,-0.17709394,0.012925018,0.03197588,0.026001623,-0.043088693,0.031905584,-0.04813018,-0.0017315283,0.029841121,-0.026876168,-0.030367695,-0.0067817485,0.02359407,-0.019723006,-0.0030676995,0.010523006,-0.027055979,0.04175819,-0.009885953,0.096520424,0.04388586,-0.03775211,-0.033325512,0.0096065905,-0.0139596285,-0.040052965,-0.002589836,0.046065394,0.004938671,-0.008818979,0.033967253,0.038127918,0.0013382456,-0.34866735,-0.06390991,0.066892646,-0.0076447544,0.034478936,0.0066651497,0.0017603931,-0.005765021,-0.059580464,-0.0011398621,-0.034723498,-0.0070240623,0.033945907,-0.07172375,0.0019033181,0.050755918,0.033208486,-0.044483263,-0.010917951,-0.013006815,0.017780134,0.027302826,0.017522654,0.050923645,-0.045407858,-0.031065013,0.0034971004,0.017281314,0.03732062,-0.020520234,0.034877818,-0.023866747,-0.070485,0.04555996,0.001389987,0.041110877,0.0083451895,0.30750144,0.041160934,-0.007575193,0.06326734,-0.07495616,0.05411205,-0.013711487,-0.018127367,0.0040174066,-0.016591415,-0.009179355,0.033549752,-0.01786939,-0.008867672,0.018478448,0.04625403,-0.028747778,-0.007066149,-0.005806406,0.0062766555,0.04459573,-0.03000371,0.014898422,-0.032604568,-0.017415427,-0.014565004,-0.022372194,-0.06727879,0.0365807,0.00958214,0.045523975,0.028445095,0.011969768,-0.06253902,-0.015415758,-0.0050557056,0.012014955,0.0024233195,-0.07337232,-0.0042311987,-0.07457154,-0.0006373777,-0.16765094,0.13003069,0.03297481,0.0144618815,0.0005355533,0.009557741,0.037592538,-0.012591949,-0.04204159,0.015775016,0.02042741,-0.026271803,0.020424932,0.091125205,-0.014388012,-0.042810924,0.051355045,-0.0075769946,0.03629031,0.010354268,0.0074680853,0.042652246,0.060397565,0.05299325,0.0070928345,0.018289784,-0.019927645,0.008178775,-0.026709922,-0.0004766831,0.018478047,0.012326361,0.061957974,-0.01432786,0.019229595,0.010431529,0.03351462,0.010213068,-0.031673603,0.01589807,0.10027719,-0.039053105,-0.058606964,-0.010657152,0.011582607,0.05528668,0.021357857,0.04105508,0.05390399,-0.0316559,0.156173,-0.048507318,0.012662477,-0.017382665,-0.005330175,0.057885952,0.06385099,0.028633239,-0.0010585266,-0.033099838,0.011883581,-0.054964617,0.034078836,-0.027739037,-0.04053948,0.019028971,-0.008881098,-0.009892724,-0.00016677074,0.008185013,0.014028663,0.015764946,0.013674434,0.040554117,-0.015574529,0.0012967308,-0.019827649,0.044048622,0.054283343,-0.019935552,0.019209668,-0.009141968,-0.06369639,-0.038524695,-0.00584429,-0.05572212,-0.020921145,-0.049070027,-0.01276479,0.051422957,0.062778324,0.02250262,0.11412264,0.014608461,0.0030205897,-0.036526274,0.050726265,0.049905915,-0.065770596,0.008405842,0.0010899245,-0.034585573,-0.004634513,0.012284967,-0.03207842,-0.04583995,-0.048865594,-0.019766245,0.12478698,0.06276402,-0.033869267,0.03652329,0.060382184,0.014759198,0.0046959203,-0.19071387,-0.032657206,-0.07738984,0.0442774,-0.05914576,-0.014506996,0.03734469,-0.0025898803,0.004546905,-0.0117728645,-0.05503146,-0.025510276,-0.020450229,-0.023852503,-0.015572229,0.06172686,0.018116174,0.013062141,0.043132544,0.020856835,0.034402605,-0.0055950414,0.012068603,-0.06377293,0.027816271,0.02069718,0.06381159,0.0031838878,-0.06427212,-0.071605794,-0.053954642,0.032803938,-0.0021615664,0.030591654,0.0039456603,-0.026492551,-0.026371498,-0.024719616,0.14168687,0.0002901896,-0.0034020492,0.031027138,0.0053976467,-0.000027014497,-0.052480403,0.0529854,-0.013960096,-0.03182876,-0.07278522,-0.029438145,-0.0076043443,-0.032225914,0.008225171,0.017322546,0.009984277,0.015520695,-0.0052385437,-0.011876693,0.07715109,-0.045244373,0.008803014,0.02424746,-0.015235667,-0.15054744,-0.0036824355,-0.016711554,-0.0013559143,-0.02194606,0.016720122,0.019720519,0.01517699,-0.03738912,-0.057589684,0.12978709,0.04813223,0.0077710785,-0.015100561,0.004117948,0.08621212,0.027476143,0.04439229,0.00030685926,-0.044507023,0.00089704886,0.061830766,0.16139033,0.024911765,-0.0074146036,0.004032755,0.039143074,-0.0898164,-0.11864838,0.04416452,-0.039557893,-0.03088087,0.11287578,0.043714676,-0.021582166,0.037369095,0.04492175,-0.0010107799,0.03280375,-0.035768308,0.15532315,-0.0009561552,-0.0034369607,-0.029741783,0.008190347,-0.051745743,-0.012318028,0.012402675,-0.04895367,-0.011466236,0.013425867,-0.033821847,-0.015193115,0.010228869,0.03193425,0.02603917,0.037040178,-0.017338518,0.01710686,0.058089267,0.030198513,-0.0008354163,-0.06520546,-0.0921685,-0.005078346],[-0.0072552343,0.03713646,-0.01699283,-0.030782733,-0.02052221,0.01125825,-0.06529242,-0.061818272,-0.020571295,-0.024209626,-0.03579918,0.015797382,0.061592482,0.02068423,0.016780416,-0.023932647,-0.010951945,0.025292471,-0.15266368,-0.012987599,-0.010199094,0.029842783,0.017119406,0.03163956,0.021315867,0.0035011058,0.013092083,-0.037269205,-0.13100713,-0.15873815,0.024110278,0.0054965187,-0.0057078693,-0.042900756,-0.00460323,-0.043012183,0.002026602,0.044829354,-0.0321034,-0.027913237,-0.0035799183,-0.0075295595,-0.013355917,0.0045460337,0.046187807,0.0027242594,0.049688134,-0.021872735,0.068736166,0.04175792,-0.0437622,0.014226286,-0.037445676,-0.055501036,-0.045524184,-0.001189907,0.044486266,-0.007421061,-0.0097211385,0.008858515,0.007311453,0.024857061,-0.35175383,-0.012672284,0.041481517,0.047193956,0.0020684737,0.047606543,-0.026176704,-0.025530554,-0.026922593,0.017605826,0.014854451,0.005629944,0.023153292,-0.041461922,-0.003056519,0.012925506,0.05518522,-0.038745392,0.026249396,0.03217421,0.019464033,-0.018742876,-0.013937561,0.045195688,-0.018083213,-0.012282628,0.0471358,0.0008688498,-0.028306754,0.0408566,0.024084115,0.0005985765,-0.06742631,0.009600122,-0.019761212,0.052697483,0.045696277,0.29864073,0.03026967,-0.0415359,0.016219707,-0.037604477,0.053452723,-0.029339043,-0.008365499,-0.03606822,0.021689609,-0.029203571,0.01769295,-0.021349482,-0.002733219,0.0033789296,0.031930774,-0.028539872,-0.04999919,0.007576535,-0.005124299,0.05567214,-0.048217237,-0.0006354506,-0.023972036,-0.052717745,0.0013329871,-0.016641501,-0.05940865,0.014591998,-0.007996123,-0.0060994998,0.034148518,-0.020664569,-0.09358414,-0.0194255,-0.0128993485,0.022041388,0.032610774,-0.052574314,0.016395817,-0.047118947,0.015677843,-0.13766375,0.10541323,0.0026426625,0.011538131,0.026277615,-0.02502458,0.0049760668,-0.053827237,-0.03863926,0.023165068,0.016438669,-0.0151872,0.002109835,0.12469035,0.020599306,-0.006932304,0.031132199,-0.011493038,0.0051031685,0.017425977,0.019842505,-0.006905538,0.03286136,0.029737378,-0.03871717,0.03207742,-0.017586391,0.019399468,-0.003148388,0.018489016,0.018581418,-0.012901189,0.017172573,-0.05461113,-0.001390115,-0.03233814,0.0011009739,0.03855168,-0.033363048,-0.015336527,0.080612056,-0.028678833,-0.046856903,-0.015384176,0.052241,0.059723865,0.032644298,0.059932925,0.06560817,-0.025778033,0.19489264,-0.09447736,-0.021961018,0.021270901,-0.004714235,0.03169394,0.033007365,-0.017643515,-0.023465928,-0.024755051,-0.014296845,-0.0002619207,0.015911218,0.015445326,-0.079413936,-0.0057071378,0.017307783,-0.005565825,-0.012172522,-0.009783294,-0.05173357,0.03838994,0.03412497,0.07624654,0.032628186,0.016304875,0.012916574,0.024889637,0.026531337,-0.0040279627,0.04415734,-0.02977549,-0.06746127,-0.03022296,-0.0021678545,-0.06871879,-0.0020891097,-0.082151935,-0.0058978163,0.03801924,0.039217323,0.03492099,0.113563396,0.025192197,0.018200427,0.024883514,0.027362043,0.011942755,-0.06134862,0.0019354849,0.015484824,-0.040022288,-0.024537606,0.020911857,-0.07808669,-0.019743685,-0.046418775,-0.03314287,0.1694522,0.050321065,-0.013430357,0.0070345113,0.038134124,0.0010241308,-0.011185799,-0.1828692,-0.025442472,-0.028564518,0.044677004,-0.0028425956,-0.00042380465,0.04030299,0.022801027,-0.009841054,-0.029609146,-0.009356221,-0.03580966,-0.028770214,-0.050125327,-0.031781837,0.104847625,0.026230568,0.02514224,0.0053547267,-0.009917238,0.07282194,0.029626124,-0.030785127,0.005750769,0.013035853,0.027320353,0.04267924,0.024914404,-0.031501085,-0.05527291,-0.04931349,-0.00094031333,-0.0029171903,0.067338765,-0.041093227,0.00045597606,-0.008067708,-0.026840648,0.18961208,0.0021951848,0.016140003,0.038745787,-0.016722713,0.0016434207,0.002311968,0.039490942,-0.03590958,-0.0054072104,-0.03100541,-0.014101151,0.058239665,-0.038461883,-0.02283073,0.008492259,-0.013109407,0.02975444,0.024842035,-0.015734265,0.09163665,-0.057609167,0.035152502,0.037537843,0.021865102,-0.2016707,-0.03457164,-0.013295931,0.048858218,-0.058543745,0.018288808,0.028178774,-0.0111076655,0.020360066,-0.026658798,0.11522286,0.053960584,-0.017099507,-0.0043872525,0.046700936,0.054960232,0.014453873,0.019755626,-0.013162808,-0.040781327,0.0028153716,0.060916595,0.15055314,-0.0048034787,0.040378716,0.023411844,0.0069524855,-0.03615119,-0.11237404,0.02728505,-0.032408927,-0.033139788,0.05818729,0.019382754,-0.035828292,0.023392975,0.071280956,-0.036502235,0.008983084,-0.034260582,0.1593053,-0.028021295,0.0172493,-0.016131653,-0.033713784,-0.04138278,0.00016605067,0.0054855584,-0.054233927,-0.013987903,0.022237027,-0.010095551,0.006079947,0.031176228,0.034318067,0.027573293,0.020763315,-0.019646917,0.012187558,0.04892568,0.04229697,0.034125984,-0.018135771,-0.035252318,-0.057188697],[0.010169066,0.014699193,0.02312678,-0.031285737,-0.019339556,0.01898938,-0.042842016,-0.065713726,0.037114225,-0.0019252088,-0.04387124,0.02680714,0.017134406,0.010056415,0.016514305,-0.07524968,-0.004598689,-0.0077995756,-0.16111827,-0.018086512,-0.023329865,0.07266939,0.035500344,0.007105781,-0.037746858,0.03954511,0.010651382,-0.03404992,-0.13568549,-0.1758981,0.017500464,0.021587882,-0.00029796895,-0.05286976,-0.021638112,-0.020357909,-0.03505305,0.015242394,-0.013434969,-0.03953229,0.007741148,-0.016568061,-0.046428822,-0.0113176145,0.050263844,-0.013899913,0.023608234,-0.030784462,0.024582472,0.041902494,-0.05761777,-0.032375082,0.00036015094,-0.03865763,-0.046571795,0.050851,-0.011026816,-0.03191825,0.010439611,0.01701438,0.0055330084,0.0587453,-0.3662647,0.025101654,0.07276847,0.019127958,-0.018416954,-0.0078095226,-0.00087658176,0.015874607,0.038312003,-0.014843252,-0.0125896605,0.01718569,0.026865218,-0.04576379,0.00359911,0.021899922,0.06563156,-0.042660784,0.0018792639,0.020148722,0.016360225,0.030104727,-0.015654275,0.06526195,0.0061962763,-0.028802281,0.038764264,0.0048531652,-0.048788548,0.035097387,0.0030290019,-0.002194582,-0.048610423,0.0012355483,0.0014674183,0.034617357,0.018160649,0.30238912,0.018115664,0.0030157077,0.040349476,-0.0703222,0.05237721,-0.0028105106,-0.028073953,-0.021660421,0.031953406,-0.0390731,0.0028894274,-0.017770546,0.005304085,-0.0061753215,0.054985832,-0.0013282879,-0.016932156,-0.009256211,0.023674654,0.043953825,-0.027819972,0.025420371,-0.04043455,-0.005284352,-0.010442454,0.0035201733,-0.06362815,0.02499165,-0.04596317,-0.011497569,0.05550298,0.00008448542,-0.09329214,0.019624306,0.022909734,0.03186377,0.0010003478,-0.031093974,0.0253383,-0.031195963,-0.018049393,-0.13012893,0.10688446,-0.010589804,0.025470642,-0.0050498014,-0.028474659,0.043146398,-0.026209809,-0.014387408,0.024687277,0.033259496,-0.04391259,-0.0050338595,0.0845666,0.022489144,0.0029990883,-0.0035517574,-0.006752627,0.029374328,0.02664534,0.025731422,0.059084013,0.08346221,0.032861166,-0.09516849,0.057318185,0.024989773,0.014103997,-0.004171578,0.018135788,-0.024807887,-0.041765466,-0.025802964,-0.012921618,-0.008061644,-0.028848117,-0.0005917901,0.02881574,-0.051334593,0.0027097291,0.063163355,-0.026775215,-0.08124945,-0.0105067,0.025091348,0.03696275,0.012843601,0.031530064,0.06319013,-0.027962644,0.17676653,-0.08200779,-0.03632199,-0.034959286,0.02156012,0.015361243,0.043850943,-0.0021428494,0.011226801,-0.046751194,-0.07139608,0.009606031,0.035172343,-0.04229935,-0.03569737,0.04477027,0.013450342,0.04269794,-0.008891381,-0.031291332,-0.0022993302,0.09038422,0.02420419,0.031999685,-0.0051883184,-0.010298845,0.028453493,0.0050622746,0.04699291,0.006085575,0.018052265,-0.022887442,-0.045732647,0.009925399,0.0068673166,-0.040608596,-0.013074616,-0.04770688,0.0011602375,0.078974366,0.04360928,0.040327042,0.073482476,0.06473103,0.014272077,-0.0487856,0.032009773,0.012478921,-0.0383686,0.016539803,0.0066691204,-0.040024173,-0.056614283,0.04952658,-0.09106773,-0.030492447,0.010533615,-0.029398412,0.18325548,0.09290254,0.027460678,0.01589842,0.031662818,-0.06166192,0.0014848855,-0.11129306,0.010330616,-0.040127635,0.03328302,-0.025017919,-0.03147771,0.06017222,-0.029784242,-0.026018031,-0.0014891784,-0.0060136514,-0.02197994,-0.005521501,-0.02919752,-0.040479988,0.09514643,0.019242264,0.042500548,0.00066325505,-0.009165173,0.025331255,-0.014075222,-0.058067344,-0.020931922,0.018429274,-0.002701154,0.053624205,0.034054026,-0.00924732,-0.07858087,-0.023325374,0.035447456,0.07162372,0.006831908,-0.03824091,-0.012311438,-0.010005245,-0.0059660277,0.12724046,0.0014100341,0.018896865,0.021953704,-0.04847068,-0.03720164,-0.009651089,0.054688897,0.013091016,-0.013793644,-0.04749705,-0.018131005,0.017314631,-0.028080247,-0.030335128,-0.0028840683,-0.04583448,0.0028758575,0.0152386045,-0.007833423,0.10375125,-0.016216613,0.017764568,0.037414994,0.0022454704,-0.17834663,-0.03604582,-0.00064713095,-0.014282952,-0.063561186,-0.030035643,0.02400106,-0.0008161259,0.025210572,-0.04692099,0.15453176,0.08460845,-0.018154804,-0.030075192,0.033266056,0.09898789,0.016117847,0.010213679,-0.018335694,-0.006946004,0.017542744,0.09943681,0.12576352,0.02319345,0.008129597,0.0032028987,-0.0053399303,-0.047532618,-0.13376793,-0.0018692309,-0.045244668,-0.020810418,0.06288976,0.00091563916,0.0054674884,0.005820324,0.031138638,-0.03758025,0.016956536,-0.04498085,0.13776563,-0.01599851,-0.000038715556,-0.008666058,-0.01248527,-0.002156642,0.022566035,0.051826704,-0.042339765,0.008286659,0.012520414,-0.004150474,-0.013118474,0.048206005,0.0003086508,-0.008351304,0.012447726,0.006553263,0.03620175,0.03051183,0.03917375,-0.029004231,-0.016662572,-0.07127831,-0.020850424]],"total_duration":7034636,"load_duration":731830,"prompt_eval_count":4}' + recorded_at: Wed, 26 Mar 2025 17:18:38 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/models_refresh_updates_models_and_returns_a_chainable_models_instance.yml b/spec/fixtures/vcr_cassettes/models_refresh_updates_models_and_returns_a_chainable_models_instance.yml index 0b01884f..ea64e3c2 100644 --- a/spec/fixtures/vcr_cassettes/models_refresh_updates_models_and_returns_a_chainable_models_instance.yml +++ b/spec/fixtures/vcr_cassettes/models_refresh_updates_models_and_returns_a_chainable_models_instance.yml @@ -1239,4 +1239,32 @@ http_interactions: encoding: ASCII-8BIT string: '{"object":"list","data":[{"id":"deepseek-chat","object":"model","owned_by":"deepseek"},{"id":"deepseek-reasoner","object":"model","owned_by":"deepseek"}]}' recorded_at: Tue, 25 Mar 2025 17:50:51 GMT +- request: + method: get + uri: http://localhost:11434/api/tags + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.12.2 + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Wed, 26 Mar 2025 17:18:38 GMT + Content-Length: + - '681' + body: + encoding: UTF-8 + string: '{"models":[{"name":"snowflake-arctic-embed:22m","model":"snowflake-arctic-embed:22m","modified_at":"2025-03-26T17:18:08.367580922Z","size":45838698,"digest":"bf75350e17522c7dfe63e98f50457b27fadcfee62f0c0767c1c86053407c2abb","details":{"parent_model":"","format":"gguf","family":"bert","families":["bert"],"parameter_size":"23M","quantization_level":"F16"}},{"name":"smollm:135m","model":"smollm:135m","modified_at":"2025-03-26T17:18:01.303574119Z","size":91739413,"digest":"b0b2a46174385c0adcaa77ff245ffeced5fc4a61447b6f221b2beb5c5a760133","details":{"parent_model":"","format":"gguf","family":"llama","families":["llama"],"parameter_size":"134.52M","quantization_level":"Q4_0"}}]}' + recorded_at: Wed, 26 Mar 2025 17:18:38 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/models_refresh_works_as_a_class_method_too.yml b/spec/fixtures/vcr_cassettes/models_refresh_works_as_a_class_method_too.yml index d2efc013..67c955d8 100644 --- a/spec/fixtures/vcr_cassettes/models_refresh_works_as_a_class_method_too.yml +++ b/spec/fixtures/vcr_cassettes/models_refresh_works_as_a_class_method_too.yml @@ -1239,4 +1239,32 @@ http_interactions: encoding: ASCII-8BIT string: '{"object":"list","data":[{"id":"deepseek-chat","object":"model","owned_by":"deepseek"},{"id":"deepseek-reasoner","object":"model","owned_by":"deepseek"}]}' recorded_at: Tue, 25 Mar 2025 17:50:52 GMT +- request: + method: get + uri: http://localhost:11434/api/tags + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.12.2 + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Wed, 26 Mar 2025 17:18:38 GMT + Content-Length: + - '681' + body: + encoding: UTF-8 + string: '{"models":[{"name":"snowflake-arctic-embed:22m","model":"snowflake-arctic-embed:22m","modified_at":"2025-03-26T17:18:08.367580922Z","size":45838698,"digest":"bf75350e17522c7dfe63e98f50457b27fadcfee62f0c0767c1c86053407c2abb","details":{"parent_model":"","format":"gguf","family":"bert","families":["bert"],"parameter_size":"23M","quantization_level":"F16"}},{"name":"smollm:135m","model":"smollm:135m","modified_at":"2025-03-26T17:18:01.303574119Z","size":91739413,"digest":"b0b2a46174385c0adcaa77ff245ffeced5fc4a61447b6f221b2beb5c5a760133","details":{"parent_model":"","format":"gguf","family":"llama","families":["llama"],"parameter_size":"134.52M","quantization_level":"Q4_0"}}]}' + recorded_at: Wed, 26 Mar 2025 17:18:38 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/providers_ollama_chat_ask_works.yml b/spec/fixtures/vcr_cassettes/providers_ollama_chat_ask_works.yml deleted file mode 100644 index 8ca26bdb..00000000 --- a/spec/fixtures/vcr_cassettes/providers_ollama_chat_ask_works.yml +++ /dev/null @@ -1,45 +0,0 @@ ---- -http_interactions: -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"smollm:135m","messages":[{"role":"user","content":"Count - from 1 to 3"}],"options":{"temperature":0.7},"stream":false}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/json; charset=utf-8 - Date: - - Tue, 25 Mar 2025 11:42:35 GMT - Server: - - Caddy - Vary: - - Accept-Encoding - Content-Length: - - '812' - body: - encoding: ASCII-8BIT - string: '{"model":"smollm:135m","created_at":"2025-03-25T11:42:35.763421821Z","message":{"role":"assistant","content":"To - count the number of numbers in a list, you can use the `count()` method on - an iterable object like a list or tuple. The `count()` method returns the - number of occurrences of each item in the iterable and its position in the - list. To find the first occurrence of an element, you can access it using - indexing and then return the value obtained by that index:\n\n```python\nnumbers - = [1, 2, 3]\nresult = numbers[0] == 1 or numbers[1] == 3\nassert result == - True\n# ... (approximate count of numbers in list)\n```"},"done_reason":"stop","done":true,"total_duration":1783007537,"load_duration":1218168782,"prompt_eval_count":16,"prompt_eval_duration":186161937,"eval_count":132,"eval_duration":376576424}' - recorded_at: Tue, 25 Mar 2025 11:42:31 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_a_single_text.yml b/spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_a_single_text.yml deleted file mode 100644 index bd9fa5d5..00000000 --- a/spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_a_single_text.yml +++ /dev/null @@ -1,38 +0,0 @@ ---- -http_interactions: -- request: - method: post - uri: http://localhost:11434/api/embed - body: - encoding: UTF-8 - string: '{"model":"snowflake-arctic-embed:22m","input":"Ruby is a programmer''s - best friend"}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/json; charset=utf-8 - Date: - - Tue, 25 Mar 2025 11:42:36 GMT - Server: - - Caddy - Vary: - - Accept-Encoding - Transfer-Encoding: - - chunked - body: - encoding: ASCII-8BIT - string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.025825415,-0.023176115,-0.052045297,-0.023625664,0.0006673469,0.009949714,-0.04538417,-0.06849524,-0.019409077,0.0010184002,-0.054927465,0.04728714,0.032690506,0.030963264,-0.028091758,-0.05092271,0.00021566867,0.023615433,-0.12640688,0.015840458,0.012315658,0.087370574,0.011073331,0.0090212375,0.007156342,-0.0052327104,0.021913407,-0.020346882,-0.03459649,-0.20068292,0.021031896,0.07291515,0.031049531,-0.04963502,0.023327535,-0.06476457,0.0131773045,0.004342761,-0.05204616,-0.03947274,0.0122103775,0.003776148,-0.050048206,-0.017586641,-0.029104842,-0.016230974,0.021660762,-0.017151477,0.0865443,0.01920734,-0.042871486,-0.0089291595,-0.02822964,-0.04884569,-0.018680912,-0.01892585,0.015438859,0.0065737013,-0.021804608,0.00633415,0.0343607,0.0017093703,-0.34944108,-0.06468269,0.0478818,-0.00246448,0.046574403,0.02243261,-0.024708489,-0.016602987,-0.011909359,0.014165576,-0.07424154,-0.03776865,0.032787047,-0.05530688,0.013535443,0.042380534,0.038827997,-0.033742167,0.015697544,0.009775907,0.0042203693,0.0011168025,0.023423292,0.04484947,-0.043061797,-0.05383481,-0.028867329,-0.0033860689,0.018773982,-0.018347567,0.03903167,-0.029658085,-0.06440208,0.040508885,-0.0017985007,0.049720276,0.033716165,0.31325525,0.04386892,0.0048334296,0.050675593,-0.056929454,0.0518016,-0.004611103,-0.0029309082,-0.028916717,0.0060408665,-0.004141483,0.01923389,-0.031655706,0.01768319,0.02311225,0.045390822,-0.024344986,-0.039786555,0.024944702,0.005075094,0.056426894,-0.0009737753,0.0037892968,-0.032363605,-0.012793344,-0.041841026,-0.014850747,-0.06273983,0.033704888,0.031475354,0.011834117,0.05125323,-0.011774348,-0.06885821,-0.014935385,-0.0006414335,0.017715653,-0.008953341,-0.097899854,-0.036503628,-0.084191576,0.023606507,-0.1339018,0.1330882,0.007957225,0.01985772,0.00030814653,0.021941159,0.05639211,-0.043463834,-0.045274723,0.011725757,-0.003486319,0.003375221,0.0074666464,0.06974618,-0.0006389784,-0.038667206,0.07041848,-0.02421246,0.03300245,-0.011266481,0.035639856,0.040018253,0.09069596,0.08246825,-0.009912788,0.012884513,-0.022981415,0.03470591,-0.022104705,0.0043493398,0.013083702,0.035951313,0.03946172,-0.038252268,0.030231304,-0.036359355,0.01005223,0.0025720727,0.0013707506,0.034241233,0.088925935,-0.051440887,-0.050102297,-0.0016456994,-0.009496842,0.062487546,0.040939905,0.07381002,0.078291304,-0.038428534,0.1316706,-0.0055638882,0.008280254,-0.021145111,0.04876571,0.040031683,0.04628573,0.046338666,-0.017028602,-0.007903445,0.007545737,-0.07565534,0.064689994,-0.022149073,-0.046088018,0.014704514,-0.040415496,0.00550196,0.006901969,0.00089305703,0.006521102,0.0366565,0.0074207284,0.039539423,0.005592426,-0.003989626,0.008083243,0.033852484,0.052595314,-0.015218367,0.03131478,0.0040506576,-0.048098013,-0.027468681,-0.024048975,-0.04536876,-0.05319465,-0.027298115,-0.01941297,0.010558779,0.06863464,0.04396793,0.08020219,0.033566475,-0.009056651,-0.014715962,0.04780099,0.05536488,-0.06740807,0.002055909,0.013943318,-0.05024147,-0.035200298,0.027621565,-0.040184192,-0.007491963,-0.06297288,-0.022879997,0.093055375,0.04880813,-0.012168053,0.019717308,0.064516716,0.020201867,0.012079503,-0.17798914,-0.027345736,-0.0612433,0.038101118,-0.06641872,-0.00939703,0.052195832,-0.03770301,-0.022270007,0.012196051,-0.041005902,-0.06945124,-0.027733557,-0.009639078,-0.059247572,0.04474978,0.00042829235,0.010153207,0.02728113,0.029422356,0.049308695,-0.038985588,-0.017589854,-0.02842523,-0.027386962,0.042216763,0.061242577,0.003747581,-0.024338258,-0.050467186,-0.013143215,0.0031099522,0.010997509,0.026045857,0.01815751,-0.027380131,0.01929404,-0.0022469186,0.111852795,0.07823112,0.024928685,0.059756078,-0.008221097,0.016979527,-0.039244134,-0.0019415446,0.011487329,-0.03280691,-0.08006135,-0.026343029,0.026450884,-0.053655412,-0.005154362,0.01307755,0.053237017,0.04086586,-0.0019484188,0.011518151,0.08618621,-0.041709326,0.047144253,0.077645905,-0.044002645,-0.16881582,-0.02115599,-0.011150404,-0.029005526,-0.022859793,-0.0107934745,0.009013299,0.0037840477,-0.023908136,-0.041892353,0.13362311,0.05498781,-0.0010903508,-0.027582854,0.02074264,0.08133009,-0.016295228,0.046583474,-0.012219358,-0.07110713,-0.031505097,0.04635908,0.13795494,0.004750067,0.044614047,0.018176915,0.020094909,-0.08733446,-0.14297998,0.045279857,0.0077459584,-0.019933412,0.059806284,0.0053598317,0.005684153,0.01267696,0.06831267,-0.03196309,0.0056615137,-0.023855256,0.14950311,0.028314097,0.0012290949,-0.034989975,0.014838987,-0.0043164054,-0.0380489,-0.002994491,-0.04658432,-0.023052199,0.009330306,0.019073954,-0.0048254183,0.039711606,0.026755748,0.05285787,0.005976852,-0.02769884,0.03918166,0.022543069,0.035913944,-0.030974701,-0.033151094,-0.061393328,0.012922418]],"total_duration":926343313,"load_duration":836913075,"prompt_eval_count":8}' - recorded_at: Tue, 25 Mar 2025 11:42:32 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_multiple_texts.yml b/spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_multiple_texts.yml deleted file mode 100644 index d5dcdb36..00000000 --- a/spec/fixtures/vcr_cassettes/providers_ollama_embeddings_can_handle_multiple_texts.yml +++ /dev/null @@ -1,37 +0,0 @@ ---- -http_interactions: -- request: - method: post - uri: http://localhost:11434/api/embed - body: - encoding: UTF-8 - string: '{"model":"snowflake-arctic-embed:22m","input":["Ruby","Python","JavaScript"]}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/json; charset=utf-8 - Date: - - Tue, 25 Mar 2025 11:42:36 GMT - Server: - - Caddy - Vary: - - Accept-Encoding - Transfer-Encoding: - - chunked - body: - encoding: ASCII-8BIT - string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.038980126,0.020101948,-0.067413226,0.007685114,-0.021361317,0.028405204,-0.05964908,-0.09178641,-0.032397546,0.008366828,-0.05523459,0.014637846,0.0298761,0.03387804,-0.016674861,-0.044479024,0.008276525,-0.0022477629,-0.12195336,-0.008178106,0.008199949,0.07350191,0.01897805,0.013661541,-0.003947917,0.00030909953,0.006917925,-0.012626692,-0.09616951,-0.17709318,0.01293276,0.031847943,0.025997223,-0.042996813,0.03192809,-0.048060544,-0.0017395425,0.029812165,-0.026901668,-0.030327402,-0.0068094945,0.023497479,-0.019625092,-0.003110331,0.010590182,-0.027034454,0.04182794,-0.009884578,0.09661056,0.043840215,-0.037773125,-0.033335246,0.009626258,-0.013944384,-0.040054895,-0.0026200123,0.046114273,0.0049590026,-0.008846017,0.034012534,0.038100995,0.0013456035,-0.34869465,-0.06399822,0.06681992,-0.007770172,0.03451249,0.006695025,0.0016939766,-0.005725403,-0.059506737,-0.0011312707,-0.034694858,-0.0070268526,0.033973437,-0.07178208,0.0019529031,0.050796922,0.033150885,-0.04453945,-0.010778929,-0.01298108,0.01772847,0.027397834,0.017516151,0.05094088,-0.045374986,-0.031055674,0.0034364148,0.017342873,0.03724968,-0.020449797,0.03487508,-0.023868825,-0.0705106,0.045591667,0.0014132301,0.04102965,0.0082013225,0.3076015,0.041163538,-0.0075212517,0.0632507,-0.07494113,0.054058343,-0.013692275,-0.018088195,0.0039990763,-0.016607765,-0.00915819,0.03353369,-0.017990997,-0.008927891,0.018497262,0.04622437,-0.028729072,-0.0070351255,-0.005821854,0.0063457754,0.044443272,-0.03001723,0.014840464,-0.03265875,-0.017414864,-0.014599514,-0.022385433,-0.06727593,0.03655243,0.009642398,0.04557801,0.028509801,0.011939836,-0.062560804,-0.015390183,-0.0050801174,0.011868977,0.00253459,-0.07341563,-0.004279252,-0.07461656,-0.0006562158,-0.16768059,0.13006905,0.03295397,0.0145061985,0.000511846,0.009465702,0.037566304,-0.012595248,-0.042188045,0.015753305,0.02033451,-0.026321119,0.020434551,0.09113539,-0.014463864,-0.04273769,0.05132384,-0.007610653,0.036329918,0.010425151,0.0075439727,0.042681746,0.060391378,0.053032257,0.0071610347,0.018304583,-0.0199126,0.008234456,-0.026586238,-0.00048163044,0.018455869,0.012418799,0.061977547,-0.014351739,0.019218396,0.010331768,0.033490002,0.0102368975,-0.031620093,0.015966186,0.10022163,-0.03886677,-0.058662754,-0.010719046,0.011613407,0.055317454,0.021442259,0.041051246,0.05395217,-0.031625535,0.1561225,-0.04847817,0.012704446,-0.017351678,-0.005412353,0.05782586,0.063770935,0.028648905,-0.0010758642,-0.03315512,0.011804742,-0.054954775,0.034165937,-0.027770827,-0.040539972,0.01901002,-0.008845964,-0.009943114,-0.00007340114,0.008205162,0.014036151,0.015788715,0.013589957,0.040579043,-0.015481178,0.0013020202,-0.019863069,0.044024546,0.054241393,-0.019910982,0.019316196,-0.009067846,-0.06370655,-0.038542934,-0.005822525,-0.05564244,-0.020892167,-0.04894251,-0.012727646,0.05143602,0.06270096,0.022492254,0.11401925,0.014643738,0.0030262705,-0.036580373,0.05074049,0.04994587,-0.06580306,0.008364971,0.0012129012,-0.034641,-0.0046832887,0.012338395,-0.032140378,-0.045876123,-0.048861995,-0.019786038,0.12485802,0.06277426,-0.033950374,0.036432575,0.06035506,0.014863595,0.0047113854,-0.19050083,-0.032735668,-0.077262625,0.044320498,-0.059189577,-0.014459053,0.03718649,-0.0026039602,0.004493112,-0.011763187,-0.05504196,-0.025533773,-0.02048363,-0.023919607,-0.015506923,0.061790027,0.01816571,0.0130165955,0.04316555,0.020895818,0.034394037,-0.00560091,0.011984886,-0.06372637,0.02781977,0.020621277,0.06389801,0.0032279587,-0.064306036,-0.07160552,-0.05394653,0.032840647,-0.0021832213,0.030553438,0.0039347326,-0.026431374,-0.026453791,-0.024773262,0.14158836,0.00027325953,-0.003358694,0.031054376,0.005467873,-0.000014875217,-0.05249387,0.05296582,-0.013941867,-0.031785127,-0.07282081,-0.029387616,-0.0076221772,-0.032214306,0.008221592,0.01732765,0.01000591,0.015568096,-0.005231348,-0.012036904,0.07718011,-0.045315113,0.008787361,0.02417641,-0.015230668,-0.15053827,-0.0037556684,-0.01667005,-0.0013223562,-0.02209581,0.016655259,0.019694244,0.015031552,-0.037394483,-0.057655845,0.12982553,0.04818329,0.0077882116,-0.015061786,0.004192891,0.08628084,0.027619699,0.044403546,0.00034237612,-0.044426452,0.00096744276,0.06186224,0.16129373,0.024928987,-0.0073914034,0.0040016263,0.039090827,-0.08990263,-0.118701264,0.04410862,-0.03954887,-0.030827247,0.112970345,0.04363939,-0.021480395,0.03728192,0.044834364,-0.0009248547,0.032832358,-0.035760213,0.15535384,-0.0009505413,-0.0034093896,-0.029711511,0.008248596,-0.051867787,-0.012275803,0.012434058,-0.04902186,-0.011476671,0.0133925,-0.03379115,-0.0151935695,0.010195133,0.031876706,0.025932532,0.036986034,-0.01739396,0.017166032,0.05808856,0.030131826,-0.0008843879,-0.06526332,-0.09222386,-0.0049838475],[-0.007225496,0.037155706,-0.016906068,-0.030758644,-0.020417303,0.011231278,-0.06530078,-0.061754078,-0.020577524,-0.024164986,-0.035808578,0.015893035,0.061571326,0.020668881,0.016767306,-0.023883428,-0.01099219,0.025237663,-0.15266667,-0.013051586,-0.010288909,0.029873036,0.017107742,0.0315594,0.021337744,0.0034486242,0.013156374,-0.037249252,-0.13094991,-0.15867794,0.024068367,0.005509016,-0.0056714285,-0.042848945,-0.0045933733,-0.04299176,0.0020768172,0.04483032,-0.03212172,-0.027772011,-0.0036520734,-0.0075447895,-0.013391376,0.0045278594,0.04607957,0.0027125278,0.049626715,-0.021857744,0.06873977,0.04173157,-0.04370165,0.014249006,-0.0373972,-0.05551407,-0.045433797,-0.0011728521,0.044487648,-0.0074436087,-0.00975718,0.008799588,0.0073077497,0.024823438,-0.35174075,-0.012705645,0.04136241,0.047284245,0.0020329098,0.04765345,-0.02604234,-0.02548834,-0.02704063,0.017578213,0.01482943,0.0055936393,0.023184825,-0.041498873,-0.003050582,0.012843925,0.05516694,-0.03866418,0.02621437,0.032198943,0.01935349,-0.018680874,-0.013953387,0.0451372,-0.018057078,-0.012344732,0.04716202,0.0010259423,-0.028411478,0.04075236,0.024121404,0.0006758823,-0.0674563,0.009551461,-0.01973488,0.05264174,0.04568158,0.29859018,0.030333413,-0.04152799,0.016276676,-0.037692044,0.053379524,-0.029166088,-0.008381986,-0.03611233,0.021734668,-0.02926269,0.01770523,-0.021257408,-0.0026680147,0.0033788746,0.03192171,-0.02859868,-0.050017837,0.007628301,-0.005211484,0.055639394,-0.04813225,-0.00062740705,-0.023975527,-0.05272858,0.0012510746,-0.016620526,-0.05937839,0.014596674,-0.007940771,-0.0060859257,0.03417475,-0.020669967,-0.09361984,-0.019438276,-0.012983339,0.022100516,0.03252378,-0.052587945,0.016381664,-0.047060754,0.015694086,-0.1377361,0.10544033,0.0026725356,0.01146019,0.026346128,-0.025007993,0.004997534,-0.053778246,-0.038643032,0.023108022,0.016371924,-0.015227947,0.0020684898,0.124686636,0.02065184,-0.0070788977,0.031109046,-0.011467157,0.0051159468,0.0174688,0.019905413,-0.0069136377,0.032805618,0.029705629,-0.038734376,0.032078113,-0.01761205,0.01944323,-0.0030690655,0.018461121,0.018608272,-0.012803209,0.017234804,-0.05453963,-0.0014086623,-0.032340996,0.0010491384,0.038566574,-0.03347248,-0.015357926,0.08070545,-0.028756669,-0.046844523,-0.01529485,0.052366853,0.059635386,0.03260225,0.05999529,0.06562162,-0.025594424,0.19492106,-0.09446214,-0.02200547,0.021350436,-0.0047113174,0.03170546,0.032968767,-0.017730163,-0.023518713,-0.024787944,-0.014301349,-0.00028776744,0.015872791,0.015544321,-0.079372294,-0.005725175,0.017331447,-0.0056501715,-0.012182198,-0.009767331,-0.05171092,0.038543854,0.034115233,0.07627104,0.032627165,0.016347326,0.012965246,0.024923127,0.02650983,-0.0040691686,0.04411213,-0.02981039,-0.06744219,-0.030292222,-0.0021420228,-0.06861754,-0.0020280352,-0.08233997,-0.0059836525,0.037955742,0.039244626,0.034866735,0.11366857,0.02521095,0.018243132,0.024956543,0.027358694,0.011940862,-0.061406422,0.0018358993,0.015471496,-0.0400448,-0.024514355,0.020818526,-0.078023,-0.019798901,-0.046464335,-0.03319194,0.16930555,0.050408904,-0.013528864,0.007027566,0.0381429,0.0010658541,-0.011183001,-0.18296444,-0.025517514,-0.028616475,0.044594944,-0.002806602,-0.00036968052,0.040348303,0.022882342,-0.0099050915,-0.029638626,-0.009392766,-0.035751175,-0.02882233,-0.05017968,-0.031793848,0.104784735,0.026196804,0.025192862,0.0053355214,-0.009864406,0.07273947,0.029665705,-0.030834008,0.005743688,0.0130977845,0.027437972,0.042631894,0.02490531,-0.031600703,-0.055224583,-0.04933041,-0.0008777641,-0.002849928,0.06742398,-0.041109774,0.00045421268,-0.008093842,-0.026830377,0.18975478,0.0022353292,0.016124677,0.03874153,-0.01676804,0.0016409162,0.0022479978,0.039468583,-0.03589011,-0.005279329,-0.031004557,-0.014081007,0.058285933,-0.03845023,-0.022855511,0.008495943,-0.013061212,0.029775871,0.024829257,-0.015684903,0.09160675,-0.057623718,0.035138898,0.037533384,0.02173393,-0.20164658,-0.034627892,-0.013216875,0.04897353,-0.058580056,0.018308442,0.028224163,-0.011080451,0.020418232,-0.026639828,0.1152522,0.05399439,-0.017088734,-0.0043683355,0.04675239,0.055089362,0.01442295,0.019836834,-0.013131093,-0.040812545,0.0028349068,0.06096238,0.15055773,-0.0047997017,0.04041006,0.023423078,0.0068679894,-0.036161505,-0.11227965,0.027264446,-0.032434683,-0.033046544,0.05816228,0.019367868,-0.035861887,0.023473343,0.07127074,-0.036597442,0.00892375,-0.03424332,0.15918937,-0.028045062,0.01727863,-0.016116075,-0.033897277,-0.04147993,0.000102095604,0.0054549514,-0.054227076,-0.014035331,0.022229984,-0.0101330625,0.0061006444,0.031121459,0.034375396,0.027529038,0.02083103,-0.01970649,0.01220227,0.048865896,0.04224607,0.034099545,-0.018085487,-0.035159428,-0.057188712],[0.010182182,0.01467856,0.02307528,-0.031243263,-0.019379467,0.018989552,-0.04283347,-0.065710135,0.037127666,-0.00186089,-0.043939225,0.02675395,0.017098242,0.01003573,0.016530303,-0.07529927,-0.0045888554,-0.00783502,-0.16103624,-0.018049028,-0.023261337,0.0726829,0.03554955,0.007101789,-0.03776669,0.03965637,0.010605459,-0.034077637,-0.1356997,-0.17605451,0.017438654,0.021631619,-0.00033740848,-0.05291991,-0.021556789,-0.020458516,-0.035007652,0.015351501,-0.013426498,-0.03958441,0.007752372,-0.016570576,-0.046401996,-0.011264202,0.05016379,-0.013889148,0.023654828,-0.030822476,0.024557399,0.041917533,-0.057632543,-0.032482482,0.00036849198,-0.038682386,-0.046676703,0.050744284,-0.010942368,-0.031797383,0.010470975,0.016948372,0.0055663995,0.058688268,-0.36635372,0.025145743,0.07269215,0.019211076,-0.018371176,-0.007865585,-0.00085583143,0.015894871,0.038337328,-0.014794488,-0.012541673,0.01718971,0.02693935,-0.045785226,0.0036220509,0.021907976,0.06554055,-0.04263025,0.0019336614,0.020152396,0.016324878,0.030021766,-0.015724592,0.06523936,0.0062361993,-0.028796729,0.038781464,0.00485937,-0.04877486,0.035066955,0.003006257,-0.0022367106,-0.04857364,0.001250449,0.0014392686,0.034671582,0.018141782,0.30240846,0.018054346,0.003062208,0.040367432,-0.07040852,0.052332688,-0.0028175337,-0.028020458,-0.021599045,0.031913813,-0.03909125,0.0028893205,-0.017719263,0.0052999025,-0.0061596422,0.054935843,-0.0012574365,-0.016914988,-0.009276138,0.023673639,0.043957185,-0.027961437,0.025381606,-0.04037111,-0.0053644218,-0.01048436,0.0035398034,-0.06366181,0.025020782,-0.046017863,-0.011454832,0.055446308,0.00011163922,-0.09325482,0.019621197,0.022895223,0.03182137,0.0010375826,-0.03117694,0.025362851,-0.031175531,-0.018045994,-0.13010256,0.10690098,-0.010491627,0.025534678,-0.0049998793,-0.028496867,0.043118607,-0.026229834,-0.01440331,0.024678908,0.033322413,-0.04394492,-0.005047783,0.0846922,0.022463208,0.0030116427,-0.003502701,-0.006854317,0.029395698,0.026690561,0.02559026,0.059080407,0.08340788,0.032878075,-0.0951223,0.05720357,0.02495402,0.014070283,-0.0042589814,0.018304987,-0.024781907,-0.041739304,-0.025803747,-0.012889254,-0.008009496,-0.028856821,-0.0005779219,0.028763987,-0.051368624,0.0027247544,0.06316944,-0.026757175,-0.08121664,-0.010547304,0.025082018,0.03702747,0.012908532,0.03141585,0.06318691,-0.027946094,0.17676711,-0.082001895,-0.036393072,-0.034927875,0.021505699,0.015366971,0.043793295,-0.0021506813,0.011197076,-0.04681245,-0.07142668,0.009581391,0.035224073,-0.04230499,-0.03571502,0.044728618,0.013419941,0.04271971,-0.008869499,-0.03126791,-0.0022953814,0.09043066,0.02422671,0.031988394,-0.005063331,-0.01025437,0.028456746,0.005116802,0.047064006,0.006069893,0.018045707,-0.022872277,-0.04572793,0.009827904,0.0069014616,-0.040622003,-0.013080576,-0.04777706,0.0012043755,0.07896354,0.043710608,0.040280547,0.073466524,0.06464221,0.014187437,-0.04872054,0.031972423,0.012510081,-0.038348954,0.016539646,0.006683025,-0.040044174,-0.056529168,0.04949601,-0.09106357,-0.030466262,0.010563386,-0.029358381,0.18323456,0.092901036,0.0274177,0.015892414,0.03165387,-0.06160097,0.0015103974,-0.11125003,0.010338306,-0.04025745,0.03327973,-0.025003629,-0.03141167,0.06007851,-0.029752823,-0.025986204,-0.0014932271,-0.00599316,-0.021954508,-0.005476444,-0.029271869,-0.040407516,0.09515277,0.019253343,0.04248291,0.00067515706,-0.009261151,0.025339367,-0.014061599,-0.0580183,-0.020854905,0.018436473,-0.0027048623,0.05364179,0.03416436,-0.009260716,-0.0785917,-0.023255466,0.03542782,0.07159498,0.0069388812,-0.038117178,-0.012323471,-0.009949083,-0.005902662,0.1273025,0.0014150682,0.018899381,0.022011757,-0.048523538,-0.03720841,-0.009601104,0.0547053,0.013078509,-0.013740014,-0.047507983,-0.018159833,0.017327625,-0.028147077,-0.030314941,-0.0028794382,-0.045816995,0.0028496154,0.015196548,-0.007854572,0.10382276,-0.01617453,0.017708423,0.037362352,0.002230973,-0.17829818,-0.036029417,-0.0006612718,-0.014223209,-0.06350168,-0.030032892,0.023901368,-0.00077770976,0.02510791,-0.04697416,0.15435414,0.08471184,-0.018154247,-0.030085038,0.03331496,0.09898532,0.016086424,0.010282825,-0.018388266,-0.006998348,0.017570151,0.0994389,0.12580456,0.023195932,0.008063885,0.003250409,-0.005355925,-0.047599785,-0.13378266,-0.0018643751,-0.045305796,-0.020819422,0.06300365,0.00095856196,0.005435208,0.0057721534,0.031151773,-0.03753951,0.016918143,-0.044961866,0.13784775,-0.016061982,-0.00000515642,-0.008715281,-0.01241248,-0.0021270465,0.022557234,0.05173467,-0.04232277,0.008206349,0.012508353,-0.004212918,-0.01315854,0.048109457,0.00035447034,-0.0082567325,0.012337424,0.0065427353,0.036199752,0.030513138,0.039167494,-0.028987426,-0.016657345,-0.07125146,-0.020769335]],"total_duration":11837394,"load_duration":2672695,"prompt_eval_count":4}' - recorded_at: Tue, 25 Mar 2025 11:42:32 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/providers_ollama_models_fetches_models_from_the_server_at_runtime.yml b/spec/fixtures/vcr_cassettes/providers_ollama_models_fetches_models_from_the_server_at_runtime.yml deleted file mode 100644 index b719a3eb..00000000 --- a/spec/fixtures/vcr_cassettes/providers_ollama_models_fetches_models_from_the_server_at_runtime.yml +++ /dev/null @@ -1,35 +0,0 @@ ---- -http_interactions: -- request: - method: get - uri: http://localhost:11434/api/tags - body: - encoding: US-ASCII - string: '' - headers: - User-Agent: - - Faraday v2.12.2 - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/json; charset=utf-8 - Date: - - Tue, 25 Mar 2025 11:42:33 GMT - Server: - - Caddy - Vary: - - Accept-Encoding - Transfer-Encoding: - - chunked - body: - encoding: ASCII-8BIT - string: '{ "models": [ { "details": { "families": [ "bert" ], "family": "bert", "format": "gguf", "parameter_size": "23M", "parent_model": "", "quantization_level": "F16" }, "digest": "bf75350e17522c7dfe63e98f50457b27fadcfee62f0c0767c1c86053407c2abb", "model": "snowflake-arctic-embed:22m", "modified_at": "2025-03-25T01:16:44.503745925Z", "name": "snowflake-arctic-embed:22m", "size": 45838698 }, { "details": { "families": [ "llama" ], "family": "llama", "format": "gguf", "parameter_size": "134.52M", "parent_model": "", "quantization_level": "Q4_0" }, "digest": "b0b2a46174385c0adcaa77ff245ffeced5fc4a61447b6f221b2beb5c5a760133", "model": "smollm:135m", "modified_at": "2025-03-25T01:16:43.495760964Z", "name": "smollm:135m", "size": 91739413 } ] }' - recorded_at: Tue, 25 Mar 2025 11:42:29 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/providers_ollama_streaming_ask_with_streaming_works.yml b/spec/fixtures/vcr_cassettes/providers_ollama_streaming_ask_with_streaming_works.yml deleted file mode 100644 index a70a2ebb..00000000 --- a/spec/fixtures/vcr_cassettes/providers_ollama_streaming_ask_with_streaming_works.yml +++ /dev/null @@ -1,101 +0,0 @@ ---- -http_interactions: -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"smollm:135m","messages":[{"role":"user","content":"Count - from 1 to 3"}],"options":{"temperature":0.7},"stream":true}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/x-ndjson - Date: - - Tue, 25 Mar 2025 11:42:35 GMT - Server: - - Caddy - Transfer-Encoding: - - chunked - body: - encoding: UTF-8 - string: | - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.7830333Z","message":{"role":"assistant","content":"Here"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.785646727Z","message":{"role":"assistant","content":" is"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.78827431Z","message":{"role":"assistant","content":" a"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.790801785Z","message":{"role":"assistant","content":" Python"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.793274065Z","message":{"role":"assistant","content":" function"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.795874434Z","message":{"role":"assistant","content":" that"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.7984565Z","message":{"role":"assistant","content":" counts"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.801031415Z","message":{"role":"assistant","content":" the"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.803573893Z","message":{"role":"assistant","content":" number"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.806231278Z","message":{"role":"assistant","content":" of"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.808821071Z","message":{"role":"assistant","content":" digits"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.81137248Z","message":{"role":"assistant","content":" in"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.813966219Z","message":{"role":"assistant","content":" a"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.816573617Z","message":{"role":"assistant","content":" string"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.81917068Z","message":{"role":"assistant","content":" and"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.821770818Z","message":{"role":"assistant","content":" returns"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.824417413Z","message":{"role":"assistant","content":" the"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.828470856Z","message":{"role":"assistant","content":" corresponding"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.831226755Z","message":{"role":"assistant","content":" integer"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.834009618Z","message":{"role":"assistant","content":" value"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.83662707Z","message":{"role":"assistant","content":":"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.839237899Z","message":{"role":"assistant","content":"\n"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.841888936Z","message":{"role":"assistant","content":"\n"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.844437076Z","message":{"role":"assistant","content":"```"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.847064226Z","message":{"role":"assistant","content":"python"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.849627235Z","message":{"role":"assistant","content":"\n"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.852219701Z","message":{"role":"assistant","content":"def"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.854814973Z","message":{"role":"assistant","content":" count"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.857436203Z","message":{"role":"assistant","content":"_"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.860108144Z","message":{"role":"assistant","content":"digits"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.862759224Z","message":{"role":"assistant","content":"("},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.865434499Z","message":{"role":"assistant","content":"s"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.868125297Z","message":{"role":"assistant","content":"):"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.870760844Z","message":{"role":"assistant","content":"\n "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.873382963Z","message":{"role":"assistant","content":" count"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.875996933Z","message":{"role":"assistant","content":" ="},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.878590201Z","message":{"role":"assistant","content":" "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.881191519Z","message":{"role":"assistant","content":"0"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.883832365Z","message":{"role":"assistant","content":"\n "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.886564727Z","message":{"role":"assistant","content":" for"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.889166207Z","message":{"role":"assistant","content":" digit"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.891879215Z","message":{"role":"assistant","content":" in"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.894548894Z","message":{"role":"assistant","content":" s"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.897207567Z","message":{"role":"assistant","content":":"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.899841625Z","message":{"role":"assistant","content":"\n "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.902498196Z","message":{"role":"assistant","content":" if"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.905107832Z","message":{"role":"assistant","content":" digit"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.907789586Z","message":{"role":"assistant","content":"."},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.910502793Z","message":{"role":"assistant","content":"is"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.9143673Z","message":{"role":"assistant","content":"digit"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.917111538Z","message":{"role":"assistant","content":"():"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.919863033Z","message":{"role":"assistant","content":"\n "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.922599882Z","message":{"role":"assistant","content":" count"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.925334577Z","message":{"role":"assistant","content":" +="},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.928067663Z","message":{"role":"assistant","content":" "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.930770166Z","message":{"role":"assistant","content":"1"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.933410933Z","message":{"role":"assistant","content":"\n "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.936033812Z","message":{"role":"assistant","content":" return"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.938684522Z","message":{"role":"assistant","content":" int"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.941285311Z","message":{"role":"assistant","content":"("},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.943928387Z","message":{"role":"assistant","content":"count"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.946601129Z","message":{"role":"assistant","content":")"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.94925745Z","message":{"role":"assistant","content":"\n"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.951855253Z","message":{"role":"assistant","content":"```"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-25T11:42:35.954468729Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":181710972,"load_duration":5399447,"prompt_eval_count":16,"prompt_eval_duration":2211058,"eval_count":65,"eval_duration":173901215} - recorded_at: Tue, 25 Mar 2025 11:42:31 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/ruby_llm/chat_spec.rb b/spec/ruby_llm/chat_spec.rb index f35c0cf7..16591e81 100644 --- a/spec/ruby_llm/chat_spec.rb +++ b/spec/ruby_llm/chat_spec.rb @@ -12,6 +12,7 @@ 'gemini-2.0-flash', 'deepseek-chat', 'gpt-4o-mini', + # FIXME: this 0.1B model is too dumb to know who Matz is 'smollm:135m' ].each do |model| it "#{model} can have a basic conversation" do # rubocop:disable RSpec/ExampleLength,RSpec/MultipleExpectations diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index 26df0428..6c7b4270 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -82,16 +82,13 @@ example.run end end -end -RSpec.shared_context 'with configured RubyLLM' do - before do + # Run once before all tests + config.before(:suite) do RubyLLM.configure do |config| - # NOTE: to ensure relevant models are pulled into your local server, do - # bundle exec rake ollama:install_models_for_specs config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL', 'http://localhost:11434') - - # FIXME: this clobbers the model list from models.json and results in all tests except for ollama's to fail + # needs to run when ONLY Ollama is configured and before any others are configured + # FIXME: RubyLLM.models.refresh!(provider: 'ollama') would be a cleaner solution RubyLLM.models.refresh! config.openai_api_key = ENV.fetch('OPENAI_API_KEY', 'test') @@ -102,3 +99,7 @@ end end end + +RSpec.shared_context 'with configured RubyLLM' do +end + From a9e9cdcd7fc0ad00462ba7f303091ec5fab38357 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 26 Mar 2025 15:03:09 -0300 Subject: [PATCH 22/55] Remove leftovers --- lib/ruby_llm/providers/ollama/streaming.rb | 2 -- 1 file changed, 2 deletions(-) diff --git a/lib/ruby_llm/providers/ollama/streaming.rb b/lib/ruby_llm/providers/ollama/streaming.rb index 68cddb8e..2e88839d 100644 --- a/lib/ruby_llm/providers/ollama/streaming.rb +++ b/lib/ruby_llm/providers/ollama/streaming.rb @@ -25,8 +25,6 @@ def handle_stream(&block) end def build_chunk(data) - raise 'wtf' if data.is_a?(Array) - Chunk.new( role: :assistant, content: data.dig('message', 'content'), From 18ec0840a1d4561201e26edbec2e19338877b30f Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 26 Mar 2025 16:42:03 -0300 Subject: [PATCH 23/55] Describe the streaming mystery some more; still no proper solution --- lib/ruby_llm/providers/ollama/streaming.rb | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/lib/ruby_llm/providers/ollama/streaming.rb b/lib/ruby_llm/providers/ollama/streaming.rb index 2e88839d..c8283c81 100644 --- a/lib/ruby_llm/providers/ollama/streaming.rb +++ b/lib/ruby_llm/providers/ollama/streaming.rb @@ -13,12 +13,12 @@ def stream_url def handle_stream(&block) to_json_stream do |data| - # FIXME: for some reason, there's an unexpected final call - # from on_data with the complete response as an Array. + # FIXME: on connection close, on_data is called with the entire response so far as one chunk + # consisting of an Array of unparsed JSON strings (ie. an array of lines). # - # It is skipped here, but this smells a bit; this method shouldn't - # need to be overridden just for this. Will look into it - done = data.is_a?(Array) || data['done'] + # It is detected and skipped here, but this is a code smell; + # likely standard SSE behavior which shouldn't be happening for NDJSON streaming. + done = data.is_a?(Array) && data.first.is_a?(String) && data.first[0] == '{' block.call(build_chunk(data)) if data && !done end @@ -47,7 +47,7 @@ def handle_sse(chunk, _parser, env, &block) next if line.empty? parsed_data = JSON.parse(line) - block.call(parsed_data) + block.call(parsed_data) unless parsed_data['done'] end end end From 8735f9585cb3f496ed6e3e6cc8bb08bbfe069b1d Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 26 Mar 2025 17:04:21 -0300 Subject: [PATCH 24/55] Streamline capabilities some more (but still mostly placeholders) --- lib/ruby_llm/providers/ollama/capabilities.rb | 93 ++----------------- lib/ruby_llm/providers/ollama/models.rb | 6 +- 2 files changed, 12 insertions(+), 87 deletions(-) diff --git a/lib/ruby_llm/providers/ollama/capabilities.rb b/lib/ruby_llm/providers/ollama/capabilities.rb index be144b47..1bd590de 100644 --- a/lib/ruby_llm/providers/ollama/capabilities.rb +++ b/lib/ruby_llm/providers/ollama/capabilities.rb @@ -7,11 +7,14 @@ module Ollama module Capabilities module_function + # FIXME: none of these facts are available from the Ollama server, + # or from the Ollama library (https://ollama.com/library) in a structured way. + # Returns the context window size (input token limit) for the given model # @param model_id [String] the model identifier # @return [Integer] the context window size in tokens def context_window_for(_model_id) - # FIXME: revise + # FIXME: placeholder 4_192 # Sensible (and conservative) default for unknown models end @@ -19,29 +22,15 @@ def context_window_for(_model_id) # @param model_id [String] the model identifier # @return [Integer] the maximum output tokens def max_tokens_for(_model_id) - # FIXME: revise + # FIXME: placeholder 32_768 end - # Returns the input price per million tokens for the given model - # @param model_id [String] the model identifier - # @return [Float] the price per million tokens in USD - def input_price_for(_model_id) - 0.0 - end - - # Returns the output price per million tokens for the given model - # @param model_id [String] the model identifier - # @return [Float] the price per million tokens in USD - def output_price_for(_model_id) - 0.0 - end - # Determines if the model supports vision (image/video) inputs # @param model_id [String] the model identifier # @return [Boolean] true if the model supports vision inputs def supports_vision?(_model_id) - # FIXME: revise + # FIXME: placeholder false end @@ -49,7 +38,7 @@ def supports_vision?(_model_id) # @param model_id [String] the model identifier # @return [Boolean] true if the model supports function calling def supports_functions?(_model_id) - # FIXME: revise + # FIXME: placeholder false end @@ -57,45 +46,7 @@ def supports_functions?(_model_id) # @param model_id [String] the model identifier # @return [Boolean] true if the model supports JSON mode def supports_json_mode?(_model_id) - # FIXME: revise - false - end - - # Formats the model ID into a human-readable display name - # @param model_id [String] the model identifier - # @return [String] the formatted display name - def format_display_name(model_id) - model_id - .delete_prefix('models/') - .split('-') - .map(&:capitalize) - .join(' ') - .gsub(/(\d+\.\d+)/, ' \1') # Add space before version numbers - .gsub(/\s+/, ' ') # Clean up multiple spaces - .strip - end - - # Determines if the model supports context caching - # @param model_id [String] the model identifier - # @return [Boolean] true if the model supports caching - def supports_caching?(_model_id) - # FIXME: revise - true - end - - # Determines if the model supports tuning - # @param model_id [String] the model identifier - # @return [Boolean] true if the model supports tuning - def supports_tuning?(_model_id) - # FIXME: revise - false - end - - # Determines if the model supports audio inputs - # @param model_id [String] the model identifier - # @return [Boolean] true if the model supports audio inputs - def supports_audio?(_model_id) - # FIXME: revise + # FIXME: placeholder false end @@ -103,35 +54,9 @@ def supports_audio?(_model_id) # @param model_id [String] the model identifier # @return [String] the model type def model_type(_model_id) - # FIXME: revise + # FIXME: placeholder 'chat' end - - # Returns the model family identifier - # @param model_id [String] the model identifier - # @return [String] the model family identifier - def model_family(_model_id) - 'other' - end - - # Returns the context length for the model - # @param model_id [String] the model identifier - # @return [Integer] the context length in tokens - def context_length(model_id) - context_window_for(model_id) - end - - # Default input price for unknown models - # @return [Float] the default input price per million tokens - def default_input_price - 0.0 - end - - # Default output price for unknown models - # @return [Float] the default output price per million tokens - def default_output_price - 0.0 - end end end end diff --git a/lib/ruby_llm/providers/ollama/models.rb b/lib/ruby_llm/providers/ollama/models.rb index 0e8dfab5..f7a22bc1 100644 --- a/lib/ruby_llm/providers/ollama/models.rb +++ b/lib/ruby_llm/providers/ollama/models.rb @@ -41,7 +41,7 @@ def parse_list_models_response(response, slug, capabilities) # rubocop:disable M ModelInfo.new( id: model_id, - # NOTE: this is date pulled into ollama, not quite date of introduction of a model + # NOTE: this is date pulled into the Ollama server, not date of introduction of a model created_at: model['modified_at'], display_name: model_id, provider: slug, @@ -52,8 +52,8 @@ def parse_list_models_response(response, slug, capabilities) # rubocop:disable M supports_vision: capabilities.supports_vision?(model_id), supports_functions: capabilities.supports_functions?(model_id), supports_json_mode: capabilities.supports_json_mode?(model_id), - input_price_per_million: capabilities.input_price_for(model_id), - output_price_per_million: capabilities.output_price_for(model_id), + input_price_per_million: 0.0, + output_price_per_million: 0.0, metadata: { byte_size: model['size']&.to_i, parameter_size: model.dig('details', 'parameter_size'), From 8d7fecff185617cf9ec5e70947ecdfd1dea023a0 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 10:49:49 -0300 Subject: [PATCH 25/55] Fix un-VCR'd `models.refresh!` --- .../vcr_cassettes/initial_model_refresh.yml | 35 +++++++++++++++++++ spec/spec_helper.rb | 3 +- 2 files changed, 36 insertions(+), 2 deletions(-) create mode 100644 spec/fixtures/vcr_cassettes/initial_model_refresh.yml diff --git a/spec/fixtures/vcr_cassettes/initial_model_refresh.yml b/spec/fixtures/vcr_cassettes/initial_model_refresh.yml new file mode 100644 index 00000000..bcaab46c --- /dev/null +++ b/spec/fixtures/vcr_cassettes/initial_model_refresh.yml @@ -0,0 +1,35 @@ +--- +http_interactions: +- request: + method: get + uri: http://localhost:11434/api/tags + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.12.2 + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 13:46:21 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Transfer-Encoding: + - chunked + body: + encoding: ASCII-8BIT + string: '{ "models": [ { "details": { "families": [ "bert" ], "family": "bert", "format": "gguf", "parameter_size": "23M", "parent_model": "", "quantization_level": "F16" }, "digest": "bf75350e17522c7dfe63e98f50457b27fadcfee62f0c0767c1c86053407c2abb", "model": "snowflake-arctic-embed:22m", "modified_at": "2025-03-25T01:52:52.027398285Z", "name": "snowflake-arctic-embed:22m", "size": 45838698 }, { "details": { "families": [ "llama" ], "family": "llama", "format": "gguf", "parameter_size": "134.52M", "parent_model": "", "quantization_level": "Q4_0" }, "digest": "b0b2a46174385c0adcaa77ff245ffeced5fc4a61447b6f221b2beb5c5a760133", "model": "smollm:135m", "modified_at": "2025-03-25T01:52:51.363408194Z", "name": "smollm:135m", "size": 91739413 } ] }' + recorded_at: Thu, 27 Mar 2025 13:46:15 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index 6c7b4270..7dfc15c2 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -83,8 +83,7 @@ end end - # Run once before all tests - config.before(:suite) do + VCR.use_cassette("initial_model_refresh") do RubyLLM.configure do |config| config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL', 'http://localhost:11434') # needs to run when ONLY Ollama is configured and before any others are configured From f377120b1f7c6254e19b9812fa2ab631b5c84518 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 11:01:13 -0300 Subject: [PATCH 26/55] Parse errors correctly --- lib/ruby_llm/providers/ollama.rb | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/lib/ruby_llm/providers/ollama.rb b/lib/ruby_llm/providers/ollama.rb index dd56f6d5..65f96934 100644 --- a/lib/ruby_llm/providers/ollama.rb +++ b/lib/ruby_llm/providers/ollama.rb @@ -31,6 +31,13 @@ def slug def configuration_requirements %i[ollama_api_base_url] end + + def parse_error(response) + return if response.body.empty? + + body = try_parse_json(response.body) + body['error'] + end end end end From b8d3c9b38f6cbcb542148f427c22758ae517be1d Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 12:24:56 -0300 Subject: [PATCH 27/55] Fix streaming --- lib/ruby_llm/providers/ollama/streaming.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/ruby_llm/providers/ollama/streaming.rb b/lib/ruby_llm/providers/ollama/streaming.rb index c8283c81..96566dda 100644 --- a/lib/ruby_llm/providers/ollama/streaming.rb +++ b/lib/ruby_llm/providers/ollama/streaming.rb @@ -47,7 +47,7 @@ def handle_sse(chunk, _parser, env, &block) next if line.empty? parsed_data = JSON.parse(line) - block.call(parsed_data) unless parsed_data['done'] + block.call(parsed_data) end end end From ce9f430d210efee47a478c05888c71fe6733a05d Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 16:55:43 -0300 Subject: [PATCH 28/55] Settle on llama3.1:8b model It's about 5 GB instead of 92MB, but it supports tool calling well and is a lot more competent. While it's an order of magnitude heavier, it should still be OK for running tests sporadically even on CPU. --- lib/tasks/ollama.rake | 11 +- ...8b_can_handle_multi-turn_conversations.yml | 108 ++++++++++++++++++ ...ma3_1_8b_can_have_a_basic_conversation.yml | 37 ++++++ ...5m_can_handle_multi-turn_conversations.yml | 61 ---------- ...llm_135m_can_have_a_basic_conversation.yml | 74 ------------ ...ama3_1_8b_supports_streaming_responses.yml | 46 ++++++++ ...ollm_135m_supports_streaming_responses.yml | 100 ---------------- .../vcr_cassettes/initial_model_refresh.yml | 6 +- spec/ruby_llm/chat_spec.rb | 18 ++- spec/ruby_llm/chat_streaming_spec.rb | 2 +- 10 files changed, 217 insertions(+), 246 deletions(-) create mode 100644 spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation.yml delete mode 100644 spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_handle_multi-turn_conversations.yml delete mode 100644 spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_have_a_basic_conversation.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses.yml delete mode 100644 spec/fixtures/vcr_cassettes/chat_streaming_responses_smollm_135m_supports_streaming_responses.yml diff --git a/lib/tasks/ollama.rake b/lib/tasks/ollama.rake index ac454932..c28465e6 100644 --- a/lib/tasks/ollama.rake +++ b/lib/tasks/ollama.rake @@ -3,7 +3,9 @@ require 'ruby_llm' def pull_model(ollama_library_model_spec, description) - warn "+ pulling #{ollama_library_model_spec} from Ollama library (#{description})" + warn <<~MESSAGE + + pulling #{ollama_library_model_spec} from Ollama library (#{description}); monitor progress in Ollama server logs + MESSAGE # ugly but effective response = RubyLLM::Providers::Ollama.send( @@ -22,11 +24,12 @@ def pull_model(ollama_library_model_spec, description) end namespace :ollama do - desc 'Install some tiny models required for running Ollama specs (downloads about 150 MB into your Ollama server)' + desc 'Install some tiny models required for running Ollama specs (downloads about 5 GiB into your Ollama server)' task :install_models_for_specs do + RubyLLM.config.request_timeout = 60 * 30 # 30min timeout per model since pull is synchronous RubyLLM.config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL') - pull_model('smollm:135m', '92MiB chat model') - pull_model('snowflake-arctic-embed:22m', '46MiB embedding model') + pull_model('llama3.1:8b', '4.9 GiB chat model') + pull_model('snowflake-arctic-embed:22m', '46 MiB embedding model') end end diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations.yml new file mode 100644 index 00000000..bdaf1f1a --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations.yml @@ -0,0 +1,108 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Who was + the creator of Ruby?"}],"options":{"temperature":0.7},"stream":false,"tools":[]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 19:46:58 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '1400' + body: + encoding: ASCII-8BIT + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:46:58.740797174Z","message":{"role":"assistant","content":"The + creator of the Ruby programming language is Yukihiro Matsumoto, a Japanese + computer programmer. He started working on Ruby in 1993 and released the first + version, known as Ruby 0.95, in 1995.\n\nMatsumoto, also known by his nickname + \"Matz,\" wanted to create a language that was easy to use and fun to program + with, while still being powerful enough for real-world applications. He drew + inspiration from various languages, including Perl, Smalltalk, Ada, and Lisp, + and incorporated features such as dynamic typing, object-oriented programming, + and a syntax similar to Perl.\n\nToday, Ruby is a popular language used in + web development (especially with the Ruby on Rails framework), scripting, + and other areas of software development. Matsumoto continues to be involved + in the development of Ruby and has also created several other projects, including + the Ruby on Rails framework and the YARV (Yet Another Ruby VM) project.\n\nMatsumoto + is often referred to as one of the most influential programmers of his generation, + and his work on Ruby has had a significant impact on the programming community."},"done_reason":"stop","done":true,"total_duration":2168998404,"load_duration":18237858,"prompt_eval_count":17,"prompt_eval_duration":3883030,"eval_count":226,"eval_duration":2146427889}' + recorded_at: Thu, 27 Mar 2025 19:46:52 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Who was + the creator of Ruby?"},{"role":"assistant","content":"The creator of the Ruby + programming language is Yukihiro Matsumoto, a Japanese computer programmer. + He started working on Ruby in 1993 and released the first version, known as + Ruby 0.95, in 1995.\n\nMatsumoto, also known by his nickname \"Matz,\" wanted + to create a language that was easy to use and fun to program with, while still + being powerful enough for real-world applications. He drew inspiration from + various languages, including Perl, Smalltalk, Ada, and Lisp, and incorporated + features such as dynamic typing, object-oriented programming, and a syntax + similar to Perl.\n\nToday, Ruby is a popular language used in web development + (especially with the Ruby on Rails framework), scripting, and other areas + of software development. Matsumoto continues to be involved in the development + of Ruby and has also created several other projects, including the Ruby on + Rails framework and the YARV (Yet Another Ruby VM) project.\n\nMatsumoto is + often referred to as one of the most influential programmers of his generation, + and his work on Ruby has had a significant impact on the programming community."},{"role":"user","content":"What + year did he create Ruby?"}],"options":{"temperature":0.7},"stream":false,"tools":[]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 19:46:59 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '690' + body: + encoding: ASCII-8BIT + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:46:59.755190489Z","message":{"role":"assistant","content":"Yukihiro + Matsumoto started working on Ruby in 1993, but it was not until 1995 that + the first version, known as Ruby 0.95, was released.\n\nHowever, if you''re + asking for a more specific answer to \"when did he create Ruby?\", I would + say that Matsumoto created the idea and initial design of Ruby around 1992-1993, + but the language gained its final form and was first publicly available in + 1995."},"done_reason":"stop","done":true,"total_duration":1009884033,"load_duration":17976970,"prompt_eval_count":259,"prompt_eval_duration":4256642,"eval_count":99,"eval_duration":986877265}' + recorded_at: Thu, 27 Mar 2025 19:46:53 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation.yml new file mode 100644 index 00000000..3385a1b6 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation.yml @@ -0,0 +1,37 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + 2 + 2?"}],"options":{"temperature":0.7},"stream":false,"tools":[]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Length: + - '310' + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 19:46:56 GMT + Server: + - Caddy + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:46:56.566074923Z","message":{"role":"assistant","content":"The + answer is: 4!"},"done_reason":"stop","done":true,"total_duration":132025686,"load_duration":17201717,"prompt_eval_count":18,"prompt_eval_duration":25849721,"eval_count":8,"eval_duration":88593644}' + recorded_at: Thu, 27 Mar 2025 19:46:49 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_handle_multi-turn_conversations.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_handle_multi-turn_conversations.yml deleted file mode 100644 index 8326a281..00000000 --- a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_handle_multi-turn_conversations.yml +++ /dev/null @@ -1,61 +0,0 @@ ---- -http_interactions: -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"smollm:135m","messages":[{"role":"user","content":"Who was - Ruby''s creator?"}],"options":{"temperature":0.7},"stream":false}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/json; charset=utf-8 - Date: - - Wed, 26 Mar 2025 17:20:39 GMT - Transfer-Encoding: - - chunked - body: - encoding: UTF-8 - string: '{"model":"smollm:135m","created_at":"2025-03-26T17:20:39.40000571Z","message":{"role":"assistant","content":"Ruby''s - creator is unknown, but some theories suggest that she might have been a member - of a team or group of women who worked on the project. Here are a few examples:\n\n1. - **Sophie Couture**: The only person to receive the Ruby Award, a posthumous - honor given to women for outstanding performance in a musical, dance, or other - performance art project. This is a notable exception, as it''s unclear whether - she was a member of a team or a single woman on the project.\n2. **Sitse Selvin**: - A member of a team led by her brother, Robert Selvin, who worked with the - project from 1975 to 1983. He is believed to have been a talented pianist - and composer, but his real role remains unknown.\n3. **Vincent Chesnutt**: - A woman who was a member of a team led by her brother, Vincent Chesnutt, who - worked with the project from 1975 to 2006. She is believed to have been a - talented pianist and composer, but her real role remains unknown.\n4. **Sandra - Lee Cox**: A woman who was a member of a team led by her brother, Sandra Cox, - who worked with the project from 1983 to 2007. She is believed to have been - a talented pianist and composer, but her real role remains unknown.\n5. **Rachel - Vash**: A woman who was a member of a team led by her brother, Rachel Vash, - who worked with the project from 1994 to 2008. She is believed to have been - a talented pianist and composer, but her real role remains unknown.\n6. **Laurie - Lidwell**: A woman who was a member of a team led by her brother, Laurie Lidwell, - who worked with the project from 1994 to 2008. She is believed to have been - a talented pianist and composer, but her real role remains unknown.\n7. **Lindsey - Foyne**: A woman who was a member of a team led by her brother, Lindsey Foyne, - who worked with the project from 1994 to 2008. She is believed to have been - a talented pianist and composer, but her real role remains unknown.\n\nThese - are just a few examples of the many people who might have been involved in - the Ruby Award or on the project. While it''s difficult to provide an exact - count, it''s clear that Rachel Vash was a key part of the project."},"done_reason":"stop","done":true,"total_duration":2071286463,"load_duration":5108714,"prompt_eval_count":15,"prompt_eval_duration":8958877,"eval_count":548,"eval_duration":2056874892}' - recorded_at: Wed, 26 Mar 2025 17:20:39 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_have_a_basic_conversation.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_have_a_basic_conversation.yml deleted file mode 100644 index 118d6ebb..00000000 --- a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_smollm_135m_can_have_a_basic_conversation.yml +++ /dev/null @@ -1,74 +0,0 @@ ---- -http_interactions: -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"smollm:135m","messages":[{"role":"user","content":"What''s - 2 + 2?"}],"options":{"temperature":0.7},"stream":false}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/json; charset=utf-8 - Date: - - Wed, 26 Mar 2025 17:18:34 GMT - Transfer-Encoding: - - chunked - body: - encoding: UTF-8 - string: '{"model":"smollm:135m","created_at":"2025-03-26T17:18:34.665407999Z","message":{"role":"assistant","content":"What - a great question! The concept of \"1+1\" is a fascinating mathematical operation - that can be understood in various ways. Here are some possible interpretations:\n\n1. - **Counting numbers**: In counting notation (binary, octal, hexadecimal, etc.), - 2 + 2 represents the binary representation of \"1\". This means that it''s - equivalent to adding 1 to itself twice!\n2. **Algebraic operations**: When - two integers are added, they become equivalent by definition. For example, - `a + b = c`, where a is positive and b is negative (i.e., 3+4=7). This equation - shows that 2 + 2 equals 5, which can be considered as \"1+1\" or \"2+2\".\n3. - **Real-world applications**: In some cases, 2 + 2 could represent a real number, - like the sum of two integers: `a + b = c`, where a is positive and b is negative - (i.e., -3). This equation shows that 1 plus 2 equals 5 in this case.\n4. **Fractional - part**: In fractional notation (fractional part), 2+2 could represent the - fractional part of \"1\", like `a/b = 0.2`, where a is positive and b is negative - (i.e., -3). This fraction shows that 2 + 2 equals 5 in this case as well, - albeit with a slightly greater numerator.\n5. **Algebraic expressions**: When - two expressions are algebraic expressions (expression without fractions), - they can be treated similarly to the real-world examples we mentioned earlier: - `a = ab`, where a is positive and b is negative. This expression shows that - 2 + 2 equals 5 in this case, albeit with an extra fraction element added.\n6. - **Symbolic manipulation**: In symbolic manipulation, like in algebra or combinatorics, - the addition of two integers can be represented as `a = ab`, where a is positive - and b is negative. This expression shows that 1 + 2 equals 5 in this case - by definition.\n7. **In mathematics education**: The concept of \"1+1\" has - been part of many mathematical proofs and discussions, often referred to as - \"integral summation\" or \"algebraic summation.\" These ideas can be seen - as a way of representing the summation of two integers that are equivalent - by definition.\n8. **Philosophical significance**: The concept of 2 + 2 raises - fundamental questions about the nature of numbers and their relationship to - reality: What is real, and what is an additive identity? Does zero have a - place in mathematics or can it be treated as a number without being additive - (i.e., 1 cannot equal zero)?\n9. **Mathematical intuition**: The concept of - 2 + 2 can evoke strong mathematical intuitions about the distribution of integers - among positive and negative numbers, which is essential to understanding some - other important properties in mathematics, like the prime number theorem or - the distribution of irrational numbers.\n10. **Philosophical implications**: - The idea of 2 + 2 has been a subject of philosophical debate, with different - interpretations (e.g., \"additive identity\" or \"non-additional\" as an additive - identity) that have challenged our understanding of mathematics and its relationship - to reality.\n\nThese are just a few examples of the many ways in which \"1+1\" - can be understood in various mathematical contexts."},"done_reason":"stop","done":true,"total_duration":3245290565,"load_duration":322808107,"prompt_eval_count":17,"prompt_eval_duration":13628372,"eval_count":733,"eval_duration":2908275176}' - recorded_at: Wed, 26 Mar 2025 17:18:34 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses.yml b/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses.yml new file mode 100644 index 00000000..d1a49912 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses.yml @@ -0,0 +1,46 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Count + from 1 to 3","images":[]}],"options":{"temperature":0.7},"stream":true,"tools":[]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Thu, 27 Mar 2025 20:15:12 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: | + {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.823627546Z","message":{"role":"assistant","content":"Here"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.836926583Z","message":{"role":"assistant","content":" it"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.845628305Z","message":{"role":"assistant","content":" is"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.854520068Z","message":{"role":"assistant","content":":\n\n"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.863223164Z","message":{"role":"assistant","content":"1"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.871980804Z","message":{"role":"assistant","content":"\n"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.880710143Z","message":{"role":"assistant","content":"2"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.889518343Z","message":{"role":"assistant","content":"\n"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.89843357Z","message":{"role":"assistant","content":"3"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.907436856Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":3301695608,"load_duration":3125133401,"prompt_eval_count":17,"prompt_eval_duration":88101212,"eval_count":10,"eval_duration":86549601} + recorded_at: Thu, 27 Mar 2025 20:15:06 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_streaming_responses_smollm_135m_supports_streaming_responses.yml b/spec/fixtures/vcr_cassettes/chat_streaming_responses_smollm_135m_supports_streaming_responses.yml deleted file mode 100644 index 390fd1fd..00000000 --- a/spec/fixtures/vcr_cassettes/chat_streaming_responses_smollm_135m_supports_streaming_responses.yml +++ /dev/null @@ -1,100 +0,0 @@ ---- -http_interactions: -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"smollm:135m","messages":[{"role":"user","content":"Count - from 1 to 3"}],"options":{"temperature":0.7},"stream":true}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/x-ndjson - Date: - - Wed, 26 Mar 2025 17:18:38 GMT - Transfer-Encoding: - - chunked - body: - encoding: UTF-8 - string: | - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.100562561Z","message":{"role":"assistant","content":"Here"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.104881895Z","message":{"role":"assistant","content":" is"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.109163649Z","message":{"role":"assistant","content":" a"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.113094772Z","message":{"role":"assistant","content":" Python"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.116972445Z","message":{"role":"assistant","content":" function"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.120733929Z","message":{"role":"assistant","content":" that"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.124307882Z","message":{"role":"assistant","content":" counts"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.128387505Z","message":{"role":"assistant","content":" the"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.132135107Z","message":{"role":"assistant","content":" number"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.13578816Z","message":{"role":"assistant","content":" of"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.139146823Z","message":{"role":"assistant","content":" digits"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.142487577Z","message":{"role":"assistant","content":" in"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.145833149Z","message":{"role":"assistant","content":" a"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.149574122Z","message":{"role":"assistant","content":" string"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.153284265Z","message":{"role":"assistant","content":":"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.156734808Z","message":{"role":"assistant","content":"\n"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.160126451Z","message":{"role":"assistant","content":"\n"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.163615804Z","message":{"role":"assistant","content":"```"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.17177554Z","message":{"role":"assistant","content":"python"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.176081914Z","message":{"role":"assistant","content":"\n"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.180185308Z","message":{"role":"assistant","content":"def"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.184394831Z","message":{"role":"assistant","content":" count"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.188109373Z","message":{"role":"assistant","content":"_"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.191586197Z","message":{"role":"assistant","content":"digits"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.19498339Z","message":{"role":"assistant","content":"("},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.198339013Z","message":{"role":"assistant","content":"s"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.201589705Z","message":{"role":"assistant","content":"):"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.205084617Z","message":{"role":"assistant","content":"\n "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.208314251Z","message":{"role":"assistant","content":" result"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.211665804Z","message":{"role":"assistant","content":" ="},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.215361477Z","message":{"role":"assistant","content":" {}"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.219057039Z","message":{"role":"assistant","content":"\n "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.222497532Z","message":{"role":"assistant","content":" for"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.226058135Z","message":{"role":"assistant","content":" char"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.229534369Z","message":{"role":"assistant","content":" in"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.232965531Z","message":{"role":"assistant","content":" s"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.236452504Z","message":{"role":"assistant","content":":"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.240042996Z","message":{"role":"assistant","content":"\n "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.24349197Z","message":{"role":"assistant","content":" if"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.247069563Z","message":{"role":"assistant","content":" char"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.250678586Z","message":{"role":"assistant","content":" not"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.254176448Z","message":{"role":"assistant","content":" in"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.257590831Z","message":{"role":"assistant","content":" result"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.260969383Z","message":{"role":"assistant","content":":"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.264846698Z","message":{"role":"assistant","content":"\n "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.268374811Z","message":{"role":"assistant","content":" result"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.272071133Z","message":{"role":"assistant","content":"["},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.275484896Z","message":{"role":"assistant","content":"char"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.278916879Z","message":{"role":"assistant","content":"]"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.282696043Z","message":{"role":"assistant","content":" ="},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.286494845Z","message":{"role":"assistant","content":" "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.290218278Z","message":{"role":"assistant","content":"0"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.293935121Z","message":{"role":"assistant","content":"\n "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.297789735Z","message":{"role":"assistant","content":" result"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.301722288Z","message":{"role":"assistant","content":"["},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.305849971Z","message":{"role":"assistant","content":"char"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.309743804Z","message":{"role":"assistant","content":"]"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.313734477Z","message":{"role":"assistant","content":" +="},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.317732522Z","message":{"role":"assistant","content":" "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.321434594Z","message":{"role":"assistant","content":"1"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.325045267Z","message":{"role":"assistant","content":"\n "},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.32905447Z","message":{"role":"assistant","content":" return"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.332839624Z","message":{"role":"assistant","content":" result"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.336708717Z","message":{"role":"assistant","content":"\n"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.34039667Z","message":{"role":"assistant","content":"```"},"done":false} - {"model":"smollm:135m","created_at":"2025-03-26T17:18:38.343979733Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":261623797,"load_duration":5114494,"prompt_eval_count":16,"prompt_eval_duration":12307330,"eval_count":66,"eval_duration":243867952} - recorded_at: Wed, 26 Mar 2025 17:18:38 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/initial_model_refresh.yml b/spec/fixtures/vcr_cassettes/initial_model_refresh.yml index bcaab46c..e12a9013 100644 --- a/spec/fixtures/vcr_cassettes/initial_model_refresh.yml +++ b/spec/fixtures/vcr_cassettes/initial_model_refresh.yml @@ -21,7 +21,7 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 13:46:21 GMT + - Thu, 27 Mar 2025 20:15:09 GMT Server: - Caddy Vary: @@ -30,6 +30,6 @@ http_interactions: - chunked body: encoding: ASCII-8BIT - string: '{ "models": [ { "details": { "families": [ "bert" ], "family": "bert", "format": "gguf", "parameter_size": "23M", "parent_model": "", "quantization_level": "F16" }, "digest": "bf75350e17522c7dfe63e98f50457b27fadcfee62f0c0767c1c86053407c2abb", "model": "snowflake-arctic-embed:22m", "modified_at": "2025-03-25T01:52:52.027398285Z", "name": "snowflake-arctic-embed:22m", "size": 45838698 }, { "details": { "families": [ "llama" ], "family": "llama", "format": "gguf", "parameter_size": "134.52M", "parent_model": "", "quantization_level": "Q4_0" }, "digest": "b0b2a46174385c0adcaa77ff245ffeced5fc4a61447b6f221b2beb5c5a760133", "model": "smollm:135m", "modified_at": "2025-03-25T01:52:51.363408194Z", "name": "smollm:135m", "size": 91739413 } ] }' - recorded_at: Thu, 27 Mar 2025 13:46:15 GMT + string: '{ "models": [ { "details": { "families": [ "granite", "clip" ], "family": "granite", "format": "gguf", "parameter_size": "2.5B", "parent_model": "", "quantization_level": "Q4_K_M" }, "digest": "3be41a661804ad72cd08269816c5a145f1df6479ad07e2b3a7e29dba575d2669", "model": "granite3.2-vision:2b", "modified_at": "2025-03-27T20:09:18.017039337Z", "name": "granite3.2-vision:2b", "size": 2437852465 }, { "details": { "families": [ "llama" ], "family": "llama", "format": "gguf", "parameter_size": "8.0B", "parent_model": "", "quantization_level": "Q4_K_M" }, "digest": "46e0c10c039e019119339687c3c1757cc81b9da49709a3b3924863ba87ca666e", "model": "llama3.1:8b", "modified_at": "2025-03-27T19:29:58.416254293Z", "name": "llama3.1:8b", "size": 4920753328 }, { "details": { "families": [ "bert" ], "family": "bert", "format": "gguf", "parameter_size": "23M", "parent_model": "", "quantization_level": "F16" }, "digest": "bf75350e17522c7dfe63e98f50457b27fadcfee62f0c0767c1c86053407c2abb", "model": "snowflake-arctic-embed:22m", "modified_at": "2025-03-25T01:52:52.027398285Z", "name": "snowflake-arctic-embed:22m", "size": 45838698 } ] }' + recorded_at: Thu, 27 Mar 2025 20:15:02 GMT recorded_with: VCR 6.3.1 diff --git a/spec/ruby_llm/chat_spec.rb b/spec/ruby_llm/chat_spec.rb index 16591e81..b8d7b789 100644 --- a/spec/ruby_llm/chat_spec.rb +++ b/spec/ruby_llm/chat_spec.rb @@ -12,8 +12,7 @@ 'gemini-2.0-flash', 'deepseek-chat', 'gpt-4o-mini', - # FIXME: this 0.1B model is too dumb to know who Matz is - 'smollm:135m' + 'llama3.1:8b' ].each do |model| it "#{model} can have a basic conversation" do # rubocop:disable RSpec/ExampleLength,RSpec/MultipleExpectations chat = RubyLLM.chat(model: model) @@ -28,7 +27,20 @@ it "#{model} can handle multi-turn conversations" do # rubocop:disable RSpec/MultipleExpectations chat = RubyLLM.chat(model: model) - first = chat.ask("Who was Ruby's creator?") + first = + if model =~ /llama/ + # HACK: provisional code just to exemplify a problem with the original question. + # llama3.1:8b takes "Ruby's creator" to refer to some fictional character, + # but apparently "creator of Ruby" sounds less about a person and gives it a little helpful push. + # + # Ideally the question could be changed and other cassettes re-recorded; + # otherwise this can probably be solved with a bigger model but it will make the repeating Ollama tests + # more computationally expensive for everyone. + chat.ask('Who was the creator of Ruby?') + else + chat.ask("Who was Ruby's creator?") + end + expect(first.content).to include('Matz') followup = chat.ask('What year did he create Ruby?') diff --git a/spec/ruby_llm/chat_streaming_spec.rb b/spec/ruby_llm/chat_streaming_spec.rb index 0f40e121..6343102b 100644 --- a/spec/ruby_llm/chat_streaming_spec.rb +++ b/spec/ruby_llm/chat_streaming_spec.rb @@ -12,7 +12,7 @@ 'gemini-2.0-flash', 'deepseek-chat', 'gpt-4o-mini', - 'smollm:135m' + 'llama3.1:8b' ].each do |model| it "#{model} supports streaming responses" do # rubocop:disable RSpec/ExampleLength,RSpec/MultipleExpectations chat = RubyLLM.chat(model: model) From e0d072f2b08fcabdf0bd144bf59205095ac36ece Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Wed, 26 Mar 2025 20:47:28 -0300 Subject: [PATCH 29/55] Implement vision --- lib/ruby_llm/providers/ollama.rb | 1 + lib/ruby_llm/providers/ollama/chat.rb | 11 +----- lib/ruby_llm/providers/ollama/media.rb | 37 +++++++++++++++++++ lib/tasks/ollama.rake | 3 +- ...ite3_2-vision_2b_can_understand_images.yml | 37 +++++++++++++++++++ spec/ruby_llm/chat_content_spec.rb | 3 +- 6 files changed, 80 insertions(+), 12 deletions(-) create mode 100644 lib/ruby_llm/providers/ollama/media.rb create mode 100644 spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml diff --git a/lib/ruby_llm/providers/ollama.rb b/lib/ruby_llm/providers/ollama.rb index 65f96934..7441e50c 100644 --- a/lib/ruby_llm/providers/ollama.rb +++ b/lib/ruby_llm/providers/ollama.rb @@ -9,6 +9,7 @@ module Ollama extend Ollama::Embeddings extend Ollama::Models extend Ollama::Streaming + extend Ollama::Media module_function diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index 39d64b3e..20305a90 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -16,7 +16,7 @@ def render_payload(messages, tools:, temperature:, model:, stream: false) { model: model, - messages: format_messages(messages), + messages: Media.format_messages(messages), options: { temperature: temperature }, @@ -24,15 +24,6 @@ def render_payload(messages, tools:, temperature:, model:, stream: false) } end - def format_messages(messages) - messages.map do |msg| - { - role: msg.role.to_s, - content: msg.content.to_s - } - end - end - def parse_completion_response(response) data = response.body diff --git a/lib/ruby_llm/providers/ollama/media.rb b/lib/ruby_llm/providers/ollama/media.rb new file mode 100644 index 00000000..f63759cb --- /dev/null +++ b/lib/ruby_llm/providers/ollama/media.rb @@ -0,0 +1,37 @@ +# frozen_string_literal: true + +module RubyLLM + module Providers + module Ollama + # Handles formatting of text or media content for Ollama + module Media + module_function + + def format_messages(messages) + messages.map do |msg| + text = nil + images = [] + + if msg.content.is_a?(Array) + msg.content.each do |part| + case part[:type] + when 'text' + text = part[:text] + when 'image' + images << part[:source][:data] + end + end + else + text = msg.content + end + + { + role: msg.role.to_s, + content: text, + }.tap { |h| h.merge!(images: images) if images.any? } + end + end + end + end + end +end diff --git a/lib/tasks/ollama.rake b/lib/tasks/ollama.rake index c28465e6..f07dcc73 100644 --- a/lib/tasks/ollama.rake +++ b/lib/tasks/ollama.rake @@ -24,12 +24,13 @@ def pull_model(ollama_library_model_spec, description) end namespace :ollama do - desc 'Install some tiny models required for running Ollama specs (downloads about 5 GiB into your Ollama server)' + desc 'Install some tiny models required for running Ollama specs (downloads about 7.5 GiB into your Ollama server)' task :install_models_for_specs do RubyLLM.config.request_timeout = 60 * 30 # 30min timeout per model since pull is synchronous RubyLLM.config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL') pull_model('llama3.1:8b', '4.9 GiB chat model') + pull_model('granite3.2-vision:2b', '2.4 GiB vision model') pull_model('snowflake-arctic-embed:22m', '46 MiB embedding model') end end diff --git a/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml b/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml new file mode 100644 index 00000000..441cca98 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml @@ -0,0 +1,37 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"granite3.2-vision:2b","messages":[{"role":"user","content":"What + do you see in this image?","images":["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"]}],"options":{"temperature":0.7},"stream":false,"tools":[]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Length: + - '380' + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 20:10:23 GMT + Server: + - Caddy + body: + encoding: UTF-8 + string: '{"model":"granite3.2-vision:2b","created_at":"2025-03-27T20:10:23.42586545Z","message":{"role":"assistant","content":"\nI + see a red diamond-like object with a white center on a black background."},"done_reason":"stop","done":true,"total_duration":165572248,"load_duration":6699362,"prompt_eval_count":2242,"prompt_eval_duration":24375911,"eval_count":20,"eval_duration":133708153}' + recorded_at: Thu, 27 Mar 2025 20:10:16 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/ruby_llm/chat_content_spec.rb b/spec/ruby_llm/chat_content_spec.rb index f72493a9..39d34f92 100644 --- a/spec/ruby_llm/chat_content_spec.rb +++ b/spec/ruby_llm/chat_content_spec.rb @@ -13,7 +13,8 @@ [ 'claude-3-5-haiku-20241022', 'gemini-2.0-flash', - 'gpt-4o-mini' + 'gpt-4o-mini', + 'granite3.2-vision:2b' ].each do |model| it "#{model} can understand images" do # rubocop:disable RSpec/MultipleExpectations chat = RubyLLM.chat(model: model) From 5a621886399884ccce7b008cfa2e8fafd697b288 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 10:04:55 -0300 Subject: [PATCH 30/55] Implement tool calling --- lib/ruby_llm/providers/ollama.rb | 1 + lib/ruby_llm/providers/ollama/capabilities.rb | 2 +- lib/ruby_llm/providers/ollama/chat.rb | 8 +-- lib/ruby_llm/providers/ollama/streaming.rb | 1 + lib/ruby_llm/providers/ollama/tools.rb | 54 +++++++++++++++++++ 5 files changed, 61 insertions(+), 5 deletions(-) create mode 100644 lib/ruby_llm/providers/ollama/tools.rb diff --git a/lib/ruby_llm/providers/ollama.rb b/lib/ruby_llm/providers/ollama.rb index 7441e50c..e66c9310 100644 --- a/lib/ruby_llm/providers/ollama.rb +++ b/lib/ruby_llm/providers/ollama.rb @@ -10,6 +10,7 @@ module Ollama extend Ollama::Models extend Ollama::Streaming extend Ollama::Media + extend Ollama::Tools module_function diff --git a/lib/ruby_llm/providers/ollama/capabilities.rb b/lib/ruby_llm/providers/ollama/capabilities.rb index 1bd590de..263201ed 100644 --- a/lib/ruby_llm/providers/ollama/capabilities.rb +++ b/lib/ruby_llm/providers/ollama/capabilities.rb @@ -39,7 +39,7 @@ def supports_vision?(_model_id) # @return [Boolean] true if the model supports function calling def supports_functions?(_model_id) # FIXME: placeholder - false + true end # Determines if the model supports JSON mode diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index 20305a90..6a5cbe65 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -12,15 +12,14 @@ def completion_url end def render_payload(messages, tools:, temperature:, model:, stream: false) - raise NotImplementedError, 'tool use not implemented in Ollama at this time' if tools.any? - { model: model, messages: Media.format_messages(messages), options: { temperature: temperature }, - stream: stream + stream: stream, + tools: tools.map { |_, tool| tool_for(tool) } } end @@ -32,7 +31,8 @@ def parse_completion_response(response) content: data.dig('message', 'content'), input_tokens: data['prompt_eval_count'].to_i, output_tokens: data['eval_count'].to_i, - model_id: data['model'] + model_id: data['model'], + tool_calls: parse_tool_calls(data.dig('message', 'tool_calls')) ) end end diff --git a/lib/ruby_llm/providers/ollama/streaming.rb b/lib/ruby_llm/providers/ollama/streaming.rb index 96566dda..289d011c 100644 --- a/lib/ruby_llm/providers/ollama/streaming.rb +++ b/lib/ruby_llm/providers/ollama/streaming.rb @@ -29,6 +29,7 @@ def build_chunk(data) role: :assistant, content: data.dig('message', 'content'), model_id: data['model'], + tool_calls: parse_tool_calls(data.dig('message', 'tool_calls')), # NOTE: unavailable in the response - https://ollama.readthedocs.io/en/api/#streaming-responses input_tokens: nil, diff --git a/lib/ruby_llm/providers/ollama/tools.rb b/lib/ruby_llm/providers/ollama/tools.rb new file mode 100644 index 00000000..257c51fb --- /dev/null +++ b/lib/ruby_llm/providers/ollama/tools.rb @@ -0,0 +1,54 @@ +# frozen_string_literal: true + +module RubyLLM + module Providers + module Ollama + # Tools methods of the Ollama API integration + module Tools + module_function + + def tool_for(tool) + { + type: 'function', + function: { + name: tool.name, + description: tool.description, + parameters: { + type: 'object', + properties: tool.parameters.transform_values { |param| param_schema(param) }, + required: tool.parameters.select { |_, p| p.required }.keys + } + } + } + end + + def param_schema(param) + { + type: param.type, + description: param.description + }.compact + end + + def parse_tool_calls(tool_calls) + return nil unless tool_calls&.any? + + tool_calls.to_h do |tc| + tc = tc['function'] if tc['function'] + name = tc['name'] + next [nil, nil] unless name =~ /\S/ + + [ + name, + ToolCall.new( + id: name, + name: name, + arguments: tc['arguments'] + ) + ] + end.compact + end + + end + end + end +end From 87f8955090da1449c7cd04699c4de17b0f234d54 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 16:26:23 -0300 Subject: [PATCH 31/55] Attempt to parse tool calling markup in text response --- lib/ruby_llm/providers/ollama/chat.rb | 2 +- lib/ruby_llm/providers/ollama/streaming.rb | 2 ++ lib/ruby_llm/providers/ollama/tools.rb | 20 ++++++++++++++++++++ 3 files changed, 23 insertions(+), 1 deletion(-) diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index 6a5cbe65..85905396 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -24,7 +24,7 @@ def render_payload(messages, tools:, temperature:, model:, stream: false) end def parse_completion_response(response) - data = response.body + data = Tools.preprocess_tool_calls(response.body) Message.new( role: :assistant, diff --git a/lib/ruby_llm/providers/ollama/streaming.rb b/lib/ruby_llm/providers/ollama/streaming.rb index 289d011c..89e868d2 100644 --- a/lib/ruby_llm/providers/ollama/streaming.rb +++ b/lib/ruby_llm/providers/ollama/streaming.rb @@ -25,6 +25,8 @@ def handle_stream(&block) end def build_chunk(data) + data = Tools.preprocess_tool_calls(data) + Chunk.new( role: :assistant, content: data.dig('message', 'content'), diff --git a/lib/ruby_llm/providers/ollama/tools.rb b/lib/ruby_llm/providers/ollama/tools.rb index 257c51fb..2e6c76f6 100644 --- a/lib/ruby_llm/providers/ollama/tools.rb +++ b/lib/ruby_llm/providers/ollama/tools.rb @@ -48,6 +48,26 @@ def parse_tool_calls(tool_calls) end.compact end + # HACK: Llama3.x yields this in the proper tool_calls response field, + # but some other models return it as markup inside the text response. + # + # Unfortunately said other models are all over the place when it comes + # to sticking to a format so this doesn't cover all edge cases. + def preprocess_tool_calls(response_data) + # Move JSON markup from inside the text to its + # specific field in the response where it should be. + # https://github.com/ollama/ollama/blob/main/docs/api.md#chat-request-with-tools + + tc = response_data['message']['tool_calls'] ||= [] + response_data['message']['content']&.gsub!(%r{(.*)}mi) do + capture = $1 + tc << JSON.parse(capture) if capture =~ /^\s*{/ + '' + end + tc.flatten! + response_data + end + end end end From e810a7ab1d878fa48b7baac97ccadd40946a6942 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 16:57:32 -0300 Subject: [PATCH 32/55] Use low temperature when tools are involved --- lib/ruby_llm/chat.rb | 4 +++- lib/ruby_llm/providers/ollama/chat.rb | 5 +++++ 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/lib/ruby_llm/chat.rb b/lib/ruby_llm/chat.rb index 9c6d2941..7d42f9fe 100644 --- a/lib/ruby_llm/chat.rb +++ b/lib/ruby_llm/chat.rb @@ -11,12 +11,14 @@ module RubyLLM class Chat include Enumerable + DEFAULT_TEMPERATURE = 0.7 + attr_reader :model, :messages, :tools def initialize(model: nil, provider: nil) model_id = model || RubyLLM.config.default_model with_model(model_id, provider: provider) - @temperature = 0.7 + @temperature = DEFAULT_TEMPERATURE @messages = [] @tools = {} @on = { diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index 85905396..c3213a48 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -12,6 +12,11 @@ def completion_url end def render_payload(messages, tools:, temperature:, model:, stream: false) + # Heuristic: if temperature is set to default and tools are in play, + # use a low temperature to reduce risk of small models ignoring available + # tools in favor of making up imaginary API calls + temperature = 0.1 if tools.any? && temperature == RubyLLM::Chat::DEFAULT_TEMPERATURE + { model: model, messages: Media.format_messages(messages), From 68c257d9421f8e2cb1f70ce008fba8f3a748cc39 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 16:58:17 -0300 Subject: [PATCH 33/55] Passing tools spec --- ...tion_calling_llama3_1_8b_can_use_tools.yml | 77 +++++++++ ..._use_tools_in_multi-turn_conversations.yml | 159 +++++++++++++++++ ...ith_multi-turn_streaming_conversations.yml | 163 ++++++++++++++++++ ..._1_8b_can_use_tools_without_parameters.yml | 87 ++++++++++ spec/ruby_llm/chat_tools_spec.rb | 3 +- 5 files changed, 488 insertions(+), 1 deletion(-) create mode 100644 spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters.yml diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools.yml new file mode 100644 index 00000000..fcb62cfe --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools.yml @@ -0,0 +1,77 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude + (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., + 13.4050)"}},"required":["latitude","longitude"]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Length: + - '400' + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 19:40:44 GMT + Server: + - Caddy + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:40:44.116572023Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":330510672,"load_duration":19297272,"prompt_eval_count":205,"prompt_eval_duration":10692419,"eval_count":28,"eval_duration":300128824}' + recorded_at: Thu, 27 Mar 2025 19:40:37 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude + (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., + 13.4050)"}},"required":["latitude","longitude"]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Length: + - '412' + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 19:40:44 GMT + Server: + - Caddy + body: + encoding: ASCII-8BIT + string: !binary |- + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMTk6NDA6NDQuNDI0MDA1MTYzWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjMwNDAyODUzNCwibG9hZF9kdXJhdGlvbiI6MTUzMzQwODgsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1OTI3NTUyLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6MjgyMTgxMjMzfQ== + recorded_at: Thu, 27 Mar 2025 19:40:37 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml new file mode 100644 index 00000000..fa2df115 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml @@ -0,0 +1,159 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude + (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., + 13.4050)"}},"required":["latitude","longitude"]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Length: + - '400' + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 19:40:44 GMT + Server: + - Caddy + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:40:44.764703701Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":335981205,"load_duration":15122386,"prompt_eval_count":205,"prompt_eval_duration":10534932,"eval_count":28,"eval_duration":309925415}' + recorded_at: Thu, 27 Mar 2025 19:40:38 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude + (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., + 13.4050)"}},"required":["latitude","longitude"]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Length: + - '412' + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 19:40:45 GMT + Server: + - Caddy + body: + encoding: ASCII-8BIT + string: !binary |- + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMTk6NDA6NDUuMDY4MDEwMDM2WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjMwMDI2MzMwOSwibG9hZF9kdXJhdGlvbiI6MTQ5NTQxNzQsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1OTE2OTIzLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6Mjc4ODY0NjM5fQ== + recorded_at: Thu, 27 Mar 2025 19:40:38 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The + tool call response indicates that the current temperature in Berlin is 15°C + and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s + the weather in Paris? (48.8575, 2.3514)"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude + (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., + 13.4050)"}},"required":["latitude","longitude"]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Length: + - '399' + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 19:40:45 GMT + Server: + - Caddy + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:40:45.402105882Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done_reason":"stop","done":true,"total_duration":331334328,"load_duration":14896321,"prompt_eval_count":297,"prompt_eval_duration":10733730,"eval_count":28,"eval_duration":304577059}' + recorded_at: Thu, 27 Mar 2025 19:40:38 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The + tool call response indicates that the current temperature in Berlin is 15°C + and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s + the weather in Paris? (48.8575, 2.3514)"},{"role":"assistant"},{"role":"tool","content":"Current + weather at 48.8575, 2.3514: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude + (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., + 13.4050)"}},"required":["latitude","longitude"]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Length: + - '411' + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 19:40:45 GMT + Server: + - Caddy + body: + encoding: ASCII-8BIT + string: !binary |- + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMTk6NDA6NDUuNzAyNDY0MTY5WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGVyZSdzIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6Mjk3ODU1NTcxLCJsb2FkX2R1cmF0aW9uIjoxNDgwMTQ1OCwicHJvbXB0X2V2YWxfY291bnQiOjIwNCwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjYwNjY0MjcsImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyNzU4MDMyMjl9 + recorded_at: Thu, 27 Mar 2025 19:40:39 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml new file mode 100644 index 00000000..410d9bce --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml @@ -0,0 +1,163 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude + (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., + 13.4050)"}},"required":["latitude","longitude"]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Thu, 27 Mar 2025 19:40:48 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: | + {"model":"llama3.1:8b","created_at":"2025-03-27T19:40:48.272828677Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T19:40:48.282376206Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":321662603,"load_duration":14969862,"prompt_eval_count":205,"prompt_eval_duration":10628407,"eval_count":28,"eval_duration":295554306} + recorded_at: Thu, 27 Mar 2025 19:40:41 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude + (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., + 13.4050)"}},"required":["latitude","longitude"]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Thu, 27 Mar 2025 19:40:48 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: ASCII-8BIT + string: !binary |- + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMTk6NDA6NDguNTc5MTczMzY4WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIG91dHB1dCBpbmRpY2F0ZXMgdGhhdCB0aGUgY3VycmVudCB0ZW1wZXJhdHVyZSBpbiBCZXJsaW4gaXMgMTXCsEMgYW5kIHRoZXJlJ3MgYSB3aW5kIHNwZWVkIG9mIDEwIGttL2guIn0sImRvbmVfcmVhc29uIjoic3RvcCIsImRvbmUiOnRydWUsInRvdGFsX2R1cmF0aW9uIjoyOTM1NTMyNzcsImxvYWRfZHVyYXRpb24iOjE0NjI3NTEyLCJwcm9tcHRfZXZhbF9jb3VudCI6MTEyLCJwcm9tcHRfZXZhbF9kdXJhdGlvbiI6NjEwNTcwMiwiZXZhbF9jb3VudCI6MjgsImV2YWxfZHVyYXRpb24iOjI3MjIzOTc3MX0K + recorded_at: Thu, 27 Mar 2025 19:40:41 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The + tool call output indicates that the current temperature in Berlin is 15°C + and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s + the weather in Paris? (48.8575, 2.3514)"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude + (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., + 13.4050)"}},"required":["latitude","longitude"]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Thu, 27 Mar 2025 19:40:48 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: | + {"model":"llama3.1:8b","created_at":"2025-03-27T19:40:48.899731222Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T19:40:48.909582967Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":327110248,"load_duration":14711739,"prompt_eval_count":297,"prompt_eval_duration":11275239,"eval_count":28,"eval_duration":300057920} + recorded_at: Thu, 27 Mar 2025 19:40:42 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The + tool call output indicates that the current temperature in Berlin is 15°C + and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s + the weather in Paris? (48.8575, 2.3514)"},{"role":"assistant"},{"role":"tool","content":"Current + weather at 48.8575, 2.3514: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude + (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., + 13.4050)"}},"required":["latitude","longitude"]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Thu, 27 Mar 2025 19:40:49 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: ASCII-8BIT + string: !binary |- + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMTk6NDA6NDkuMjEwNzE3NDQyWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIG91dHB1dCBpbmRpY2F0ZXMgdGhhdCB0aGUgY3VycmVudCB0ZW1wZXJhdHVyZSBpbiBQYXJpcyBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5ODAxMzMxNiwibG9hZF9kdXJhdGlvbiI6MTUyNTkzMTMsInByb21wdF9ldmFsX2NvdW50IjoyMDQsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1OTExNjA3LCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6Mjc1NzAxNzY3fQo= + recorded_at: Thu, 27 Mar 2025 19:40:42 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters.yml new file mode 100644 index 00000000..ef9cae23 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters.yml @@ -0,0 +1,87 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the best language to learn?"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Length: + - '372' + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 19:40:45 GMT + Server: + - Caddy + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:40:45.890115845Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done_reason":"stop","done":true,"total_duration":182670710,"load_duration":15026207,"prompt_eval_count":155,"prompt_eval_duration":8306450,"eval_count":15,"eval_duration":158941659}' + recorded_at: Thu, 27 Mar 2025 19:40:39 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the best language to learn?"},{"role":"assistant"},{"role":"tool","content":"Ruby"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 27 Mar 2025 19:40:47 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '1360' + body: + encoding: ASCII-8BIT + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:40:47.954756575Z","message":{"role":"assistant","content":"The + tool suggests Ruby as one of the top languages to learn, but it doesn''t provide + any specific reasons why. Let me try to get more information from the tool.\n\nOkay, + I''ve got some additional data from the tool. It seems that Ruby is a popular + choice for web development and has a strong focus on simplicity and ease of + use. However, the tool also suggests considering other languages such as Python, + JavaScript, or Java, depending on your specific needs and goals.\n\nHere''s + a more detailed breakdown:\n\n* **Ruby**: Great for web development, especially + with the Ruby on Rails framework.\n* **Python**: Versatile language suitable + for data science, machine learning, web development, and more.\n* **JavaScript**: + Essential for front-end web development and popular in back-end development + as well.\n* **Java**: Object-oriented language used in Android app development, + web development, and enterprise software development.\n\nUltimately, the best + language to learn depends on your interests, career goals, and the type of + projects you want to work on."},"done_reason":"stop","done":true,"total_duration":2061922803,"load_duration":14748701,"prompt_eval_count":77,"prompt_eval_duration":4208460,"eval_count":211,"eval_duration":2042436378}' + recorded_at: Thu, 27 Mar 2025 19:40:41 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/ruby_llm/chat_tools_spec.rb b/spec/ruby_llm/chat_tools_spec.rb index daa0821a..acafc3c1 100644 --- a/spec/ruby_llm/chat_tools_spec.rb +++ b/spec/ruby_llm/chat_tools_spec.rb @@ -28,7 +28,8 @@ def execute [ 'claude-3-5-haiku-20241022', 'gemini-2.0-flash', - 'gpt-4o-mini' + 'gpt-4o-mini', + 'llama3.1:8b' ].each do |model| it "#{model} can use tools" do # rubocop:disable RSpec/MultipleExpectations chat = RubyLLM.chat(model: model) From bb2e1bfe7f0888ba9a13be1f7c6615630ebb51c0 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 12:37:13 -0300 Subject: [PATCH 34/55] Rubocop appeasement --- lib/ruby_llm/providers/ollama/media.rb | 2 +- lib/ruby_llm/providers/ollama/tools.rb | 3 +-- spec/spec_helper.rb | 4 ++-- 3 files changed, 4 insertions(+), 5 deletions(-) diff --git a/lib/ruby_llm/providers/ollama/media.rb b/lib/ruby_llm/providers/ollama/media.rb index f63759cb..c9d38d4c 100644 --- a/lib/ruby_llm/providers/ollama/media.rb +++ b/lib/ruby_llm/providers/ollama/media.rb @@ -27,7 +27,7 @@ def format_messages(messages) { role: msg.role.to_s, - content: text, + content: text }.tap { |h| h.merge!(images: images) if images.any? } end end diff --git a/lib/ruby_llm/providers/ollama/tools.rb b/lib/ruby_llm/providers/ollama/tools.rb index 2e6c76f6..5f2a8872 100644 --- a/lib/ruby_llm/providers/ollama/tools.rb +++ b/lib/ruby_llm/providers/ollama/tools.rb @@ -60,14 +60,13 @@ def preprocess_tool_calls(response_data) tc = response_data['message']['tool_calls'] ||= [] response_data['message']['content']&.gsub!(%r{(.*)}mi) do - capture = $1 + capture = ::Regexp.last_match(1) tc << JSON.parse(capture) if capture =~ /^\s*{/ '' end tc.flatten! response_data end - end end end diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index 7dfc15c2..51e9ce6b 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -83,7 +83,8 @@ end end - VCR.use_cassette("initial_model_refresh") do + # Run once at test suite startup + VCR.use_cassette('initial_model_refresh') do RubyLLM.configure do |config| config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL', 'http://localhost:11434') # needs to run when ONLY Ollama is configured and before any others are configured @@ -101,4 +102,3 @@ RSpec.shared_context 'with configured RubyLLM' do end - From c57613cca172e5da3c00c958f9aa126f9aa08aa6 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 17:57:49 -0300 Subject: [PATCH 35/55] Refresh cassettes for good measure --- ...8b_can_handle_multi-turn_conversations.yml | 89 ++++++++++--------- ...ma3_1_8b_can_have_a_basic_conversation.yml | 10 +-- ...tion_calling_llama3_1_8b_can_use_tools.yml | 16 ++-- ..._use_tools_in_multi-turn_conversations.yml | 32 +++---- ...ith_multi-turn_streaming_conversations.yml | 40 ++++----- ..._1_8b_can_use_tools_without_parameters.yml | 39 +++----- ...ama3_1_8b_supports_streaming_responses.yml | 29 +++--- ...ite3_2-vision_2b_can_understand_images.yml | 10 +-- 8 files changed, 129 insertions(+), 136 deletions(-) diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations.yml index bdaf1f1a..d4a8a25c 100644 --- a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations.yml +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations.yml @@ -24,52 +24,51 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 19:46:58 GMT + - Thu, 27 Mar 2025 20:52:52 GMT Server: - Caddy Vary: - Accept-Encoding Content-Length: - - '1400' + - '1339' body: encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:46:58.740797174Z","message":{"role":"assistant","content":"The - creator of the Ruby programming language is Yukihiro Matsumoto, a Japanese - computer programmer. He started working on Ruby in 1993 and released the first - version, known as Ruby 0.95, in 1995.\n\nMatsumoto, also known by his nickname - \"Matz,\" wanted to create a language that was easy to use and fun to program - with, while still being powerful enough for real-world applications. He drew - inspiration from various languages, including Perl, Smalltalk, Ada, and Lisp, - and incorporated features such as dynamic typing, object-oriented programming, - and a syntax similar to Perl.\n\nToday, Ruby is a popular language used in - web development (especially with the Ruby on Rails framework), scripting, - and other areas of software development. Matsumoto continues to be involved - in the development of Ruby and has also created several other projects, including - the Ruby on Rails framework and the YARV (Yet Another Ruby VM) project.\n\nMatsumoto - is often referred to as one of the most influential programmers of his generation, - and his work on Ruby has had a significant impact on the programming community."},"done_reason":"stop","done":true,"total_duration":2168998404,"load_duration":18237858,"prompt_eval_count":17,"prompt_eval_duration":3883030,"eval_count":226,"eval_duration":2146427889}' - recorded_at: Thu, 27 Mar 2025 19:46:52 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:52:52.883344011Z","message":{"role":"assistant","content":"The + creator of the programming language Ruby is Yukihiro Matsumoto, a Japanese + computer programmer. He began working on Ruby in 1993 and released the first + version, Ruby 0.95, in 1995. Matsumoto''s goal with Ruby was to create a language + that was easy to use and enjoyable for developers, while also being powerful + and flexible.\n\nMatsumoto, who is often referred to as \"Matz\" by his peers, + has continued to be involved with the development of Ruby throughout its history, + and is still active in the community today. He is known for his commitment + to making Ruby a language that is accessible to developers of all skill levels, + and for his emphasis on the importance of community and collaboration.\n\nIn + 1999, Matsumoto founded the Ruby Development Team (now known as the Ruby Core + Team), which oversees the development of the Ruby programming language. Today, + Ruby is widely used in web development, scripting, and other applications, + and has a large and active global community of developers who contribute to + its growth and development."},"done_reason":"stop","done":true,"total_duration":2099993065,"load_duration":15225883,"prompt_eval_count":17,"prompt_eval_duration":4027231,"eval_count":216,"eval_duration":2080377970}' + recorded_at: Thu, 27 Mar 2025 20:52:46 GMT - request: method: post uri: http://localhost:11434/api/chat body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Who was - the creator of Ruby?"},{"role":"assistant","content":"The creator of the Ruby - programming language is Yukihiro Matsumoto, a Japanese computer programmer. - He started working on Ruby in 1993 and released the first version, known as - Ruby 0.95, in 1995.\n\nMatsumoto, also known by his nickname \"Matz,\" wanted - to create a language that was easy to use and fun to program with, while still - being powerful enough for real-world applications. He drew inspiration from - various languages, including Perl, Smalltalk, Ada, and Lisp, and incorporated - features such as dynamic typing, object-oriented programming, and a syntax - similar to Perl.\n\nToday, Ruby is a popular language used in web development - (especially with the Ruby on Rails framework), scripting, and other areas - of software development. Matsumoto continues to be involved in the development - of Ruby and has also created several other projects, including the Ruby on - Rails framework and the YARV (Yet Another Ruby VM) project.\n\nMatsumoto is - often referred to as one of the most influential programmers of his generation, - and his work on Ruby has had a significant impact on the programming community."},{"role":"user","content":"What + the creator of Ruby?"},{"role":"assistant","content":"The creator of the programming + language Ruby is Yukihiro Matsumoto, a Japanese computer programmer. He began + working on Ruby in 1993 and released the first version, Ruby 0.95, in 1995. + Matsumoto''s goal with Ruby was to create a language that was easy to use + and enjoyable for developers, while also being powerful and flexible.\n\nMatsumoto, + who is often referred to as \"Matz\" by his peers, has continued to be involved + with the development of Ruby throughout its history, and is still active in + the community today. He is known for his commitment to making Ruby a language + that is accessible to developers of all skill levels, and for his emphasis + on the importance of community and collaboration.\n\nIn 1999, Matsumoto founded + the Ruby Development Team (now known as the Ruby Core Team), which oversees + the development of the Ruby programming language. Today, Ruby is widely used + in web development, scripting, and other applications, and has a large and + active global community of developers who contribute to its growth and development."},{"role":"user","content":"What year did he create Ruby?"}],"options":{"temperature":0.7},"stream":false,"tools":[]}' headers: User-Agent: @@ -88,21 +87,25 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 19:46:59 GMT + - Thu, 27 Mar 2025 20:52:54 GMT Server: - Caddy Vary: - Accept-Encoding Content-Length: - - '690' + - '1022' body: encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:46:59.755190489Z","message":{"role":"assistant","content":"Yukihiro - Matsumoto started working on Ruby in 1993, but it was not until 1995 that - the first version, known as Ruby 0.95, was released.\n\nHowever, if you''re - asking for a more specific answer to \"when did he create Ruby?\", I would - say that Matsumoto created the idea and initial design of Ruby around 1992-1993, - but the language gained its final form and was first publicly available in - 1995."},"done_reason":"stop","done":true,"total_duration":1009884033,"load_duration":17976970,"prompt_eval_count":259,"prompt_eval_duration":4256642,"eval_count":99,"eval_duration":986877265}' - recorded_at: Thu, 27 Mar 2025 19:46:53 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.655557443Z","message":{"role":"assistant","content":"Yukihiro + Matsumoto began working on the design of the Ruby programming language in + 1993. He started writing the code for Ruby in December 1995, and released + the first version, Ruby 0.95, on February 24, 1995.\n\nHowever, it''s worth + noting that the language as we know it today, with its modern syntax and features, + was finalized around 1997-1998. Matsumoto has said in interviews that he considered + Ruby to be a \"finished\" product by around 1998, although it continues to + evolve and improve to this day.\n\nSo while 1993 marks the beginning of Matsumoto''s + work on Ruby, 1995 is the year when the first version of the language was + released, and 1997-1998 mark the time when the modern version of Ruby started + to take shape."},"done_reason":"stop","done":true,"total_duration":1768670371,"load_duration":15370697,"prompt_eval_count":249,"prompt_eval_duration":4097509,"eval_count":177,"eval_duration":1748440674}' + recorded_at: Thu, 27 Mar 2025 20:52:47 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation.yml index 3385a1b6..8ec4969c 100644 --- a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation.yml +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation.yml @@ -22,16 +22,16 @@ http_interactions: message: OK headers: Content-Length: - - '310' + - '309' Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 19:46:56 GMT + - Thu, 27 Mar 2025 20:52:50 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:46:56.566074923Z","message":{"role":"assistant","content":"The - answer is: 4!"},"done_reason":"stop","done":true,"total_duration":132025686,"load_duration":17201717,"prompt_eval_count":18,"prompt_eval_duration":25849721,"eval_count":8,"eval_duration":88593644}' - recorded_at: Thu, 27 Mar 2025 19:46:49 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:52:50.778698618Z","message":{"role":"assistant","content":"The + answer is 4!"},"done_reason":"stop","done":true,"total_duration":113151682,"load_duration":17646551,"prompt_eval_count":18,"prompt_eval_duration":25510313,"eval_count":7,"eval_duration":69332453}' + recorded_at: Thu, 27 Mar 2025 20:52:44 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools.yml index fcb62cfe..642144fe 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools.yml @@ -29,20 +29,20 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 19:40:44 GMT + - Thu, 27 Mar 2025 20:52:55 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:40:44.116572023Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":330510672,"load_duration":19297272,"prompt_eval_count":205,"prompt_eval_duration":10692419,"eval_count":28,"eval_duration":300128824}' - recorded_at: Thu, 27 Mar 2025 19:40:37 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:52:55.210031365Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":327978180,"load_duration":15623627,"prompt_eval_count":205,"prompt_eval_duration":12561197,"eval_count":28,"eval_duration":299354569}' + recorded_at: Thu, 27 Mar 2025 20:52:48 GMT - request: method: post uri: http://localhost:11434/api/chat body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., @@ -62,16 +62,16 @@ http_interactions: message: OK headers: Content-Length: - - '412' + - '435' Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 19:40:44 GMT + - Thu, 27 Mar 2025 20:52:55 GMT Server: - Caddy body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMTk6NDA6NDQuNDI0MDA1MTYzWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjMwNDAyODUzNCwibG9hZF9kdXJhdGlvbiI6MTUzMzQwODgsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1OTI3NTUyLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6MjgyMTgxMjMzfQ== - recorded_at: Thu, 27 Mar 2025 19:40:37 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMjA6NTI6NTUuNTE1NDY1MTA4WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlIHdpbmQgc3BlZWQgaXMgYXBwcm94aW1hdGVseSAxMCBraWxvbWV0ZXJzIHBlciBob3VyLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6MzAyNDc4Njc0LCJsb2FkX2R1cmF0aW9uIjoxNDcxMTc2NywicHJvbXB0X2V2YWxfY291bnQiOjExMiwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjYwMTcwMDUsImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyODEwNTA1NDB9 + recorded_at: Thu, 27 Mar 2025 20:52:48 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml index fa2df115..25f57360 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml @@ -29,20 +29,20 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 19:40:44 GMT + - Thu, 27 Mar 2025 20:53:54 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:40:44.764703701Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":335981205,"load_duration":15122386,"prompt_eval_count":205,"prompt_eval_duration":10534932,"eval_count":28,"eval_duration":309925415}' - recorded_at: Thu, 27 Mar 2025 19:40:38 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:53:54.056546141Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":375038607,"load_duration":19702489,"prompt_eval_count":205,"prompt_eval_duration":43370375,"eval_count":28,"eval_duration":311651215}' + recorded_at: Thu, 27 Mar 2025 20:53:47 GMT - request: method: post uri: http://localhost:11434/api/chat body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., @@ -66,21 +66,21 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 19:40:45 GMT + - Thu, 27 Mar 2025 20:53:54 GMT Server: - Caddy body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMTk6NDA6NDUuMDY4MDEwMDM2WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjMwMDI2MzMwOSwibG9hZF9kdXJhdGlvbiI6MTQ5NTQxNzQsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1OTE2OTIzLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6Mjc4ODY0NjM5fQ== - recorded_at: Thu, 27 Mar 2025 19:40:38 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMjA6NTM6NTQuMzUyNTYyNDMzWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5MzE2MzQxNCwibG9hZF9kdXJhdGlvbiI6MTUxNTM4MDQsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1ODAxNjIyLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6MjcxNTc3OTYyfQ== + recorded_at: Thu, 27 Mar 2025 20:53:47 GMT - request: method: post uri: http://localhost:11434/api/chat body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The tool call response indicates that the current temperature in Berlin is 15°C and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s @@ -107,24 +107,24 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 19:40:45 GMT + - Thu, 27 Mar 2025 20:53:54 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:40:45.402105882Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done_reason":"stop","done":true,"total_duration":331334328,"load_duration":14896321,"prompt_eval_count":297,"prompt_eval_duration":10733730,"eval_count":28,"eval_duration":304577059}' - recorded_at: Thu, 27 Mar 2025 19:40:38 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:53:54.681058938Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done_reason":"stop","done":true,"total_duration":325240591,"load_duration":14868711,"prompt_eval_count":297,"prompt_eval_duration":10941313,"eval_count":28,"eval_duration":298076119}' + recorded_at: Thu, 27 Mar 2025 20:53:48 GMT - request: method: post uri: http://localhost:11434/api/chat body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The tool call response indicates that the current temperature in Berlin is 15°C and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s - the weather in Paris? (48.8575, 2.3514)"},{"role":"assistant"},{"role":"tool","content":"Current + the weather in Paris? (48.8575, 2.3514)"},{"role":"assistant","content":null},{"role":"tool","content":"Current weather at 48.8575, 2.3514: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., @@ -148,12 +148,12 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 19:40:45 GMT + - Thu, 27 Mar 2025 20:53:54 GMT Server: - Caddy body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMTk6NDA6NDUuNzAyNDY0MTY5WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGVyZSdzIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6Mjk3ODU1NTcxLCJsb2FkX2R1cmF0aW9uIjoxNDgwMTQ1OCwicHJvbXB0X2V2YWxfY291bnQiOjIwNCwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjYwNjY0MjcsImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyNzU4MDMyMjl9 - recorded_at: Thu, 27 Mar 2025 19:40:39 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMjA6NTM6NTQuOTgxMjY0NDUzWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGVyZSdzIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6Mjk3MzE4NjA1LCJsb2FkX2R1cmF0aW9uIjoxNDcxMjgyMywicHJvbXB0X2V2YWxfY291bnQiOjIwNCwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjYxMTE0MTQsImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyNzUzMzgwNTZ9 + recorded_at: Thu, 27 Mar 2025 20:53:48 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml index 410d9bce..40568a13 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml @@ -27,7 +27,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Thu, 27 Mar 2025 19:40:48 GMT + - Thu, 27 Mar 2025 20:52:56 GMT Server: - Caddy Transfer-Encoding: @@ -35,16 +35,16 @@ http_interactions: body: encoding: UTF-8 string: | - {"model":"llama3.1:8b","created_at":"2025-03-27T19:40:48.272828677Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T19:40:48.282376206Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":321662603,"load_duration":14969862,"prompt_eval_count":205,"prompt_eval_duration":10628407,"eval_count":28,"eval_duration":295554306} - recorded_at: Thu, 27 Mar 2025 19:40:41 GMT + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:56.880657556Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:56.890641104Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":318070144,"load_duration":14748268,"prompt_eval_count":205,"prompt_eval_duration":10456487,"eval_count":28,"eval_duration":292444560} + recorded_at: Thu, 27 Mar 2025 20:52:50 GMT - request: method: post uri: http://localhost:11434/api/chat body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., @@ -66,7 +66,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Thu, 27 Mar 2025 19:40:48 GMT + - Thu, 27 Mar 2025 20:52:57 GMT Server: - Caddy Transfer-Encoding: @@ -74,17 +74,17 @@ http_interactions: body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMTk6NDA6NDguNTc5MTczMzY4WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIG91dHB1dCBpbmRpY2F0ZXMgdGhhdCB0aGUgY3VycmVudCB0ZW1wZXJhdHVyZSBpbiBCZXJsaW4gaXMgMTXCsEMgYW5kIHRoZXJlJ3MgYSB3aW5kIHNwZWVkIG9mIDEwIGttL2guIn0sImRvbmVfcmVhc29uIjoic3RvcCIsImRvbmUiOnRydWUsInRvdGFsX2R1cmF0aW9uIjoyOTM1NTMyNzcsImxvYWRfZHVyYXRpb24iOjE0NjI3NTEyLCJwcm9tcHRfZXZhbF9jb3VudCI6MTEyLCJwcm9tcHRfZXZhbF9kdXJhdGlvbiI6NjEwNTcwMiwiZXZhbF9jb3VudCI6MjgsImV2YWxfZHVyYXRpb24iOjI3MjIzOTc3MX0K - recorded_at: Thu, 27 Mar 2025 19:40:41 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMjA6NTI6NTcuMTg4MTE4MDg0WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5NDE5NTI5MiwibG9hZF9kdXJhdGlvbiI6MTUwMjY0MjgsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1ODYyNDg0LCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6MjcyNjU0MDM2fQo= + recorded_at: Thu, 27 Mar 2025 20:52:50 GMT - request: method: post uri: http://localhost:11434/api/chat body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The - tool call output indicates that the current temperature in Berlin is 15°C + tool call response indicates that the current temperature in Berlin is 15°C and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s the weather in Paris? (48.8575, 2.3514)"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude @@ -107,7 +107,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Thu, 27 Mar 2025 19:40:48 GMT + - Thu, 27 Mar 2025 20:52:57 GMT Server: - Caddy Transfer-Encoding: @@ -115,20 +115,20 @@ http_interactions: body: encoding: UTF-8 string: | - {"model":"llama3.1:8b","created_at":"2025-03-27T19:40:48.899731222Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T19:40:48.909582967Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":327110248,"load_duration":14711739,"prompt_eval_count":297,"prompt_eval_duration":11275239,"eval_count":28,"eval_duration":300057920} - recorded_at: Thu, 27 Mar 2025 19:40:42 GMT + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:57.515458112Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:57.525308095Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":329660702,"load_duration":15200490,"prompt_eval_count":297,"prompt_eval_duration":11060319,"eval_count":28,"eval_duration":302338771} + recorded_at: Thu, 27 Mar 2025 20:52:50 GMT - request: method: post uri: http://localhost:11434/api/chat body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant"},{"role":"tool","content":"Current + the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The - tool call output indicates that the current temperature in Berlin is 15°C + tool call response indicates that the current temperature in Berlin is 15°C and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s - the weather in Paris? (48.8575, 2.3514)"},{"role":"assistant"},{"role":"tool","content":"Current + the weather in Paris? (48.8575, 2.3514)"},{"role":"assistant","content":null},{"role":"tool","content":"Current weather at 48.8575, 2.3514: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., @@ -150,7 +150,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Thu, 27 Mar 2025 19:40:49 GMT + - Thu, 27 Mar 2025 20:52:57 GMT Server: - Caddy Transfer-Encoding: @@ -158,6 +158,6 @@ http_interactions: body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMTk6NDA6NDkuMjEwNzE3NDQyWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIG91dHB1dCBpbmRpY2F0ZXMgdGhhdCB0aGUgY3VycmVudCB0ZW1wZXJhdHVyZSBpbiBQYXJpcyBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5ODAxMzMxNiwibG9hZF9kdXJhdGlvbiI6MTUyNTkzMTMsInByb21wdF9ldmFsX2NvdW50IjoyMDQsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1OTExNjA3LCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6Mjc1NzAxNzY3fQo= - recorded_at: Thu, 27 Mar 2025 19:40:42 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMjA6NTI6NTcuODMwNjA4ODQzWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGVyZSdzIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6MzAyMTY2Njk4LCJsb2FkX2R1cmF0aW9uIjoxNDk2MTYxOSwicHJvbXB0X2V2YWxfY291bnQiOjIwNCwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjU3ODgyNzEsImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyODAzNTU4ODl9Cg== + recorded_at: Thu, 27 Mar 2025 20:52:51 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters.yml index ef9cae23..ec5bcced 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters.yml @@ -27,20 +27,20 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 19:40:45 GMT + - Thu, 27 Mar 2025 20:52:56 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:40:45.890115845Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done_reason":"stop","done":true,"total_duration":182670710,"load_duration":15026207,"prompt_eval_count":155,"prompt_eval_duration":8306450,"eval_count":15,"eval_duration":158941659}' - recorded_at: Thu, 27 Mar 2025 19:40:39 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:52:56.203907181Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done_reason":"stop","done":true,"total_duration":182150710,"load_duration":14773924,"prompt_eval_count":155,"prompt_eval_duration":8142700,"eval_count":15,"eval_duration":158886588}' + recorded_at: Thu, 27 Mar 2025 20:52:49 GMT - request: method: post uri: http://localhost:11434/api/chat body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the best language to learn?"},{"role":"assistant"},{"role":"tool","content":"Ruby"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' headers: User-Agent: @@ -56,32 +56,19 @@ http_interactions: code: 200 message: OK headers: + Content-Length: + - '477' Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 19:40:47 GMT + - Thu, 27 Mar 2025 20:52:56 GMT Server: - Caddy - Vary: - - Accept-Encoding - Content-Length: - - '1360' body: - encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T19:40:47.954756575Z","message":{"role":"assistant","content":"The - tool suggests Ruby as one of the top languages to learn, but it doesn''t provide - any specific reasons why. Let me try to get more information from the tool.\n\nOkay, - I''ve got some additional data from the tool. It seems that Ruby is a popular - choice for web development and has a strong focus on simplicity and ease of - use. However, the tool also suggests considering other languages such as Python, - JavaScript, or Java, depending on your specific needs and goals.\n\nHere''s - a more detailed breakdown:\n\n* **Ruby**: Great for web development, especially - with the Ruby on Rails framework.\n* **Python**: Versatile language suitable - for data science, machine learning, web development, and more.\n* **JavaScript**: - Essential for front-end web development and popular in back-end development - as well.\n* **Java**: Object-oriented language used in Android app development, - web development, and enterprise software development.\n\nUltimately, the best - language to learn depends on your interests, career goals, and the type of - projects you want to work on."},"done_reason":"stop","done":true,"total_duration":2061922803,"load_duration":14748701,"prompt_eval_count":77,"prompt_eval_duration":4208460,"eval_count":211,"eval_duration":2042436378}' - recorded_at: Thu, 27 Mar 2025 19:40:41 GMT + encoding: UTF-8 + string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:52:56.567419236Z","message":{"role":"assistant","content":"The + tool suggests that Ruby is a good choice for learning programming languages. + It has a simple syntax and is often used in web development, making it a great + language for beginners."},"done_reason":"stop","done":true,"total_duration":360862790,"load_duration":14805187,"prompt_eval_count":77,"prompt_eval_duration":4288885,"eval_count":36,"eval_duration":341210120}' + recorded_at: Thu, 27 Mar 2025 20:52:49 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses.yml b/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses.yml index d1a49912..66428233 100644 --- a/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses.yml +++ b/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses.yml @@ -6,7 +6,7 @@ http_interactions: body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Count - from 1 to 3","images":[]}],"options":{"temperature":0.7},"stream":true,"tools":[]}' + from 1 to 3"}],"options":{"temperature":0.7},"stream":true,"tools":[]}' headers: User-Agent: - Faraday v2.12.2 @@ -24,7 +24,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Thu, 27 Mar 2025 20:15:12 GMT + - Thu, 27 Mar 2025 20:52:54 GMT Server: - Caddy Transfer-Encoding: @@ -32,15 +32,18 @@ http_interactions: body: encoding: UTF-8 string: | - {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.823627546Z","message":{"role":"assistant","content":"Here"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.836926583Z","message":{"role":"assistant","content":" it"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.845628305Z","message":{"role":"assistant","content":" is"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.854520068Z","message":{"role":"assistant","content":":\n\n"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.863223164Z","message":{"role":"assistant","content":"1"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.871980804Z","message":{"role":"assistant","content":"\n"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.880710143Z","message":{"role":"assistant","content":"2"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.889518343Z","message":{"role":"assistant","content":"\n"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.89843357Z","message":{"role":"assistant","content":"3"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:15:12.907436856Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":3301695608,"load_duration":3125133401,"prompt_eval_count":17,"prompt_eval_duration":88101212,"eval_count":10,"eval_duration":86549601} - recorded_at: Thu, 27 Mar 2025 20:15:06 GMT + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.711670439Z","message":{"role":"assistant","content":"Here"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.722005791Z","message":{"role":"assistant","content":" it"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.730875308Z","message":{"role":"assistant","content":" goes"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.73973626Z","message":{"role":"assistant","content":":\n\n"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.748715477Z","message":{"role":"assistant","content":"1"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.757750051Z","message":{"role":"assistant","content":","},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.766838327Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.775953172Z","message":{"role":"assistant","content":"2"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.784999128Z","message":{"role":"assistant","content":","},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.794182418Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.803269803Z","message":{"role":"assistant","content":"3"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.812379489Z","message":{"role":"assistant","content":"!"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.821504569Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":143359811,"load_duration":17391722,"prompt_eval_count":17,"prompt_eval_duration":3802940,"eval_count":13,"eval_duration":121838818} + recorded_at: Thu, 27 Mar 2025 20:52:48 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml b/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml index 441cca98..5aa897a6 100644 --- a/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml +++ b/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml @@ -22,16 +22,16 @@ http_interactions: message: OK headers: Content-Length: - - '380' + - '374' Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 20:10:23 GMT + - Thu, 27 Mar 2025 20:52:50 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"granite3.2-vision:2b","created_at":"2025-03-27T20:10:23.42586545Z","message":{"role":"assistant","content":"\nI - see a red diamond-like object with a white center on a black background."},"done_reason":"stop","done":true,"total_duration":165572248,"load_duration":6699362,"prompt_eval_count":2242,"prompt_eval_duration":24375911,"eval_count":20,"eval_duration":133708153}' - recorded_at: Thu, 27 Mar 2025 20:10:16 GMT + string: '{"model":"granite3.2-vision:2b","created_at":"2025-03-27T20:52:50.595761025Z","message":{"role":"assistant","content":"\nI + see a large red diamond with sharp angles and a smooth surface."},"done_reason":"stop","done":true,"total_duration":552064725,"load_duration":10092978,"prompt_eval_count":2242,"prompt_eval_duration":425090887,"eval_count":18,"eval_duration":115966422}' + recorded_at: Thu, 27 Mar 2025 20:52:43 GMT recorded_with: VCR 6.3.1 From 24a8eed4bbd1db5289b21fd2ff07befa9dca6b1c Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 18:33:07 -0300 Subject: [PATCH 36/55] Models involved in tests are no longer tiny :shrug: --- lib/tasks/ollama.rake | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/tasks/ollama.rake b/lib/tasks/ollama.rake index f07dcc73..3e3da1bb 100644 --- a/lib/tasks/ollama.rake +++ b/lib/tasks/ollama.rake @@ -24,7 +24,7 @@ def pull_model(ollama_library_model_spec, description) end namespace :ollama do - desc 'Install some tiny models required for running Ollama specs (downloads about 7.5 GiB into your Ollama server)' + desc 'Install some models required for running Ollama specs (downloads about 7.5 GiB into your Ollama server)' task :install_models_for_specs do RubyLLM.config.request_timeout = 60 * 30 # 30min timeout per model since pull is synchronous RubyLLM.config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL') From 4284eb998eba5b7ed9b995536572ff203150de99 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 23:20:08 -0300 Subject: [PATCH 37/55] Don't send empty tools property --- lib/ruby_llm/providers/ollama/chat.rb | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index c3213a48..bcd9e4e0 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -23,9 +23,8 @@ def render_payload(messages, tools:, temperature:, model:, stream: false) options: { temperature: temperature }, - stream: stream, - tools: tools.map { |_, tool| tool_for(tool) } - } + stream: stream + }.tap { |h| h.merge!(tools: tools) if tools.any? } end def parse_completion_response(response) From 79fe8e0e2747815fe49155dc4177655ac713b07b Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 27 Mar 2025 23:27:23 -0300 Subject: [PATCH 38/55] Rubocop appeasement --- lib/ruby_llm/providers/ollama/media.rb | 36 ++++++++++++++----------- lib/ruby_llm/providers/ollama/models.rb | 2 +- lib/ruby_llm/providers/ollama/tools.rb | 12 +++------ lib/tasks/ollama.rake | 2 +- spec/spec_helper.rb | 1 + 5 files changed, 27 insertions(+), 26 deletions(-) diff --git a/lib/ruby_llm/providers/ollama/media.rb b/lib/ruby_llm/providers/ollama/media.rb index c9d38d4c..15e474a8 100644 --- a/lib/ruby_llm/providers/ollama/media.rb +++ b/lib/ruby_llm/providers/ollama/media.rb @@ -9,21 +9,7 @@ module Media def format_messages(messages) messages.map do |msg| - text = nil - images = [] - - if msg.content.is_a?(Array) - msg.content.each do |part| - case part[:type] - when 'text' - text = part[:text] - when 'image' - images << part[:source][:data] - end - end - else - text = msg.content - end + text, images = separate_by_type(msg) { role: msg.role.to_s, @@ -31,6 +17,26 @@ def format_messages(messages) }.tap { |h| h.merge!(images: images) if images.any? } end end + + def separate_by_type(msg) # rubocop:disable Metrics/MethodLength + text = nil + images = [] + + if msg.content.is_a?(Array) + msg.content.each do |part| + case part[:type] + when 'text' + text = part[:text] + when 'image' + images << part[:source][:data] + end + end + else + text = msg.content + end + + [text, images] + end end end end diff --git a/lib/ruby_llm/providers/ollama/models.rb b/lib/ruby_llm/providers/ollama/models.rb index f7a22bc1..6a336f1b 100644 --- a/lib/ruby_llm/providers/ollama/models.rb +++ b/lib/ruby_llm/providers/ollama/models.rb @@ -35,7 +35,7 @@ def list_models private - def parse_list_models_response(response, slug, capabilities) # rubocop:disable Metrics/MethodLength + def parse_list_models_response(response, slug, capabilities) # rubocop:disable Metrics/MethodLength,Metrics/AbcSize (response.body['models'] || []).map do |model| model_id = model['name'] diff --git a/lib/ruby_llm/providers/ollama/tools.rb b/lib/ruby_llm/providers/ollama/tools.rb index 5f2a8872..97789591 100644 --- a/lib/ruby_llm/providers/ollama/tools.rb +++ b/lib/ruby_llm/providers/ollama/tools.rb @@ -7,7 +7,7 @@ module Ollama module Tools module_function - def tool_for(tool) + def tool_for(tool) # rubocop:disable Metrics/MethodLength { type: 'function', function: { @@ -30,20 +30,14 @@ def param_schema(param) end def parse_tool_calls(tool_calls) - return nil unless tool_calls&.any? - - tool_calls.to_h do |tc| + (tool_calls || []).to_h do |tc| tc = tc['function'] if tc['function'] name = tc['name'] next [nil, nil] unless name =~ /\S/ [ name, - ToolCall.new( - id: name, - name: name, - arguments: tc['arguments'] - ) + ToolCall.new(id: name, name: name, arguments: tc['arguments']) ] end.compact end diff --git a/lib/tasks/ollama.rake b/lib/tasks/ollama.rake index 3e3da1bb..7082213d 100644 --- a/lib/tasks/ollama.rake +++ b/lib/tasks/ollama.rake @@ -2,7 +2,7 @@ require 'ruby_llm' -def pull_model(ollama_library_model_spec, description) +def pull_model(ollama_library_model_spec, description) # rubocop:disable Metrics/MethodLength warn <<~MESSAGE + pulling #{ollama_library_model_spec} from Ollama library (#{description}); monitor progress in Ollama server logs MESSAGE diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index 51e9ce6b..c8c45b08 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -101,4 +101,5 @@ end RSpec.shared_context 'with configured RubyLLM' do + # Put any per-test preeambles here end From 2f27a4e83951e2f5b61870fbebb4dc55d0c336b0 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Fri, 28 Mar 2025 11:57:05 -0300 Subject: [PATCH 39/55] Fix tools --- lib/ruby_llm/providers/ollama/chat.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index bcd9e4e0..69a917e8 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -24,7 +24,7 @@ def render_payload(messages, tools:, temperature:, model:, stream: false) temperature: temperature }, stream: stream - }.tap { |h| h.merge!(tools: tools) if tools.any? } + }.tap { |h| h.merge!(tools: tools.map { |_, t| tool_for(t) }) if tools.any? } end def parse_completion_response(response) From a3635b5fc614f09832cb61b1090d8e236012a2e4 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Fri, 28 Mar 2025 12:26:04 -0300 Subject: [PATCH 40/55] Add unit test for preprocess_tool_calls --- lib/ruby_llm/providers/ollama/tools.rb | 17 ++++++--- spec/ruby_llm/providers/ollama/tools_spec.rb | 40 ++++++++++++++++++++ 2 files changed, 52 insertions(+), 5 deletions(-) create mode 100644 spec/ruby_llm/providers/ollama/tools_spec.rb diff --git a/lib/ruby_llm/providers/ollama/tools.rb b/lib/ruby_llm/providers/ollama/tools.rb index 97789591..94df9ccf 100644 --- a/lib/ruby_llm/providers/ollama/tools.rb +++ b/lib/ruby_llm/providers/ollama/tools.rb @@ -52,11 +52,18 @@ def preprocess_tool_calls(response_data) # specific field in the response where it should be. # https://github.com/ollama/ollama/blob/main/docs/api.md#chat-request-with-tools - tc = response_data['message']['tool_calls'] ||= [] - response_data['message']['content']&.gsub!(%r{(.*)}mi) do - capture = ::Regexp.last_match(1) - tc << JSON.parse(capture) if capture =~ /^\s*{/ - '' + m = response_data['message'] + tc = m['tool_calls'] ||= [] + + [ + %r{(.*)}mi, + %r{(.*)}mi + ].each do |regex| + m['content'] = m['content'].gsub(regex) do + capture = ::Regexp.last_match(1) + tc << JSON.parse(capture) + '' + end end tc.flatten! response_data diff --git a/spec/ruby_llm/providers/ollama/tools_spec.rb b/spec/ruby_llm/providers/ollama/tools_spec.rb new file mode 100644 index 00000000..45a72098 --- /dev/null +++ b/spec/ruby_llm/providers/ollama/tools_spec.rb @@ -0,0 +1,40 @@ +# frozen_string_literal: true + +require 'spec_helper' +require 'dotenv/load' + +def mock_response_with(response_text) + { + 'message' => { + 'content' => response_text, + 'tool_calls' => [] + } + } +end + +def cases + { + 'granite3.2-vision:2b' => %q( [{"name": "get_weather", "arguments": {"latitude": "52.5200", "longitude": "13.4050"}}] ), + 'nemotron-mini:4b' => %q( {"name": "get_weather", "arguments": {"latitude": "52.5200", "longitude": "13.4050"}} ) + } +end + +RSpec.describe RubyLLM::Providers::Ollama::Tools do + describe '.preprocess_tool_calls' do + cases.each do |model, response_text| + it "correctly parses #{model} tool calling markup" do # rubocop:disable RSpec/MultipleExpectations + mock_response = mock_response_with(response_text) + m = mock_response['message'] + + described_class.preprocess_tool_calls(mock_response) + + # needs to remove markup from the text response + expect(m['content']).not_to include(' Date: Fri, 28 Mar 2025 17:34:56 -0300 Subject: [PATCH 41/55] No need to replace tool call markup --- lib/ruby_llm/providers/ollama/tools.rb | 17 +++++++++-------- spec/ruby_llm/providers/ollama/tools_spec.rb | 11 +++-------- 2 files changed, 12 insertions(+), 16 deletions(-) diff --git a/lib/ruby_llm/providers/ollama/tools.rb b/lib/ruby_llm/providers/ollama/tools.rb index 94df9ccf..5c638f66 100644 --- a/lib/ruby_llm/providers/ollama/tools.rb +++ b/lib/ruby_llm/providers/ollama/tools.rb @@ -47,9 +47,9 @@ def parse_tool_calls(tool_calls) # # Unfortunately said other models are all over the place when it comes # to sticking to a format so this doesn't cover all edge cases. - def preprocess_tool_calls(response_data) - # Move JSON markup from inside the text to its - # specific field in the response where it should be. + def preprocess_tool_calls(response_data) # rubocop:disable Metrics/MethodLength + # Parse JSON markup from inside the text and + # fill in proper fields in the response # https://github.com/ollama/ollama/blob/main/docs/api.md#chat-request-with-tools m = response_data['message'] @@ -58,12 +58,13 @@ def preprocess_tool_calls(response_data) [ %r{(.*)}mi, %r{(.*)}mi - ].each do |regex| - m['content'] = m['content'].gsub(regex) do - capture = ::Regexp.last_match(1) - tc << JSON.parse(capture) - '' + ].find do |regex| + done = false + m['content'].scan(regex) do |(match)| + tc << JSON.parse(match) + done = true end + done end tc.flatten! response_data diff --git a/spec/ruby_llm/providers/ollama/tools_spec.rb b/spec/ruby_llm/providers/ollama/tools_spec.rb index 45a72098..b3f25217 100644 --- a/spec/ruby_llm/providers/ollama/tools_spec.rb +++ b/spec/ruby_llm/providers/ollama/tools_spec.rb @@ -14,8 +14,8 @@ def mock_response_with(response_text) def cases { - 'granite3.2-vision:2b' => %q( [{"name": "get_weather", "arguments": {"latitude": "52.5200", "longitude": "13.4050"}}] ), - 'nemotron-mini:4b' => %q( {"name": "get_weather", "arguments": {"latitude": "52.5200", "longitude": "13.4050"}} ) + 'granite3.2-vision:2b' => %q( [{"name": "get_weather", "arguments": {"latitude": "52.5200", "longitude": "13.4050"}}] ), # rubocop:disable Style/RedundantPercentQ,Layout/LineLength + 'nemotron-mini:4b' => %q( {"name": "get_weather", "arguments": {"latitude": "52.5200", "longitude": "13.4050"}} ) # rubocop:disable Style/RedundantPercentQ,Layout/LineLength,Layout/HashAlignment } end @@ -24,14 +24,9 @@ def cases cases.each do |model, response_text| it "correctly parses #{model} tool calling markup" do # rubocop:disable RSpec/MultipleExpectations mock_response = mock_response_with(response_text) + mock_response = described_class.preprocess_tool_calls(mock_response) m = mock_response['message'] - described_class.preprocess_tool_calls(mock_response) - - # needs to remove markup from the text response - expect(m['content']).not_to include(' Date: Tue, 1 Apr 2025 21:46:42 -0300 Subject: [PATCH 42/55] Update cassettes All cassettes for Ollama are up to date; I manually copied the new Bedrock responses for model listings. VCR data will be synthetic until someone can run tests with all providers properly enabled, including a local Ollama server having run the rake task to get test models. --- ...8b_can_handle_multi-turn_conversations.yml | 111 ---------------- ...e_multi-turn_conversations_with_ollama.yml | 106 +++++++++++++++ ...have_a_basic_conversation_with_ollama.yml} | 12 +- ..._multi-turn_conversations_with_ollama.yml} | 24 ++-- ...n_streaming_conversations_with_ollama.yml} | 28 ++-- ...llama3_1_8b_can_use_tools_with_ollama.yml} | 14 +- ..._tools_without_parameters_with_ollama.yml} | 37 ++++-- ...ama3_1_8b_supports_streaming_responses.yml | 49 ------- ...pports_streaming_responses_with_ollama.yml | 49 +++++++ ...ite3_2-vision_2b_can_understand_images.yml | 21 +-- ...tic-embed_22m_can_handle_a_single_text.yml | 12 +- ...ic-embed_22m_can_handle_multiple_texts.yml | 12 +- .../vcr_cassettes/initial_model_refresh.yml | 124 ++++++++++++++++++ ...nd_returns_a_chainable_models_instance.yml | 124 ++++++++++++++++++ ...ls_refresh_works_as_a_class_method_too.yml | 124 ++++++++++++++++++ 15 files changed, 620 insertions(+), 227 deletions(-) delete mode 100644 spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations_with_ollama.yml rename spec/fixtures/vcr_cassettes/{chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation.yml => chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation_with_ollama.yml} (56%) rename spec/fixtures/vcr_cassettes/{chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml => chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations_with_ollama.yml} (81%) rename spec/fixtures/vcr_cassettes/{chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml => chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations_with_ollama.yml} (78%) rename spec/fixtures/vcr_cassettes/{chat_function_calling_llama3_1_8b_can_use_tools.yml => chat_function_calling_llama3_1_8b_can_use_tools_with_ollama.yml} (75%) rename spec/fixtures/vcr_cassettes/{chat_function_calling_llama3_1_8b_can_use_tools_without_parameters.yml => chat_function_calling_llama3_1_8b_can_use_tools_without_parameters_with_ollama.yml} (50%) delete mode 100644 spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses_with_ollama.yml diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations.yml deleted file mode 100644 index d4a8a25c..00000000 --- a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations.yml +++ /dev/null @@ -1,111 +0,0 @@ ---- -http_interactions: -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Who was - the creator of Ruby?"}],"options":{"temperature":0.7},"stream":false,"tools":[]}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/json; charset=utf-8 - Date: - - Thu, 27 Mar 2025 20:52:52 GMT - Server: - - Caddy - Vary: - - Accept-Encoding - Content-Length: - - '1339' - body: - encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:52:52.883344011Z","message":{"role":"assistant","content":"The - creator of the programming language Ruby is Yukihiro Matsumoto, a Japanese - computer programmer. He began working on Ruby in 1993 and released the first - version, Ruby 0.95, in 1995. Matsumoto''s goal with Ruby was to create a language - that was easy to use and enjoyable for developers, while also being powerful - and flexible.\n\nMatsumoto, who is often referred to as \"Matz\" by his peers, - has continued to be involved with the development of Ruby throughout its history, - and is still active in the community today. He is known for his commitment - to making Ruby a language that is accessible to developers of all skill levels, - and for his emphasis on the importance of community and collaboration.\n\nIn - 1999, Matsumoto founded the Ruby Development Team (now known as the Ruby Core - Team), which oversees the development of the Ruby programming language. Today, - Ruby is widely used in web development, scripting, and other applications, - and has a large and active global community of developers who contribute to - its growth and development."},"done_reason":"stop","done":true,"total_duration":2099993065,"load_duration":15225883,"prompt_eval_count":17,"prompt_eval_duration":4027231,"eval_count":216,"eval_duration":2080377970}' - recorded_at: Thu, 27 Mar 2025 20:52:46 GMT -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Who was - the creator of Ruby?"},{"role":"assistant","content":"The creator of the programming - language Ruby is Yukihiro Matsumoto, a Japanese computer programmer. He began - working on Ruby in 1993 and released the first version, Ruby 0.95, in 1995. - Matsumoto''s goal with Ruby was to create a language that was easy to use - and enjoyable for developers, while also being powerful and flexible.\n\nMatsumoto, - who is often referred to as \"Matz\" by his peers, has continued to be involved - with the development of Ruby throughout its history, and is still active in - the community today. He is known for his commitment to making Ruby a language - that is accessible to developers of all skill levels, and for his emphasis - on the importance of community and collaboration.\n\nIn 1999, Matsumoto founded - the Ruby Development Team (now known as the Ruby Core Team), which oversees - the development of the Ruby programming language. Today, Ruby is widely used - in web development, scripting, and other applications, and has a large and - active global community of developers who contribute to its growth and development."},{"role":"user","content":"What - year did he create Ruby?"}],"options":{"temperature":0.7},"stream":false,"tools":[]}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/json; charset=utf-8 - Date: - - Thu, 27 Mar 2025 20:52:54 GMT - Server: - - Caddy - Vary: - - Accept-Encoding - Content-Length: - - '1022' - body: - encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.655557443Z","message":{"role":"assistant","content":"Yukihiro - Matsumoto began working on the design of the Ruby programming language in - 1993. He started writing the code for Ruby in December 1995, and released - the first version, Ruby 0.95, on February 24, 1995.\n\nHowever, it''s worth - noting that the language as we know it today, with its modern syntax and features, - was finalized around 1997-1998. Matsumoto has said in interviews that he considered - Ruby to be a \"finished\" product by around 1998, although it continues to - evolve and improve to this day.\n\nSo while 1993 marks the beginning of Matsumoto''s - work on Ruby, 1995 is the year when the first version of the language was - released, and 1997-1998 mark the time when the modern version of Ruby started - to take shape."},"done_reason":"stop","done":true,"total_duration":1768670371,"load_duration":15370697,"prompt_eval_count":249,"prompt_eval_duration":4097509,"eval_count":177,"eval_duration":1748440674}' - recorded_at: Thu, 27 Mar 2025 20:52:47 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations_with_ollama.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations_with_ollama.yml new file mode 100644 index 00000000..97645abd --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations_with_ollama.yml @@ -0,0 +1,106 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Who was + the creator of Ruby?"}],"options":{"temperature":0.7},"stream":false}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Wed, 02 Apr 2025 00:44:07 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '1334' + body: + encoding: ASCII-8BIT + string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:07.063167441Z","message":{"role":"assistant","content":"The + creator of the Ruby programming language is Yukihiro \"Matz\" Matsumoto. He + is a Japanese computer programmer and is often referred to as the \"Benevolent + Dictator for Life\" (BDFL) of the Ruby project.\n\nMatsumoto was born in 1961 + in Kyoto, Japan. He started programming at the age of six and became interested + in computers at an early age. In the late 1980s, he worked on several projects, + including a version of the Emacs text editor for MS-DOS.\n\nIn 1993, Matsumoto + began working on Ruby as a scripting language for Unix-like operating systems. + He was influenced by languages such as Perl, Smalltalk, and Ada, and wanted + to create a language that was easy to learn, fun to use, and had a strong + focus on object-oriented programming.\n\nRuby was first released in 1995, + and it quickly gained popularity due to its simplicity, flexibility, and ease + of use. Matsumoto continues to be involved with the Ruby project to this day, + and is widely recognized as one of the most influential figures in the world + of programming languages."},"done_reason":"stop","done":true,"total_duration":2242629806,"load_duration":14953975,"prompt_eval_count":17,"prompt_eval_duration":3947091,"eval_count":233,"eval_duration":2223358525}' + recorded_at: Wed, 02 Apr 2025 00:43:58 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Who was + the creator of Ruby?"},{"role":"assistant","content":"The creator of the Ruby + programming language is Yukihiro \"Matz\" Matsumoto. He is a Japanese computer + programmer and is often referred to as the \"Benevolent Dictator for Life\" + (BDFL) of the Ruby project.\n\nMatsumoto was born in 1961 in Kyoto, Japan. + He started programming at the age of six and became interested in computers + at an early age. In the late 1980s, he worked on several projects, including + a version of the Emacs text editor for MS-DOS.\n\nIn 1993, Matsumoto began + working on Ruby as a scripting language for Unix-like operating systems. He + was influenced by languages such as Perl, Smalltalk, and Ada, and wanted to + create a language that was easy to learn, fun to use, and had a strong focus + on object-oriented programming.\n\nRuby was first released in 1995, and it + quickly gained popularity due to its simplicity, flexibility, and ease of + use. Matsumoto continues to be involved with the Ruby project to this day, + and is widely recognized as one of the most influential figures in the world + of programming languages."},{"role":"user","content":"What year did he create + Ruby?"}],"options":{"temperature":0.7},"stream":false}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Wed, 02 Apr 2025 00:44:07 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '537' + body: + encoding: ASCII-8BIT + string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:07.717871079Z","message":{"role":"assistant","content":"Yukihiro + \"Matz\" Matsumoto started working on Ruby in 1993, but it was first released + publicly on December 21, 1995. So, while the idea and development of Ruby + began in 1993, the language itself was officially released to the public in + 1995."},"done_reason":"stop","done":true,"total_duration":649227133,"load_duration":16363391,"prompt_eval_count":266,"prompt_eval_duration":4060912,"eval_count":64,"eval_duration":628004959}' + recorded_at: Wed, 02 Apr 2025 00:43:59 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation_with_ollama.yml similarity index 56% rename from spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation.yml rename to spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation_with_ollama.yml index 8ec4969c..8d5c2821 100644 --- a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation.yml +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation_with_ollama.yml @@ -6,7 +6,7 @@ http_interactions: body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - 2 + 2?"}],"options":{"temperature":0.7},"stream":false,"tools":[]}' + 2 + 2?"}],"options":{"temperature":0.7},"stream":false}' headers: User-Agent: - Faraday v2.12.2 @@ -22,16 +22,16 @@ http_interactions: message: OK headers: Content-Length: - - '309' + - '310' Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 20:52:50 GMT + - Wed, 02 Apr 2025 00:44:04 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:52:50.778698618Z","message":{"role":"assistant","content":"The - answer is 4!"},"done_reason":"stop","done":true,"total_duration":113151682,"load_duration":17646551,"prompt_eval_count":18,"prompt_eval_duration":25510313,"eval_count":7,"eval_duration":69332453}' - recorded_at: Thu, 27 Mar 2025 20:52:44 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:04.815124255Z","message":{"role":"assistant","content":"The + answer is: 4!"},"done_reason":"stop","done":true,"total_duration":123712849,"load_duration":19150499,"prompt_eval_count":18,"prompt_eval_duration":25924381,"eval_count":8,"eval_duration":78214407}' + recorded_at: Wed, 02 Apr 2025 00:43:56 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations_with_ollama.yml similarity index 81% rename from spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml rename to spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations_with_ollama.yml index 25f57360..191d3769 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations_with_ollama.yml @@ -29,13 +29,13 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 20:53:54 GMT + - Wed, 02 Apr 2025 00:44:55 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:53:54.056546141Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":375038607,"load_duration":19702489,"prompt_eval_count":205,"prompt_eval_duration":43370375,"eval_count":28,"eval_duration":311651215}' - recorded_at: Thu, 27 Mar 2025 20:53:47 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:55.362545781Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":318881239,"load_duration":14740837,"prompt_eval_count":205,"prompt_eval_duration":10492700,"eval_count":28,"eval_duration":293241996}' + recorded_at: Wed, 02 Apr 2025 00:44:46 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -66,14 +66,14 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 20:53:54 GMT + - Wed, 02 Apr 2025 00:44:55 GMT Server: - Caddy body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMjA6NTM6NTQuMzUyNTYyNDMzWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5MzE2MzQxNCwibG9hZF9kdXJhdGlvbiI6MTUxNTM4MDQsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1ODAxNjIyLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6MjcxNTc3OTYyfQ== - recorded_at: Thu, 27 Mar 2025 20:53:47 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMDJUMDA6NDQ6NTUuNjU4NjQ0Njc2WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5MjE3ODIzMywibG9hZF9kdXJhdGlvbiI6MTQ3MDQxMzksInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1OTgzNTgwLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6MjcwOTc5NjkwfQ== + recorded_at: Wed, 02 Apr 2025 00:44:47 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -107,13 +107,13 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 20:53:54 GMT + - Wed, 02 Apr 2025 00:44:55 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:53:54.681058938Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done_reason":"stop","done":true,"total_duration":325240591,"load_duration":14868711,"prompt_eval_count":297,"prompt_eval_duration":10941313,"eval_count":28,"eval_duration":298076119}' - recorded_at: Thu, 27 Mar 2025 20:53:48 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:55.989004993Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done_reason":"stop","done":true,"total_duration":326895256,"load_duration":14909752,"prompt_eval_count":297,"prompt_eval_duration":11194663,"eval_count":28,"eval_duration":299619023}' + recorded_at: Wed, 02 Apr 2025 00:44:47 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -148,12 +148,12 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 20:53:54 GMT + - Wed, 02 Apr 2025 00:44:56 GMT Server: - Caddy body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMjA6NTM6NTQuOTgxMjY0NDUzWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGVyZSdzIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6Mjk3MzE4NjA1LCJsb2FkX2R1cmF0aW9uIjoxNDcxMjgyMywicHJvbXB0X2V2YWxfY291bnQiOjIwNCwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjYxMTE0MTQsImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyNzUzMzgwNTZ9 - recorded_at: Thu, 27 Mar 2025 20:53:48 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMDJUMDA6NDQ6NTYuMjkwNTU5NDYxWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGVyZSdzIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6Mjk4MjU0MTAzLCJsb2FkX2R1cmF0aW9uIjoxNDgxNjIyMiwicHJvbXB0X2V2YWxfY291bnQiOjIwNCwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjU4ODg4MjksImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyNzYzODY4MTJ9 + recorded_at: Wed, 02 Apr 2025 00:44:47 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations_with_ollama.yml similarity index 78% rename from spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml rename to spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations_with_ollama.yml index 40568a13..c6e7eaf4 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations_with_ollama.yml @@ -27,7 +27,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Thu, 27 Mar 2025 20:52:56 GMT + - Wed, 02 Apr 2025 00:44:58 GMT Server: - Caddy Transfer-Encoding: @@ -35,9 +35,9 @@ http_interactions: body: encoding: UTF-8 string: | - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:56.880657556Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:56.890641104Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":318070144,"load_duration":14748268,"prompt_eval_count":205,"prompt_eval_duration":10456487,"eval_count":28,"eval_duration":292444560} - recorded_at: Thu, 27 Mar 2025 20:52:50 GMT + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:58.864685667Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:58.875226528Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":320697041,"load_duration":16695054,"prompt_eval_count":205,"prompt_eval_duration":10264902,"eval_count":28,"eval_duration":293365741} + recorded_at: Wed, 02 Apr 2025 00:44:50 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -66,7 +66,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Thu, 27 Mar 2025 20:52:57 GMT + - Wed, 02 Apr 2025 00:44:59 GMT Server: - Caddy Transfer-Encoding: @@ -74,8 +74,8 @@ http_interactions: body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMjA6NTI6NTcuMTg4MTE4MDg0WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5NDE5NTI5MiwibG9hZF9kdXJhdGlvbiI6MTUwMjY0MjgsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1ODYyNDg0LCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6MjcyNjU0MDM2fQo= - recorded_at: Thu, 27 Mar 2025 20:52:50 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMDJUMDA6NDQ6NTkuMTcyNjA3OTM3WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5MzgwNzI1MSwibG9hZF9kdXJhdGlvbiI6MTU0MjM0MjQsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1OTk4MjQxLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6MjcxNzgwNTg2fQo= + recorded_at: Wed, 02 Apr 2025 00:44:50 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -107,7 +107,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Thu, 27 Mar 2025 20:52:57 GMT + - Wed, 02 Apr 2025 00:44:59 GMT Server: - Caddy Transfer-Encoding: @@ -115,9 +115,9 @@ http_interactions: body: encoding: UTF-8 string: | - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:57.515458112Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:57.525308095Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":329660702,"load_duration":15200490,"prompt_eval_count":297,"prompt_eval_duration":11060319,"eval_count":28,"eval_duration":302338771} - recorded_at: Thu, 27 Mar 2025 20:52:50 GMT + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:59.489661886Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:59.499416856Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":323629188,"load_duration":14622347,"prompt_eval_count":297,"prompt_eval_duration":11016766,"eval_count":28,"eval_duration":296821849} + recorded_at: Wed, 02 Apr 2025 00:44:51 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -150,7 +150,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Thu, 27 Mar 2025 20:52:57 GMT + - Wed, 02 Apr 2025 00:44:59 GMT Server: - Caddy Transfer-Encoding: @@ -158,6 +158,6 @@ http_interactions: body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMjA6NTI6NTcuODMwNjA4ODQzWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGVyZSdzIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6MzAyMTY2Njk4LCJsb2FkX2R1cmF0aW9uIjoxNDk2MTYxOSwicHJvbXB0X2V2YWxfY291bnQiOjIwNCwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjU3ODgyNzEsImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyODAzNTU4ODl9Cg== - recorded_at: Thu, 27 Mar 2025 20:52:51 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMDJUMDA6NDQ6NTkuODAwODgzMjEzWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGVyZSdzIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6Mjk4NjkxNDIwLCJsb2FkX2R1cmF0aW9uIjoxNTE3NjgxMCwicHJvbXB0X2V2YWxfY291bnQiOjIwNCwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjYxMDU5ODIsImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyNzYyOTMzMDR9Cg== + recorded_at: Wed, 02 Apr 2025 00:44:51 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_ollama.yml similarity index 75% rename from spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools.yml rename to spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_ollama.yml index 642144fe..a3a91b5a 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_ollama.yml @@ -29,13 +29,13 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 20:52:55 GMT + - Wed, 02 Apr 2025 00:44:54 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:52:55.210031365Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":327978180,"load_duration":15623627,"prompt_eval_count":205,"prompt_eval_duration":12561197,"eval_count":28,"eval_duration":299354569}' - recorded_at: Thu, 27 Mar 2025 20:52:48 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:54.741999837Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":345595895,"load_duration":15252457,"prompt_eval_count":205,"prompt_eval_duration":35001065,"eval_count":28,"eval_duration":295009892}' + recorded_at: Wed, 02 Apr 2025 00:44:46 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -62,16 +62,16 @@ http_interactions: message: OK headers: Content-Length: - - '435' + - '412' Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 20:52:55 GMT + - Wed, 02 Apr 2025 00:44:55 GMT Server: - Caddy body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDMtMjdUMjA6NTI6NTUuNTE1NDY1MTA4WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlIHdpbmQgc3BlZWQgaXMgYXBwcm94aW1hdGVseSAxMCBraWxvbWV0ZXJzIHBlciBob3VyLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6MzAyNDc4Njc0LCJsb2FkX2R1cmF0aW9uIjoxNDcxMTc2NywicHJvbXB0X2V2YWxfY291bnQiOjExMiwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjYwMTcwMDUsImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyODEwNTA1NDB9 - recorded_at: Thu, 27 Mar 2025 20:52:48 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMDJUMDA6NDQ6NTUuMDM3OTY4MDk0WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5MTg5NTM3NCwibG9hZF9kdXJhdGlvbiI6MTQ5MzM4NjksInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1ODk1NzIzLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6MjcwNDU2NjA5fQ== + recorded_at: Wed, 02 Apr 2025 00:44:46 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters_with_ollama.yml similarity index 50% rename from spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters.yml rename to spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters_with_ollama.yml index ec5bcced..94dbbbde 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters_with_ollama.yml @@ -27,13 +27,13 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 20:52:56 GMT + - Wed, 02 Apr 2025 00:44:56 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:52:56.203907181Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done_reason":"stop","done":true,"total_duration":182150710,"load_duration":14773924,"prompt_eval_count":155,"prompt_eval_duration":8142700,"eval_count":15,"eval_duration":158886588}' - recorded_at: Thu, 27 Mar 2025 20:52:49 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:56.484008223Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done_reason":"stop","done":true,"total_duration":187125431,"load_duration":16763705,"prompt_eval_count":155,"prompt_eval_duration":8191628,"eval_count":15,"eval_duration":161762904}' + recorded_at: Wed, 02 Apr 2025 00:44:48 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -56,19 +56,32 @@ http_interactions: code: 200 message: OK headers: - Content-Length: - - '477' Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 20:52:56 GMT + - Wed, 02 Apr 2025 00:44:58 GMT Server: - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '1365' body: - encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-03-27T20:52:56.567419236Z","message":{"role":"assistant","content":"The - tool suggests that Ruby is a good choice for learning programming languages. - It has a simple syntax and is often used in web development, making it a great - language for beginners."},"done_reason":"stop","done":true,"total_duration":360862790,"load_duration":14805187,"prompt_eval_count":77,"prompt_eval_duration":4288885,"eval_count":36,"eval_duration":341210120}' - recorded_at: Thu, 27 Mar 2025 20:52:49 GMT + encoding: ASCII-8BIT + string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:58.547429762Z","message":{"role":"assistant","content":"The + best language to learn is often subjective and depends on personal goals, + interests, and career aspirations. However, based on various sources and industry + trends, Ruby is a popular choice among developers due to its simplicity, readability, + and versatility.\n\nHere are some reasons why Ruby stands out:\n\n1. **Easy + to Learn**: Ruby has a clean syntax and is relatively easy to learn for beginners.\n2. **Versatile**: + Ruby can be used for web development (with frameworks like Ruby on Rails), + scripting, testing, and even system administration.\n3. **Large Community**: + Ruby has an active community with many resources available online, including + documentation, tutorials, and forums.\n4. **Job Prospects**: Knowledge of + Ruby is in demand, especially in the field of web development.\n\nUltimately, + the best language to learn depends on your specific needs and goals. If you''re + interested in web development, Python or JavaScript might be a better fit. + However, if you want a language that''s easy to learn and versatile, Ruby + is definitely worth considering."},"done_reason":"stop","done":true,"total_duration":2060128193,"load_duration":14761969,"prompt_eval_count":77,"prompt_eval_duration":4504575,"eval_count":212,"eval_duration":2040277638}' + recorded_at: Wed, 02 Apr 2025 00:44:50 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses.yml b/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses.yml deleted file mode 100644 index 66428233..00000000 --- a/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses.yml +++ /dev/null @@ -1,49 +0,0 @@ ---- -http_interactions: -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Count - from 1 to 3"}],"options":{"temperature":0.7},"stream":true,"tools":[]}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/x-ndjson - Date: - - Thu, 27 Mar 2025 20:52:54 GMT - Server: - - Caddy - Transfer-Encoding: - - chunked - body: - encoding: UTF-8 - string: | - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.711670439Z","message":{"role":"assistant","content":"Here"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.722005791Z","message":{"role":"assistant","content":" it"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.730875308Z","message":{"role":"assistant","content":" goes"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.73973626Z","message":{"role":"assistant","content":":\n\n"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.748715477Z","message":{"role":"assistant","content":"1"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.757750051Z","message":{"role":"assistant","content":","},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.766838327Z","message":{"role":"assistant","content":" "},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.775953172Z","message":{"role":"assistant","content":"2"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.784999128Z","message":{"role":"assistant","content":","},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.794182418Z","message":{"role":"assistant","content":" "},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.803269803Z","message":{"role":"assistant","content":"3"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.812379489Z","message":{"role":"assistant","content":"!"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-03-27T20:52:54.821504569Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":143359811,"load_duration":17391722,"prompt_eval_count":17,"prompt_eval_duration":3802940,"eval_count":13,"eval_duration":121838818} - recorded_at: Thu, 27 Mar 2025 20:52:48 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses_with_ollama.yml b/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses_with_ollama.yml new file mode 100644 index 00000000..148f7293 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses_with_ollama.yml @@ -0,0 +1,49 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Count + from 1 to 3"}],"options":{"temperature":0.7},"stream":true}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Wed, 02 Apr 2025 00:44:09 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: | + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.29998922Z","message":{"role":"assistant","content":"Here"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.310551658Z","message":{"role":"assistant","content":" it"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.319358021Z","message":{"role":"assistant","content":" goes"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.328271328Z","message":{"role":"assistant","content":":\n\n"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.337219141Z","message":{"role":"assistant","content":"1"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.346221234Z","message":{"role":"assistant","content":","},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.355314621Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.36441234Z","message":{"role":"assistant","content":"2"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.373598811Z","message":{"role":"assistant","content":","},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.38281648Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.392123995Z","message":{"role":"assistant","content":"3"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.401296079Z","message":{"role":"assistant","content":"!"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.410507031Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":144038210,"load_duration":17785003,"prompt_eval_count":17,"prompt_eval_duration":3721943,"eval_count":13,"eval_duration":121874042} + recorded_at: Wed, 02 Apr 2025 00:44:01 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml b/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml index 5aa897a6..47df3c19 100644 --- a/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml +++ b/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml @@ -6,7 +6,7 @@ http_interactions: body: encoding: UTF-8 string: '{"model":"granite3.2-vision:2b","messages":[{"role":"user","content":"What - do you see in this image?","images":["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"]}],"options":{"temperature":0.7},"stream":false,"tools":[]}' + do you see in this image?","images":["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"]}],"options":{"temperature":0.7},"stream":false}' headers: User-Agent: - Faraday v2.12.2 @@ -21,17 +21,22 @@ http_interactions: code: 200 message: OK headers: - Content-Length: - - '374' Content-Type: - application/json; charset=utf-8 Date: - - Thu, 27 Mar 2025 20:52:50 GMT + - Wed, 02 Apr 2025 00:44:02 GMT Server: - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '546' body: - encoding: UTF-8 - string: '{"model":"granite3.2-vision:2b","created_at":"2025-03-27T20:52:50.595761025Z","message":{"role":"assistant","content":"\nI - see a large red diamond with sharp angles and a smooth surface."},"done_reason":"stop","done":true,"total_duration":552064725,"load_duration":10092978,"prompt_eval_count":2242,"prompt_eval_duration":425090887,"eval_count":18,"eval_duration":115966422}' - recorded_at: Thu, 27 Mar 2025 20:52:43 GMT + encoding: ASCII-8BIT + string: '{"model":"granite3.2-vision:2b","created_at":"2025-04-02T00:44:02.426116551Z","message":{"role":"assistant","content":"\nI''m + sorry, but I can''t provide a description or answer any question related to + this image as it seems to be an error or placeholder. If you have another + image or if there''s something specific you''d like me to help with, please + let me know!"},"done_reason":"stop","done":true,"total_duration":404422192,"load_duration":8680145,"prompt_eval_count":2242,"prompt_eval_duration":21957042,"eval_count":55,"eval_duration":372859182}' + recorded_at: Wed, 02 Apr 2025 00:43:54 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_a_single_text.yml b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_a_single_text.yml index 0ce408e9..8256b717 100644 --- a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_a_single_text.yml +++ b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_a_single_text.yml @@ -24,11 +24,15 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Wed, 26 Mar 2025 17:18:38 GMT + - Wed, 02 Apr 2025 00:44:15 GMT + Server: + - Caddy + Vary: + - Accept-Encoding Transfer-Encoding: - chunked body: - encoding: UTF-8 - string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.025819365,-0.023147449,-0.05204419,-0.02359659,0.0006516247,0.009969577,-0.0453889,-0.068442866,-0.019442763,0.0009812108,-0.05498037,0.04730593,0.032717418,0.030947946,-0.028105065,-0.05090078,0.00025667102,0.023571288,-0.12629306,0.015917534,0.01231173,0.08733777,0.011108408,0.009003669,0.00718937,-0.0052934815,0.02193917,-0.020292742,-0.03461139,-0.20070425,0.02107215,0.072910964,0.031031353,-0.049616367,0.023306997,-0.06486672,0.013256376,0.0043853885,-0.052061625,-0.039435886,0.012164081,0.003788034,-0.050004035,-0.01751829,-0.029081171,-0.016297124,0.021628456,-0.017189225,0.08650422,0.019240791,-0.04283047,-0.008972946,-0.0282798,-0.048760213,-0.018701227,-0.018923806,0.015387223,0.0066132424,-0.021767087,0.006322427,0.034335203,0.0016922819,-0.3494393,-0.06468288,0.04789346,-0.00242133,0.046571758,0.022469908,-0.024689795,-0.016555127,-0.011920086,0.014217722,-0.074248835,-0.0378238,0.03272102,-0.055375192,0.013477699,0.042363465,0.038778525,-0.033732694,0.015692627,0.009818383,0.004275665,0.0011522578,0.023426272,0.044826716,-0.043028492,-0.05380732,-0.028874718,-0.0033281562,0.018819876,-0.018340344,0.03899947,-0.029625487,-0.064442106,0.04053737,-0.0017892135,0.049774364,0.033641562,0.31321952,0.04387253,0.004834189,0.050648943,-0.056952856,0.051840045,-0.004622082,-0.0029022766,-0.028918024,0.006063617,-0.0041818386,0.019223802,-0.031667218,0.017668251,0.023125196,0.045376316,-0.024328684,-0.03980277,0.024929393,0.0051530804,0.056438677,-0.0009725082,0.0037956084,-0.03239649,-0.012817254,-0.041858695,-0.014856791,-0.06271684,0.033761166,0.031467415,0.011851511,0.051261365,-0.01179492,-0.068899974,-0.014964267,-0.00063179573,0.017690614,-0.009009361,-0.09789638,-0.036439195,-0.0841935,0.023575196,-0.13396092,0.13305002,0.007911912,0.019786658,0.0002827157,0.02192103,0.05638941,-0.043504674,-0.04524754,0.011735054,-0.0035346176,0.0033445251,0.007442268,0.069734655,-0.0006457193,-0.03868659,0.07044447,-0.024192037,0.032955248,-0.011209725,0.03564046,0.039964315,0.09071652,0.08253361,-0.009900468,0.012840352,-0.02295395,0.03471711,-0.022090193,0.0044087064,0.0130827855,0.035907153,0.039426714,-0.03819838,0.030248774,-0.036349647,0.010017172,0.0025868686,0.0013163028,0.03427282,0.08895476,-0.051354308,-0.050073903,-0.0016582799,-0.009518917,0.06254944,0.040961392,0.07374542,0.078283615,-0.038456604,0.13166244,-0.0055810083,0.008324925,-0.021115026,0.04865895,0.040081963,0.04631163,0.04633088,-0.017098077,-0.007893804,0.007607068,-0.07570857,0.064662516,-0.022200007,-0.04613742,0.014698096,-0.040343154,0.0054809875,0.0068689506,0.00092213764,0.006511137,0.036636386,0.0075024543,0.039534982,0.005514188,-0.003920646,0.008136021,0.033838425,0.05254808,-0.015216625,0.031380977,0.0040966547,-0.04814886,-0.027520526,-0.024087062,-0.04536847,-0.05320231,-0.027292114,-0.01939129,0.010507547,0.068630666,0.043998722,0.0801662,0.03348169,-0.009085184,-0.01477701,0.047791857,0.05540584,-0.06736693,0.0020285759,0.013938147,-0.05031106,-0.035206556,0.02761124,-0.04022496,-0.007451326,-0.06296886,-0.022859126,0.09301553,0.048795525,-0.012271036,0.019697173,0.06446396,0.020241095,0.012088095,-0.17798372,-0.027375236,-0.061207205,0.038104277,-0.06642423,-0.009415216,0.052199904,-0.037760843,-0.022187525,0.012181313,-0.041066676,-0.06942215,-0.027730862,-0.009680216,-0.059220828,0.04467606,0.0003948015,0.01014289,0.027306745,0.029429084,0.0493429,-0.039006017,-0.01756003,-0.028417608,-0.027354918,0.042255033,0.061257206,0.0036709877,-0.024329077,-0.050390333,-0.013186946,0.0031478943,0.011040366,0.026129626,0.018130504,-0.027353661,0.019211745,-0.0022117277,0.1118481,0.0782376,0.024995422,0.059711028,-0.008173296,0.017002877,-0.039264616,-0.001962071,0.011470576,-0.032904048,-0.079988904,-0.02629866,0.026457293,-0.053743444,-0.0051814294,0.013066732,0.05321082,0.040862862,-0.0019826875,0.011493213,0.08629233,-0.041718166,0.047269218,0.07769727,-0.044020433,-0.16877456,-0.021221237,-0.011129706,-0.028999822,-0.022866756,-0.010865134,0.009030771,0.003806579,-0.024056332,-0.041828144,0.13366036,0.0550153,-0.0011019756,-0.027688803,0.02077072,0.08133359,-0.016294481,0.046593014,-0.012201837,-0.07112024,-0.03148493,0.046461217,0.13798657,0.004675504,0.04464258,0.018120104,0.020195337,-0.0872914,-0.1429005,0.045251735,0.007702035,-0.019940052,0.0597414,0.0053394698,0.005676257,0.012717743,0.068366244,-0.03198958,0.00562614,-0.023898745,0.14956613,0.028330524,0.0012210672,-0.034995347,0.014900526,-0.0042808442,-0.038005907,-0.0029655711,-0.046612997,-0.023074953,0.0093577355,0.019100675,-0.0048536737,0.03977017,0.02677702,0.05293125,0.005948059,-0.02770206,0.03918424,0.022482652,0.03589692,-0.030975368,-0.03310301,-0.061353248,0.012955803]],"total_duration":282200344,"load_duration":275638829,"prompt_eval_count":8}' - recorded_at: Wed, 26 Mar 2025 17:18:38 GMT + encoding: ASCII-8BIT + string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.025825415,-0.023176115,-0.052045297,-0.023625664,0.0006673469,0.009949714,-0.04538417,-0.06849524,-0.019409077,0.0010184002,-0.054927465,0.04728714,0.032690506,0.030963264,-0.028091758,-0.05092271,0.00021566867,0.023615433,-0.12640688,0.015840458,0.012315658,0.087370574,0.011073331,0.0090212375,0.007156342,-0.0052327104,0.021913407,-0.020346882,-0.03459649,-0.20068292,0.021031896,0.07291515,0.031049531,-0.04963502,0.023327535,-0.06476457,0.0131773045,0.004342761,-0.05204616,-0.03947274,0.0122103775,0.003776148,-0.050048206,-0.017586641,-0.029104842,-0.016230974,0.021660762,-0.017151477,0.0865443,0.01920734,-0.042871486,-0.0089291595,-0.02822964,-0.04884569,-0.018680912,-0.01892585,0.015438859,0.0065737013,-0.021804608,0.00633415,0.0343607,0.0017093703,-0.34944108,-0.06468269,0.0478818,-0.00246448,0.046574403,0.02243261,-0.024708489,-0.016602987,-0.011909359,0.014165576,-0.07424154,-0.03776865,0.032787047,-0.05530688,0.013535443,0.042380534,0.038827997,-0.033742167,0.015697544,0.009775907,0.0042203693,0.0011168025,0.023423292,0.04484947,-0.043061797,-0.05383481,-0.028867329,-0.0033860689,0.018773982,-0.018347567,0.03903167,-0.029658085,-0.06440208,0.040508885,-0.0017985007,0.049720276,0.033716165,0.31325525,0.04386892,0.0048334296,0.050675593,-0.056929454,0.0518016,-0.004611103,-0.0029309082,-0.028916717,0.0060408665,-0.004141483,0.01923389,-0.031655706,0.01768319,0.02311225,0.045390822,-0.024344986,-0.039786555,0.024944702,0.005075094,0.056426894,-0.0009737753,0.0037892968,-0.032363605,-0.012793344,-0.041841026,-0.014850747,-0.06273983,0.033704888,0.031475354,0.011834117,0.05125323,-0.011774348,-0.06885821,-0.014935385,-0.0006414335,0.017715653,-0.008953341,-0.097899854,-0.036503628,-0.084191576,0.023606507,-0.1339018,0.1330882,0.007957225,0.01985772,0.00030814653,0.021941159,0.05639211,-0.043463834,-0.045274723,0.011725757,-0.003486319,0.003375221,0.0074666464,0.06974618,-0.0006389784,-0.038667206,0.07041848,-0.02421246,0.03300245,-0.011266481,0.035639856,0.040018253,0.09069596,0.08246825,-0.009912788,0.012884513,-0.022981415,0.03470591,-0.022104705,0.0043493398,0.013083702,0.035951313,0.03946172,-0.038252268,0.030231304,-0.036359355,0.01005223,0.0025720727,0.0013707506,0.034241233,0.088925935,-0.051440887,-0.050102297,-0.0016456994,-0.009496842,0.062487546,0.040939905,0.07381002,0.078291304,-0.038428534,0.1316706,-0.0055638882,0.008280254,-0.021145111,0.04876571,0.040031683,0.04628573,0.046338666,-0.017028602,-0.007903445,0.007545737,-0.07565534,0.064689994,-0.022149073,-0.046088018,0.014704514,-0.040415496,0.00550196,0.006901969,0.00089305703,0.006521102,0.0366565,0.0074207284,0.039539423,0.005592426,-0.003989626,0.008083243,0.033852484,0.052595314,-0.015218367,0.03131478,0.0040506576,-0.048098013,-0.027468681,-0.024048975,-0.04536876,-0.05319465,-0.027298115,-0.01941297,0.010558779,0.06863464,0.04396793,0.08020219,0.033566475,-0.009056651,-0.014715962,0.04780099,0.05536488,-0.06740807,0.002055909,0.013943318,-0.05024147,-0.035200298,0.027621565,-0.040184192,-0.007491963,-0.06297288,-0.022879997,0.093055375,0.04880813,-0.012168053,0.019717308,0.064516716,0.020201867,0.012079503,-0.17798914,-0.027345736,-0.0612433,0.038101118,-0.06641872,-0.00939703,0.052195832,-0.03770301,-0.022270007,0.012196051,-0.041005902,-0.06945124,-0.027733557,-0.009639078,-0.059247572,0.04474978,0.00042829235,0.010153207,0.02728113,0.029422356,0.049308695,-0.038985588,-0.017589854,-0.02842523,-0.027386962,0.042216763,0.061242577,0.003747581,-0.024338258,-0.050467186,-0.013143215,0.0031099522,0.010997509,0.026045857,0.01815751,-0.027380131,0.01929404,-0.0022469186,0.111852795,0.07823112,0.024928685,0.059756078,-0.008221097,0.016979527,-0.039244134,-0.0019415446,0.011487329,-0.03280691,-0.08006135,-0.026343029,0.026450884,-0.053655412,-0.005154362,0.01307755,0.053237017,0.04086586,-0.0019484188,0.011518151,0.08618621,-0.041709326,0.047144253,0.077645905,-0.044002645,-0.16881582,-0.02115599,-0.011150404,-0.029005526,-0.022859793,-0.0107934745,0.009013299,0.0037840477,-0.023908136,-0.041892353,0.13362311,0.05498781,-0.0010903508,-0.027582854,0.02074264,0.08133009,-0.016295228,0.046583474,-0.012219358,-0.07110713,-0.031505097,0.04635908,0.13795494,0.004750067,0.044614047,0.018176915,0.020094909,-0.08733446,-0.14297998,0.045279857,0.0077459584,-0.019933412,0.059806284,0.0053598317,0.005684153,0.01267696,0.06831267,-0.03196309,0.0056615137,-0.023855256,0.14950311,0.028314097,0.0012290949,-0.034989975,0.014838987,-0.0043164054,-0.0380489,-0.002994491,-0.04658432,-0.023052199,0.009330306,0.019073954,-0.0048254183,0.039711606,0.026755748,0.05285787,0.005976852,-0.02769884,0.03918166,0.022543069,0.035913944,-0.030974701,-0.033151094,-0.061393328,0.012922418]],"total_duration":7800878,"load_duration":1435596,"prompt_eval_count":8}' + recorded_at: Wed, 02 Apr 2025 00:44:07 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml index 1cbab58b..2568478d 100644 --- a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml +++ b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml @@ -23,11 +23,15 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Wed, 26 Mar 2025 17:18:38 GMT + - Wed, 02 Apr 2025 00:44:15 GMT + Server: + - Caddy + Vary: + - Accept-Encoding Transfer-Encoding: - chunked body: - encoding: UTF-8 - string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.0388441,0.020130958,-0.067431964,0.007655712,-0.02143178,0.028401934,-0.059553344,-0.09178961,-0.032458898,0.008410962,-0.055265877,0.014614829,0.029787311,0.03382428,-0.01684954,-0.04444329,0.008301062,-0.0022140234,-0.122114494,-0.008171147,0.008162438,0.07341534,0.018977866,0.013705484,-0.0040139267,0.00035185603,0.0069316016,-0.01251507,-0.09616702,-0.17709394,0.012925018,0.03197588,0.026001623,-0.043088693,0.031905584,-0.04813018,-0.0017315283,0.029841121,-0.026876168,-0.030367695,-0.0067817485,0.02359407,-0.019723006,-0.0030676995,0.010523006,-0.027055979,0.04175819,-0.009885953,0.096520424,0.04388586,-0.03775211,-0.033325512,0.0096065905,-0.0139596285,-0.040052965,-0.002589836,0.046065394,0.004938671,-0.008818979,0.033967253,0.038127918,0.0013382456,-0.34866735,-0.06390991,0.066892646,-0.0076447544,0.034478936,0.0066651497,0.0017603931,-0.005765021,-0.059580464,-0.0011398621,-0.034723498,-0.0070240623,0.033945907,-0.07172375,0.0019033181,0.050755918,0.033208486,-0.044483263,-0.010917951,-0.013006815,0.017780134,0.027302826,0.017522654,0.050923645,-0.045407858,-0.031065013,0.0034971004,0.017281314,0.03732062,-0.020520234,0.034877818,-0.023866747,-0.070485,0.04555996,0.001389987,0.041110877,0.0083451895,0.30750144,0.041160934,-0.007575193,0.06326734,-0.07495616,0.05411205,-0.013711487,-0.018127367,0.0040174066,-0.016591415,-0.009179355,0.033549752,-0.01786939,-0.008867672,0.018478448,0.04625403,-0.028747778,-0.007066149,-0.005806406,0.0062766555,0.04459573,-0.03000371,0.014898422,-0.032604568,-0.017415427,-0.014565004,-0.022372194,-0.06727879,0.0365807,0.00958214,0.045523975,0.028445095,0.011969768,-0.06253902,-0.015415758,-0.0050557056,0.012014955,0.0024233195,-0.07337232,-0.0042311987,-0.07457154,-0.0006373777,-0.16765094,0.13003069,0.03297481,0.0144618815,0.0005355533,0.009557741,0.037592538,-0.012591949,-0.04204159,0.015775016,0.02042741,-0.026271803,0.020424932,0.091125205,-0.014388012,-0.042810924,0.051355045,-0.0075769946,0.03629031,0.010354268,0.0074680853,0.042652246,0.060397565,0.05299325,0.0070928345,0.018289784,-0.019927645,0.008178775,-0.026709922,-0.0004766831,0.018478047,0.012326361,0.061957974,-0.01432786,0.019229595,0.010431529,0.03351462,0.010213068,-0.031673603,0.01589807,0.10027719,-0.039053105,-0.058606964,-0.010657152,0.011582607,0.05528668,0.021357857,0.04105508,0.05390399,-0.0316559,0.156173,-0.048507318,0.012662477,-0.017382665,-0.005330175,0.057885952,0.06385099,0.028633239,-0.0010585266,-0.033099838,0.011883581,-0.054964617,0.034078836,-0.027739037,-0.04053948,0.019028971,-0.008881098,-0.009892724,-0.00016677074,0.008185013,0.014028663,0.015764946,0.013674434,0.040554117,-0.015574529,0.0012967308,-0.019827649,0.044048622,0.054283343,-0.019935552,0.019209668,-0.009141968,-0.06369639,-0.038524695,-0.00584429,-0.05572212,-0.020921145,-0.049070027,-0.01276479,0.051422957,0.062778324,0.02250262,0.11412264,0.014608461,0.0030205897,-0.036526274,0.050726265,0.049905915,-0.065770596,0.008405842,0.0010899245,-0.034585573,-0.004634513,0.012284967,-0.03207842,-0.04583995,-0.048865594,-0.019766245,0.12478698,0.06276402,-0.033869267,0.03652329,0.060382184,0.014759198,0.0046959203,-0.19071387,-0.032657206,-0.07738984,0.0442774,-0.05914576,-0.014506996,0.03734469,-0.0025898803,0.004546905,-0.0117728645,-0.05503146,-0.025510276,-0.020450229,-0.023852503,-0.015572229,0.06172686,0.018116174,0.013062141,0.043132544,0.020856835,0.034402605,-0.0055950414,0.012068603,-0.06377293,0.027816271,0.02069718,0.06381159,0.0031838878,-0.06427212,-0.071605794,-0.053954642,0.032803938,-0.0021615664,0.030591654,0.0039456603,-0.026492551,-0.026371498,-0.024719616,0.14168687,0.0002901896,-0.0034020492,0.031027138,0.0053976467,-0.000027014497,-0.052480403,0.0529854,-0.013960096,-0.03182876,-0.07278522,-0.029438145,-0.0076043443,-0.032225914,0.008225171,0.017322546,0.009984277,0.015520695,-0.0052385437,-0.011876693,0.07715109,-0.045244373,0.008803014,0.02424746,-0.015235667,-0.15054744,-0.0036824355,-0.016711554,-0.0013559143,-0.02194606,0.016720122,0.019720519,0.01517699,-0.03738912,-0.057589684,0.12978709,0.04813223,0.0077710785,-0.015100561,0.004117948,0.08621212,0.027476143,0.04439229,0.00030685926,-0.044507023,0.00089704886,0.061830766,0.16139033,0.024911765,-0.0074146036,0.004032755,0.039143074,-0.0898164,-0.11864838,0.04416452,-0.039557893,-0.03088087,0.11287578,0.043714676,-0.021582166,0.037369095,0.04492175,-0.0010107799,0.03280375,-0.035768308,0.15532315,-0.0009561552,-0.0034369607,-0.029741783,0.008190347,-0.051745743,-0.012318028,0.012402675,-0.04895367,-0.011466236,0.013425867,-0.033821847,-0.015193115,0.010228869,0.03193425,0.02603917,0.037040178,-0.017338518,0.01710686,0.058089267,0.030198513,-0.0008354163,-0.06520546,-0.0921685,-0.005078346],[-0.0072552343,0.03713646,-0.01699283,-0.030782733,-0.02052221,0.01125825,-0.06529242,-0.061818272,-0.020571295,-0.024209626,-0.03579918,0.015797382,0.061592482,0.02068423,0.016780416,-0.023932647,-0.010951945,0.025292471,-0.15266368,-0.012987599,-0.010199094,0.029842783,0.017119406,0.03163956,0.021315867,0.0035011058,0.013092083,-0.037269205,-0.13100713,-0.15873815,0.024110278,0.0054965187,-0.0057078693,-0.042900756,-0.00460323,-0.043012183,0.002026602,0.044829354,-0.0321034,-0.027913237,-0.0035799183,-0.0075295595,-0.013355917,0.0045460337,0.046187807,0.0027242594,0.049688134,-0.021872735,0.068736166,0.04175792,-0.0437622,0.014226286,-0.037445676,-0.055501036,-0.045524184,-0.001189907,0.044486266,-0.007421061,-0.0097211385,0.008858515,0.007311453,0.024857061,-0.35175383,-0.012672284,0.041481517,0.047193956,0.0020684737,0.047606543,-0.026176704,-0.025530554,-0.026922593,0.017605826,0.014854451,0.005629944,0.023153292,-0.041461922,-0.003056519,0.012925506,0.05518522,-0.038745392,0.026249396,0.03217421,0.019464033,-0.018742876,-0.013937561,0.045195688,-0.018083213,-0.012282628,0.0471358,0.0008688498,-0.028306754,0.0408566,0.024084115,0.0005985765,-0.06742631,0.009600122,-0.019761212,0.052697483,0.045696277,0.29864073,0.03026967,-0.0415359,0.016219707,-0.037604477,0.053452723,-0.029339043,-0.008365499,-0.03606822,0.021689609,-0.029203571,0.01769295,-0.021349482,-0.002733219,0.0033789296,0.031930774,-0.028539872,-0.04999919,0.007576535,-0.005124299,0.05567214,-0.048217237,-0.0006354506,-0.023972036,-0.052717745,0.0013329871,-0.016641501,-0.05940865,0.014591998,-0.007996123,-0.0060994998,0.034148518,-0.020664569,-0.09358414,-0.0194255,-0.0128993485,0.022041388,0.032610774,-0.052574314,0.016395817,-0.047118947,0.015677843,-0.13766375,0.10541323,0.0026426625,0.011538131,0.026277615,-0.02502458,0.0049760668,-0.053827237,-0.03863926,0.023165068,0.016438669,-0.0151872,0.002109835,0.12469035,0.020599306,-0.006932304,0.031132199,-0.011493038,0.0051031685,0.017425977,0.019842505,-0.006905538,0.03286136,0.029737378,-0.03871717,0.03207742,-0.017586391,0.019399468,-0.003148388,0.018489016,0.018581418,-0.012901189,0.017172573,-0.05461113,-0.001390115,-0.03233814,0.0011009739,0.03855168,-0.033363048,-0.015336527,0.080612056,-0.028678833,-0.046856903,-0.015384176,0.052241,0.059723865,0.032644298,0.059932925,0.06560817,-0.025778033,0.19489264,-0.09447736,-0.021961018,0.021270901,-0.004714235,0.03169394,0.033007365,-0.017643515,-0.023465928,-0.024755051,-0.014296845,-0.0002619207,0.015911218,0.015445326,-0.079413936,-0.0057071378,0.017307783,-0.005565825,-0.012172522,-0.009783294,-0.05173357,0.03838994,0.03412497,0.07624654,0.032628186,0.016304875,0.012916574,0.024889637,0.026531337,-0.0040279627,0.04415734,-0.02977549,-0.06746127,-0.03022296,-0.0021678545,-0.06871879,-0.0020891097,-0.082151935,-0.0058978163,0.03801924,0.039217323,0.03492099,0.113563396,0.025192197,0.018200427,0.024883514,0.027362043,0.011942755,-0.06134862,0.0019354849,0.015484824,-0.040022288,-0.024537606,0.020911857,-0.07808669,-0.019743685,-0.046418775,-0.03314287,0.1694522,0.050321065,-0.013430357,0.0070345113,0.038134124,0.0010241308,-0.011185799,-0.1828692,-0.025442472,-0.028564518,0.044677004,-0.0028425956,-0.00042380465,0.04030299,0.022801027,-0.009841054,-0.029609146,-0.009356221,-0.03580966,-0.028770214,-0.050125327,-0.031781837,0.104847625,0.026230568,0.02514224,0.0053547267,-0.009917238,0.07282194,0.029626124,-0.030785127,0.005750769,0.013035853,0.027320353,0.04267924,0.024914404,-0.031501085,-0.05527291,-0.04931349,-0.00094031333,-0.0029171903,0.067338765,-0.041093227,0.00045597606,-0.008067708,-0.026840648,0.18961208,0.0021951848,0.016140003,0.038745787,-0.016722713,0.0016434207,0.002311968,0.039490942,-0.03590958,-0.0054072104,-0.03100541,-0.014101151,0.058239665,-0.038461883,-0.02283073,0.008492259,-0.013109407,0.02975444,0.024842035,-0.015734265,0.09163665,-0.057609167,0.035152502,0.037537843,0.021865102,-0.2016707,-0.03457164,-0.013295931,0.048858218,-0.058543745,0.018288808,0.028178774,-0.0111076655,0.020360066,-0.026658798,0.11522286,0.053960584,-0.017099507,-0.0043872525,0.046700936,0.054960232,0.014453873,0.019755626,-0.013162808,-0.040781327,0.0028153716,0.060916595,0.15055314,-0.0048034787,0.040378716,0.023411844,0.0069524855,-0.03615119,-0.11237404,0.02728505,-0.032408927,-0.033139788,0.05818729,0.019382754,-0.035828292,0.023392975,0.071280956,-0.036502235,0.008983084,-0.034260582,0.1593053,-0.028021295,0.0172493,-0.016131653,-0.033713784,-0.04138278,0.00016605067,0.0054855584,-0.054233927,-0.013987903,0.022237027,-0.010095551,0.006079947,0.031176228,0.034318067,0.027573293,0.020763315,-0.019646917,0.012187558,0.04892568,0.04229697,0.034125984,-0.018135771,-0.035252318,-0.057188697],[0.010169066,0.014699193,0.02312678,-0.031285737,-0.019339556,0.01898938,-0.042842016,-0.065713726,0.037114225,-0.0019252088,-0.04387124,0.02680714,0.017134406,0.010056415,0.016514305,-0.07524968,-0.004598689,-0.0077995756,-0.16111827,-0.018086512,-0.023329865,0.07266939,0.035500344,0.007105781,-0.037746858,0.03954511,0.010651382,-0.03404992,-0.13568549,-0.1758981,0.017500464,0.021587882,-0.00029796895,-0.05286976,-0.021638112,-0.020357909,-0.03505305,0.015242394,-0.013434969,-0.03953229,0.007741148,-0.016568061,-0.046428822,-0.0113176145,0.050263844,-0.013899913,0.023608234,-0.030784462,0.024582472,0.041902494,-0.05761777,-0.032375082,0.00036015094,-0.03865763,-0.046571795,0.050851,-0.011026816,-0.03191825,0.010439611,0.01701438,0.0055330084,0.0587453,-0.3662647,0.025101654,0.07276847,0.019127958,-0.018416954,-0.0078095226,-0.00087658176,0.015874607,0.038312003,-0.014843252,-0.0125896605,0.01718569,0.026865218,-0.04576379,0.00359911,0.021899922,0.06563156,-0.042660784,0.0018792639,0.020148722,0.016360225,0.030104727,-0.015654275,0.06526195,0.0061962763,-0.028802281,0.038764264,0.0048531652,-0.048788548,0.035097387,0.0030290019,-0.002194582,-0.048610423,0.0012355483,0.0014674183,0.034617357,0.018160649,0.30238912,0.018115664,0.0030157077,0.040349476,-0.0703222,0.05237721,-0.0028105106,-0.028073953,-0.021660421,0.031953406,-0.0390731,0.0028894274,-0.017770546,0.005304085,-0.0061753215,0.054985832,-0.0013282879,-0.016932156,-0.009256211,0.023674654,0.043953825,-0.027819972,0.025420371,-0.04043455,-0.005284352,-0.010442454,0.0035201733,-0.06362815,0.02499165,-0.04596317,-0.011497569,0.05550298,0.00008448542,-0.09329214,0.019624306,0.022909734,0.03186377,0.0010003478,-0.031093974,0.0253383,-0.031195963,-0.018049393,-0.13012893,0.10688446,-0.010589804,0.025470642,-0.0050498014,-0.028474659,0.043146398,-0.026209809,-0.014387408,0.024687277,0.033259496,-0.04391259,-0.0050338595,0.0845666,0.022489144,0.0029990883,-0.0035517574,-0.006752627,0.029374328,0.02664534,0.025731422,0.059084013,0.08346221,0.032861166,-0.09516849,0.057318185,0.024989773,0.014103997,-0.004171578,0.018135788,-0.024807887,-0.041765466,-0.025802964,-0.012921618,-0.008061644,-0.028848117,-0.0005917901,0.02881574,-0.051334593,0.0027097291,0.063163355,-0.026775215,-0.08124945,-0.0105067,0.025091348,0.03696275,0.012843601,0.031530064,0.06319013,-0.027962644,0.17676653,-0.08200779,-0.03632199,-0.034959286,0.02156012,0.015361243,0.043850943,-0.0021428494,0.011226801,-0.046751194,-0.07139608,0.009606031,0.035172343,-0.04229935,-0.03569737,0.04477027,0.013450342,0.04269794,-0.008891381,-0.031291332,-0.0022993302,0.09038422,0.02420419,0.031999685,-0.0051883184,-0.010298845,0.028453493,0.0050622746,0.04699291,0.006085575,0.018052265,-0.022887442,-0.045732647,0.009925399,0.0068673166,-0.040608596,-0.013074616,-0.04770688,0.0011602375,0.078974366,0.04360928,0.040327042,0.073482476,0.06473103,0.014272077,-0.0487856,0.032009773,0.012478921,-0.0383686,0.016539803,0.0066691204,-0.040024173,-0.056614283,0.04952658,-0.09106773,-0.030492447,0.010533615,-0.029398412,0.18325548,0.09290254,0.027460678,0.01589842,0.031662818,-0.06166192,0.0014848855,-0.11129306,0.010330616,-0.040127635,0.03328302,-0.025017919,-0.03147771,0.06017222,-0.029784242,-0.026018031,-0.0014891784,-0.0060136514,-0.02197994,-0.005521501,-0.02919752,-0.040479988,0.09514643,0.019242264,0.042500548,0.00066325505,-0.009165173,0.025331255,-0.014075222,-0.058067344,-0.020931922,0.018429274,-0.002701154,0.053624205,0.034054026,-0.00924732,-0.07858087,-0.023325374,0.035447456,0.07162372,0.006831908,-0.03824091,-0.012311438,-0.010005245,-0.0059660277,0.12724046,0.0014100341,0.018896865,0.021953704,-0.04847068,-0.03720164,-0.009651089,0.054688897,0.013091016,-0.013793644,-0.04749705,-0.018131005,0.017314631,-0.028080247,-0.030335128,-0.0028840683,-0.04583448,0.0028758575,0.0152386045,-0.007833423,0.10375125,-0.016216613,0.017764568,0.037414994,0.0022454704,-0.17834663,-0.03604582,-0.00064713095,-0.014282952,-0.063561186,-0.030035643,0.02400106,-0.0008161259,0.025210572,-0.04692099,0.15453176,0.08460845,-0.018154804,-0.030075192,0.033266056,0.09898789,0.016117847,0.010213679,-0.018335694,-0.006946004,0.017542744,0.09943681,0.12576352,0.02319345,0.008129597,0.0032028987,-0.0053399303,-0.047532618,-0.13376793,-0.0018692309,-0.045244668,-0.020810418,0.06288976,0.00091563916,0.0054674884,0.005820324,0.031138638,-0.03758025,0.016956536,-0.04498085,0.13776563,-0.01599851,-0.000038715556,-0.008666058,-0.01248527,-0.002156642,0.022566035,0.051826704,-0.042339765,0.008286659,0.012520414,-0.004150474,-0.013118474,0.048206005,0.0003086508,-0.008351304,0.012447726,0.006553263,0.03620175,0.03051183,0.03917375,-0.029004231,-0.016662572,-0.07127831,-0.020850424]],"total_duration":7034636,"load_duration":731830,"prompt_eval_count":4}' - recorded_at: Wed, 26 Mar 2025 17:18:38 GMT + encoding: ASCII-8BIT + string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.038980126,0.020101948,-0.067413226,0.007685114,-0.021361317,0.028405204,-0.05964908,-0.09178641,-0.032397546,0.008366828,-0.05523459,0.014637846,0.0298761,0.03387804,-0.016674861,-0.044479024,0.008276525,-0.0022477629,-0.12195336,-0.008178106,0.008199949,0.07350191,0.01897805,0.013661541,-0.003947917,0.00030909953,0.006917925,-0.012626692,-0.09616951,-0.17709318,0.01293276,0.031847943,0.025997223,-0.042996813,0.03192809,-0.048060544,-0.0017395425,0.029812165,-0.026901668,-0.030327402,-0.0068094945,0.023497479,-0.019625092,-0.003110331,0.010590182,-0.027034454,0.04182794,-0.009884578,0.09661056,0.043840215,-0.037773125,-0.033335246,0.009626258,-0.013944384,-0.040054895,-0.0026200123,0.046114273,0.0049590026,-0.008846017,0.034012534,0.038100995,0.0013456035,-0.34869465,-0.06399822,0.06681992,-0.007770172,0.03451249,0.006695025,0.0016939766,-0.005725403,-0.059506737,-0.0011312707,-0.034694858,-0.0070268526,0.033973437,-0.07178208,0.0019529031,0.050796922,0.033150885,-0.04453945,-0.010778929,-0.01298108,0.01772847,0.027397834,0.017516151,0.05094088,-0.045374986,-0.031055674,0.0034364148,0.017342873,0.03724968,-0.020449797,0.03487508,-0.023868825,-0.0705106,0.045591667,0.0014132301,0.04102965,0.0082013225,0.3076015,0.041163538,-0.0075212517,0.0632507,-0.07494113,0.054058343,-0.013692275,-0.018088195,0.0039990763,-0.016607765,-0.00915819,0.03353369,-0.017990997,-0.008927891,0.018497262,0.04622437,-0.028729072,-0.0070351255,-0.005821854,0.0063457754,0.044443272,-0.03001723,0.014840464,-0.03265875,-0.017414864,-0.014599514,-0.022385433,-0.06727593,0.03655243,0.009642398,0.04557801,0.028509801,0.011939836,-0.062560804,-0.015390183,-0.0050801174,0.011868977,0.00253459,-0.07341563,-0.004279252,-0.07461656,-0.0006562158,-0.16768059,0.13006905,0.03295397,0.0145061985,0.000511846,0.009465702,0.037566304,-0.012595248,-0.042188045,0.015753305,0.02033451,-0.026321119,0.020434551,0.09113539,-0.014463864,-0.04273769,0.05132384,-0.007610653,0.036329918,0.010425151,0.0075439727,0.042681746,0.060391378,0.053032257,0.0071610347,0.018304583,-0.0199126,0.008234456,-0.026586238,-0.00048163044,0.018455869,0.012418799,0.061977547,-0.014351739,0.019218396,0.010331768,0.033490002,0.0102368975,-0.031620093,0.015966186,0.10022163,-0.03886677,-0.058662754,-0.010719046,0.011613407,0.055317454,0.021442259,0.041051246,0.05395217,-0.031625535,0.1561225,-0.04847817,0.012704446,-0.017351678,-0.005412353,0.05782586,0.063770935,0.028648905,-0.0010758642,-0.03315512,0.011804742,-0.054954775,0.034165937,-0.027770827,-0.040539972,0.01901002,-0.008845964,-0.009943114,-0.00007340114,0.008205162,0.014036151,0.015788715,0.013589957,0.040579043,-0.015481178,0.0013020202,-0.019863069,0.044024546,0.054241393,-0.019910982,0.019316196,-0.009067846,-0.06370655,-0.038542934,-0.005822525,-0.05564244,-0.020892167,-0.04894251,-0.012727646,0.05143602,0.06270096,0.022492254,0.11401925,0.014643738,0.0030262705,-0.036580373,0.05074049,0.04994587,-0.06580306,0.008364971,0.0012129012,-0.034641,-0.0046832887,0.012338395,-0.032140378,-0.045876123,-0.048861995,-0.019786038,0.12485802,0.06277426,-0.033950374,0.036432575,0.06035506,0.014863595,0.0047113854,-0.19050083,-0.032735668,-0.077262625,0.044320498,-0.059189577,-0.014459053,0.03718649,-0.0026039602,0.004493112,-0.011763187,-0.05504196,-0.025533773,-0.02048363,-0.023919607,-0.015506923,0.061790027,0.01816571,0.0130165955,0.04316555,0.020895818,0.034394037,-0.00560091,0.011984886,-0.06372637,0.02781977,0.020621277,0.06389801,0.0032279587,-0.064306036,-0.07160552,-0.05394653,0.032840647,-0.0021832213,0.030553438,0.0039347326,-0.026431374,-0.026453791,-0.024773262,0.14158836,0.00027325953,-0.003358694,0.031054376,0.005467873,-0.000014875217,-0.05249387,0.05296582,-0.013941867,-0.031785127,-0.07282081,-0.029387616,-0.0076221772,-0.032214306,0.008221592,0.01732765,0.01000591,0.015568096,-0.005231348,-0.012036904,0.07718011,-0.045315113,0.008787361,0.02417641,-0.015230668,-0.15053827,-0.0037556684,-0.01667005,-0.0013223562,-0.02209581,0.016655259,0.019694244,0.015031552,-0.037394483,-0.057655845,0.12982553,0.04818329,0.0077882116,-0.015061786,0.004192891,0.08628084,0.027619699,0.044403546,0.00034237612,-0.044426452,0.00096744276,0.06186224,0.16129373,0.024928987,-0.0073914034,0.0040016263,0.039090827,-0.08990263,-0.118701264,0.04410862,-0.03954887,-0.030827247,0.112970345,0.04363939,-0.021480395,0.03728192,0.044834364,-0.0009248547,0.032832358,-0.035760213,0.15535384,-0.0009505413,-0.0034093896,-0.029711511,0.008248596,-0.051867787,-0.012275803,0.012434058,-0.04902186,-0.011476671,0.0133925,-0.03379115,-0.0151935695,0.010195133,0.031876706,0.025932532,0.036986034,-0.01739396,0.017166032,0.05808856,0.030131826,-0.0008843879,-0.06526332,-0.09222386,-0.0049838475],[-0.007225496,0.037155706,-0.016906068,-0.030758644,-0.020417303,0.011231278,-0.06530078,-0.061754078,-0.020577524,-0.024164986,-0.035808578,0.015893035,0.061571326,0.020668881,0.016767306,-0.023883428,-0.01099219,0.025237663,-0.15266667,-0.013051586,-0.010288909,0.029873036,0.017107742,0.0315594,0.021337744,0.0034486242,0.013156374,-0.037249252,-0.13094991,-0.15867794,0.024068367,0.005509016,-0.0056714285,-0.042848945,-0.0045933733,-0.04299176,0.0020768172,0.04483032,-0.03212172,-0.027772011,-0.0036520734,-0.0075447895,-0.013391376,0.0045278594,0.04607957,0.0027125278,0.049626715,-0.021857744,0.06873977,0.04173157,-0.04370165,0.014249006,-0.0373972,-0.05551407,-0.045433797,-0.0011728521,0.044487648,-0.0074436087,-0.00975718,0.008799588,0.0073077497,0.024823438,-0.35174075,-0.012705645,0.04136241,0.047284245,0.0020329098,0.04765345,-0.02604234,-0.02548834,-0.02704063,0.017578213,0.01482943,0.0055936393,0.023184825,-0.041498873,-0.003050582,0.012843925,0.05516694,-0.03866418,0.02621437,0.032198943,0.01935349,-0.018680874,-0.013953387,0.0451372,-0.018057078,-0.012344732,0.04716202,0.0010259423,-0.028411478,0.04075236,0.024121404,0.0006758823,-0.0674563,0.009551461,-0.01973488,0.05264174,0.04568158,0.29859018,0.030333413,-0.04152799,0.016276676,-0.037692044,0.053379524,-0.029166088,-0.008381986,-0.03611233,0.021734668,-0.02926269,0.01770523,-0.021257408,-0.0026680147,0.0033788746,0.03192171,-0.02859868,-0.050017837,0.007628301,-0.005211484,0.055639394,-0.04813225,-0.00062740705,-0.023975527,-0.05272858,0.0012510746,-0.016620526,-0.05937839,0.014596674,-0.007940771,-0.0060859257,0.03417475,-0.020669967,-0.09361984,-0.019438276,-0.012983339,0.022100516,0.03252378,-0.052587945,0.016381664,-0.047060754,0.015694086,-0.1377361,0.10544033,0.0026725356,0.01146019,0.026346128,-0.025007993,0.004997534,-0.053778246,-0.038643032,0.023108022,0.016371924,-0.015227947,0.0020684898,0.124686636,0.02065184,-0.0070788977,0.031109046,-0.011467157,0.0051159468,0.0174688,0.019905413,-0.0069136377,0.032805618,0.029705629,-0.038734376,0.032078113,-0.01761205,0.01944323,-0.0030690655,0.018461121,0.018608272,-0.012803209,0.017234804,-0.05453963,-0.0014086623,-0.032340996,0.0010491384,0.038566574,-0.03347248,-0.015357926,0.08070545,-0.028756669,-0.046844523,-0.01529485,0.052366853,0.059635386,0.03260225,0.05999529,0.06562162,-0.025594424,0.19492106,-0.09446214,-0.02200547,0.021350436,-0.0047113174,0.03170546,0.032968767,-0.017730163,-0.023518713,-0.024787944,-0.014301349,-0.00028776744,0.015872791,0.015544321,-0.079372294,-0.005725175,0.017331447,-0.0056501715,-0.012182198,-0.009767331,-0.05171092,0.038543854,0.034115233,0.07627104,0.032627165,0.016347326,0.012965246,0.024923127,0.02650983,-0.0040691686,0.04411213,-0.02981039,-0.06744219,-0.030292222,-0.0021420228,-0.06861754,-0.0020280352,-0.08233997,-0.0059836525,0.037955742,0.039244626,0.034866735,0.11366857,0.02521095,0.018243132,0.024956543,0.027358694,0.011940862,-0.061406422,0.0018358993,0.015471496,-0.0400448,-0.024514355,0.020818526,-0.078023,-0.019798901,-0.046464335,-0.03319194,0.16930555,0.050408904,-0.013528864,0.007027566,0.0381429,0.0010658541,-0.011183001,-0.18296444,-0.025517514,-0.028616475,0.044594944,-0.002806602,-0.00036968052,0.040348303,0.022882342,-0.0099050915,-0.029638626,-0.009392766,-0.035751175,-0.02882233,-0.05017968,-0.031793848,0.104784735,0.026196804,0.025192862,0.0053355214,-0.009864406,0.07273947,0.029665705,-0.030834008,0.005743688,0.0130977845,0.027437972,0.042631894,0.02490531,-0.031600703,-0.055224583,-0.04933041,-0.0008777641,-0.002849928,0.06742398,-0.041109774,0.00045421268,-0.008093842,-0.026830377,0.18975478,0.0022353292,0.016124677,0.03874153,-0.01676804,0.0016409162,0.0022479978,0.039468583,-0.03589011,-0.005279329,-0.031004557,-0.014081007,0.058285933,-0.03845023,-0.022855511,0.008495943,-0.013061212,0.029775871,0.024829257,-0.015684903,0.09160675,-0.057623718,0.035138898,0.037533384,0.02173393,-0.20164658,-0.034627892,-0.013216875,0.04897353,-0.058580056,0.018308442,0.028224163,-0.011080451,0.020418232,-0.026639828,0.1152522,0.05399439,-0.017088734,-0.0043683355,0.04675239,0.055089362,0.01442295,0.019836834,-0.013131093,-0.040812545,0.0028349068,0.06096238,0.15055773,-0.0047997017,0.04041006,0.023423078,0.0068679894,-0.036161505,-0.11227965,0.027264446,-0.032434683,-0.033046544,0.05816228,0.019367868,-0.035861887,0.023473343,0.07127074,-0.036597442,0.00892375,-0.03424332,0.15918937,-0.028045062,0.01727863,-0.016116075,-0.033897277,-0.04147993,0.000102095604,0.0054549514,-0.054227076,-0.014035331,0.022229984,-0.0101330625,0.0061006444,0.031121459,0.034375396,0.027529038,0.02083103,-0.01970649,0.01220227,0.048865896,0.04224607,0.034099545,-0.018085487,-0.035159428,-0.057188712],[0.010182182,0.01467856,0.02307528,-0.031243263,-0.019379467,0.018989552,-0.04283347,-0.065710135,0.037127666,-0.00186089,-0.043939225,0.02675395,0.017098242,0.01003573,0.016530303,-0.07529927,-0.0045888554,-0.00783502,-0.16103624,-0.018049028,-0.023261337,0.0726829,0.03554955,0.007101789,-0.03776669,0.03965637,0.010605459,-0.034077637,-0.1356997,-0.17605451,0.017438654,0.021631619,-0.00033740848,-0.05291991,-0.021556789,-0.020458516,-0.035007652,0.015351501,-0.013426498,-0.03958441,0.007752372,-0.016570576,-0.046401996,-0.011264202,0.05016379,-0.013889148,0.023654828,-0.030822476,0.024557399,0.041917533,-0.057632543,-0.032482482,0.00036849198,-0.038682386,-0.046676703,0.050744284,-0.010942368,-0.031797383,0.010470975,0.016948372,0.0055663995,0.058688268,-0.36635372,0.025145743,0.07269215,0.019211076,-0.018371176,-0.007865585,-0.00085583143,0.015894871,0.038337328,-0.014794488,-0.012541673,0.01718971,0.02693935,-0.045785226,0.0036220509,0.021907976,0.06554055,-0.04263025,0.0019336614,0.020152396,0.016324878,0.030021766,-0.015724592,0.06523936,0.0062361993,-0.028796729,0.038781464,0.00485937,-0.04877486,0.035066955,0.003006257,-0.0022367106,-0.04857364,0.001250449,0.0014392686,0.034671582,0.018141782,0.30240846,0.018054346,0.003062208,0.040367432,-0.07040852,0.052332688,-0.0028175337,-0.028020458,-0.021599045,0.031913813,-0.03909125,0.0028893205,-0.017719263,0.0052999025,-0.0061596422,0.054935843,-0.0012574365,-0.016914988,-0.009276138,0.023673639,0.043957185,-0.027961437,0.025381606,-0.04037111,-0.0053644218,-0.01048436,0.0035398034,-0.06366181,0.025020782,-0.046017863,-0.011454832,0.055446308,0.00011163922,-0.09325482,0.019621197,0.022895223,0.03182137,0.0010375826,-0.03117694,0.025362851,-0.031175531,-0.018045994,-0.13010256,0.10690098,-0.010491627,0.025534678,-0.0049998793,-0.028496867,0.043118607,-0.026229834,-0.01440331,0.024678908,0.033322413,-0.04394492,-0.005047783,0.0846922,0.022463208,0.0030116427,-0.003502701,-0.006854317,0.029395698,0.026690561,0.02559026,0.059080407,0.08340788,0.032878075,-0.0951223,0.05720357,0.02495402,0.014070283,-0.0042589814,0.018304987,-0.024781907,-0.041739304,-0.025803747,-0.012889254,-0.008009496,-0.028856821,-0.0005779219,0.028763987,-0.051368624,0.0027247544,0.06316944,-0.026757175,-0.08121664,-0.010547304,0.025082018,0.03702747,0.012908532,0.03141585,0.06318691,-0.027946094,0.17676711,-0.082001895,-0.036393072,-0.034927875,0.021505699,0.015366971,0.043793295,-0.0021506813,0.011197076,-0.04681245,-0.07142668,0.009581391,0.035224073,-0.04230499,-0.03571502,0.044728618,0.013419941,0.04271971,-0.008869499,-0.03126791,-0.0022953814,0.09043066,0.02422671,0.031988394,-0.005063331,-0.01025437,0.028456746,0.005116802,0.047064006,0.006069893,0.018045707,-0.022872277,-0.04572793,0.009827904,0.0069014616,-0.040622003,-0.013080576,-0.04777706,0.0012043755,0.07896354,0.043710608,0.040280547,0.073466524,0.06464221,0.014187437,-0.04872054,0.031972423,0.012510081,-0.038348954,0.016539646,0.006683025,-0.040044174,-0.056529168,0.04949601,-0.09106357,-0.030466262,0.010563386,-0.029358381,0.18323456,0.092901036,0.0274177,0.015892414,0.03165387,-0.06160097,0.0015103974,-0.11125003,0.010338306,-0.04025745,0.03327973,-0.025003629,-0.03141167,0.06007851,-0.029752823,-0.025986204,-0.0014932271,-0.00599316,-0.021954508,-0.005476444,-0.029271869,-0.040407516,0.09515277,0.019253343,0.04248291,0.00067515706,-0.009261151,0.025339367,-0.014061599,-0.0580183,-0.020854905,0.018436473,-0.0027048623,0.05364179,0.03416436,-0.009260716,-0.0785917,-0.023255466,0.03542782,0.07159498,0.0069388812,-0.038117178,-0.012323471,-0.009949083,-0.005902662,0.1273025,0.0014150682,0.018899381,0.022011757,-0.048523538,-0.03720841,-0.009601104,0.0547053,0.013078509,-0.013740014,-0.047507983,-0.018159833,0.017327625,-0.028147077,-0.030314941,-0.0028794382,-0.045816995,0.0028496154,0.015196548,-0.007854572,0.10382276,-0.01617453,0.017708423,0.037362352,0.002230973,-0.17829818,-0.036029417,-0.0006612718,-0.014223209,-0.06350168,-0.030032892,0.023901368,-0.00077770976,0.02510791,-0.04697416,0.15435414,0.08471184,-0.018154247,-0.030085038,0.03331496,0.09898532,0.016086424,0.010282825,-0.018388266,-0.006998348,0.017570151,0.0994389,0.12580456,0.023195932,0.008063885,0.003250409,-0.005355925,-0.047599785,-0.13378266,-0.0018643751,-0.045305796,-0.020819422,0.06300365,0.00095856196,0.005435208,0.0057721534,0.031151773,-0.03753951,0.016918143,-0.044961866,0.13784775,-0.016061982,-0.00000515642,-0.008715281,-0.01241248,-0.0021270465,0.022557234,0.05173467,-0.04232277,0.008206349,0.012508353,-0.004212918,-0.01315854,0.048109457,0.00035447034,-0.0082567325,0.012337424,0.0065427353,0.036199752,0.030513138,0.039167494,-0.028987426,-0.016657345,-0.07125146,-0.020769335]],"total_duration":9249807,"load_duration":1162717,"prompt_eval_count":4}' + recorded_at: Wed, 02 Apr 2025 00:44:07 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/initial_model_refresh.yml b/spec/fixtures/vcr_cassettes/initial_model_refresh.yml index e12a9013..bf4dcd78 100644 --- a/spec/fixtures/vcr_cassettes/initial_model_refresh.yml +++ b/spec/fixtures/vcr_cassettes/initial_model_refresh.yml @@ -32,4 +32,128 @@ http_interactions: encoding: ASCII-8BIT string: '{ "models": [ { "details": { "families": [ "granite", "clip" ], "family": "granite", "format": "gguf", "parameter_size": "2.5B", "parent_model": "", "quantization_level": "Q4_K_M" }, "digest": "3be41a661804ad72cd08269816c5a145f1df6479ad07e2b3a7e29dba575d2669", "model": "granite3.2-vision:2b", "modified_at": "2025-03-27T20:09:18.017039337Z", "name": "granite3.2-vision:2b", "size": 2437852465 }, { "details": { "families": [ "llama" ], "family": "llama", "format": "gguf", "parameter_size": "8.0B", "parent_model": "", "quantization_level": "Q4_K_M" }, "digest": "46e0c10c039e019119339687c3c1757cc81b9da49709a3b3924863ba87ca666e", "model": "llama3.1:8b", "modified_at": "2025-03-27T19:29:58.416254293Z", "name": "llama3.1:8b", "size": 4920753328 }, { "details": { "families": [ "bert" ], "family": "bert", "format": "gguf", "parameter_size": "23M", "parent_model": "", "quantization_level": "F16" }, "digest": "bf75350e17522c7dfe63e98f50457b27fadcfee62f0c0767c1c86053407c2abb", "model": "snowflake-arctic-embed:22m", "modified_at": "2025-03-25T01:52:52.027398285Z", "name": "snowflake-arctic-embed:22m", "size": 45838698 } ] }' recorded_at: Thu, 27 Mar 2025 20:15:02 GMT +- request: + method: get + uri: https://bedrock.us-west-2.amazonaws.com/foundation-models + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.12.2 + Host: + - bedrock.us-west-2.amazonaws.com + X-Amz-Date: + - 20250325T171540Z + X-Amz-Security-Token: + - IQoJb3JpZ2luX2VjELH//////////wEaCXVzLXdlc3QtMiJGMEQCIDILea5LoQt0bejpnAvGlODePXWs+SVOVYKadYo/Rk9CAiBvj7jTOPExaq5kzi5J7Q2EI2OPjkGHwhnRvXZUSqD6LCqSAwgaEAYaDDIyMTg3MTkxNTQ2MyIMSNqSOazgocTuFlBsKu8C3Nbecj9HZFdBXZ7kaWtb3fByaNE9zYowsMzOb08Ugng8UL9qxzm5g0wT+NFvcJg4JvHNBlfxQyqhoqRAzSN8FAevZ2Pf59sReQbMAaKK0+CdIlH+begPkvTzwGvbj6CQhcRWkeD0UWRgLj1qpwJc2MhogI4CaSILeh/gkUC2fwtLaLK8KoXkrC+XWSvs/P+Qn5gF/YcwWYmlJjo1Y7zkaSRPD/V/SXrdEKCb7lHMkB9HgGSiV0kLg5y6KAcmBbG2HWd7S4qRu0Ko3lm3PIch5E4X7UDcxVLBtX0YErNR7vIRQvpbZ9itrjDqF1Wcckw26asVdC1UxbOSWrnAGqk8RFZrS17i4CP+XV+dQ3jD4/+ILYjKvXynqYA4TAwahL0104h7JCFELXmQOEwPmIPX4hmutyUEkkmfout1krQmzjE01ltNitPgVJzOI3On9YHKqBNp0aEgd6xC9frMseZ8Bb+d8B1Jx9oIBCVvH8RRtTDox4u/BjqnAVK1mPlee72ZUnkKg4jzL3LJL3OmDMBOEGSHmUoOTQ40feXeTlY01glfh7Cx3ExDxAUNIz96zwmhuVVSdwP9aGGsumlYsTJRz7wpDvgq8eGV+9JD9uG+55rtGsH8EzBS9Xw5bxJpBvmpIuRw6fKr7wBiCTTVyRR+Jl7JqGoQelm41v/mXIjzsO43zWUbwInRyFYzqxwmiPSHGwJJnn7eQriksmHxxh4i + X-Amz-Content-Sha256: + - e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 + Authorization: + - AWS4-HMAC-SHA256 Credential=ASIATHKEYYHDRJWE7TAB/20250325/us-west-2/bedrock/aws4_request, + SignedHeaders=host;x-amz-content-sha256;x-amz-date;x-amz-security-token, Signature=e4a35761abf5be047cdd3c2b4383e1f3b30031acb59a6254960f1ef94b1a939a + Content-Type: + - application/json + Accept: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + response: + status: + code: 200 + message: OK + headers: + Date: + - Tue, 25 Mar 2025 17:14:59 GMT + Content-Type: + - application/json + Content-Length: + - '45249' + Connection: + - keep-alive + X-Amzn-Requestid: + - '08c81519-bf5d-4c0f-8dad-e1fe0e12c7fa' + body: + encoding: UTF-8 + string: '{"modelSummaries":[{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-tg1-large","modelId":"amazon.titan-tg1-large","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text Large","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-g1-text-02","modelId":"amazon.titan-embed-g1-text-02","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text Embeddings v2","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING","CONTINUED_PRE_TRAINING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-lite-v1:0:4k","modelId":"amazon.titan-text-lite-v1:0:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-lite-v1","modelId":"amazon.titan-text-lite-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","CONTINUED_PRE_TRAINING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-express-v1:0:8k","modelId":"amazon.titan-text-express-v1:0:8k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Express","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-express-v1","modelId":"amazon.titan-text-express-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Express","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE","VIDEO"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.nova-pro-v1:0","modelId":"amazon.nova-pro-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova + Pro","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE","VIDEO"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.nova-lite-v1:0","modelId":"amazon.nova-lite-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova + Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.nova-micro-v1:0","modelId":"amazon.nova-micro-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova + Micro","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-text-v1:2:8k","modelId":"amazon.titan-embed-text-v1:2:8k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Embeddings G1 - Text","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-text-v1","modelId":"amazon.titan-embed-text-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Embeddings G1 - Text","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-text-v2:0","modelId":"amazon.titan-embed-text-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text Embeddings V2","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-image-v1:0","modelId":"amazon.titan-embed-image-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Multimodal Embeddings G1","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-image-v1","modelId":"amazon.titan-embed-image-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Multimodal Embeddings G1","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-image-generator-v1:0","modelId":"amazon.titan-image-generator-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Image Generator G1","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-image-generator-v1","modelId":"amazon.titan-image-generator-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Image Generator G1","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED","ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-image-generator-v2:0","modelId":"amazon.titan-image-generator-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Image Generator G1 v2","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.rerank-v1:0","modelId":"amazon.rerank-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Rerank + 1.0","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-diffusion-xl-v1:0","modelId":"stability.stable-diffusion-xl-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"SDXL + 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-diffusion-xl-v1","modelId":"stability.stable-diffusion-xl-v1","modelLifecycle":{"status":"LEGACY"},"modelName":"SDXL + 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.sd3-large-v1:0","modelId":"stability.sd3-large-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"SD3 + Large 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.sd3-5-large-v1:0","modelId":"stability.sd3-5-large-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable + Diffusion 3.5 Large","outputModalities":["IMAGE"],"providerName":"Stability + AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-core-v1:0","modelId":"stability.stable-image-core-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Stable + Image Core 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-core-v1:1","modelId":"stability.stable-image-core-v1:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable + Image Core 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-ultra-v1:0","modelId":"stability.stable-image-ultra-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Stable + Image Ultra 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-ultra-v1:1","modelId":"stability.stable-image-ultra-v1:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable + Image Ultra 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:18k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:18k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:51k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:51k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:200k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-7-sonnet-20250219-v1:0","modelId":"anthropic.claude-3-7-sonnet-20250219-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.7 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-haiku-20241022-v1:0","modelId":"anthropic.claude-3-5-haiku-20241022-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-instant-v1:2:100k","modelId":"anthropic.claude-instant-v1:2:100k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + Instant","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-instant-v1","modelId":"anthropic.claude-instant-v1","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + Instant","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:0:18k","modelId":"anthropic.claude-v2:0:18k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:0:100k","modelId":"anthropic.claude-v2:0:100k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:1:18k","modelId":"anthropic.claude-v2:1:18k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:1:200k","modelId":"anthropic.claude-v2:1:200k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:1","modelId":"anthropic.claude-v2:1","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2","modelId":"anthropic.claude-v2","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0:28k","modelId":"anthropic.claude-3-sonnet-20240229-v1:0:28k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0:200k","modelId":"anthropic.claude-3-sonnet-20240229-v1:0:200k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0","modelId":"anthropic.claude-3-sonnet-20240229-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-haiku-20240307-v1:0:48k","modelId":"anthropic.claude-3-haiku-20240307-v1:0:48k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-haiku-20240307-v1:0:200k","modelId":"anthropic.claude-3-haiku-20240307-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-haiku-20240307-v1:0","modelId":"anthropic.claude-3-haiku-20240307-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0:12k","modelId":"anthropic.claude-3-opus-20240229-v1:0:12k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0:28k","modelId":"anthropic.claude-3-opus-20240229-v1:0:28k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0:200k","modelId":"anthropic.claude-3-opus-20240229-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0","modelId":"anthropic.claude-3-opus-20240229-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:18k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:18k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:51k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:51k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:200k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND","INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-text-v14:7:4k","modelId":"cohere.command-text-v14:7:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-text-v14","modelId":"cohere.command-text-v14","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-r-v1:0","modelId":"cohere.command-r-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + R","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-r-plus-v1:0","modelId":"cohere.command-r-plus-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + R+","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-light-text-v14:7:4k","modelId":"cohere.command-light-text-v14:7:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + Light","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-light-text-v14","modelId":"cohere.command-light-text-v14","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + Light","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-english-v3:0:512","modelId":"cohere.embed-english-v3:0:512","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + English","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-english-v3","modelId":"cohere.embed-english-v3","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + English","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-multilingual-v3:0:512","modelId":"cohere.embed-multilingual-v3:0:512","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + Multilingual","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-multilingual-v3","modelId":"cohere.embed-multilingual-v3","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + Multilingual","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.rerank-v3-5:0","modelId":"cohere.rerank-v3-5:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Rerank + 3.5","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/deepseek.r1-v1:0","modelId":"deepseek.r1-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"DeepSeek-R1","outputModalities":["TEXT"],"providerName":"DeepSeek","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-8b-instruct-v1:0","modelId":"meta.llama3-8b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-70b-instruct-v1:0","modelId":"meta.llama3-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-8b-instruct-v1:0:128k","modelId":"meta.llama3-1-8b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-8b-instruct-v1:0","modelId":"meta.llama3-1-8b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-70b-instruct-v1:0:128k","modelId":"meta.llama3-1-70b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-70b-instruct-v1:0","modelId":"meta.llama3-1-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-405b-instruct-v1:0","modelId":"meta.llama3-1-405b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 405B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-11b-instruct-v1:0:128k","modelId":"meta.llama3-2-11b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 11B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-11b-instruct-v1:0","modelId":"meta.llama3-2-11b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 11B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-90b-instruct-v1:0:128k","modelId":"meta.llama3-2-90b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 90B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-90b-instruct-v1:0","modelId":"meta.llama3-2-90b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 90B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-1b-instruct-v1:0:128k","modelId":"meta.llama3-2-1b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 1B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-1b-instruct-v1:0","modelId":"meta.llama3-2-1b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 1B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-3b-instruct-v1:0:128k","modelId":"meta.llama3-2-3b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 3B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-3b-instruct-v1:0","modelId":"meta.llama3-2-3b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 3B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-3-70b-instruct-v1:0","modelId":"meta.llama3-3-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.3 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mistral-7b-instruct-v0:2","modelId":"mistral.mistral-7b-instruct-v0:2","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral + 7B Instruct","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mixtral-8x7b-instruct-v0:1","modelId":"mistral.mixtral-8x7b-instruct-v0:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mixtral + 8x7B Instruct","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mistral-large-2402-v1:0","modelId":"mistral.mistral-large-2402-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral + Large (24.02)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mistral-large-2407-v1:0","modelId":"mistral.mistral-large-2407-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral + Large (24.07)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/luma.ray-v2:0","modelId":"luma.ray-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Ray + v2","outputModalities":["VIDEO"],"providerName":"Luma AI","responseStreamingSupported":false}]}' + recorded_at: Tue, 25 Mar 2025 17:15:40 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/models_refresh_updates_models_and_returns_a_chainable_models_instance.yml b/spec/fixtures/vcr_cassettes/models_refresh_updates_models_and_returns_a_chainable_models_instance.yml index ea64e3c2..3bcddd37 100644 --- a/spec/fixtures/vcr_cassettes/models_refresh_updates_models_and_returns_a_chainable_models_instance.yml +++ b/spec/fixtures/vcr_cassettes/models_refresh_updates_models_and_returns_a_chainable_models_instance.yml @@ -1267,4 +1267,128 @@ http_interactions: encoding: UTF-8 string: '{"models":[{"name":"snowflake-arctic-embed:22m","model":"snowflake-arctic-embed:22m","modified_at":"2025-03-26T17:18:08.367580922Z","size":45838698,"digest":"bf75350e17522c7dfe63e98f50457b27fadcfee62f0c0767c1c86053407c2abb","details":{"parent_model":"","format":"gguf","family":"bert","families":["bert"],"parameter_size":"23M","quantization_level":"F16"}},{"name":"smollm:135m","model":"smollm:135m","modified_at":"2025-03-26T17:18:01.303574119Z","size":91739413,"digest":"b0b2a46174385c0adcaa77ff245ffeced5fc4a61447b6f221b2beb5c5a760133","details":{"parent_model":"","format":"gguf","family":"llama","families":["llama"],"parameter_size":"134.52M","quantization_level":"Q4_0"}}]}' recorded_at: Wed, 26 Mar 2025 17:18:38 GMT +- request: + method: get + uri: https://bedrock.us-west-2.amazonaws.com/foundation-models + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.12.2 + Host: + - bedrock.us-west-2.amazonaws.com + X-Amz-Date: + - 20250325T171540Z + X-Amz-Security-Token: + - IQoJb3JpZ2luX2VjELH//////////wEaCXVzLXdlc3QtMiJGMEQCIDILea5LoQt0bejpnAvGlODePXWs+SVOVYKadYo/Rk9CAiBvj7jTOPExaq5kzi5J7Q2EI2OPjkGHwhnRvXZUSqD6LCqSAwgaEAYaDDIyMTg3MTkxNTQ2MyIMSNqSOazgocTuFlBsKu8C3Nbecj9HZFdBXZ7kaWtb3fByaNE9zYowsMzOb08Ugng8UL9qxzm5g0wT+NFvcJg4JvHNBlfxQyqhoqRAzSN8FAevZ2Pf59sReQbMAaKK0+CdIlH+begPkvTzwGvbj6CQhcRWkeD0UWRgLj1qpwJc2MhogI4CaSILeh/gkUC2fwtLaLK8KoXkrC+XWSvs/P+Qn5gF/YcwWYmlJjo1Y7zkaSRPD/V/SXrdEKCb7lHMkB9HgGSiV0kLg5y6KAcmBbG2HWd7S4qRu0Ko3lm3PIch5E4X7UDcxVLBtX0YErNR7vIRQvpbZ9itrjDqF1Wcckw26asVdC1UxbOSWrnAGqk8RFZrS17i4CP+XV+dQ3jD4/+ILYjKvXynqYA4TAwahL0104h7JCFELXmQOEwPmIPX4hmutyUEkkmfout1krQmzjE01ltNitPgVJzOI3On9YHKqBNp0aEgd6xC9frMseZ8Bb+d8B1Jx9oIBCVvH8RRtTDox4u/BjqnAVK1mPlee72ZUnkKg4jzL3LJL3OmDMBOEGSHmUoOTQ40feXeTlY01glfh7Cx3ExDxAUNIz96zwmhuVVSdwP9aGGsumlYsTJRz7wpDvgq8eGV+9JD9uG+55rtGsH8EzBS9Xw5bxJpBvmpIuRw6fKr7wBiCTTVyRR+Jl7JqGoQelm41v/mXIjzsO43zWUbwInRyFYzqxwmiPSHGwJJnn7eQriksmHxxh4i + X-Amz-Content-Sha256: + - e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 + Authorization: + - AWS4-HMAC-SHA256 Credential=ASIATHKEYYHDRJWE7TAB/20250325/us-west-2/bedrock/aws4_request, + SignedHeaders=host;x-amz-content-sha256;x-amz-date;x-amz-security-token, Signature=e4a35761abf5be047cdd3c2b4383e1f3b30031acb59a6254960f1ef94b1a939a + Content-Type: + - application/json + Accept: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + response: + status: + code: 200 + message: OK + headers: + Date: + - Tue, 25 Mar 2025 17:14:59 GMT + Content-Type: + - application/json + Content-Length: + - '45249' + Connection: + - keep-alive + X-Amzn-Requestid: + - '08c81519-bf5d-4c0f-8dad-e1fe0e12c7fa' + body: + encoding: UTF-8 + string: '{"modelSummaries":[{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-tg1-large","modelId":"amazon.titan-tg1-large","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text Large","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-g1-text-02","modelId":"amazon.titan-embed-g1-text-02","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text Embeddings v2","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING","CONTINUED_PRE_TRAINING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-lite-v1:0:4k","modelId":"amazon.titan-text-lite-v1:0:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-lite-v1","modelId":"amazon.titan-text-lite-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","CONTINUED_PRE_TRAINING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-express-v1:0:8k","modelId":"amazon.titan-text-express-v1:0:8k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Express","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-express-v1","modelId":"amazon.titan-text-express-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Express","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE","VIDEO"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.nova-pro-v1:0","modelId":"amazon.nova-pro-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova + Pro","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE","VIDEO"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.nova-lite-v1:0","modelId":"amazon.nova-lite-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova + Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.nova-micro-v1:0","modelId":"amazon.nova-micro-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova + Micro","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-text-v1:2:8k","modelId":"amazon.titan-embed-text-v1:2:8k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Embeddings G1 - Text","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-text-v1","modelId":"amazon.titan-embed-text-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Embeddings G1 - Text","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-text-v2:0","modelId":"amazon.titan-embed-text-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text Embeddings V2","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-image-v1:0","modelId":"amazon.titan-embed-image-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Multimodal Embeddings G1","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-image-v1","modelId":"amazon.titan-embed-image-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Multimodal Embeddings G1","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-image-generator-v1:0","modelId":"amazon.titan-image-generator-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Image Generator G1","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-image-generator-v1","modelId":"amazon.titan-image-generator-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Image Generator G1","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED","ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-image-generator-v2:0","modelId":"amazon.titan-image-generator-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Image Generator G1 v2","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.rerank-v1:0","modelId":"amazon.rerank-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Rerank + 1.0","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-diffusion-xl-v1:0","modelId":"stability.stable-diffusion-xl-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"SDXL + 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-diffusion-xl-v1","modelId":"stability.stable-diffusion-xl-v1","modelLifecycle":{"status":"LEGACY"},"modelName":"SDXL + 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.sd3-large-v1:0","modelId":"stability.sd3-large-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"SD3 + Large 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.sd3-5-large-v1:0","modelId":"stability.sd3-5-large-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable + Diffusion 3.5 Large","outputModalities":["IMAGE"],"providerName":"Stability + AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-core-v1:0","modelId":"stability.stable-image-core-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Stable + Image Core 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-core-v1:1","modelId":"stability.stable-image-core-v1:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable + Image Core 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-ultra-v1:0","modelId":"stability.stable-image-ultra-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Stable + Image Ultra 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-ultra-v1:1","modelId":"stability.stable-image-ultra-v1:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable + Image Ultra 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:18k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:18k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:51k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:51k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:200k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-7-sonnet-20250219-v1:0","modelId":"anthropic.claude-3-7-sonnet-20250219-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.7 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-haiku-20241022-v1:0","modelId":"anthropic.claude-3-5-haiku-20241022-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-instant-v1:2:100k","modelId":"anthropic.claude-instant-v1:2:100k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + Instant","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-instant-v1","modelId":"anthropic.claude-instant-v1","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + Instant","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:0:18k","modelId":"anthropic.claude-v2:0:18k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:0:100k","modelId":"anthropic.claude-v2:0:100k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:1:18k","modelId":"anthropic.claude-v2:1:18k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:1:200k","modelId":"anthropic.claude-v2:1:200k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:1","modelId":"anthropic.claude-v2:1","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2","modelId":"anthropic.claude-v2","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0:28k","modelId":"anthropic.claude-3-sonnet-20240229-v1:0:28k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0:200k","modelId":"anthropic.claude-3-sonnet-20240229-v1:0:200k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0","modelId":"anthropic.claude-3-sonnet-20240229-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-haiku-20240307-v1:0:48k","modelId":"anthropic.claude-3-haiku-20240307-v1:0:48k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-haiku-20240307-v1:0:200k","modelId":"anthropic.claude-3-haiku-20240307-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-haiku-20240307-v1:0","modelId":"anthropic.claude-3-haiku-20240307-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0:12k","modelId":"anthropic.claude-3-opus-20240229-v1:0:12k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0:28k","modelId":"anthropic.claude-3-opus-20240229-v1:0:28k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0:200k","modelId":"anthropic.claude-3-opus-20240229-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0","modelId":"anthropic.claude-3-opus-20240229-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:18k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:18k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:51k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:51k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:200k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND","INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-text-v14:7:4k","modelId":"cohere.command-text-v14:7:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-text-v14","modelId":"cohere.command-text-v14","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-r-v1:0","modelId":"cohere.command-r-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + R","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-r-plus-v1:0","modelId":"cohere.command-r-plus-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + R+","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-light-text-v14:7:4k","modelId":"cohere.command-light-text-v14:7:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + Light","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-light-text-v14","modelId":"cohere.command-light-text-v14","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + Light","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-english-v3:0:512","modelId":"cohere.embed-english-v3:0:512","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + English","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-english-v3","modelId":"cohere.embed-english-v3","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + English","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-multilingual-v3:0:512","modelId":"cohere.embed-multilingual-v3:0:512","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + Multilingual","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-multilingual-v3","modelId":"cohere.embed-multilingual-v3","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + Multilingual","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.rerank-v3-5:0","modelId":"cohere.rerank-v3-5:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Rerank + 3.5","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/deepseek.r1-v1:0","modelId":"deepseek.r1-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"DeepSeek-R1","outputModalities":["TEXT"],"providerName":"DeepSeek","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-8b-instruct-v1:0","modelId":"meta.llama3-8b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-70b-instruct-v1:0","modelId":"meta.llama3-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-8b-instruct-v1:0:128k","modelId":"meta.llama3-1-8b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-8b-instruct-v1:0","modelId":"meta.llama3-1-8b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-70b-instruct-v1:0:128k","modelId":"meta.llama3-1-70b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-70b-instruct-v1:0","modelId":"meta.llama3-1-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-405b-instruct-v1:0","modelId":"meta.llama3-1-405b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 405B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-11b-instruct-v1:0:128k","modelId":"meta.llama3-2-11b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 11B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-11b-instruct-v1:0","modelId":"meta.llama3-2-11b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 11B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-90b-instruct-v1:0:128k","modelId":"meta.llama3-2-90b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 90B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-90b-instruct-v1:0","modelId":"meta.llama3-2-90b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 90B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-1b-instruct-v1:0:128k","modelId":"meta.llama3-2-1b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 1B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-1b-instruct-v1:0","modelId":"meta.llama3-2-1b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 1B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-3b-instruct-v1:0:128k","modelId":"meta.llama3-2-3b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 3B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-3b-instruct-v1:0","modelId":"meta.llama3-2-3b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 3B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-3-70b-instruct-v1:0","modelId":"meta.llama3-3-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.3 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mistral-7b-instruct-v0:2","modelId":"mistral.mistral-7b-instruct-v0:2","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral + 7B Instruct","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mixtral-8x7b-instruct-v0:1","modelId":"mistral.mixtral-8x7b-instruct-v0:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mixtral + 8x7B Instruct","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mistral-large-2402-v1:0","modelId":"mistral.mistral-large-2402-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral + Large (24.02)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mistral-large-2407-v1:0","modelId":"mistral.mistral-large-2407-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral + Large (24.07)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/luma.ray-v2:0","modelId":"luma.ray-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Ray + v2","outputModalities":["VIDEO"],"providerName":"Luma AI","responseStreamingSupported":false}]}' + recorded_at: Tue, 25 Mar 2025 17:15:40 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/models_refresh_works_as_a_class_method_too.yml b/spec/fixtures/vcr_cassettes/models_refresh_works_as_a_class_method_too.yml index 67c955d8..fffc6ec3 100644 --- a/spec/fixtures/vcr_cassettes/models_refresh_works_as_a_class_method_too.yml +++ b/spec/fixtures/vcr_cassettes/models_refresh_works_as_a_class_method_too.yml @@ -1267,4 +1267,128 @@ http_interactions: encoding: UTF-8 string: '{"models":[{"name":"snowflake-arctic-embed:22m","model":"snowflake-arctic-embed:22m","modified_at":"2025-03-26T17:18:08.367580922Z","size":45838698,"digest":"bf75350e17522c7dfe63e98f50457b27fadcfee62f0c0767c1c86053407c2abb","details":{"parent_model":"","format":"gguf","family":"bert","families":["bert"],"parameter_size":"23M","quantization_level":"F16"}},{"name":"smollm:135m","model":"smollm:135m","modified_at":"2025-03-26T17:18:01.303574119Z","size":91739413,"digest":"b0b2a46174385c0adcaa77ff245ffeced5fc4a61447b6f221b2beb5c5a760133","details":{"parent_model":"","format":"gguf","family":"llama","families":["llama"],"parameter_size":"134.52M","quantization_level":"Q4_0"}}]}' recorded_at: Wed, 26 Mar 2025 17:18:38 GMT +- request: + method: get + uri: https://bedrock.us-west-2.amazonaws.com/foundation-models + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.12.2 + Host: + - bedrock.us-west-2.amazonaws.com + X-Amz-Date: + - 20250325T171540Z + X-Amz-Security-Token: + - IQoJb3JpZ2luX2VjELH//////////wEaCXVzLXdlc3QtMiJGMEQCIDILea5LoQt0bejpnAvGlODePXWs+SVOVYKadYo/Rk9CAiBvj7jTOPExaq5kzi5J7Q2EI2OPjkGHwhnRvXZUSqD6LCqSAwgaEAYaDDIyMTg3MTkxNTQ2MyIMSNqSOazgocTuFlBsKu8C3Nbecj9HZFdBXZ7kaWtb3fByaNE9zYowsMzOb08Ugng8UL9qxzm5g0wT+NFvcJg4JvHNBlfxQyqhoqRAzSN8FAevZ2Pf59sReQbMAaKK0+CdIlH+begPkvTzwGvbj6CQhcRWkeD0UWRgLj1qpwJc2MhogI4CaSILeh/gkUC2fwtLaLK8KoXkrC+XWSvs/P+Qn5gF/YcwWYmlJjo1Y7zkaSRPD/V/SXrdEKCb7lHMkB9HgGSiV0kLg5y6KAcmBbG2HWd7S4qRu0Ko3lm3PIch5E4X7UDcxVLBtX0YErNR7vIRQvpbZ9itrjDqF1Wcckw26asVdC1UxbOSWrnAGqk8RFZrS17i4CP+XV+dQ3jD4/+ILYjKvXynqYA4TAwahL0104h7JCFELXmQOEwPmIPX4hmutyUEkkmfout1krQmzjE01ltNitPgVJzOI3On9YHKqBNp0aEgd6xC9frMseZ8Bb+d8B1Jx9oIBCVvH8RRtTDox4u/BjqnAVK1mPlee72ZUnkKg4jzL3LJL3OmDMBOEGSHmUoOTQ40feXeTlY01glfh7Cx3ExDxAUNIz96zwmhuVVSdwP9aGGsumlYsTJRz7wpDvgq8eGV+9JD9uG+55rtGsH8EzBS9Xw5bxJpBvmpIuRw6fKr7wBiCTTVyRR+Jl7JqGoQelm41v/mXIjzsO43zWUbwInRyFYzqxwmiPSHGwJJnn7eQriksmHxxh4i + X-Amz-Content-Sha256: + - e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 + Authorization: + - AWS4-HMAC-SHA256 Credential=ASIATHKEYYHDRJWE7TAB/20250325/us-west-2/bedrock/aws4_request, + SignedHeaders=host;x-amz-content-sha256;x-amz-date;x-amz-security-token, Signature=e4a35761abf5be047cdd3c2b4383e1f3b30031acb59a6254960f1ef94b1a939a + Content-Type: + - application/json + Accept: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + response: + status: + code: 200 + message: OK + headers: + Date: + - Tue, 25 Mar 2025 17:14:59 GMT + Content-Type: + - application/json + Content-Length: + - '45249' + Connection: + - keep-alive + X-Amzn-Requestid: + - '08c81519-bf5d-4c0f-8dad-e1fe0e12c7fa' + body: + encoding: UTF-8 + string: '{"modelSummaries":[{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-tg1-large","modelId":"amazon.titan-tg1-large","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text Large","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-g1-text-02","modelId":"amazon.titan-embed-g1-text-02","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text Embeddings v2","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING","CONTINUED_PRE_TRAINING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-lite-v1:0:4k","modelId":"amazon.titan-text-lite-v1:0:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-lite-v1","modelId":"amazon.titan-text-lite-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","CONTINUED_PRE_TRAINING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-express-v1:0:8k","modelId":"amazon.titan-text-express-v1:0:8k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Express","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-express-v1","modelId":"amazon.titan-text-express-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Express","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE","VIDEO"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.nova-pro-v1:0","modelId":"amazon.nova-pro-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova + Pro","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE","VIDEO"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.nova-lite-v1:0","modelId":"amazon.nova-lite-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova + Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.nova-micro-v1:0","modelId":"amazon.nova-micro-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova + Micro","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-text-v1:2:8k","modelId":"amazon.titan-embed-text-v1:2:8k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Embeddings G1 - Text","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-text-v1","modelId":"amazon.titan-embed-text-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Embeddings G1 - Text","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-text-v2:0","modelId":"amazon.titan-embed-text-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text Embeddings V2","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-image-v1:0","modelId":"amazon.titan-embed-image-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Multimodal Embeddings G1","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-image-v1","modelId":"amazon.titan-embed-image-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Multimodal Embeddings G1","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-image-generator-v1:0","modelId":"amazon.titan-image-generator-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Image Generator G1","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-image-generator-v1","modelId":"amazon.titan-image-generator-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Image Generator G1","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED","ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-image-generator-v2:0","modelId":"amazon.titan-image-generator-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Image Generator G1 v2","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.rerank-v1:0","modelId":"amazon.rerank-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Rerank + 1.0","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-diffusion-xl-v1:0","modelId":"stability.stable-diffusion-xl-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"SDXL + 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-diffusion-xl-v1","modelId":"stability.stable-diffusion-xl-v1","modelLifecycle":{"status":"LEGACY"},"modelName":"SDXL + 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.sd3-large-v1:0","modelId":"stability.sd3-large-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"SD3 + Large 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.sd3-5-large-v1:0","modelId":"stability.sd3-5-large-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable + Diffusion 3.5 Large","outputModalities":["IMAGE"],"providerName":"Stability + AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-core-v1:0","modelId":"stability.stable-image-core-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Stable + Image Core 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-core-v1:1","modelId":"stability.stable-image-core-v1:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable + Image Core 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-ultra-v1:0","modelId":"stability.stable-image-ultra-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Stable + Image Ultra 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-ultra-v1:1","modelId":"stability.stable-image-ultra-v1:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable + Image Ultra 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:18k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:18k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:51k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:51k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:200k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-7-sonnet-20250219-v1:0","modelId":"anthropic.claude-3-7-sonnet-20250219-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.7 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-haiku-20241022-v1:0","modelId":"anthropic.claude-3-5-haiku-20241022-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-instant-v1:2:100k","modelId":"anthropic.claude-instant-v1:2:100k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + Instant","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-instant-v1","modelId":"anthropic.claude-instant-v1","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + Instant","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:0:18k","modelId":"anthropic.claude-v2:0:18k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:0:100k","modelId":"anthropic.claude-v2:0:100k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:1:18k","modelId":"anthropic.claude-v2:1:18k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:1:200k","modelId":"anthropic.claude-v2:1:200k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:1","modelId":"anthropic.claude-v2:1","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2","modelId":"anthropic.claude-v2","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0:28k","modelId":"anthropic.claude-3-sonnet-20240229-v1:0:28k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0:200k","modelId":"anthropic.claude-3-sonnet-20240229-v1:0:200k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0","modelId":"anthropic.claude-3-sonnet-20240229-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-haiku-20240307-v1:0:48k","modelId":"anthropic.claude-3-haiku-20240307-v1:0:48k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-haiku-20240307-v1:0:200k","modelId":"anthropic.claude-3-haiku-20240307-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-haiku-20240307-v1:0","modelId":"anthropic.claude-3-haiku-20240307-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0:12k","modelId":"anthropic.claude-3-opus-20240229-v1:0:12k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0:28k","modelId":"anthropic.claude-3-opus-20240229-v1:0:28k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0:200k","modelId":"anthropic.claude-3-opus-20240229-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0","modelId":"anthropic.claude-3-opus-20240229-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:18k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:18k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:51k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:51k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:200k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND","INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-text-v14:7:4k","modelId":"cohere.command-text-v14:7:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-text-v14","modelId":"cohere.command-text-v14","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-r-v1:0","modelId":"cohere.command-r-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + R","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-r-plus-v1:0","modelId":"cohere.command-r-plus-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + R+","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-light-text-v14:7:4k","modelId":"cohere.command-light-text-v14:7:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + Light","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-light-text-v14","modelId":"cohere.command-light-text-v14","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + Light","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-english-v3:0:512","modelId":"cohere.embed-english-v3:0:512","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + English","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-english-v3","modelId":"cohere.embed-english-v3","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + English","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-multilingual-v3:0:512","modelId":"cohere.embed-multilingual-v3:0:512","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + Multilingual","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-multilingual-v3","modelId":"cohere.embed-multilingual-v3","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + Multilingual","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.rerank-v3-5:0","modelId":"cohere.rerank-v3-5:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Rerank + 3.5","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/deepseek.r1-v1:0","modelId":"deepseek.r1-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"DeepSeek-R1","outputModalities":["TEXT"],"providerName":"DeepSeek","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-8b-instruct-v1:0","modelId":"meta.llama3-8b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-70b-instruct-v1:0","modelId":"meta.llama3-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-8b-instruct-v1:0:128k","modelId":"meta.llama3-1-8b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-8b-instruct-v1:0","modelId":"meta.llama3-1-8b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-70b-instruct-v1:0:128k","modelId":"meta.llama3-1-70b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-70b-instruct-v1:0","modelId":"meta.llama3-1-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-405b-instruct-v1:0","modelId":"meta.llama3-1-405b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 405B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-11b-instruct-v1:0:128k","modelId":"meta.llama3-2-11b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 11B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-11b-instruct-v1:0","modelId":"meta.llama3-2-11b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 11B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-90b-instruct-v1:0:128k","modelId":"meta.llama3-2-90b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 90B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-90b-instruct-v1:0","modelId":"meta.llama3-2-90b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 90B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-1b-instruct-v1:0:128k","modelId":"meta.llama3-2-1b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 1B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-1b-instruct-v1:0","modelId":"meta.llama3-2-1b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 1B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-3b-instruct-v1:0:128k","modelId":"meta.llama3-2-3b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 3B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-3b-instruct-v1:0","modelId":"meta.llama3-2-3b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 3B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-3-70b-instruct-v1:0","modelId":"meta.llama3-3-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.3 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mistral-7b-instruct-v0:2","modelId":"mistral.mistral-7b-instruct-v0:2","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral + 7B Instruct","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mixtral-8x7b-instruct-v0:1","modelId":"mistral.mixtral-8x7b-instruct-v0:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mixtral + 8x7B Instruct","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mistral-large-2402-v1:0","modelId":"mistral.mistral-large-2402-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral + Large (24.02)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mistral-large-2407-v1:0","modelId":"mistral.mistral-large-2407-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral + Large (24.07)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/luma.ray-v2:0","modelId":"luma.ray-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Ray + v2","outputModalities":["VIDEO"],"providerName":"Luma AI","responseStreamingSupported":false}]}' + recorded_at: Tue, 25 Mar 2025 17:15:40 GMT recorded_with: VCR 6.3.1 From 7b4406f2c0d0dab1aed5a9973b5190ccfa0c3d31 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Fri, 11 Apr 2025 17:23:31 -0300 Subject: [PATCH 43/55] Revert "Use low temperature when tools are involved" In retrospect, this is too automagic and ultimately not needed at the library level. This reverts commit e810a7ab1d878fa48b7baac97ccadd40946a6942. --- lib/ruby_llm/chat.rb | 4 +--- lib/ruby_llm/providers/ollama/chat.rb | 5 ----- 2 files changed, 1 insertion(+), 8 deletions(-) diff --git a/lib/ruby_llm/chat.rb b/lib/ruby_llm/chat.rb index f1f6ba06..a854bb82 100644 --- a/lib/ruby_llm/chat.rb +++ b/lib/ruby_llm/chat.rb @@ -11,14 +11,12 @@ module RubyLLM class Chat include Enumerable - DEFAULT_TEMPERATURE = 0.7 - attr_reader :model, :messages, :tools def initialize(model: nil, provider: nil) model_id = model || RubyLLM.config.default_model with_model(model_id, provider: provider) - @temperature = DEFAULT_TEMPERATURE + @temperature = 0.7 @messages = [] @tools = {} @on = { diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index 69a917e8..2d3130a0 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -12,11 +12,6 @@ def completion_url end def render_payload(messages, tools:, temperature:, model:, stream: false) - # Heuristic: if temperature is set to default and tools are in play, - # use a low temperature to reduce risk of small models ignoring available - # tools in favor of making up imaginary API calls - temperature = 0.1 if tools.any? && temperature == RubyLLM::Chat::DEFAULT_TEMPERATURE - { model: model, messages: Media.format_messages(messages), From a7b40af36862b5ac8d01d15c854b2dd0640c841f Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Fri, 11 Apr 2025 18:14:07 -0300 Subject: [PATCH 44/55] Configure Ollama from env var when needed --- bin/console | 1 + lib/tasks/model_updater.rb | 1 + 2 files changed, 2 insertions(+) diff --git a/bin/console b/bin/console index b5e87168..e97e6eb9 100755 --- a/bin/console +++ b/bin/console @@ -16,6 +16,7 @@ RubyLLM.configure do |config| config.bedrock_secret_key = ENV.fetch('AWS_SECRET_ACCESS_KEY', nil) config.bedrock_region = ENV.fetch('AWS_REGION', nil) config.bedrock_session_token = ENV.fetch('AWS_SESSION_TOKEN', nil) + config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL', nil) end IRB.start(__FILE__) diff --git a/lib/tasks/model_updater.rb b/lib/tasks/model_updater.rb index 7685a219..95daf453 100644 --- a/lib/tasks/model_updater.rb +++ b/lib/tasks/model_updater.rb @@ -19,6 +19,7 @@ def configure_from_env config.anthropic_api_key = ENV.fetch('ANTHROPIC_API_KEY', nil) config.gemini_api_key = ENV.fetch('GEMINI_API_KEY', nil) config.deepseek_api_key = ENV.fetch('DEEPSEEK_API_KEY', nil) + config.ollama_api_base_url = ENV.fetch('OLLAMA_API_BASE_URL', nil) configure_bedrock(config) config.request_timeout = 30 end From b22460b2b67fd3e14ac91bc5efd68b57e7207b54 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Fri, 11 Apr 2025 17:16:13 -0300 Subject: [PATCH 45/55] Update ollama related cassetes --- ...e_multi-turn_conversations_with_ollama.yml | 106 ----------- ...8b_can_handle_multi-turn_conversations.yml | 104 +++++++++++ ...a3_1_8b_can_have_a_basic_conversation.yml} | 8 +- ...ious_system_messages_when_replace_true.yml | 127 ++++++++++++++ ...8b_successfully_uses_the_system_prompt.yml | 52 ++++++ ...e_tools_without_parameters_with_ollama.yml | 87 ---------- ...ling_ollama_llama3_1_8b_can_use_tools.yml} | 18 +- ...use_tools_in_multi-turn_conversations.yml} | 50 +++--- ...th_multi-turn_streaming_conversations.yml} | 52 +++--- ..._1_8b_can_use_tools_without_parameters.yml | 83 +++++++++ ..._in_multi-turn_streaming_conversations.yml | 164 ++++++++++++++++++ ...pports_streaming_responses_with_ollama.yml | 49 ------ ...ama3_1_8b_supports_streaming_responses.yml | 49 ++++++ ...te3_2-vision_2b_can_understand_images.yml} | 21 +-- ...ic-embed_22m_can_handle_a_single_text.yml} | 6 +- ...c-embed_22m_can_handle_multiple_texts.yml} | 6 +- 16 files changed, 659 insertions(+), 323 deletions(-) delete mode 100644 spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations_with_ollama.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_handle_multi-turn_conversations.yml rename spec/fixtures/vcr_cassettes/{chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation_with_ollama.yml => chat_basic_chat_functionality_ollama_llama3_1_8b_can_have_a_basic_conversation.yml} (69%) create mode 100644 spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_replaces_previous_system_messages_when_replace_true.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_successfully_uses_the_system_prompt.yml delete mode 100644 spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters_with_ollama.yml rename spec/fixtures/vcr_cassettes/{chat_function_calling_llama3_1_8b_can_use_tools_with_ollama.yml => chat_function_calling_ollama_llama3_1_8b_can_use_tools.yml} (70%) rename spec/fixtures/vcr_cassettes/{chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations_with_ollama.yml => chat_function_calling_ollama_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml} (63%) rename spec/fixtures/vcr_cassettes/{chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations_with_ollama.yml => chat_function_calling_ollama_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml} (59%) create mode 100644 spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters_in_multi-turn_streaming_conversations.yml delete mode 100644 spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses_with_ollama.yml create mode 100644 spec/fixtures/vcr_cassettes/chat_streaming_responses_ollama_llama3_1_8b_supports_streaming_responses.yml rename spec/fixtures/vcr_cassettes/{chat_vision_models_granite3_2-vision_2b_can_understand_images.yml => chat_vision_models_ollama_granite3_2-vision_2b_can_understand_images.yml} (97%) rename spec/fixtures/vcr_cassettes/{embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_a_single_text.yml => embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_a_single_text.yml} (97%) rename spec/fixtures/vcr_cassettes/{embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml => embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml} (98%) diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations_with_ollama.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations_with_ollama.yml deleted file mode 100644 index 97645abd..00000000 --- a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_handle_multi-turn_conversations_with_ollama.yml +++ /dev/null @@ -1,106 +0,0 @@ ---- -http_interactions: -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Who was - the creator of Ruby?"}],"options":{"temperature":0.7},"stream":false}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/json; charset=utf-8 - Date: - - Wed, 02 Apr 2025 00:44:07 GMT - Server: - - Caddy - Vary: - - Accept-Encoding - Content-Length: - - '1334' - body: - encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:07.063167441Z","message":{"role":"assistant","content":"The - creator of the Ruby programming language is Yukihiro \"Matz\" Matsumoto. He - is a Japanese computer programmer and is often referred to as the \"Benevolent - Dictator for Life\" (BDFL) of the Ruby project.\n\nMatsumoto was born in 1961 - in Kyoto, Japan. He started programming at the age of six and became interested - in computers at an early age. In the late 1980s, he worked on several projects, - including a version of the Emacs text editor for MS-DOS.\n\nIn 1993, Matsumoto - began working on Ruby as a scripting language for Unix-like operating systems. - He was influenced by languages such as Perl, Smalltalk, and Ada, and wanted - to create a language that was easy to learn, fun to use, and had a strong - focus on object-oriented programming.\n\nRuby was first released in 1995, - and it quickly gained popularity due to its simplicity, flexibility, and ease - of use. Matsumoto continues to be involved with the Ruby project to this day, - and is widely recognized as one of the most influential figures in the world - of programming languages."},"done_reason":"stop","done":true,"total_duration":2242629806,"load_duration":14953975,"prompt_eval_count":17,"prompt_eval_duration":3947091,"eval_count":233,"eval_duration":2223358525}' - recorded_at: Wed, 02 Apr 2025 00:43:58 GMT -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Who was - the creator of Ruby?"},{"role":"assistant","content":"The creator of the Ruby - programming language is Yukihiro \"Matz\" Matsumoto. He is a Japanese computer - programmer and is often referred to as the \"Benevolent Dictator for Life\" - (BDFL) of the Ruby project.\n\nMatsumoto was born in 1961 in Kyoto, Japan. - He started programming at the age of six and became interested in computers - at an early age. In the late 1980s, he worked on several projects, including - a version of the Emacs text editor for MS-DOS.\n\nIn 1993, Matsumoto began - working on Ruby as a scripting language for Unix-like operating systems. He - was influenced by languages such as Perl, Smalltalk, and Ada, and wanted to - create a language that was easy to learn, fun to use, and had a strong focus - on object-oriented programming.\n\nRuby was first released in 1995, and it - quickly gained popularity due to its simplicity, flexibility, and ease of - use. Matsumoto continues to be involved with the Ruby project to this day, - and is widely recognized as one of the most influential figures in the world - of programming languages."},{"role":"user","content":"What year did he create - Ruby?"}],"options":{"temperature":0.7},"stream":false}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/json; charset=utf-8 - Date: - - Wed, 02 Apr 2025 00:44:07 GMT - Server: - - Caddy - Vary: - - Accept-Encoding - Content-Length: - - '537' - body: - encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:07.717871079Z","message":{"role":"assistant","content":"Yukihiro - \"Matz\" Matsumoto started working on Ruby in 1993, but it was first released - publicly on December 21, 1995. So, while the idea and development of Ruby - began in 1993, the language itself was officially released to the public in - 1995."},"done_reason":"stop","done":true,"total_duration":649227133,"load_duration":16363391,"prompt_eval_count":266,"prompt_eval_duration":4060912,"eval_count":64,"eval_duration":628004959}' - recorded_at: Wed, 02 Apr 2025 00:43:59 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_handle_multi-turn_conversations.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_handle_multi-turn_conversations.yml new file mode 100644 index 00000000..dd5b93b4 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_handle_multi-turn_conversations.yml @@ -0,0 +1,104 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Who was + the creator of Ruby?"}],"options":{"temperature":0.7},"stream":false}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Fri, 11 Apr 2025 20:25:22 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '1253' + body: + encoding: ASCII-8BIT + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:22.619412823Z","message":{"role":"assistant","content":"The + creator of the Ruby programming language is Yukihiro Matsumoto, a Japanese + computer programmer. He began working on Ruby in 1993 and released the first + version, Ruby 1.0, in December 1995.\n\nMatsumoto, who is also known as \"Matz,\" + was born in 1960 in Nagoya, Japan. He studied computer science at Nagoya University + and later worked for several companies in Japan before starting his work on + Ruby.\n\nMatsumoto''s goal with Ruby was to create a language that combined + the features of Perl, Smalltalk, and Ada, which he considered the best aspects + of each language. He wanted to create a language that was easy to use, flexible, + and could be used for rapid development and prototyping.\n\nToday, Ruby is + widely used in web development, scripting, and other areas, thanks to its + simplicity, flexibility, and powerful libraries such as Rails. Matsumoto continues + to contribute to the Ruby community and is still involved with the language''s + development."},"done_reason":"stop","done":true,"total_duration":2083117838,"load_duration":15975913,"prompt_eval_count":17,"prompt_eval_duration":25655133,"eval_count":206,"eval_duration":2041201259}' + recorded_at: Fri, 11 Apr 2025 20:25:19 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Who was + the creator of Ruby?"},{"role":"assistant","content":"The creator of the Ruby + programming language is Yukihiro Matsumoto, a Japanese computer programmer. + He began working on Ruby in 1993 and released the first version, Ruby 1.0, + in December 1995.\n\nMatsumoto, who is also known as \"Matz,\" was born in + 1960 in Nagoya, Japan. He studied computer science at Nagoya University and + later worked for several companies in Japan before starting his work on Ruby.\n\nMatsumoto''s + goal with Ruby was to create a language that combined the features of Perl, + Smalltalk, and Ada, which he considered the best aspects of each language. + He wanted to create a language that was easy to use, flexible, and could be + used for rapid development and prototyping.\n\nToday, Ruby is widely used + in web development, scripting, and other areas, thanks to its simplicity, + flexibility, and powerful libraries such as Rails. Matsumoto continues to + contribute to the Ruby community and is still involved with the language''s + development."},{"role":"user","content":"What year did he create Ruby?"}],"options":{"temperature":0.7},"stream":false}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Fri, 11 Apr 2025 20:25:23 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '697' + body: + encoding: ASCII-8BIT + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:23.592467715Z","message":{"role":"assistant","content":"Yukihiro + Matsumoto started working on Ruby in 1993, but it was first released in 1995 + under the name \"Ruby\" (although initially called \"Pearl\" before being + changed to avoid a trademark conflict with the company Gemstone Systems).\n\nHowever, + if you''re asking when he began conceptualizing and designing Ruby, that would + be around 1992-1993.\n\nThe first public release of Ruby was in December 1995."},"done_reason":"stop","done":true,"total_duration":969542955,"load_duration":14935414,"prompt_eval_count":239,"prompt_eval_duration":4486434,"eval_count":93,"eval_duration":949351502}' + recorded_at: Fri, 11 Apr 2025 20:25:20 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation_with_ollama.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_have_a_basic_conversation.yml similarity index 69% rename from spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation_with_ollama.yml rename to spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_have_a_basic_conversation.yml index 8d5c2821..a0c6f0ec 100644 --- a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_llama3_1_8b_can_have_a_basic_conversation_with_ollama.yml +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_have_a_basic_conversation.yml @@ -26,12 +26,12 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Wed, 02 Apr 2025 00:44:04 GMT + - Fri, 11 Apr 2025 20:24:03 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:04.815124255Z","message":{"role":"assistant","content":"The - answer is: 4!"},"done_reason":"stop","done":true,"total_duration":123712849,"load_duration":19150499,"prompt_eval_count":18,"prompt_eval_duration":25924381,"eval_count":8,"eval_duration":78214407}' - recorded_at: Wed, 02 Apr 2025 00:43:56 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:24:03.848130137Z","message":{"role":"assistant","content":"The + answer is: 4!"},"done_reason":"stop","done":true,"total_duration":132852925,"load_duration":18835949,"prompt_eval_count":18,"prompt_eval_duration":31501211,"eval_count":8,"eval_duration":82031197}' + recorded_at: Fri, 11 Apr 2025 20:24:00 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_replaces_previous_system_messages_when_replace_true.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_replaces_previous_system_messages_when_replace_true.yml new file mode 100644 index 00000000..1b7aea84 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_replaces_previous_system_messages_when_replace_true.yml @@ -0,0 +1,127 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"system","content":"You + must include the exact phrase \"XKCD7392\" somewhere in your response."},{"role":"user","content":"Tell + me about the weather."}],"options":{"temperature":0.0},"stream":false}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Fri, 11 Apr 2025 20:24:10 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '1169' + body: + encoding: ASCII-8BIT + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:24:10.088054586Z","message":{"role":"assistant","content":"The + weather! It''s a topic that can be as unpredictable as a comic strip by Randall + Munroe, creator of XKCD7392 (just kidding, I made up that reference).\n\nBut + seriously, the weather is a complex and dynamic system that can vary greatly + depending on your location and time of year. From scorching heatwaves to torrential + downpours, it''s always something.\n\nCurrently, I don''t have real-time access + to specific weather conditions in your area. However, I can suggest some ways + for you to find out the current weather forecast:\n\n1. Check online weather + websites or apps like AccuWeather, Weather.com, or Dark Sky.\n2. Tune into + local news or weather reports on TV or radio.\n3. Use a voice assistant like + Siri, Google Assistant, or Alexa to get the latest weather updates.\n\nRemember + to always check the forecast before heading out, especially if you have outdoor + plans!"},"done_reason":"stop","done":true,"total_duration":1855020675,"load_duration":14571739,"prompt_eval_count":39,"prompt_eval_duration":2653810,"eval_count":186,"eval_duration":1837339473}' + recorded_at: Fri, 11 Apr 2025 20:24:06 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Tell me + about the weather."},{"role":"assistant","content":"The weather! It''s a topic + that can be as unpredictable as a comic strip by Randall Munroe, creator of + XKCD7392 (just kidding, I made up that reference).\n\nBut seriously, the weather + is a complex and dynamic system that can vary greatly depending on your location + and time of year. From scorching heatwaves to torrential downpours, it''s + always something.\n\nCurrently, I don''t have real-time access to specific + weather conditions in your area. However, I can suggest some ways for you + to find out the current weather forecast:\n\n1. Check online weather websites + or apps like AccuWeather, Weather.com, or Dark Sky.\n2. Tune into local news + or weather reports on TV or radio.\n3. Use a voice assistant like Siri, Google + Assistant, or Alexa to get the latest weather updates.\n\nRemember to always + check the forecast before heading out, especially if you have outdoor plans!"},{"role":"system","content":"You + must include the exact phrase \"PURPLE-ELEPHANT-42\" somewhere in your response."},{"role":"user","content":"What + are some good books?"}],"options":{"temperature":0.0},"stream":false}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Fri, 11 Apr 2025 20:24:15 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Transfer-Encoding: + - chunked + body: + encoding: ASCII-8BIT + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.144612445Z","message":{"role":"assistant","content":"There + are so many great books out there, it''s hard to narrow it down. But I''ll + give you a few recommendations across various genres:\n\n**Fiction**\n\n1. + \"The Hitchhiker''s Guide to the Galaxy\" by Douglas Adams - A comedic science + fiction series that''s out of this world (pun intended).\n2. \"1984\" by George + Orwell - A classic dystopian novel that''s eerily relevant today.\n3. \"The + Night Circus\" by Erin Morgenstern - A magical and imaginative tale about + love, magic, and mystery.\n\n**Non-Fiction**\n\n1. \"Sapiens: A Brief History + of Humankind\" by Yuval Noah Harari - A sweeping narrative that covers the + entire history of our species.\n2. \"The Immortal Life of Henrietta Lacks\" + by Rebecca Skloot - A fascinating story about science, ethics, and humanity.\n3. + \"A Short History of Nearly Everything\" by Bill Bryson - A comprehensive + and engaging overview of various scientific disciplines.\n\n**Science Fiction**\n\n1. + \"Dune\" by Frank Herbert - A classic epic that explores politics, ecology, + and human nature in a far-off desert planet.\n2. \"The Three-Body Problem\" + by Liu Cixin - A thought-provoking novel that explores the first contact between + humans and an alien civilization.\n3. \"Ready Player One\" by Ernest Cline + - A fun and nostalgic romp through 80s pop culture.\n\n**Mystery/Thriller**\n\n1. + \"Gone Girl\" by Gillian Flynn - A twisty and suspenseful tale about marriage, + deception, and the unreliability of appearances.\n2. \"The Silence of the + Lambs\" by Thomas Harris - A chilling and intelligent thriller that pits a + young FBI agent against a brilliant and terrifying serial killer.\n3. \"The + Girl with the Dragon Tattoo\" by Stieg Larsson - A gritty and atmospheric + mystery that explores corruption, power, and family secrets.\n\nOf course, + these are just a few examples, and there are countless other amazing books + out there. But if you''re looking for something to get started, I hope this + helps!\n\nAnd remember, when it comes to reading, the possibilities are as + vast as the number of stars in the universe... or at least, that''s what I''d + like to think, but let''s be real, it''s probably more like PURPLE-ELEPHANT-42."},"done_reason":"stop","done":true,"total_duration":5052746637,"load_duration":14525916,"prompt_eval_count":243,"prompt_eval_duration":15682393,"eval_count":493,"eval_duration":5021731638}' + recorded_at: Fri, 11 Apr 2025 20:24:12 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_successfully_uses_the_system_prompt.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_successfully_uses_the_system_prompt.yml new file mode 100644 index 00000000..78a04b8a --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_successfully_uses_the_system_prompt.yml @@ -0,0 +1,52 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"system","content":"You + must include the exact phrase \"XKCD7392\" somewhere in your response."},{"role":"user","content":"Tell + me about the weather."}],"options":{"temperature":0.0},"stream":false}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Fri, 11 Apr 2025 20:24:08 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '1281' + body: + encoding: ASCII-8BIT + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:24:08.228024187Z","message":{"role":"assistant","content":"The + weather! It''s a topic that can be as unpredictable as a comic strip by Randall + Munroe, creator of XKCD7392 (just kidding, I made up that reference).\n\nBut + seriously, the weather is a complex and dynamic system that can vary greatly + depending on your location and time of year. From scorching heatwaves to torrential + downpours, it''s always something.\n\nCurrently, I''m a large language model, + I don''t have real-time access to current weather conditions. However, I can + suggest some ways for you to find out the latest forecast in your area:\n\n1. + Check online weather websites such as AccuWeather or Weather.com.\n2. Use + a mobile app like Dark Sky or The Weather Channel.\n3. Tune into local news + broadcasts or radio stations.\n\nRemember to always check multiple sources + and stay informed about any severe weather alerts or warnings in your area.\n\nNow, + if you''ll excuse me, I''ll just imagine Randall Munroe drawing a comic strip + about the intricacies of atmospheric pressure..."},"done_reason":"stop","done":true,"total_duration":2067130923,"load_duration":14476194,"prompt_eval_count":39,"prompt_eval_duration":4965316,"eval_count":207,"eval_duration":2047250270}' + recorded_at: Fri, 11 Apr 2025 20:24:05 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters_with_ollama.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters_with_ollama.yml deleted file mode 100644 index 94dbbbde..00000000 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_without_parameters_with_ollama.yml +++ /dev/null @@ -1,87 +0,0 @@ ---- -http_interactions: -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the best language to learn?"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets - the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Length: - - '372' - Content-Type: - - application/json; charset=utf-8 - Date: - - Wed, 02 Apr 2025 00:44:56 GMT - Server: - - Caddy - body: - encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:56.484008223Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done_reason":"stop","done":true,"total_duration":187125431,"load_duration":16763705,"prompt_eval_count":155,"prompt_eval_duration":8191628,"eval_count":15,"eval_duration":161762904}' - recorded_at: Wed, 02 Apr 2025 00:44:48 GMT -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets - the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/json; charset=utf-8 - Date: - - Wed, 02 Apr 2025 00:44:58 GMT - Server: - - Caddy - Vary: - - Accept-Encoding - Content-Length: - - '1365' - body: - encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:58.547429762Z","message":{"role":"assistant","content":"The - best language to learn is often subjective and depends on personal goals, - interests, and career aspirations. However, based on various sources and industry - trends, Ruby is a popular choice among developers due to its simplicity, readability, - and versatility.\n\nHere are some reasons why Ruby stands out:\n\n1. **Easy - to Learn**: Ruby has a clean syntax and is relatively easy to learn for beginners.\n2. **Versatile**: - Ruby can be used for web development (with frameworks like Ruby on Rails), - scripting, testing, and even system administration.\n3. **Large Community**: - Ruby has an active community with many resources available online, including - documentation, tutorials, and forums.\n4. **Job Prospects**: Knowledge of - Ruby is in demand, especially in the field of web development.\n\nUltimately, - the best language to learn depends on your specific needs and goals. If you''re - interested in web development, Python or JavaScript might be a better fit. - However, if you want a language that''s easy to learn and versatile, Ruby - is definitely worth considering."},"done_reason":"stop","done":true,"total_duration":2060128193,"load_duration":14761969,"prompt_eval_count":77,"prompt_eval_duration":4504575,"eval_count":212,"eval_duration":2040277638}' - recorded_at: Wed, 02 Apr 2025 00:44:50 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_ollama.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools.yml similarity index 70% rename from spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_ollama.yml rename to spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools.yml index a3a91b5a..715c20e7 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_ollama.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools.yml @@ -6,7 +6,7 @@ http_interactions: body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -29,13 +29,13 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Wed, 02 Apr 2025 00:44:54 GMT + - Fri, 11 Apr 2025 20:25:56 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:54.741999837Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":345595895,"load_duration":15252457,"prompt_eval_count":205,"prompt_eval_duration":35001065,"eval_count":28,"eval_duration":295009892}' - recorded_at: Wed, 02 Apr 2025 00:44:46 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:56.847264344Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":381909743,"load_duration":15162341,"prompt_eval_count":205,"prompt_eval_duration":41158913,"eval_count":28,"eval_duration":325264197}' + recorded_at: Fri, 11 Apr 2025 20:25:53 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -43,7 +43,7 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -62,16 +62,16 @@ http_interactions: message: OK headers: Content-Length: - - '412' + - '405' Content-Type: - application/json; charset=utf-8 Date: - - Wed, 02 Apr 2025 00:44:55 GMT + - Fri, 11 Apr 2025 20:25:57 GMT Server: - Caddy body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMDJUMDA6NDQ6NTUuMDM3OTY4MDk0WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5MTg5NTM3NCwibG9hZF9kdXJhdGlvbiI6MTQ5MzM4NjksInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1ODk1NzIzLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6MjcwNDU2NjA5fQ== - recorded_at: Wed, 02 Apr 2025 00:44:46 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTFUMjA6MjU6NTcuMTMxODQ4MDU0WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlZCB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyB3aXRoIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6MjgxMjA1MTY3LCJsb2FkX2R1cmF0aW9uIjoxNDkxODI4MSwicHJvbXB0X2V2YWxfY291bnQiOjExMiwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjY1OTczMDYsImV2YWxfY291bnQiOjI2LCJldmFsX2R1cmF0aW9uIjoyNTkxMTMwMTR9 + recorded_at: Fri, 11 Apr 2025 20:25:53 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations_with_ollama.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml similarity index 63% rename from spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations_with_ollama.yml rename to spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml index 191d3769..c59971ae 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_in_multi-turn_conversations_with_ollama.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml @@ -6,7 +6,7 @@ http_interactions: body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -29,13 +29,13 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Wed, 02 Apr 2025 00:44:55 GMT + - Fri, 11 Apr 2025 20:25:24 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:55.362545781Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":318881239,"load_duration":14740837,"prompt_eval_count":205,"prompt_eval_duration":10492700,"eval_count":28,"eval_duration":293241996}' - recorded_at: Wed, 02 Apr 2025 00:44:46 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:24.527590336Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":329015521,"load_duration":15026522,"prompt_eval_count":205,"prompt_eval_duration":10145164,"eval_count":28,"eval_duration":303403570}' + recorded_at: Fri, 11 Apr 2025 20:25:21 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -43,7 +43,7 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -62,18 +62,18 @@ http_interactions: message: OK headers: Content-Length: - - '412' + - '401' Content-Type: - application/json; charset=utf-8 Date: - - Wed, 02 Apr 2025 00:44:55 GMT + - Fri, 11 Apr 2025 20:25:24 GMT Server: - Caddy body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMDJUMDA6NDQ6NTUuNjU4NjQ0Njc2WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5MjE3ODIzMywibG9hZF9kdXJhdGlvbiI6MTQ3MDQxMzksInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1OTgzNTgwLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6MjcwOTc5NjkwfQ== - recorded_at: Wed, 02 Apr 2025 00:44:47 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTFUMjA6MjU6MjQuODI2MTYxNjA2WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJCYXNlZCBvbiB0aGUgdG9vbCBjYWxsIHJlc3BvbnNlLCB0aGUgY3VycmVudCB0ZW1wZXJhdHVyZSBpbiBCZXJsaW4gaXMgMTXCsEMgYW5kIHRoZSB3aW5kIHNwZWVkIGlzIDEwIGttL2guIn0sImRvbmVfcmVhc29uIjoic3RvcCIsImRvbmUiOnRydWUsInRvdGFsX2R1cmF0aW9uIjoyOTQ3NjU1MDYsImxvYWRfZHVyYXRpb24iOjE2NzE0MTk1LCJwcm9tcHRfZXZhbF9jb3VudCI6MTEyLCJwcm9tcHRfZXZhbF9kdXJhdGlvbiI6NjI2MjgyOSwiZXZhbF9jb3VudCI6MjcsImV2YWxfZHVyYXRpb24iOjI3MTE4OTEwNn0= + recorded_at: Fri, 11 Apr 2025 20:25:21 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -81,10 +81,10 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The - tool call response indicates that the current temperature in Berlin is 15°C - and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s - the weather in Paris? (48.8575, 2.3514)"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"Based + on the tool call response, the current temperature in Berlin is 15°C and the + wind speed is 10 km/h."},{"role":"user","content":"What''s the weather in + Paris? (48.8575, 2.3514)"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -107,13 +107,13 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Wed, 02 Apr 2025 00:44:55 GMT + - Fri, 11 Apr 2025 20:25:25 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-04-02T00:44:55.989004993Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done_reason":"stop","done":true,"total_duration":326895256,"load_duration":14909752,"prompt_eval_count":297,"prompt_eval_duration":11194663,"eval_count":28,"eval_duration":299619023}' - recorded_at: Wed, 02 Apr 2025 00:44:47 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:25.168651652Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done_reason":"stop","done":true,"total_duration":338662575,"load_duration":14553272,"prompt_eval_count":296,"prompt_eval_duration":11999377,"eval_count":28,"eval_duration":311031157}' + recorded_at: Fri, 11 Apr 2025 20:25:22 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -121,11 +121,11 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The - tool call response indicates that the current temperature in Berlin is 15°C - and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s - the weather in Paris? (48.8575, 2.3514)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 48.8575, 2.3514: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"Based + on the tool call response, the current temperature in Berlin is 15°C and the + wind speed is 10 km/h."},{"role":"user","content":"What''s the weather in + Paris? (48.8575, 2.3514)"},{"role":"assistant","content":null},{"role":"tool","content":"Current + weather at 48.8575, 2.3514: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -144,16 +144,16 @@ http_interactions: message: OK headers: Content-Length: - - '411' + - '399' Content-Type: - application/json; charset=utf-8 Date: - - Wed, 02 Apr 2025 00:44:56 GMT + - Fri, 11 Apr 2025 20:25:25 GMT Server: - Caddy body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMDJUMDA6NDQ6NTYuMjkwNTU5NDYxWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGVyZSdzIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6Mjk4MjU0MTAzLCJsb2FkX2R1cmF0aW9uIjoxNDgxNjIyMiwicHJvbXB0X2V2YWxfY291bnQiOjIwNCwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjU4ODg4MjksImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyNzYzODY4MTJ9 - recorded_at: Wed, 02 Apr 2025 00:44:47 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTFUMjA6MjU6MjUuNDY4MDgyMjdaIiwibWVzc2FnZSI6eyJyb2xlIjoiYXNzaXN0YW50IiwiY29udGVudCI6IkJhc2VkIG9uIHRoZSB0b29sIGNhbGwgcmVzcG9uc2UsIHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGUgd2luZCBzcGVlZCBpcyAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6Mjk2MDE3MTQyLCJsb2FkX2R1cmF0aW9uIjoxNDY0NzM5OSwicHJvbXB0X2V2YWxfY291bnQiOjIwMywicHJvbXB0X2V2YWxfZHVyYXRpb24iOjY0MjUxOTYsImV2YWxfY291bnQiOjI3LCJldmFsX2R1cmF0aW9uIjoyNzM2OTY3MzZ9 + recorded_at: Fri, 11 Apr 2025 20:25:22 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations_with_ollama.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml similarity index 59% rename from spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations_with_ollama.yml rename to spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml index c6e7eaf4..6c3721aa 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations_with_ollama.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml @@ -6,7 +6,7 @@ http_interactions: body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -27,7 +27,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Wed, 02 Apr 2025 00:44:58 GMT + - Fri, 11 Apr 2025 20:25:28 GMT Server: - Caddy Transfer-Encoding: @@ -35,9 +35,9 @@ http_interactions: body: encoding: UTF-8 string: | - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:58.864685667Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:58.875226528Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":320697041,"load_duration":16695054,"prompt_eval_count":205,"prompt_eval_duration":10264902,"eval_count":28,"eval_duration":293365741} - recorded_at: Wed, 02 Apr 2025 00:44:50 GMT + {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:28.754929242Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:28.764752046Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":334869516,"load_duration":15995280,"prompt_eval_count":205,"prompt_eval_duration":10124579,"eval_count":28,"eval_duration":308426498} + recorded_at: Fri, 11 Apr 2025 20:25:25 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -45,7 +45,7 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -66,7 +66,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Wed, 02 Apr 2025 00:44:59 GMT + - Fri, 11 Apr 2025 20:25:29 GMT Server: - Caddy Transfer-Encoding: @@ -74,8 +74,8 @@ http_interactions: body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMDJUMDA6NDQ6NTkuMTcyNjA3OTM3WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5MzgwNzI1MSwibG9hZF9kdXJhdGlvbiI6MTU0MjM0MjQsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1OTk4MjQxLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6MjcxNzgwNTg2fQo= - recorded_at: Wed, 02 Apr 2025 00:44:50 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTFUMjA6MjU6MjkuMzQ5ODE4ODUyWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiIgVG9vbCBjYWxsIG91dHB1dCB1c2VkIHRvIGFuc3dlcjogXG4gQ3VycmVudCB3ZWF0aGVyIGF0IEJlcmxpbiAoNTIuNTIwMMKwIE4sIDEzLjQwNTDCsCBFKTogTGlnaHQgQ2xvdWQsIDU5wrBGIC8gMTXCsEMgd2l0aCBhIGdlbnRsZSBicmVlemUgb2YgNiBtcGggKDEwIGttL2gpIGZyb20gdGhlIFNTRS4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjU4MTU1NTg2MSwibG9hZF9kdXJhdGlvbiI6MTQ3NjcxOTgsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo2MDg3NDczLCJldmFsX2NvdW50Ijo1NiwiZXZhbF9kdXJhdGlvbiI6NTYwMDc4OTQ2fQo= + recorded_at: Fri, 11 Apr 2025 20:25:26 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -83,10 +83,11 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The - tool call response indicates that the current temperature in Berlin is 15°C - and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s - the weather in Paris? (48.8575, 2.3514)"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":" + Tool call output used to answer: \n Current weather at Berlin (52.5200° N, + 13.4050° E): Light Cloud, 59°F / 15°C with a gentle breeze of 6 mph (10 km/h) + from the SSE."},{"role":"user","content":"What''s the weather in Paris? (48.8575, + 2.3514)"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -107,7 +108,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Wed, 02 Apr 2025 00:44:59 GMT + - Fri, 11 Apr 2025 20:25:29 GMT Server: - Caddy Transfer-Encoding: @@ -115,9 +116,9 @@ http_interactions: body: encoding: UTF-8 string: | - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:59.489661886Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:59.499416856Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":323629188,"load_duration":14622347,"prompt_eval_count":297,"prompt_eval_duration":11016766,"eval_count":28,"eval_duration":296821849} - recorded_at: Wed, 02 Apr 2025 00:44:51 GMT + {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:29.683144042Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:29.693314795Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":339669240,"load_duration":14602372,"prompt_eval_count":325,"prompt_eval_duration":12643651,"eval_count":28,"eval_duration":311308989} + recorded_at: Fri, 11 Apr 2025 20:25:26 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -125,11 +126,12 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The - tool call response indicates that the current temperature in Berlin is 15°C - and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s - the weather in Paris? (48.8575, 2.3514)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 48.8575, 2.3514: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":" + Tool call output used to answer: \n Current weather at Berlin (52.5200° N, + 13.4050° E): Light Cloud, 59°F / 15°C with a gentle breeze of 6 mph (10 km/h) + from the SSE."},{"role":"user","content":"What''s the weather in Paris? (48.8575, + 2.3514)"},{"role":"assistant","content":null},{"role":"tool","content":"Current + weather at 48.8575, 2.3514: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -150,7 +152,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Wed, 02 Apr 2025 00:44:59 GMT + - Fri, 11 Apr 2025 20:25:30 GMT Server: - Caddy Transfer-Encoding: @@ -158,6 +160,6 @@ http_interactions: body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMDJUMDA6NDQ6NTkuODAwODgzMjEzWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGVyZSdzIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6Mjk4NjkxNDIwLCJsb2FkX2R1cmF0aW9uIjoxNTE3NjgxMCwicHJvbXB0X2V2YWxfY291bnQiOjIwNCwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjYxMDU5ODIsImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyNzYyOTMzMDR9Cg== - recorded_at: Wed, 02 Apr 2025 00:44:51 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTFUMjA6MjU6MzAuMjc3MjM1NjYxWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUb29sIGNhbGwgb3V0cHV0IHVzZWQgdG8gYW5zd2VyOlxuIEN1cnJlbnQgd2VhdGhlciBhdCBQYXJpcyAoNDguODU2N8KwIE4sIDIuMjk0NcKwIEUpOiBMaWdodCBDbG91ZCwgNTnCsEYgLyAxNcKwQyB3aXRoIGEgZ2VudGxlIGJyZWV6ZSBvZiA2IG1waCAoMTAga20vaCkgZnJvbSB0aGUgU1NFLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6NTgwMTc4OTk2LCJsb2FkX2R1cmF0aW9uIjoxNTEzOTk4NSwicHJvbXB0X2V2YWxfY291bnQiOjIzMiwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjY4MjQ0ODQsImV2YWxfY291bnQiOjU1LCJldmFsX2R1cmF0aW9uIjo1NTcxMTA2ODh9Cg== + recorded_at: Fri, 11 Apr 2025 20:25:27 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters.yml new file mode 100644 index 00000000..a4661058 --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters.yml @@ -0,0 +1,83 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the best language to learn?"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Length: + - '371' + Content-Type: + - application/json; charset=utf-8 + Date: + - Fri, 11 Apr 2025 20:25:25 GMT + Server: + - Caddy + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:25.67535401Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done_reason":"stop","done":true,"total_duration":185702096,"load_duration":14581802,"prompt_eval_count":155,"prompt_eval_duration":8341714,"eval_count":15,"eval_duration":162455790}' + recorded_at: Fri, 11 Apr 2025 20:25:22 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Fri, 11 Apr 2025 20:25:27 GMT + Server: + - Caddy + Vary: + - Accept-Encoding + Content-Length: + - '1043' + body: + encoding: ASCII-8BIT + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:27.098095205Z","message":{"role":"assistant","content":"The + output suggests that Ruby is one of the top languages recommended for learning, + but it doesn''t provide an exhaustive list. \n\nHere are some other top programming + languages that are commonly used and in-demand:\n1. Python: Known for its + simplicity, versatility, and large community.\n2. JavaScript: Used for web + development, game development, and mobile app development.\n3. Java: A popular + language for Android app development, web development, and enterprise software + development.\n4. C++: A high-performance language used in systems programming, + game development, and other applications that require direct hardware manipulation.\n\nThe + best language to learn depends on your goals, interests, and the type of projects + you want to work on."},"done_reason":"stop","done":true,"total_duration":1418644485,"load_duration":15145034,"prompt_eval_count":77,"prompt_eval_duration":4868578,"eval_count":142,"eval_duration":1398040040}' + recorded_at: Fri, 11 Apr 2025 20:25:23 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters_in_multi-turn_streaming_conversations.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters_in_multi-turn_streaming_conversations.yml new file mode 100644 index 00000000..7e14a00d --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters_in_multi-turn_streaming_conversations.yml @@ -0,0 +1,164 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the best language to learn?"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Fri, 11 Apr 2025 20:25:27 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: | + {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:27.315789926Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:27.325514651Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":185235270,"load_duration":15163241,"prompt_eval_count":155,"prompt_eval_duration":7878737,"eval_count":15,"eval_duration":161808281} + recorded_at: Fri, 11 Apr 2025 20:25:24 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Fri, 11 Apr 2025 20:25:27 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:27.7992387Z","message":{"role":"assistant","content":"This + was determined by using a tool that analyzed various programming languages + and their uses. The results showed that Ruby is currently one of the most + in-demand and versatile languages, making it an excellent choice for beginners + and experienced developers alike."},"done_reason":"stop","done":true,"total_duration":470215206,"load_duration":14776780,"prompt_eval_count":77,"prompt_eval_duration":4597457,"eval_count":46,"eval_duration":450213396} + + ' + recorded_at: Fri, 11 Apr 2025 20:25:24 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"},{"role":"assistant","content":"This + was determined by using a tool that analyzed various programming languages + and their uses. The results showed that Ruby is currently one of the most + in-demand and versatile languages, making it an excellent choice for beginners + and experienced developers alike."},{"role":"user","content":"Tell me again: + what''s the best language to learn?"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Fri, 11 Apr 2025 20:25:27 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: | + {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:27.986550241Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:27.996688354Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":193925963,"load_duration":14787489,"prompt_eval_count":234,"prompt_eval_duration":8799661,"eval_count":15,"eval_duration":169210924} + recorded_at: Fri, 11 Apr 2025 20:25:24 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s + the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"},{"role":"assistant","content":"This + was determined by using a tool that analyzed various programming languages + and their uses. The results showed that Ruby is currently one of the most + in-demand and versatile languages, making it an excellent choice for beginners + and experienced developers alike."},{"role":"user","content":"Tell me again: + what''s the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Fri, 11 Apr 2025 20:25:28 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:28.38537108Z","message":{"role":"assistant","content":"The + tool analysis still shows that Ruby is a top contender among programming languages + due to its simplicity, flexibility, and wide range of applications, making + it an excellent choice for learning."},"done_reason":"stop","done":true,"total_duration":384856281,"load_duration":14473706,"prompt_eval_count":156,"prompt_eval_duration":5059295,"eval_count":36,"eval_duration":364120261} + + ' + recorded_at: Fri, 11 Apr 2025 20:25:25 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses_with_ollama.yml b/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses_with_ollama.yml deleted file mode 100644 index 148f7293..00000000 --- a/spec/fixtures/vcr_cassettes/chat_streaming_responses_llama3_1_8b_supports_streaming_responses_with_ollama.yml +++ /dev/null @@ -1,49 +0,0 @@ ---- -http_interactions: -- request: - method: post - uri: http://localhost:11434/api/chat - body: - encoding: UTF-8 - string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Count - from 1 to 3"}],"options":{"temperature":0.7},"stream":true}' - headers: - User-Agent: - - Faraday v2.12.2 - Content-Type: - - application/json - Accept-Encoding: - - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 - Accept: - - "*/*" - response: - status: - code: 200 - message: OK - headers: - Content-Type: - - application/x-ndjson - Date: - - Wed, 02 Apr 2025 00:44:09 GMT - Server: - - Caddy - Transfer-Encoding: - - chunked - body: - encoding: UTF-8 - string: | - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.29998922Z","message":{"role":"assistant","content":"Here"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.310551658Z","message":{"role":"assistant","content":" it"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.319358021Z","message":{"role":"assistant","content":" goes"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.328271328Z","message":{"role":"assistant","content":":\n\n"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.337219141Z","message":{"role":"assistant","content":"1"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.346221234Z","message":{"role":"assistant","content":","},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.355314621Z","message":{"role":"assistant","content":" "},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.36441234Z","message":{"role":"assistant","content":"2"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.373598811Z","message":{"role":"assistant","content":","},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.38281648Z","message":{"role":"assistant","content":" "},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.392123995Z","message":{"role":"assistant","content":"3"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.401296079Z","message":{"role":"assistant","content":"!"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-02T00:44:09.410507031Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":144038210,"load_duration":17785003,"prompt_eval_count":17,"prompt_eval_duration":3721943,"eval_count":13,"eval_duration":121874042} - recorded_at: Wed, 02 Apr 2025 00:44:01 GMT -recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_streaming_responses_ollama_llama3_1_8b_supports_streaming_responses.yml b/spec/fixtures/vcr_cassettes/chat_streaming_responses_ollama_llama3_1_8b_supports_streaming_responses.yml new file mode 100644 index 00000000..f7d0d65f --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_streaming_responses_ollama_llama3_1_8b_supports_streaming_responses.yml @@ -0,0 +1,49 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Count + from 1 to 3"}],"options":{"temperature":0.7},"stream":true}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Fri, 11 Apr 2025 20:24:15 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: | + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.193952052Z","message":{"role":"assistant","content":"Here"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.205661714Z","message":{"role":"assistant","content":" it"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.214701178Z","message":{"role":"assistant","content":" goes"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.223829155Z","message":{"role":"assistant","content":":\n\n"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.23287118Z","message":{"role":"assistant","content":"1"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.242017149Z","message":{"role":"assistant","content":","},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.251300012Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.260657388Z","message":{"role":"assistant","content":"2"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.269916027Z","message":{"role":"assistant","content":","},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.279318375Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.288601803Z","message":{"role":"assistant","content":"3"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.297983455Z","message":{"role":"assistant","content":"!"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.307439815Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":144697142,"load_duration":14437554,"prompt_eval_count":17,"prompt_eval_duration":4078794,"eval_count":13,"eval_duration":125760297} + recorded_at: Fri, 11 Apr 2025 20:24:12 GMT +recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml b/spec/fixtures/vcr_cassettes/chat_vision_models_ollama_granite3_2-vision_2b_can_understand_images.yml similarity index 97% rename from spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml rename to spec/fixtures/vcr_cassettes/chat_vision_models_ollama_granite3_2-vision_2b_can_understand_images.yml index 47df3c19..01fcebff 100644 --- a/spec/fixtures/vcr_cassettes/chat_vision_models_granite3_2-vision_2b_can_understand_images.yml +++ b/spec/fixtures/vcr_cassettes/chat_vision_models_ollama_granite3_2-vision_2b_can_understand_images.yml @@ -21,22 +21,19 @@ http_interactions: code: 200 message: OK headers: + Content-Length: + - '484' Content-Type: - application/json; charset=utf-8 Date: - - Wed, 02 Apr 2025 00:44:02 GMT + - Fri, 11 Apr 2025 20:24:03 GMT Server: - Caddy - Vary: - - Accept-Encoding - Content-Length: - - '546' body: - encoding: ASCII-8BIT - string: '{"model":"granite3.2-vision:2b","created_at":"2025-04-02T00:44:02.426116551Z","message":{"role":"assistant","content":"\nI''m - sorry, but I can''t provide a description or answer any question related to - this image as it seems to be an error or placeholder. If you have another - image or if there''s something specific you''d like me to help with, please - let me know!"},"done_reason":"stop","done":true,"total_duration":404422192,"load_duration":8680145,"prompt_eval_count":2242,"prompt_eval_duration":21957042,"eval_count":55,"eval_duration":372859182}' - recorded_at: Wed, 02 Apr 2025 00:43:54 GMT + encoding: UTF-8 + string: '{"model":"granite3.2-vision:2b","created_at":"2025-04-11T20:24:03.122857934Z","message":{"role":"assistant","content":"\nI''m + unable to view or analyze images. My capabilities are limited to text-based + interactions. If you have any questions or need assistance with something + else, feel free to ask!"},"done_reason":"stop","done":true,"total_duration":292340255,"load_duration":9777040,"prompt_eval_count":2242,"prompt_eval_duration":23093714,"eval_count":38,"eval_duration":258539543}' + recorded_at: Fri, 11 Apr 2025 20:23:59 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_a_single_text.yml b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_a_single_text.yml similarity index 97% rename from spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_a_single_text.yml rename to spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_a_single_text.yml index 8256b717..c180c360 100644 --- a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_a_single_text.yml +++ b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_a_single_text.yml @@ -24,7 +24,7 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Wed, 02 Apr 2025 00:44:15 GMT + - Fri, 11 Apr 2025 20:24:21 GMT Server: - Caddy Vary: @@ -33,6 +33,6 @@ http_interactions: - chunked body: encoding: ASCII-8BIT - string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.025825415,-0.023176115,-0.052045297,-0.023625664,0.0006673469,0.009949714,-0.04538417,-0.06849524,-0.019409077,0.0010184002,-0.054927465,0.04728714,0.032690506,0.030963264,-0.028091758,-0.05092271,0.00021566867,0.023615433,-0.12640688,0.015840458,0.012315658,0.087370574,0.011073331,0.0090212375,0.007156342,-0.0052327104,0.021913407,-0.020346882,-0.03459649,-0.20068292,0.021031896,0.07291515,0.031049531,-0.04963502,0.023327535,-0.06476457,0.0131773045,0.004342761,-0.05204616,-0.03947274,0.0122103775,0.003776148,-0.050048206,-0.017586641,-0.029104842,-0.016230974,0.021660762,-0.017151477,0.0865443,0.01920734,-0.042871486,-0.0089291595,-0.02822964,-0.04884569,-0.018680912,-0.01892585,0.015438859,0.0065737013,-0.021804608,0.00633415,0.0343607,0.0017093703,-0.34944108,-0.06468269,0.0478818,-0.00246448,0.046574403,0.02243261,-0.024708489,-0.016602987,-0.011909359,0.014165576,-0.07424154,-0.03776865,0.032787047,-0.05530688,0.013535443,0.042380534,0.038827997,-0.033742167,0.015697544,0.009775907,0.0042203693,0.0011168025,0.023423292,0.04484947,-0.043061797,-0.05383481,-0.028867329,-0.0033860689,0.018773982,-0.018347567,0.03903167,-0.029658085,-0.06440208,0.040508885,-0.0017985007,0.049720276,0.033716165,0.31325525,0.04386892,0.0048334296,0.050675593,-0.056929454,0.0518016,-0.004611103,-0.0029309082,-0.028916717,0.0060408665,-0.004141483,0.01923389,-0.031655706,0.01768319,0.02311225,0.045390822,-0.024344986,-0.039786555,0.024944702,0.005075094,0.056426894,-0.0009737753,0.0037892968,-0.032363605,-0.012793344,-0.041841026,-0.014850747,-0.06273983,0.033704888,0.031475354,0.011834117,0.05125323,-0.011774348,-0.06885821,-0.014935385,-0.0006414335,0.017715653,-0.008953341,-0.097899854,-0.036503628,-0.084191576,0.023606507,-0.1339018,0.1330882,0.007957225,0.01985772,0.00030814653,0.021941159,0.05639211,-0.043463834,-0.045274723,0.011725757,-0.003486319,0.003375221,0.0074666464,0.06974618,-0.0006389784,-0.038667206,0.07041848,-0.02421246,0.03300245,-0.011266481,0.035639856,0.040018253,0.09069596,0.08246825,-0.009912788,0.012884513,-0.022981415,0.03470591,-0.022104705,0.0043493398,0.013083702,0.035951313,0.03946172,-0.038252268,0.030231304,-0.036359355,0.01005223,0.0025720727,0.0013707506,0.034241233,0.088925935,-0.051440887,-0.050102297,-0.0016456994,-0.009496842,0.062487546,0.040939905,0.07381002,0.078291304,-0.038428534,0.1316706,-0.0055638882,0.008280254,-0.021145111,0.04876571,0.040031683,0.04628573,0.046338666,-0.017028602,-0.007903445,0.007545737,-0.07565534,0.064689994,-0.022149073,-0.046088018,0.014704514,-0.040415496,0.00550196,0.006901969,0.00089305703,0.006521102,0.0366565,0.0074207284,0.039539423,0.005592426,-0.003989626,0.008083243,0.033852484,0.052595314,-0.015218367,0.03131478,0.0040506576,-0.048098013,-0.027468681,-0.024048975,-0.04536876,-0.05319465,-0.027298115,-0.01941297,0.010558779,0.06863464,0.04396793,0.08020219,0.033566475,-0.009056651,-0.014715962,0.04780099,0.05536488,-0.06740807,0.002055909,0.013943318,-0.05024147,-0.035200298,0.027621565,-0.040184192,-0.007491963,-0.06297288,-0.022879997,0.093055375,0.04880813,-0.012168053,0.019717308,0.064516716,0.020201867,0.012079503,-0.17798914,-0.027345736,-0.0612433,0.038101118,-0.06641872,-0.00939703,0.052195832,-0.03770301,-0.022270007,0.012196051,-0.041005902,-0.06945124,-0.027733557,-0.009639078,-0.059247572,0.04474978,0.00042829235,0.010153207,0.02728113,0.029422356,0.049308695,-0.038985588,-0.017589854,-0.02842523,-0.027386962,0.042216763,0.061242577,0.003747581,-0.024338258,-0.050467186,-0.013143215,0.0031099522,0.010997509,0.026045857,0.01815751,-0.027380131,0.01929404,-0.0022469186,0.111852795,0.07823112,0.024928685,0.059756078,-0.008221097,0.016979527,-0.039244134,-0.0019415446,0.011487329,-0.03280691,-0.08006135,-0.026343029,0.026450884,-0.053655412,-0.005154362,0.01307755,0.053237017,0.04086586,-0.0019484188,0.011518151,0.08618621,-0.041709326,0.047144253,0.077645905,-0.044002645,-0.16881582,-0.02115599,-0.011150404,-0.029005526,-0.022859793,-0.0107934745,0.009013299,0.0037840477,-0.023908136,-0.041892353,0.13362311,0.05498781,-0.0010903508,-0.027582854,0.02074264,0.08133009,-0.016295228,0.046583474,-0.012219358,-0.07110713,-0.031505097,0.04635908,0.13795494,0.004750067,0.044614047,0.018176915,0.020094909,-0.08733446,-0.14297998,0.045279857,0.0077459584,-0.019933412,0.059806284,0.0053598317,0.005684153,0.01267696,0.06831267,-0.03196309,0.0056615137,-0.023855256,0.14950311,0.028314097,0.0012290949,-0.034989975,0.014838987,-0.0043164054,-0.0380489,-0.002994491,-0.04658432,-0.023052199,0.009330306,0.019073954,-0.0048254183,0.039711606,0.026755748,0.05285787,0.005976852,-0.02769884,0.03918166,0.022543069,0.035913944,-0.030974701,-0.033151094,-0.061393328,0.012922418]],"total_duration":7800878,"load_duration":1435596,"prompt_eval_count":8}' - recorded_at: Wed, 02 Apr 2025 00:44:07 GMT + string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.025825415,-0.023176115,-0.052045297,-0.023625664,0.0006673469,0.009949714,-0.04538417,-0.06849524,-0.019409077,0.0010184002,-0.054927465,0.04728714,0.032690506,0.030963264,-0.028091758,-0.05092271,0.00021566867,0.023615433,-0.12640688,0.015840458,0.012315658,0.087370574,0.011073331,0.0090212375,0.007156342,-0.0052327104,0.021913407,-0.020346882,-0.03459649,-0.20068292,0.021031896,0.07291515,0.031049531,-0.04963502,0.023327535,-0.06476457,0.0131773045,0.004342761,-0.05204616,-0.03947274,0.0122103775,0.003776148,-0.050048206,-0.017586641,-0.029104842,-0.016230974,0.021660762,-0.017151477,0.0865443,0.01920734,-0.042871486,-0.0089291595,-0.02822964,-0.04884569,-0.018680912,-0.01892585,0.015438859,0.0065737013,-0.021804608,0.00633415,0.0343607,0.0017093703,-0.34944108,-0.06468269,0.0478818,-0.00246448,0.046574403,0.02243261,-0.024708489,-0.016602987,-0.011909359,0.014165576,-0.07424154,-0.03776865,0.032787047,-0.05530688,0.013535443,0.042380534,0.038827997,-0.033742167,0.015697544,0.009775907,0.0042203693,0.0011168025,0.023423292,0.04484947,-0.043061797,-0.05383481,-0.028867329,-0.0033860689,0.018773982,-0.018347567,0.03903167,-0.029658085,-0.06440208,0.040508885,-0.0017985007,0.049720276,0.033716165,0.31325525,0.04386892,0.0048334296,0.050675593,-0.056929454,0.0518016,-0.004611103,-0.0029309082,-0.028916717,0.0060408665,-0.004141483,0.01923389,-0.031655706,0.01768319,0.02311225,0.045390822,-0.024344986,-0.039786555,0.024944702,0.005075094,0.056426894,-0.0009737753,0.0037892968,-0.032363605,-0.012793344,-0.041841026,-0.014850747,-0.06273983,0.033704888,0.031475354,0.011834117,0.05125323,-0.011774348,-0.06885821,-0.014935385,-0.0006414335,0.017715653,-0.008953341,-0.097899854,-0.036503628,-0.084191576,0.023606507,-0.1339018,0.1330882,0.007957225,0.01985772,0.00030814653,0.021941159,0.05639211,-0.043463834,-0.045274723,0.011725757,-0.003486319,0.003375221,0.0074666464,0.06974618,-0.0006389784,-0.038667206,0.07041848,-0.02421246,0.03300245,-0.011266481,0.035639856,0.040018253,0.09069596,0.08246825,-0.009912788,0.012884513,-0.022981415,0.03470591,-0.022104705,0.0043493398,0.013083702,0.035951313,0.03946172,-0.038252268,0.030231304,-0.036359355,0.01005223,0.0025720727,0.0013707506,0.034241233,0.088925935,-0.051440887,-0.050102297,-0.0016456994,-0.009496842,0.062487546,0.040939905,0.07381002,0.078291304,-0.038428534,0.1316706,-0.0055638882,0.008280254,-0.021145111,0.04876571,0.040031683,0.04628573,0.046338666,-0.017028602,-0.007903445,0.007545737,-0.07565534,0.064689994,-0.022149073,-0.046088018,0.014704514,-0.040415496,0.00550196,0.006901969,0.00089305703,0.006521102,0.0366565,0.0074207284,0.039539423,0.005592426,-0.003989626,0.008083243,0.033852484,0.052595314,-0.015218367,0.03131478,0.0040506576,-0.048098013,-0.027468681,-0.024048975,-0.04536876,-0.05319465,-0.027298115,-0.01941297,0.010558779,0.06863464,0.04396793,0.08020219,0.033566475,-0.009056651,-0.014715962,0.04780099,0.05536488,-0.06740807,0.002055909,0.013943318,-0.05024147,-0.035200298,0.027621565,-0.040184192,-0.007491963,-0.06297288,-0.022879997,0.093055375,0.04880813,-0.012168053,0.019717308,0.064516716,0.020201867,0.012079503,-0.17798914,-0.027345736,-0.0612433,0.038101118,-0.06641872,-0.00939703,0.052195832,-0.03770301,-0.022270007,0.012196051,-0.041005902,-0.06945124,-0.027733557,-0.009639078,-0.059247572,0.04474978,0.00042829235,0.010153207,0.02728113,0.029422356,0.049308695,-0.038985588,-0.017589854,-0.02842523,-0.027386962,0.042216763,0.061242577,0.003747581,-0.024338258,-0.050467186,-0.013143215,0.0031099522,0.010997509,0.026045857,0.01815751,-0.027380131,0.01929404,-0.0022469186,0.111852795,0.07823112,0.024928685,0.059756078,-0.008221097,0.016979527,-0.039244134,-0.0019415446,0.011487329,-0.03280691,-0.08006135,-0.026343029,0.026450884,-0.053655412,-0.005154362,0.01307755,0.053237017,0.04086586,-0.0019484188,0.011518151,0.08618621,-0.041709326,0.047144253,0.077645905,-0.044002645,-0.16881582,-0.02115599,-0.011150404,-0.029005526,-0.022859793,-0.0107934745,0.009013299,0.0037840477,-0.023908136,-0.041892353,0.13362311,0.05498781,-0.0010903508,-0.027582854,0.02074264,0.08133009,-0.016295228,0.046583474,-0.012219358,-0.07110713,-0.031505097,0.04635908,0.13795494,0.004750067,0.044614047,0.018176915,0.020094909,-0.08733446,-0.14297998,0.045279857,0.0077459584,-0.019933412,0.059806284,0.0053598317,0.005684153,0.01267696,0.06831267,-0.03196309,0.0056615137,-0.023855256,0.14950311,0.028314097,0.0012290949,-0.034989975,0.014838987,-0.0043164054,-0.0380489,-0.002994491,-0.04658432,-0.023052199,0.009330306,0.019073954,-0.0048254183,0.039711606,0.026755748,0.05285787,0.005976852,-0.02769884,0.03918166,0.022543069,0.035913944,-0.030974701,-0.033151094,-0.061393328,0.012922418]],"total_duration":30114529,"load_duration":5548388,"prompt_eval_count":8}' + recorded_at: Fri, 11 Apr 2025 20:24:17 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml similarity index 98% rename from spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml rename to spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml index 2568478d..222c0bf0 100644 --- a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml +++ b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml @@ -23,7 +23,7 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Wed, 02 Apr 2025 00:44:15 GMT + - Fri, 11 Apr 2025 20:24:21 GMT Server: - Caddy Vary: @@ -32,6 +32,6 @@ http_interactions: - chunked body: encoding: ASCII-8BIT - string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.038980126,0.020101948,-0.067413226,0.007685114,-0.021361317,0.028405204,-0.05964908,-0.09178641,-0.032397546,0.008366828,-0.05523459,0.014637846,0.0298761,0.03387804,-0.016674861,-0.044479024,0.008276525,-0.0022477629,-0.12195336,-0.008178106,0.008199949,0.07350191,0.01897805,0.013661541,-0.003947917,0.00030909953,0.006917925,-0.012626692,-0.09616951,-0.17709318,0.01293276,0.031847943,0.025997223,-0.042996813,0.03192809,-0.048060544,-0.0017395425,0.029812165,-0.026901668,-0.030327402,-0.0068094945,0.023497479,-0.019625092,-0.003110331,0.010590182,-0.027034454,0.04182794,-0.009884578,0.09661056,0.043840215,-0.037773125,-0.033335246,0.009626258,-0.013944384,-0.040054895,-0.0026200123,0.046114273,0.0049590026,-0.008846017,0.034012534,0.038100995,0.0013456035,-0.34869465,-0.06399822,0.06681992,-0.007770172,0.03451249,0.006695025,0.0016939766,-0.005725403,-0.059506737,-0.0011312707,-0.034694858,-0.0070268526,0.033973437,-0.07178208,0.0019529031,0.050796922,0.033150885,-0.04453945,-0.010778929,-0.01298108,0.01772847,0.027397834,0.017516151,0.05094088,-0.045374986,-0.031055674,0.0034364148,0.017342873,0.03724968,-0.020449797,0.03487508,-0.023868825,-0.0705106,0.045591667,0.0014132301,0.04102965,0.0082013225,0.3076015,0.041163538,-0.0075212517,0.0632507,-0.07494113,0.054058343,-0.013692275,-0.018088195,0.0039990763,-0.016607765,-0.00915819,0.03353369,-0.017990997,-0.008927891,0.018497262,0.04622437,-0.028729072,-0.0070351255,-0.005821854,0.0063457754,0.044443272,-0.03001723,0.014840464,-0.03265875,-0.017414864,-0.014599514,-0.022385433,-0.06727593,0.03655243,0.009642398,0.04557801,0.028509801,0.011939836,-0.062560804,-0.015390183,-0.0050801174,0.011868977,0.00253459,-0.07341563,-0.004279252,-0.07461656,-0.0006562158,-0.16768059,0.13006905,0.03295397,0.0145061985,0.000511846,0.009465702,0.037566304,-0.012595248,-0.042188045,0.015753305,0.02033451,-0.026321119,0.020434551,0.09113539,-0.014463864,-0.04273769,0.05132384,-0.007610653,0.036329918,0.010425151,0.0075439727,0.042681746,0.060391378,0.053032257,0.0071610347,0.018304583,-0.0199126,0.008234456,-0.026586238,-0.00048163044,0.018455869,0.012418799,0.061977547,-0.014351739,0.019218396,0.010331768,0.033490002,0.0102368975,-0.031620093,0.015966186,0.10022163,-0.03886677,-0.058662754,-0.010719046,0.011613407,0.055317454,0.021442259,0.041051246,0.05395217,-0.031625535,0.1561225,-0.04847817,0.012704446,-0.017351678,-0.005412353,0.05782586,0.063770935,0.028648905,-0.0010758642,-0.03315512,0.011804742,-0.054954775,0.034165937,-0.027770827,-0.040539972,0.01901002,-0.008845964,-0.009943114,-0.00007340114,0.008205162,0.014036151,0.015788715,0.013589957,0.040579043,-0.015481178,0.0013020202,-0.019863069,0.044024546,0.054241393,-0.019910982,0.019316196,-0.009067846,-0.06370655,-0.038542934,-0.005822525,-0.05564244,-0.020892167,-0.04894251,-0.012727646,0.05143602,0.06270096,0.022492254,0.11401925,0.014643738,0.0030262705,-0.036580373,0.05074049,0.04994587,-0.06580306,0.008364971,0.0012129012,-0.034641,-0.0046832887,0.012338395,-0.032140378,-0.045876123,-0.048861995,-0.019786038,0.12485802,0.06277426,-0.033950374,0.036432575,0.06035506,0.014863595,0.0047113854,-0.19050083,-0.032735668,-0.077262625,0.044320498,-0.059189577,-0.014459053,0.03718649,-0.0026039602,0.004493112,-0.011763187,-0.05504196,-0.025533773,-0.02048363,-0.023919607,-0.015506923,0.061790027,0.01816571,0.0130165955,0.04316555,0.020895818,0.034394037,-0.00560091,0.011984886,-0.06372637,0.02781977,0.020621277,0.06389801,0.0032279587,-0.064306036,-0.07160552,-0.05394653,0.032840647,-0.0021832213,0.030553438,0.0039347326,-0.026431374,-0.026453791,-0.024773262,0.14158836,0.00027325953,-0.003358694,0.031054376,0.005467873,-0.000014875217,-0.05249387,0.05296582,-0.013941867,-0.031785127,-0.07282081,-0.029387616,-0.0076221772,-0.032214306,0.008221592,0.01732765,0.01000591,0.015568096,-0.005231348,-0.012036904,0.07718011,-0.045315113,0.008787361,0.02417641,-0.015230668,-0.15053827,-0.0037556684,-0.01667005,-0.0013223562,-0.02209581,0.016655259,0.019694244,0.015031552,-0.037394483,-0.057655845,0.12982553,0.04818329,0.0077882116,-0.015061786,0.004192891,0.08628084,0.027619699,0.044403546,0.00034237612,-0.044426452,0.00096744276,0.06186224,0.16129373,0.024928987,-0.0073914034,0.0040016263,0.039090827,-0.08990263,-0.118701264,0.04410862,-0.03954887,-0.030827247,0.112970345,0.04363939,-0.021480395,0.03728192,0.044834364,-0.0009248547,0.032832358,-0.035760213,0.15535384,-0.0009505413,-0.0034093896,-0.029711511,0.008248596,-0.051867787,-0.012275803,0.012434058,-0.04902186,-0.011476671,0.0133925,-0.03379115,-0.0151935695,0.010195133,0.031876706,0.025932532,0.036986034,-0.01739396,0.017166032,0.05808856,0.030131826,-0.0008843879,-0.06526332,-0.09222386,-0.0049838475],[-0.007225496,0.037155706,-0.016906068,-0.030758644,-0.020417303,0.011231278,-0.06530078,-0.061754078,-0.020577524,-0.024164986,-0.035808578,0.015893035,0.061571326,0.020668881,0.016767306,-0.023883428,-0.01099219,0.025237663,-0.15266667,-0.013051586,-0.010288909,0.029873036,0.017107742,0.0315594,0.021337744,0.0034486242,0.013156374,-0.037249252,-0.13094991,-0.15867794,0.024068367,0.005509016,-0.0056714285,-0.042848945,-0.0045933733,-0.04299176,0.0020768172,0.04483032,-0.03212172,-0.027772011,-0.0036520734,-0.0075447895,-0.013391376,0.0045278594,0.04607957,0.0027125278,0.049626715,-0.021857744,0.06873977,0.04173157,-0.04370165,0.014249006,-0.0373972,-0.05551407,-0.045433797,-0.0011728521,0.044487648,-0.0074436087,-0.00975718,0.008799588,0.0073077497,0.024823438,-0.35174075,-0.012705645,0.04136241,0.047284245,0.0020329098,0.04765345,-0.02604234,-0.02548834,-0.02704063,0.017578213,0.01482943,0.0055936393,0.023184825,-0.041498873,-0.003050582,0.012843925,0.05516694,-0.03866418,0.02621437,0.032198943,0.01935349,-0.018680874,-0.013953387,0.0451372,-0.018057078,-0.012344732,0.04716202,0.0010259423,-0.028411478,0.04075236,0.024121404,0.0006758823,-0.0674563,0.009551461,-0.01973488,0.05264174,0.04568158,0.29859018,0.030333413,-0.04152799,0.016276676,-0.037692044,0.053379524,-0.029166088,-0.008381986,-0.03611233,0.021734668,-0.02926269,0.01770523,-0.021257408,-0.0026680147,0.0033788746,0.03192171,-0.02859868,-0.050017837,0.007628301,-0.005211484,0.055639394,-0.04813225,-0.00062740705,-0.023975527,-0.05272858,0.0012510746,-0.016620526,-0.05937839,0.014596674,-0.007940771,-0.0060859257,0.03417475,-0.020669967,-0.09361984,-0.019438276,-0.012983339,0.022100516,0.03252378,-0.052587945,0.016381664,-0.047060754,0.015694086,-0.1377361,0.10544033,0.0026725356,0.01146019,0.026346128,-0.025007993,0.004997534,-0.053778246,-0.038643032,0.023108022,0.016371924,-0.015227947,0.0020684898,0.124686636,0.02065184,-0.0070788977,0.031109046,-0.011467157,0.0051159468,0.0174688,0.019905413,-0.0069136377,0.032805618,0.029705629,-0.038734376,0.032078113,-0.01761205,0.01944323,-0.0030690655,0.018461121,0.018608272,-0.012803209,0.017234804,-0.05453963,-0.0014086623,-0.032340996,0.0010491384,0.038566574,-0.03347248,-0.015357926,0.08070545,-0.028756669,-0.046844523,-0.01529485,0.052366853,0.059635386,0.03260225,0.05999529,0.06562162,-0.025594424,0.19492106,-0.09446214,-0.02200547,0.021350436,-0.0047113174,0.03170546,0.032968767,-0.017730163,-0.023518713,-0.024787944,-0.014301349,-0.00028776744,0.015872791,0.015544321,-0.079372294,-0.005725175,0.017331447,-0.0056501715,-0.012182198,-0.009767331,-0.05171092,0.038543854,0.034115233,0.07627104,0.032627165,0.016347326,0.012965246,0.024923127,0.02650983,-0.0040691686,0.04411213,-0.02981039,-0.06744219,-0.030292222,-0.0021420228,-0.06861754,-0.0020280352,-0.08233997,-0.0059836525,0.037955742,0.039244626,0.034866735,0.11366857,0.02521095,0.018243132,0.024956543,0.027358694,0.011940862,-0.061406422,0.0018358993,0.015471496,-0.0400448,-0.024514355,0.020818526,-0.078023,-0.019798901,-0.046464335,-0.03319194,0.16930555,0.050408904,-0.013528864,0.007027566,0.0381429,0.0010658541,-0.011183001,-0.18296444,-0.025517514,-0.028616475,0.044594944,-0.002806602,-0.00036968052,0.040348303,0.022882342,-0.0099050915,-0.029638626,-0.009392766,-0.035751175,-0.02882233,-0.05017968,-0.031793848,0.104784735,0.026196804,0.025192862,0.0053355214,-0.009864406,0.07273947,0.029665705,-0.030834008,0.005743688,0.0130977845,0.027437972,0.042631894,0.02490531,-0.031600703,-0.055224583,-0.04933041,-0.0008777641,-0.002849928,0.06742398,-0.041109774,0.00045421268,-0.008093842,-0.026830377,0.18975478,0.0022353292,0.016124677,0.03874153,-0.01676804,0.0016409162,0.0022479978,0.039468583,-0.03589011,-0.005279329,-0.031004557,-0.014081007,0.058285933,-0.03845023,-0.022855511,0.008495943,-0.013061212,0.029775871,0.024829257,-0.015684903,0.09160675,-0.057623718,0.035138898,0.037533384,0.02173393,-0.20164658,-0.034627892,-0.013216875,0.04897353,-0.058580056,0.018308442,0.028224163,-0.011080451,0.020418232,-0.026639828,0.1152522,0.05399439,-0.017088734,-0.0043683355,0.04675239,0.055089362,0.01442295,0.019836834,-0.013131093,-0.040812545,0.0028349068,0.06096238,0.15055773,-0.0047997017,0.04041006,0.023423078,0.0068679894,-0.036161505,-0.11227965,0.027264446,-0.032434683,-0.033046544,0.05816228,0.019367868,-0.035861887,0.023473343,0.07127074,-0.036597442,0.00892375,-0.03424332,0.15918937,-0.028045062,0.01727863,-0.016116075,-0.033897277,-0.04147993,0.000102095604,0.0054549514,-0.054227076,-0.014035331,0.022229984,-0.0101330625,0.0061006444,0.031121459,0.034375396,0.027529038,0.02083103,-0.01970649,0.01220227,0.048865896,0.04224607,0.034099545,-0.018085487,-0.035159428,-0.057188712],[0.010182182,0.01467856,0.02307528,-0.031243263,-0.019379467,0.018989552,-0.04283347,-0.065710135,0.037127666,-0.00186089,-0.043939225,0.02675395,0.017098242,0.01003573,0.016530303,-0.07529927,-0.0045888554,-0.00783502,-0.16103624,-0.018049028,-0.023261337,0.0726829,0.03554955,0.007101789,-0.03776669,0.03965637,0.010605459,-0.034077637,-0.1356997,-0.17605451,0.017438654,0.021631619,-0.00033740848,-0.05291991,-0.021556789,-0.020458516,-0.035007652,0.015351501,-0.013426498,-0.03958441,0.007752372,-0.016570576,-0.046401996,-0.011264202,0.05016379,-0.013889148,0.023654828,-0.030822476,0.024557399,0.041917533,-0.057632543,-0.032482482,0.00036849198,-0.038682386,-0.046676703,0.050744284,-0.010942368,-0.031797383,0.010470975,0.016948372,0.0055663995,0.058688268,-0.36635372,0.025145743,0.07269215,0.019211076,-0.018371176,-0.007865585,-0.00085583143,0.015894871,0.038337328,-0.014794488,-0.012541673,0.01718971,0.02693935,-0.045785226,0.0036220509,0.021907976,0.06554055,-0.04263025,0.0019336614,0.020152396,0.016324878,0.030021766,-0.015724592,0.06523936,0.0062361993,-0.028796729,0.038781464,0.00485937,-0.04877486,0.035066955,0.003006257,-0.0022367106,-0.04857364,0.001250449,0.0014392686,0.034671582,0.018141782,0.30240846,0.018054346,0.003062208,0.040367432,-0.07040852,0.052332688,-0.0028175337,-0.028020458,-0.021599045,0.031913813,-0.03909125,0.0028893205,-0.017719263,0.0052999025,-0.0061596422,0.054935843,-0.0012574365,-0.016914988,-0.009276138,0.023673639,0.043957185,-0.027961437,0.025381606,-0.04037111,-0.0053644218,-0.01048436,0.0035398034,-0.06366181,0.025020782,-0.046017863,-0.011454832,0.055446308,0.00011163922,-0.09325482,0.019621197,0.022895223,0.03182137,0.0010375826,-0.03117694,0.025362851,-0.031175531,-0.018045994,-0.13010256,0.10690098,-0.010491627,0.025534678,-0.0049998793,-0.028496867,0.043118607,-0.026229834,-0.01440331,0.024678908,0.033322413,-0.04394492,-0.005047783,0.0846922,0.022463208,0.0030116427,-0.003502701,-0.006854317,0.029395698,0.026690561,0.02559026,0.059080407,0.08340788,0.032878075,-0.0951223,0.05720357,0.02495402,0.014070283,-0.0042589814,0.018304987,-0.024781907,-0.041739304,-0.025803747,-0.012889254,-0.008009496,-0.028856821,-0.0005779219,0.028763987,-0.051368624,0.0027247544,0.06316944,-0.026757175,-0.08121664,-0.010547304,0.025082018,0.03702747,0.012908532,0.03141585,0.06318691,-0.027946094,0.17676711,-0.082001895,-0.036393072,-0.034927875,0.021505699,0.015366971,0.043793295,-0.0021506813,0.011197076,-0.04681245,-0.07142668,0.009581391,0.035224073,-0.04230499,-0.03571502,0.044728618,0.013419941,0.04271971,-0.008869499,-0.03126791,-0.0022953814,0.09043066,0.02422671,0.031988394,-0.005063331,-0.01025437,0.028456746,0.005116802,0.047064006,0.006069893,0.018045707,-0.022872277,-0.04572793,0.009827904,0.0069014616,-0.040622003,-0.013080576,-0.04777706,0.0012043755,0.07896354,0.043710608,0.040280547,0.073466524,0.06464221,0.014187437,-0.04872054,0.031972423,0.012510081,-0.038348954,0.016539646,0.006683025,-0.040044174,-0.056529168,0.04949601,-0.09106357,-0.030466262,0.010563386,-0.029358381,0.18323456,0.092901036,0.0274177,0.015892414,0.03165387,-0.06160097,0.0015103974,-0.11125003,0.010338306,-0.04025745,0.03327973,-0.025003629,-0.03141167,0.06007851,-0.029752823,-0.025986204,-0.0014932271,-0.00599316,-0.021954508,-0.005476444,-0.029271869,-0.040407516,0.09515277,0.019253343,0.04248291,0.00067515706,-0.009261151,0.025339367,-0.014061599,-0.0580183,-0.020854905,0.018436473,-0.0027048623,0.05364179,0.03416436,-0.009260716,-0.0785917,-0.023255466,0.03542782,0.07159498,0.0069388812,-0.038117178,-0.012323471,-0.009949083,-0.005902662,0.1273025,0.0014150682,0.018899381,0.022011757,-0.048523538,-0.03720841,-0.009601104,0.0547053,0.013078509,-0.013740014,-0.047507983,-0.018159833,0.017327625,-0.028147077,-0.030314941,-0.0028794382,-0.045816995,0.0028496154,0.015196548,-0.007854572,0.10382276,-0.01617453,0.017708423,0.037362352,0.002230973,-0.17829818,-0.036029417,-0.0006612718,-0.014223209,-0.06350168,-0.030032892,0.023901368,-0.00077770976,0.02510791,-0.04697416,0.15435414,0.08471184,-0.018154247,-0.030085038,0.03331496,0.09898532,0.016086424,0.010282825,-0.018388266,-0.006998348,0.017570151,0.0994389,0.12580456,0.023195932,0.008063885,0.003250409,-0.005355925,-0.047599785,-0.13378266,-0.0018643751,-0.045305796,-0.020819422,0.06300365,0.00095856196,0.005435208,0.0057721534,0.031151773,-0.03753951,0.016918143,-0.044961866,0.13784775,-0.016061982,-0.00000515642,-0.008715281,-0.01241248,-0.0021270465,0.022557234,0.05173467,-0.04232277,0.008206349,0.012508353,-0.004212918,-0.01315854,0.048109457,0.00035447034,-0.0082567325,0.012337424,0.0065427353,0.036199752,0.030513138,0.039167494,-0.028987426,-0.016657345,-0.07125146,-0.020769335]],"total_duration":9249807,"load_duration":1162717,"prompt_eval_count":4}' - recorded_at: Wed, 02 Apr 2025 00:44:07 GMT + string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.038980126,0.020101948,-0.067413226,0.007685114,-0.021361317,0.028405204,-0.05964908,-0.09178641,-0.032397546,0.008366828,-0.05523459,0.014637846,0.0298761,0.03387804,-0.016674861,-0.044479024,0.008276525,-0.0022477629,-0.12195336,-0.008178106,0.008199949,0.07350191,0.01897805,0.013661541,-0.003947917,0.00030909953,0.006917925,-0.012626692,-0.09616951,-0.17709318,0.01293276,0.031847943,0.025997223,-0.042996813,0.03192809,-0.048060544,-0.0017395425,0.029812165,-0.026901668,-0.030327402,-0.0068094945,0.023497479,-0.019625092,-0.003110331,0.010590182,-0.027034454,0.04182794,-0.009884578,0.09661056,0.043840215,-0.037773125,-0.033335246,0.009626258,-0.013944384,-0.040054895,-0.0026200123,0.046114273,0.0049590026,-0.008846017,0.034012534,0.038100995,0.0013456035,-0.34869465,-0.06399822,0.06681992,-0.007770172,0.03451249,0.006695025,0.0016939766,-0.005725403,-0.059506737,-0.0011312707,-0.034694858,-0.0070268526,0.033973437,-0.07178208,0.0019529031,0.050796922,0.033150885,-0.04453945,-0.010778929,-0.01298108,0.01772847,0.027397834,0.017516151,0.05094088,-0.045374986,-0.031055674,0.0034364148,0.017342873,0.03724968,-0.020449797,0.03487508,-0.023868825,-0.0705106,0.045591667,0.0014132301,0.04102965,0.0082013225,0.3076015,0.041163538,-0.0075212517,0.0632507,-0.07494113,0.054058343,-0.013692275,-0.018088195,0.0039990763,-0.016607765,-0.00915819,0.03353369,-0.017990997,-0.008927891,0.018497262,0.04622437,-0.028729072,-0.0070351255,-0.005821854,0.0063457754,0.044443272,-0.03001723,0.014840464,-0.03265875,-0.017414864,-0.014599514,-0.022385433,-0.06727593,0.03655243,0.009642398,0.04557801,0.028509801,0.011939836,-0.062560804,-0.015390183,-0.0050801174,0.011868977,0.00253459,-0.07341563,-0.004279252,-0.07461656,-0.0006562158,-0.16768059,0.13006905,0.03295397,0.0145061985,0.000511846,0.009465702,0.037566304,-0.012595248,-0.042188045,0.015753305,0.02033451,-0.026321119,0.020434551,0.09113539,-0.014463864,-0.04273769,0.05132384,-0.007610653,0.036329918,0.010425151,0.0075439727,0.042681746,0.060391378,0.053032257,0.0071610347,0.018304583,-0.0199126,0.008234456,-0.026586238,-0.00048163044,0.018455869,0.012418799,0.061977547,-0.014351739,0.019218396,0.010331768,0.033490002,0.0102368975,-0.031620093,0.015966186,0.10022163,-0.03886677,-0.058662754,-0.010719046,0.011613407,0.055317454,0.021442259,0.041051246,0.05395217,-0.031625535,0.1561225,-0.04847817,0.012704446,-0.017351678,-0.005412353,0.05782586,0.063770935,0.028648905,-0.0010758642,-0.03315512,0.011804742,-0.054954775,0.034165937,-0.027770827,-0.040539972,0.01901002,-0.008845964,-0.009943114,-0.00007340114,0.008205162,0.014036151,0.015788715,0.013589957,0.040579043,-0.015481178,0.0013020202,-0.019863069,0.044024546,0.054241393,-0.019910982,0.019316196,-0.009067846,-0.06370655,-0.038542934,-0.005822525,-0.05564244,-0.020892167,-0.04894251,-0.012727646,0.05143602,0.06270096,0.022492254,0.11401925,0.014643738,0.0030262705,-0.036580373,0.05074049,0.04994587,-0.06580306,0.008364971,0.0012129012,-0.034641,-0.0046832887,0.012338395,-0.032140378,-0.045876123,-0.048861995,-0.019786038,0.12485802,0.06277426,-0.033950374,0.036432575,0.06035506,0.014863595,0.0047113854,-0.19050083,-0.032735668,-0.077262625,0.044320498,-0.059189577,-0.014459053,0.03718649,-0.0026039602,0.004493112,-0.011763187,-0.05504196,-0.025533773,-0.02048363,-0.023919607,-0.015506923,0.061790027,0.01816571,0.0130165955,0.04316555,0.020895818,0.034394037,-0.00560091,0.011984886,-0.06372637,0.02781977,0.020621277,0.06389801,0.0032279587,-0.064306036,-0.07160552,-0.05394653,0.032840647,-0.0021832213,0.030553438,0.0039347326,-0.026431374,-0.026453791,-0.024773262,0.14158836,0.00027325953,-0.003358694,0.031054376,0.005467873,-0.000014875217,-0.05249387,0.05296582,-0.013941867,-0.031785127,-0.07282081,-0.029387616,-0.0076221772,-0.032214306,0.008221592,0.01732765,0.01000591,0.015568096,-0.005231348,-0.012036904,0.07718011,-0.045315113,0.008787361,0.02417641,-0.015230668,-0.15053827,-0.0037556684,-0.01667005,-0.0013223562,-0.02209581,0.016655259,0.019694244,0.015031552,-0.037394483,-0.057655845,0.12982553,0.04818329,0.0077882116,-0.015061786,0.004192891,0.08628084,0.027619699,0.044403546,0.00034237612,-0.044426452,0.00096744276,0.06186224,0.16129373,0.024928987,-0.0073914034,0.0040016263,0.039090827,-0.08990263,-0.118701264,0.04410862,-0.03954887,-0.030827247,0.112970345,0.04363939,-0.021480395,0.03728192,0.044834364,-0.0009248547,0.032832358,-0.035760213,0.15535384,-0.0009505413,-0.0034093896,-0.029711511,0.008248596,-0.051867787,-0.012275803,0.012434058,-0.04902186,-0.011476671,0.0133925,-0.03379115,-0.0151935695,0.010195133,0.031876706,0.025932532,0.036986034,-0.01739396,0.017166032,0.05808856,0.030131826,-0.0008843879,-0.06526332,-0.09222386,-0.0049838475],[-0.007225496,0.037155706,-0.016906068,-0.030758644,-0.020417303,0.011231278,-0.06530078,-0.061754078,-0.020577524,-0.024164986,-0.035808578,0.015893035,0.061571326,0.020668881,0.016767306,-0.023883428,-0.01099219,0.025237663,-0.15266667,-0.013051586,-0.010288909,0.029873036,0.017107742,0.0315594,0.021337744,0.0034486242,0.013156374,-0.037249252,-0.13094991,-0.15867794,0.024068367,0.005509016,-0.0056714285,-0.042848945,-0.0045933733,-0.04299176,0.0020768172,0.04483032,-0.03212172,-0.027772011,-0.0036520734,-0.0075447895,-0.013391376,0.0045278594,0.04607957,0.0027125278,0.049626715,-0.021857744,0.06873977,0.04173157,-0.04370165,0.014249006,-0.0373972,-0.05551407,-0.045433797,-0.0011728521,0.044487648,-0.0074436087,-0.00975718,0.008799588,0.0073077497,0.024823438,-0.35174075,-0.012705645,0.04136241,0.047284245,0.0020329098,0.04765345,-0.02604234,-0.02548834,-0.02704063,0.017578213,0.01482943,0.0055936393,0.023184825,-0.041498873,-0.003050582,0.012843925,0.05516694,-0.03866418,0.02621437,0.032198943,0.01935349,-0.018680874,-0.013953387,0.0451372,-0.018057078,-0.012344732,0.04716202,0.0010259423,-0.028411478,0.04075236,0.024121404,0.0006758823,-0.0674563,0.009551461,-0.01973488,0.05264174,0.04568158,0.29859018,0.030333413,-0.04152799,0.016276676,-0.037692044,0.053379524,-0.029166088,-0.008381986,-0.03611233,0.021734668,-0.02926269,0.01770523,-0.021257408,-0.0026680147,0.0033788746,0.03192171,-0.02859868,-0.050017837,0.007628301,-0.005211484,0.055639394,-0.04813225,-0.00062740705,-0.023975527,-0.05272858,0.0012510746,-0.016620526,-0.05937839,0.014596674,-0.007940771,-0.0060859257,0.03417475,-0.020669967,-0.09361984,-0.019438276,-0.012983339,0.022100516,0.03252378,-0.052587945,0.016381664,-0.047060754,0.015694086,-0.1377361,0.10544033,0.0026725356,0.01146019,0.026346128,-0.025007993,0.004997534,-0.053778246,-0.038643032,0.023108022,0.016371924,-0.015227947,0.0020684898,0.124686636,0.02065184,-0.0070788977,0.031109046,-0.011467157,0.0051159468,0.0174688,0.019905413,-0.0069136377,0.032805618,0.029705629,-0.038734376,0.032078113,-0.01761205,0.01944323,-0.0030690655,0.018461121,0.018608272,-0.012803209,0.017234804,-0.05453963,-0.0014086623,-0.032340996,0.0010491384,0.038566574,-0.03347248,-0.015357926,0.08070545,-0.028756669,-0.046844523,-0.01529485,0.052366853,0.059635386,0.03260225,0.05999529,0.06562162,-0.025594424,0.19492106,-0.09446214,-0.02200547,0.021350436,-0.0047113174,0.03170546,0.032968767,-0.017730163,-0.023518713,-0.024787944,-0.014301349,-0.00028776744,0.015872791,0.015544321,-0.079372294,-0.005725175,0.017331447,-0.0056501715,-0.012182198,-0.009767331,-0.05171092,0.038543854,0.034115233,0.07627104,0.032627165,0.016347326,0.012965246,0.024923127,0.02650983,-0.0040691686,0.04411213,-0.02981039,-0.06744219,-0.030292222,-0.0021420228,-0.06861754,-0.0020280352,-0.08233997,-0.0059836525,0.037955742,0.039244626,0.034866735,0.11366857,0.02521095,0.018243132,0.024956543,0.027358694,0.011940862,-0.061406422,0.0018358993,0.015471496,-0.0400448,-0.024514355,0.020818526,-0.078023,-0.019798901,-0.046464335,-0.03319194,0.16930555,0.050408904,-0.013528864,0.007027566,0.0381429,0.0010658541,-0.011183001,-0.18296444,-0.025517514,-0.028616475,0.044594944,-0.002806602,-0.00036968052,0.040348303,0.022882342,-0.0099050915,-0.029638626,-0.009392766,-0.035751175,-0.02882233,-0.05017968,-0.031793848,0.104784735,0.026196804,0.025192862,0.0053355214,-0.009864406,0.07273947,0.029665705,-0.030834008,0.005743688,0.0130977845,0.027437972,0.042631894,0.02490531,-0.031600703,-0.055224583,-0.04933041,-0.0008777641,-0.002849928,0.06742398,-0.041109774,0.00045421268,-0.008093842,-0.026830377,0.18975478,0.0022353292,0.016124677,0.03874153,-0.01676804,0.0016409162,0.0022479978,0.039468583,-0.03589011,-0.005279329,-0.031004557,-0.014081007,0.058285933,-0.03845023,-0.022855511,0.008495943,-0.013061212,0.029775871,0.024829257,-0.015684903,0.09160675,-0.057623718,0.035138898,0.037533384,0.02173393,-0.20164658,-0.034627892,-0.013216875,0.04897353,-0.058580056,0.018308442,0.028224163,-0.011080451,0.020418232,-0.026639828,0.1152522,0.05399439,-0.017088734,-0.0043683355,0.04675239,0.055089362,0.01442295,0.019836834,-0.013131093,-0.040812545,0.0028349068,0.06096238,0.15055773,-0.0047997017,0.04041006,0.023423078,0.0068679894,-0.036161505,-0.11227965,0.027264446,-0.032434683,-0.033046544,0.05816228,0.019367868,-0.035861887,0.023473343,0.07127074,-0.036597442,0.00892375,-0.03424332,0.15918937,-0.028045062,0.01727863,-0.016116075,-0.033897277,-0.04147993,0.000102095604,0.0054549514,-0.054227076,-0.014035331,0.022229984,-0.0101330625,0.0061006444,0.031121459,0.034375396,0.027529038,0.02083103,-0.01970649,0.01220227,0.048865896,0.04224607,0.034099545,-0.018085487,-0.035159428,-0.057188712],[0.010182182,0.01467856,0.02307528,-0.031243263,-0.019379467,0.018989552,-0.04283347,-0.065710135,0.037127666,-0.00186089,-0.043939225,0.02675395,0.017098242,0.01003573,0.016530303,-0.07529927,-0.0045888554,-0.00783502,-0.16103624,-0.018049028,-0.023261337,0.0726829,0.03554955,0.007101789,-0.03776669,0.03965637,0.010605459,-0.034077637,-0.1356997,-0.17605451,0.017438654,0.021631619,-0.00033740848,-0.05291991,-0.021556789,-0.020458516,-0.035007652,0.015351501,-0.013426498,-0.03958441,0.007752372,-0.016570576,-0.046401996,-0.011264202,0.05016379,-0.013889148,0.023654828,-0.030822476,0.024557399,0.041917533,-0.057632543,-0.032482482,0.00036849198,-0.038682386,-0.046676703,0.050744284,-0.010942368,-0.031797383,0.010470975,0.016948372,0.0055663995,0.058688268,-0.36635372,0.025145743,0.07269215,0.019211076,-0.018371176,-0.007865585,-0.00085583143,0.015894871,0.038337328,-0.014794488,-0.012541673,0.01718971,0.02693935,-0.045785226,0.0036220509,0.021907976,0.06554055,-0.04263025,0.0019336614,0.020152396,0.016324878,0.030021766,-0.015724592,0.06523936,0.0062361993,-0.028796729,0.038781464,0.00485937,-0.04877486,0.035066955,0.003006257,-0.0022367106,-0.04857364,0.001250449,0.0014392686,0.034671582,0.018141782,0.30240846,0.018054346,0.003062208,0.040367432,-0.07040852,0.052332688,-0.0028175337,-0.028020458,-0.021599045,0.031913813,-0.03909125,0.0028893205,-0.017719263,0.0052999025,-0.0061596422,0.054935843,-0.0012574365,-0.016914988,-0.009276138,0.023673639,0.043957185,-0.027961437,0.025381606,-0.04037111,-0.0053644218,-0.01048436,0.0035398034,-0.06366181,0.025020782,-0.046017863,-0.011454832,0.055446308,0.00011163922,-0.09325482,0.019621197,0.022895223,0.03182137,0.0010375826,-0.03117694,0.025362851,-0.031175531,-0.018045994,-0.13010256,0.10690098,-0.010491627,0.025534678,-0.0049998793,-0.028496867,0.043118607,-0.026229834,-0.01440331,0.024678908,0.033322413,-0.04394492,-0.005047783,0.0846922,0.022463208,0.0030116427,-0.003502701,-0.006854317,0.029395698,0.026690561,0.02559026,0.059080407,0.08340788,0.032878075,-0.0951223,0.05720357,0.02495402,0.014070283,-0.0042589814,0.018304987,-0.024781907,-0.041739304,-0.025803747,-0.012889254,-0.008009496,-0.028856821,-0.0005779219,0.028763987,-0.051368624,0.0027247544,0.06316944,-0.026757175,-0.08121664,-0.010547304,0.025082018,0.03702747,0.012908532,0.03141585,0.06318691,-0.027946094,0.17676711,-0.082001895,-0.036393072,-0.034927875,0.021505699,0.015366971,0.043793295,-0.0021506813,0.011197076,-0.04681245,-0.07142668,0.009581391,0.035224073,-0.04230499,-0.03571502,0.044728618,0.013419941,0.04271971,-0.008869499,-0.03126791,-0.0022953814,0.09043066,0.02422671,0.031988394,-0.005063331,-0.01025437,0.028456746,0.005116802,0.047064006,0.006069893,0.018045707,-0.022872277,-0.04572793,0.009827904,0.0069014616,-0.040622003,-0.013080576,-0.04777706,0.0012043755,0.07896354,0.043710608,0.040280547,0.073466524,0.06464221,0.014187437,-0.04872054,0.031972423,0.012510081,-0.038348954,0.016539646,0.006683025,-0.040044174,-0.056529168,0.04949601,-0.09106357,-0.030466262,0.010563386,-0.029358381,0.18323456,0.092901036,0.0274177,0.015892414,0.03165387,-0.06160097,0.0015103974,-0.11125003,0.010338306,-0.04025745,0.03327973,-0.025003629,-0.03141167,0.06007851,-0.029752823,-0.025986204,-0.0014932271,-0.00599316,-0.021954508,-0.005476444,-0.029271869,-0.040407516,0.09515277,0.019253343,0.04248291,0.00067515706,-0.009261151,0.025339367,-0.014061599,-0.0580183,-0.020854905,0.018436473,-0.0027048623,0.05364179,0.03416436,-0.009260716,-0.0785917,-0.023255466,0.03542782,0.07159498,0.0069388812,-0.038117178,-0.012323471,-0.009949083,-0.005902662,0.1273025,0.0014150682,0.018899381,0.022011757,-0.048523538,-0.03720841,-0.009601104,0.0547053,0.013078509,-0.013740014,-0.047507983,-0.018159833,0.017327625,-0.028147077,-0.030314941,-0.0028794382,-0.045816995,0.0028496154,0.015196548,-0.007854572,0.10382276,-0.01617453,0.017708423,0.037362352,0.002230973,-0.17829818,-0.036029417,-0.0006612718,-0.014223209,-0.06350168,-0.030032892,0.023901368,-0.00077770976,0.02510791,-0.04697416,0.15435414,0.08471184,-0.018154247,-0.030085038,0.03331496,0.09898532,0.016086424,0.010282825,-0.018388266,-0.006998348,0.017570151,0.0994389,0.12580456,0.023195932,0.008063885,0.003250409,-0.005355925,-0.047599785,-0.13378266,-0.0018643751,-0.045305796,-0.020819422,0.06300365,0.00095856196,0.005435208,0.0057721534,0.031151773,-0.03753951,0.016918143,-0.044961866,0.13784775,-0.016061982,-0.00000515642,-0.008715281,-0.01241248,-0.0021270465,0.022557234,0.05173467,-0.04232277,0.008206349,0.012508353,-0.004212918,-0.01315854,0.048109457,0.00035447034,-0.0082567325,0.012337424,0.0065427353,0.036199752,0.030513138,0.039167494,-0.028987426,-0.016657345,-0.07125146,-0.020769335]],"total_duration":11480915,"load_duration":2711876,"prompt_eval_count":4}' + recorded_at: Fri, 11 Apr 2025 20:24:17 GMT recorded_with: VCR 6.3.1 From 758374f09412fed7605e4ab328ea4c8cd30660b0 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 17 Apr 2025 09:55:34 -0300 Subject: [PATCH 46/55] Merge model list --- .../vcr_cassettes/initial_model_refresh.yml | 1477 +++++++++++++++-- 1 file changed, 1384 insertions(+), 93 deletions(-) diff --git a/spec/fixtures/vcr_cassettes/initial_model_refresh.yml b/spec/fixtures/vcr_cassettes/initial_model_refresh.yml index bf4dcd78..0741f946 100644 --- a/spec/fixtures/vcr_cassettes/initial_model_refresh.yml +++ b/spec/fixtures/vcr_cassettes/initial_model_refresh.yml @@ -34,126 +34,1417 @@ http_interactions: recorded_at: Thu, 27 Mar 2025 20:15:02 GMT - request: method: get - uri: https://bedrock.us-west-2.amazonaws.com/foundation-models + uri: https://api.openai.com/v1/models body: encoding: US-ASCII string: '' headers: User-Agent: - Faraday v2.12.2 - Host: - - bedrock.us-west-2.amazonaws.com - X-Amz-Date: - - 20250325T171540Z - X-Amz-Security-Token: - - IQoJb3JpZ2luX2VjELH//////////wEaCXVzLXdlc3QtMiJGMEQCIDILea5LoQt0bejpnAvGlODePXWs+SVOVYKadYo/Rk9CAiBvj7jTOPExaq5kzi5J7Q2EI2OPjkGHwhnRvXZUSqD6LCqSAwgaEAYaDDIyMTg3MTkxNTQ2MyIMSNqSOazgocTuFlBsKu8C3Nbecj9HZFdBXZ7kaWtb3fByaNE9zYowsMzOb08Ugng8UL9qxzm5g0wT+NFvcJg4JvHNBlfxQyqhoqRAzSN8FAevZ2Pf59sReQbMAaKK0+CdIlH+begPkvTzwGvbj6CQhcRWkeD0UWRgLj1qpwJc2MhogI4CaSILeh/gkUC2fwtLaLK8KoXkrC+XWSvs/P+Qn5gF/YcwWYmlJjo1Y7zkaSRPD/V/SXrdEKCb7lHMkB9HgGSiV0kLg5y6KAcmBbG2HWd7S4qRu0Ko3lm3PIch5E4X7UDcxVLBtX0YErNR7vIRQvpbZ9itrjDqF1Wcckw26asVdC1UxbOSWrnAGqk8RFZrS17i4CP+XV+dQ3jD4/+ILYjKvXynqYA4TAwahL0104h7JCFELXmQOEwPmIPX4hmutyUEkkmfout1krQmzjE01ltNitPgVJzOI3On9YHKqBNp0aEgd6xC9frMseZ8Bb+d8B1Jx9oIBCVvH8RRtTDox4u/BjqnAVK1mPlee72ZUnkKg4jzL3LJL3OmDMBOEGSHmUoOTQ40feXeTlY01glfh7Cx3ExDxAUNIz96zwmhuVVSdwP9aGGsumlYsTJRz7wpDvgq8eGV+9JD9uG+55rtGsH8EzBS9Xw5bxJpBvmpIuRw6fKr7wBiCTTVyRR+Jl7JqGoQelm41v/mXIjzsO43zWUbwInRyFYzqxwmiPSHGwJJnn7eQriksmHxxh4i - X-Amz-Content-Sha256: - - e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 Authorization: - - AWS4-HMAC-SHA256 Credential=ASIATHKEYYHDRJWE7TAB/20250325/us-west-2/bedrock/aws4_request, - SignedHeaders=host;x-amz-content-sha256;x-amz-date;x-amz-security-token, Signature=e4a35761abf5be047cdd3c2b4383e1f3b30031acb59a6254960f1ef94b1a939a + - Bearer + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Date: + - Wed, 02 Apr 2025 17:53:38 GMT Content-Type: - application/json + Transfer-Encoding: + - chunked + Connection: + - keep-alive + Openai-Version: + - '2020-10-01' + X-Request-Id: + - "" + Openai-Processing-Ms: + - '492' + Strict-Transport-Security: + - max-age=31536000; includeSubDomains; preload + Cf-Cache-Status: + - DYNAMIC + Set-Cookie: + - "" + - "" + X-Content-Type-Options: + - nosniff + Server: + - cloudflare + Cf-Ray: + - "" + Alt-Svc: + - h3=":443"; ma=86400 + body: + encoding: ASCII-8BIT + string: |- + { + "object": "list", + "data": [ + { + "id": "gpt-4o-realtime-preview-2024-12-17", + "object": "model", + "created": 1733945430, + "owned_by": "system" + }, + { + "id": "gpt-4o-audio-preview-2024-12-17", + "object": "model", + "created": 1734034239, + "owned_by": "system" + }, + { + "id": "dall-e-3", + "object": "model", + "created": 1698785189, + "owned_by": "system" + }, + { + "id": "dall-e-2", + "object": "model", + "created": 1698798177, + "owned_by": "system" + }, + { + "id": "gpt-4o-audio-preview-2024-10-01", + "object": "model", + "created": 1727389042, + "owned_by": "system" + }, + { + "id": "gpt-4o-mini-realtime-preview-2024-12-17", + "object": "model", + "created": 1734112601, + "owned_by": "system" + }, + { + "id": "gpt-4o-mini-realtime-preview", + "object": "model", + "created": 1734387380, + "owned_by": "system" + }, + { + "id": "gpt-4o-realtime-preview-2024-10-01", + "object": "model", + "created": 1727131766, + "owned_by": "system" + }, + { + "id": "gpt-4o-transcribe", + "object": "model", + "created": 1742068463, + "owned_by": "system" + }, + { + "id": "gpt-4o-mini-transcribe", + "object": "model", + "created": 1742068596, + "owned_by": "system" + }, + { + "id": "gpt-4o-realtime-preview", + "object": "model", + "created": 1727659998, + "owned_by": "system" + }, + { + "id": "babbage-002", + "object": "model", + "created": 1692634615, + "owned_by": "system" + }, + { + "id": "gpt-4o-mini-tts", + "object": "model", + "created": 1742403959, + "owned_by": "system" + }, + { + "id": "tts-1-hd-1106", + "object": "model", + "created": 1699053533, + "owned_by": "system" + }, + { + "id": "text-embedding-3-large", + "object": "model", + "created": 1705953180, + "owned_by": "system" + }, + { + "id": "gpt-4", + "object": "model", + "created": 1687882411, + "owned_by": "openai" + }, + { + "id": "text-embedding-ada-002", + "object": "model", + "created": 1671217299, + "owned_by": "openai-internal" + }, + { + "id": "omni-moderation-latest", + "object": "model", + "created": 1731689265, + "owned_by": "system" + }, + { + "id": "tts-1-hd", + "object": "model", + "created": 1699046015, + "owned_by": "system" + }, + { + "id": "gpt-4o-mini-audio-preview", + "object": "model", + "created": 1734387424, + "owned_by": "system" + }, + { + "id": "gpt-4o-audio-preview", + "object": "model", + "created": 1727460443, + "owned_by": "system" + }, + { + "id": "o1-preview-2024-09-12", + "object": "model", + "created": 1725648865, + "owned_by": "system" + }, + { + "id": "gpt-3.5-turbo-instruct-0914", + "object": "model", + "created": 1694122472, + "owned_by": "system" + }, + { + "id": "gpt-4o-mini-search-preview", + "object": "model", + "created": 1741391161, + "owned_by": "system" + }, + { + "id": "tts-1-1106", + "object": "model", + "created": 1699053241, + "owned_by": "system" + }, + { + "id": "davinci-002", + "object": "model", + "created": 1692634301, + "owned_by": "system" + }, + { + "id": "gpt-3.5-turbo-1106", + "object": "model", + "created": 1698959748, + "owned_by": "system" + }, + { + "id": "gpt-4-turbo", + "object": "model", + "created": 1712361441, + "owned_by": "system" + }, + { + "id": "gpt-4-0125-preview", + "object": "model", + "created": 1706037612, + "owned_by": "system" + }, + { + "id": "gpt-3.5-turbo-instruct", + "object": "model", + "created": 1692901427, + "owned_by": "system" + }, + { + "id": "gpt-3.5-turbo", + "object": "model", + "created": 1677610602, + "owned_by": "openai" + }, + { + "id": "gpt-4-turbo-preview", + "object": "model", + "created": 1706037777, + "owned_by": "system" + }, + { + "id": "chatgpt-4o-latest", + "object": "model", + "created": 1723515131, + "owned_by": "system" + }, + { + "id": "gpt-4o-mini-search-preview-2025-03-11", + "object": "model", + "created": 1741390858, + "owned_by": "system" + }, + { + "id": "gpt-4o-2024-11-20", + "object": "model", + "created": 1739331543, + "owned_by": "system" + }, + { + "id": "whisper-1", + "object": "model", + "created": 1677532384, + "owned_by": "openai-internal" + }, + { + "id": "gpt-3.5-turbo-0125", + "object": "model", + "created": 1706048358, + "owned_by": "system" + }, + { + "id": "gpt-4o-2024-05-13", + "object": "model", + "created": 1715368132, + "owned_by": "system" + }, + { + "id": "gpt-3.5-turbo-16k", + "object": "model", + "created": 1683758102, + "owned_by": "openai-internal" + }, + { + "id": "gpt-4-turbo-2024-04-09", + "object": "model", + "created": 1712601677, + "owned_by": "system" + }, + { + "id": "gpt-4-1106-preview", + "object": "model", + "created": 1698957206, + "owned_by": "system" + }, + { + "id": "o1-preview", + "object": "model", + "created": 1725648897, + "owned_by": "system" + }, + { + "id": "gpt-4-0613", + "object": "model", + "created": 1686588896, + "owned_by": "openai" + }, + { + "id": "gpt-4o-search-preview", + "object": "model", + "created": 1741388720, + "owned_by": "system" + }, + { + "id": "gpt-4.5-preview", + "object": "model", + "created": 1740623059, + "owned_by": "system" + }, + { + "id": "gpt-4.5-preview-2025-02-27", + "object": "model", + "created": 1740623304, + "owned_by": "system" + }, + { + "id": "gpt-4o-search-preview-2025-03-11", + "object": "model", + "created": 1741388170, + "owned_by": "system" + }, + { + "id": "tts-1", + "object": "model", + "created": 1681940951, + "owned_by": "openai-internal" + }, + { + "id": "omni-moderation-2024-09-26", + "object": "model", + "created": 1732734466, + "owned_by": "system" + }, + { + "id": "o1-2024-12-17", + "object": "model", + "created": 1734326976, + "owned_by": "system" + }, + { + "id": "o1", + "object": "model", + "created": 1734375816, + "owned_by": "system" + }, + { + "id": "o1-pro", + "object": "model", + "created": 1742251791, + "owned_by": "system" + }, + { + "id": "text-embedding-3-small", + "object": "model", + "created": 1705948997, + "owned_by": "system" + }, + { + "id": "o1-pro-2025-03-19", + "object": "model", + "created": 1742251504, + "owned_by": "system" + }, + { + "id": "gpt-4o", + "object": "model", + "created": 1715367049, + "owned_by": "system" + }, + { + "id": "gpt-4o-mini", + "object": "model", + "created": 1721172741, + "owned_by": "system" + }, + { + "id": "o3-mini", + "object": "model", + "created": 1737146383, + "owned_by": "system" + }, + { + "id": "gpt-4o-2024-08-06", + "object": "model", + "created": 1722814719, + "owned_by": "system" + }, + { + "id": "o3-mini-2025-01-31", + "object": "model", + "created": 1738010200, + "owned_by": "system" + }, + { + "id": "gpt-4o-mini-2024-07-18", + "object": "model", + "created": 1721172717, + "owned_by": "system" + }, + { + "id": "o1-mini", + "object": "model", + "created": 1725649008, + "owned_by": "system" + }, + { + "id": "gpt-4o-mini-audio-preview-2024-12-17", + "object": "model", + "created": 1734115920, + "owned_by": "system" + }, + { + "id": "o1-mini-2024-09-12", + "object": "model", + "created": 1725648979, + "owned_by": "system" + } + ] + } + recorded_at: Wed, 02 Apr 2025 17:53:38 GMT +- request: + method: get + uri: https://api.anthropic.com/v1/models + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.12.2 + X-Api-Key: + - "" + Anthropic-Version: + - '2023-06-01' + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Date: + - Wed, 02 Apr 2025 17:53:39 GMT + Content-Type: - application/json + Transfer-Encoding: + - chunked + Connection: + - keep-alive + Request-Id: + - "" + Anthropic-Organization-Id: + - 0137b15c-16bf-490d-9f90-8cfd7e325ec0 + Via: + - 1.1 google + Cf-Cache-Status: + - DYNAMIC + X-Robots-Tag: + - none + Server: + - cloudflare + Cf-Ray: + - "" + body: + encoding: ASCII-8BIT + string: '{"data":[{"type":"model","id":"claude-3-7-sonnet-20250219","display_name":"Claude + 3.7 Sonnet","created_at":"2025-02-24T00:00:00Z"},{"type":"model","id":"claude-3-5-sonnet-20241022","display_name":"Claude + 3.5 Sonnet (New)","created_at":"2024-10-22T00:00:00Z"},{"type":"model","id":"claude-3-5-haiku-20241022","display_name":"Claude + 3.5 Haiku","created_at":"2024-10-22T00:00:00Z"},{"type":"model","id":"claude-3-5-sonnet-20240620","display_name":"Claude + 3.5 Sonnet (Old)","created_at":"2024-06-20T00:00:00Z"},{"type":"model","id":"claude-3-haiku-20240307","display_name":"Claude + 3 Haiku","created_at":"2024-03-07T00:00:00Z"},{"type":"model","id":"claude-3-opus-20240229","display_name":"Claude + 3 Opus","created_at":"2024-02-29T00:00:00Z"},{"type":"model","id":"claude-3-sonnet-20240229","display_name":"Claude + 3 Sonnet","created_at":"2024-02-29T00:00:00Z"},{"type":"model","id":"claude-2.1","display_name":"Claude + 2.1","created_at":"2023-11-21T00:00:00Z"},{"type":"model","id":"claude-2.0","display_name":"Claude + 2.0","created_at":"2023-07-11T00:00:00Z"}],"has_more":false,"first_id":"claude-3-7-sonnet-20250219","last_id":"claude-2.0"}' + recorded_at: Wed, 02 Apr 2025 17:53:39 GMT +- request: + method: get + uri: https://generativelanguage.googleapis.com/v1beta/models + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.12.2 + X-Goog-Api-Key: + - "" Accept-Encoding: - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=UTF-8 + Vary: + - Origin + - Referer + - X-Origin + Date: + - Wed, 02 Apr 2025 17:53:39 GMT + Server: + - scaffolding on HTTPServer2 + X-Xss-Protection: + - '0' + X-Frame-Options: + - SAMEORIGIN + X-Content-Type-Options: + - nosniff + Server-Timing: + - gfet4t7; dur=86 + Alt-Svc: + - h3=":443"; ma=2592000,h3-29=":443"; ma=2592000 + Transfer-Encoding: + - chunked + body: + encoding: ASCII-8BIT + string: | + { + "models": [ + { + "name": "models/chat-bison-001", + "version": "001", + "displayName": "PaLM 2 Chat (Legacy)", + "description": "A legacy text-only model optimized for chat conversations", + "inputTokenLimit": 4096, + "outputTokenLimit": 1024, + "supportedGenerationMethods": [ + "generateMessage", + "countMessageTokens" + ], + "temperature": 0.25, + "topP": 0.95, + "topK": 40 + }, + { + "name": "models/text-bison-001", + "version": "001", + "displayName": "PaLM 2 (Legacy)", + "description": "A legacy model that understands text and generates text as an output", + "inputTokenLimit": 8196, + "outputTokenLimit": 1024, + "supportedGenerationMethods": [ + "generateText", + "countTextTokens", + "createTunedTextModel" + ], + "temperature": 0.7, + "topP": 0.95, + "topK": 40 + }, + { + "name": "models/embedding-gecko-001", + "version": "001", + "displayName": "Embedding Gecko", + "description": "Obtain a distributed representation of a text.", + "inputTokenLimit": 1024, + "outputTokenLimit": 1, + "supportedGenerationMethods": [ + "embedText", + "countTextTokens" + ] + }, + { + "name": "models/gemini-1.0-pro-vision-latest", + "version": "001", + "displayName": "Gemini 1.0 Pro Vision", + "description": "The original Gemini 1.0 Pro Vision model version which was optimized for image understanding. Gemini 1.0 Pro Vision was deprecated on July 12, 2024. Move to a newer Gemini version.", + "inputTokenLimit": 12288, + "outputTokenLimit": 4096, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 0.4, + "topP": 1, + "topK": 32 + }, + { + "name": "models/gemini-pro-vision", + "version": "001", + "displayName": "Gemini 1.0 Pro Vision", + "description": "The original Gemini 1.0 Pro Vision model version which was optimized for image understanding. Gemini 1.0 Pro Vision was deprecated on July 12, 2024. Move to a newer Gemini version.", + "inputTokenLimit": 12288, + "outputTokenLimit": 4096, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 0.4, + "topP": 1, + "topK": 32 + }, + { + "name": "models/gemini-1.5-pro-latest", + "version": "001", + "displayName": "Gemini 1.5 Pro Latest", + "description": "Alias that points to the most recent production (non-experimental) release of Gemini 1.5 Pro, our mid-size multimodal model that supports up to 2 million tokens.", + "inputTokenLimit": 2000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-pro-001", + "version": "001", + "displayName": "Gemini 1.5 Pro 001", + "description": "Stable version of Gemini 1.5 Pro, our mid-size multimodal model that supports up to 2 million tokens, released in May of 2024.", + "inputTokenLimit": 2000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens", + "createCachedContent" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-pro-002", + "version": "002", + "displayName": "Gemini 1.5 Pro 002", + "description": "Stable version of Gemini 1.5 Pro, our mid-size multimodal model that supports up to 2 million tokens, released in September of 2024.", + "inputTokenLimit": 2000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens", + "createCachedContent" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-pro", + "version": "001", + "displayName": "Gemini 1.5 Pro", + "description": "Stable version of Gemini 1.5 Pro, our mid-size multimodal model that supports up to 2 million tokens, released in May of 2024.", + "inputTokenLimit": 2000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-flash-latest", + "version": "001", + "displayName": "Gemini 1.5 Flash Latest", + "description": "Alias that points to the most recent production (non-experimental) release of Gemini 1.5 Flash, our fast and versatile multimodal model for scaling across diverse tasks.", + "inputTokenLimit": 1000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-flash-001", + "version": "001", + "displayName": "Gemini 1.5 Flash 001", + "description": "Stable version of Gemini 1.5 Flash, our fast and versatile multimodal model for scaling across diverse tasks, released in May of 2024.", + "inputTokenLimit": 1000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens", + "createCachedContent" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-flash-001-tuning", + "version": "001", + "displayName": "Gemini 1.5 Flash 001 Tuning", + "description": "Version of Gemini 1.5 Flash that supports tuning, our fast and versatile multimodal model for scaling across diverse tasks, released in May of 2024.", + "inputTokenLimit": 16384, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens", + "createTunedModel" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-flash", + "version": "001", + "displayName": "Gemini 1.5 Flash", + "description": "Alias that points to the most recent stable version of Gemini 1.5 Flash, our fast and versatile multimodal model for scaling across diverse tasks.", + "inputTokenLimit": 1000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-flash-002", + "version": "002", + "displayName": "Gemini 1.5 Flash 002", + "description": "Stable version of Gemini 1.5 Flash, our fast and versatile multimodal model for scaling across diverse tasks, released in September of 2024.", + "inputTokenLimit": 1000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens", + "createCachedContent" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-flash-8b", + "version": "001", + "displayName": "Gemini 1.5 Flash-8B", + "description": "Stable version of Gemini 1.5 Flash-8B, our smallest and most cost effective Flash model, released in October of 2024.", + "inputTokenLimit": 1000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "createCachedContent", + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-flash-8b-001", + "version": "001", + "displayName": "Gemini 1.5 Flash-8B 001", + "description": "Stable version of Gemini 1.5 Flash-8B, our smallest and most cost effective Flash model, released in October of 2024.", + "inputTokenLimit": 1000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "createCachedContent", + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-flash-8b-latest", + "version": "001", + "displayName": "Gemini 1.5 Flash-8B Latest", + "description": "Alias that points to the most recent production (non-experimental) release of Gemini 1.5 Flash-8B, our smallest and most cost effective Flash model, released in October of 2024.", + "inputTokenLimit": 1000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "createCachedContent", + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-flash-8b-exp-0827", + "version": "001", + "displayName": "Gemini 1.5 Flash 8B Experimental 0827", + "description": "Experimental release (August 27th, 2024) of Gemini 1.5 Flash-8B, our smallest and most cost effective Flash model. Replaced by Gemini-1.5-flash-8b-001 (stable).", + "inputTokenLimit": 1000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-1.5-flash-8b-exp-0924", + "version": "001", + "displayName": "Gemini 1.5 Flash 8B Experimental 0924", + "description": "Experimental release (September 24th, 2024) of Gemini 1.5 Flash-8B, our smallest and most cost effective Flash model. Replaced by Gemini-1.5-flash-8b-001 (stable).", + "inputTokenLimit": 1000000, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.5-pro-exp-03-25", + "version": "2.5-exp-03-25", + "displayName": "Gemini 2.5 Pro Experimental 03-25", + "description": "Experimental release (March 25th, 2025) of Gemini 2.5 Pro", + "inputTokenLimit": 1048576, + "outputTokenLimit": 65536, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-flash-exp", + "version": "2.0", + "displayName": "Gemini 2.0 Flash Experimental", + "description": "Gemini 2.0 Flash Experimental", + "inputTokenLimit": 1048576, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens", + "bidiGenerateContent" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-flash", + "version": "2.0", + "displayName": "Gemini 2.0 Flash", + "description": "Gemini 2.0 Flash", + "inputTokenLimit": 1048576, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-flash-001", + "version": "2.0", + "displayName": "Gemini 2.0 Flash 001", + "description": "Stable version of Gemini 2.0 Flash, our fast and versatile multimodal model for scaling across diverse tasks, released in January of 2025.", + "inputTokenLimit": 1048576, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-flash-exp-image-generation", + "version": "2.0", + "displayName": "Gemini 2.0 Flash (Image Generation) Experimental", + "description": "Gemini 2.0 Flash (Image Generation) Experimental", + "inputTokenLimit": 1048576, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens", + "bidiGenerateContent" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-flash-lite-001", + "version": "2.0", + "displayName": "Gemini 2.0 Flash-Lite 001", + "description": "Stable version of Gemini 2.0 Flash Lite", + "inputTokenLimit": 1048576, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-flash-lite", + "version": "2.0", + "displayName": "Gemini 2.0 Flash-Lite", + "description": "Gemini 2.0 Flash-Lite", + "inputTokenLimit": 1048576, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-flash-lite-preview-02-05", + "version": "preview-02-05", + "displayName": "Gemini 2.0 Flash-Lite Preview 02-05", + "description": "Preview release (February 5th, 2025) of Gemini 2.0 Flash Lite", + "inputTokenLimit": 1048576, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-flash-lite-preview", + "version": "preview-02-05", + "displayName": "Gemini 2.0 Flash-Lite Preview", + "description": "Preview release (February 5th, 2025) of Gemini 2.0 Flash Lite", + "inputTokenLimit": 1048576, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 40, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-pro-exp", + "version": "2.5-exp-03-25", + "displayName": "Gemini 2.0 Pro Experimental", + "description": "Experimental release (March 25th, 2025) of Gemini 2.5 Pro", + "inputTokenLimit": 1048576, + "outputTokenLimit": 65536, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-pro-exp-02-05", + "version": "2.5-exp-03-25", + "displayName": "Gemini 2.0 Pro Experimental 02-05", + "description": "Experimental release (March 25th, 2025) of Gemini 2.5 Pro", + "inputTokenLimit": 1048576, + "outputTokenLimit": 65536, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemini-exp-1206", + "version": "2.5-exp-03-25", + "displayName": "Gemini Experimental 1206", + "description": "Experimental release (March 25th, 2025) of Gemini 2.5 Pro", + "inputTokenLimit": 1048576, + "outputTokenLimit": 65536, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-flash-thinking-exp-01-21", + "version": "2.0-exp-01-21", + "displayName": "Gemini 2.0 Flash Thinking Experimental 01-21", + "description": "Experimental release (January 21st, 2025) of Gemini 2.0 Flash Thinking", + "inputTokenLimit": 1048576, + "outputTokenLimit": 65536, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 0.7, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-flash-thinking-exp", + "version": "2.0-exp-01-21", + "displayName": "Gemini 2.0 Flash Thinking Experimental 01-21", + "description": "Experimental release (January 21st, 2025) of Gemini 2.0 Flash Thinking", + "inputTokenLimit": 1048576, + "outputTokenLimit": 65536, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 0.7, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.0-flash-thinking-exp-1219", + "version": "2.0", + "displayName": "Gemini 2.0 Flash Thinking Experimental", + "description": "Gemini 2.0 Flash Thinking Experimental", + "inputTokenLimit": 1048576, + "outputTokenLimit": 65536, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 0.7, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/learnlm-1.5-pro-experimental", + "version": "001", + "displayName": "LearnLM 1.5 Pro Experimental", + "description": "Alias that points to the most recent stable version of Gemini 1.5 Pro, our mid-size multimodal model that supports up to 2 million tokens.", + "inputTokenLimit": 32767, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemma-3-4b-it", + "version": "001", + "displayName": "Gemma 3 4B", + "inputTokenLimit": 32768, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64 + }, + { + "name": "models/gemma-3-12b-it", + "version": "001", + "displayName": "Gemma 3 12B", + "inputTokenLimit": 32768, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64 + }, + { + "name": "models/gemma-3-27b-it", + "version": "001", + "displayName": "Gemma 3 27B", + "inputTokenLimit": 131072, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64 + }, + { + "name": "models/embedding-001", + "version": "001", + "displayName": "Embedding 001", + "description": "Obtain a distributed representation of a text.", + "inputTokenLimit": 2048, + "outputTokenLimit": 1, + "supportedGenerationMethods": [ + "embedContent" + ] + }, + { + "name": "models/text-embedding-004", + "version": "004", + "displayName": "Text Embedding 004", + "description": "Obtain a distributed representation of a text.", + "inputTokenLimit": 2048, + "outputTokenLimit": 1, + "supportedGenerationMethods": [ + "embedContent" + ] + }, + { + "name": "models/gemini-embedding-exp-03-07", + "version": "exp-03-07", + "displayName": "Gemini Embedding Experimental 03-07", + "description": "Obtain a distributed representation of a text.", + "inputTokenLimit": 8192, + "outputTokenLimit": 1, + "supportedGenerationMethods": [ + "embedContent" + ] + }, + { + "name": "models/gemini-embedding-exp", + "version": "exp-03-07", + "displayName": "Gemini Embedding Experimental", + "description": "Obtain a distributed representation of a text.", + "inputTokenLimit": 8192, + "outputTokenLimit": 1, + "supportedGenerationMethods": [ + "embedContent" + ] + }, + { + "name": "models/aqa", + "version": "001", + "displayName": "Model that performs Attributed Question Answering.", + "description": "Model trained to return answers to questions that are grounded in provided sources, along with estimating answerable probability.", + "inputTokenLimit": 7168, + "outputTokenLimit": 1024, + "supportedGenerationMethods": [ + "generateAnswer" + ], + "temperature": 0.2, + "topP": 1, + "topK": 40 + }, + { + "name": "models/imagen-3.0-generate-002", + "version": "002", + "displayName": "Imagen 3.0 002 model", + "description": "Vertex served Imagen 3.0 002 model", + "inputTokenLimit": 480, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "predict" + ] + } + ] + } + recorded_at: Wed, 02 Apr 2025 17:53:39 GMT +- request: + method: get + uri: https://api.deepseek.com/models + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.12.2 + Authorization: + - Bearer + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Date: + - Wed, 02 Apr 2025 17:53:39 GMT + Content-Type: + - application/json + Transfer-Encoding: + - chunked + Connection: + - keep-alive + Vary: + - origin, access-control-request-method, access-control-request-headers + Access-Control-Allow-Credentials: + - 'true' + X-Ds-Trace-Id: + - eb9c177a0c3141beac66e5213c60ac6a + Strict-Transport-Security: + - max-age=31536000; includeSubDomains; preload + X-Content-Type-Options: + - nosniff + Cf-Cache-Status: + - DYNAMIC + Set-Cookie: + - "" + Server: + - cloudflare + Cf-Ray: + - "" + body: + encoding: ASCII-8BIT + string: '{"object":"list","data":[{"id":"deepseek-chat","object":"model","owned_by":"deepseek"},{"id":"deepseek-reasoner","object":"model","owned_by":"deepseek"}]}' + recorded_at: Wed, 02 Apr 2025 17:53:39 GMT +- request: + method: get + uri: http://localhost:11434/api/tags + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.12.2 + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/json; charset=utf-8 + Date: + - Wed, 26 Mar 2025 17:18:38 GMT + Content-Length: + - '681' + body: + encoding: UTF-8 + string: '{"models":[{"name":"snowflake-arctic-embed:22m","model":"snowflake-arctic-embed:22m","modified_at":"2025-03-26T17:18:08.367580922Z","size":45838698,"digest":"bf75350e17522c7dfe63e98f50457b27fadcfee62f0c0767c1c86053407c2abb","details":{"parent_model":"","format":"gguf","family":"bert","families":["bert"],"parameter_size":"23M","quantization_level":"F16"}},{"name":"smollm:135m","model":"smollm:135m","modified_at":"2025-03-26T17:18:01.303574119Z","size":91739413,"digest":"b0b2a46174385c0adcaa77ff245ffeced5fc4a61447b6f221b2beb5c5a760133","details":{"parent_model":"","format":"gguf","family":"llama","families":["llama"],"parameter_size":"134.52M","quantization_level":"Q4_0"}}]}' + recorded_at: Wed, 26 Mar 2025 17:18:38 GMT +- request: + method: get + uri: https://bedrock..amazonaws.com/foundation-models + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.12.2 + Host: + - bedrock..amazonaws.com + X-Amz-Date: + - 20250402T175339Z + X-Amz-Content-Sha256: + - e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 + Authorization: + - AWS4-HMAC-SHA256 Credential=/20250402//bedrock/aws4_request, + SignedHeaders=host;x-amz-content-sha256;x-amz-date, Signature=5f69d324c05740f272e7c07046b973076335bd284cd150f03901ba9b30a62f4e + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" response: status: code: 200 message: OK headers: Date: - - Tue, 25 Mar 2025 17:14:59 GMT + - Wed, 02 Apr 2025 17:53:40 GMT Content-Type: - application/json Content-Length: - - '45249' + - '45253' Connection: - keep-alive X-Amzn-Requestid: - - '08c81519-bf5d-4c0f-8dad-e1fe0e12c7fa' + - 62d4de6c-de54-44b7-b02e-51731449128a body: encoding: UTF-8 - string: '{"modelSummaries":[{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-tg1-large","modelId":"amazon.titan-tg1-large","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Text Large","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-g1-text-02","modelId":"amazon.titan-embed-g1-text-02","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Text Embeddings v2","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING","CONTINUED_PRE_TRAINING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-lite-v1:0:4k","modelId":"amazon.titan-text-lite-v1:0:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Text G1 - Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-lite-v1","modelId":"amazon.titan-text-lite-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Text G1 - Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","CONTINUED_PRE_TRAINING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-express-v1:0:8k","modelId":"amazon.titan-text-express-v1:0:8k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Text G1 - Express","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-text-express-v1","modelId":"amazon.titan-text-express-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Text G1 - Express","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE","VIDEO"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.nova-pro-v1:0","modelId":"amazon.nova-pro-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova - Pro","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE","VIDEO"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.nova-lite-v1:0","modelId":"amazon.nova-lite-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova - Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.nova-micro-v1:0","modelId":"amazon.nova-micro-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova - Micro","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-text-v1:2:8k","modelId":"amazon.titan-embed-text-v1:2:8k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Embeddings G1 - Text","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-text-v1","modelId":"amazon.titan-embed-text-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Embeddings G1 - Text","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-text-v2:0","modelId":"amazon.titan-embed-text-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Text Embeddings V2","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-image-v1:0","modelId":"amazon.titan-embed-image-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Multimodal Embeddings G1","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-embed-image-v1","modelId":"amazon.titan-embed-image-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Multimodal Embeddings G1","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-image-generator-v1:0","modelId":"amazon.titan-image-generator-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Image Generator G1","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-image-generator-v1","modelId":"amazon.titan-image-generator-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Image Generator G1","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED","ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.titan-image-generator-v2:0","modelId":"amazon.titan-image-generator-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan - Image Generator G1 v2","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/amazon.rerank-v1:0","modelId":"amazon.rerank-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Rerank - 1.0","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-diffusion-xl-v1:0","modelId":"stability.stable-diffusion-xl-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"SDXL - 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-diffusion-xl-v1","modelId":"stability.stable-diffusion-xl-v1","modelLifecycle":{"status":"LEGACY"},"modelName":"SDXL - 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.sd3-large-v1:0","modelId":"stability.sd3-large-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"SD3 - Large 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.sd3-5-large-v1:0","modelId":"stability.sd3-5-large-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable + string: '{"modelSummaries":[{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-tg1-large","modelId":"amazon.titan-tg1-large","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text Large","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-embed-g1-text-02","modelId":"amazon.titan-embed-g1-text-02","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text Embeddings v2","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING","CONTINUED_PRE_TRAINING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-text-lite-v1:0:4k","modelId":"amazon.titan-text-lite-v1:0:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-text-lite-v1","modelId":"amazon.titan-text-lite-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","CONTINUED_PRE_TRAINING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-text-express-v1:0:8k","modelId":"amazon.titan-text-express-v1:0:8k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Express","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-text-express-v1","modelId":"amazon.titan-text-express-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text G1 - Express","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE","VIDEO"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.nova-pro-v1:0","modelId":"amazon.nova-pro-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova + Pro","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE","VIDEO"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.nova-lite-v1:0","modelId":"amazon.nova-lite-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova + Lite","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.nova-micro-v1:0","modelId":"amazon.nova-micro-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Nova + Micro","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-embed-text-v1:2:8k","modelId":"amazon.titan-embed-text-v1:2:8k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Embeddings G1 - Text","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-embed-text-v1","modelId":"amazon.titan-embed-text-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Embeddings G1 - Text","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-embed-text-v2:0","modelId":"amazon.titan-embed-text-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Text Embeddings V2","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-embed-image-v1:0","modelId":"amazon.titan-embed-image-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Multimodal Embeddings G1","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-embed-image-v1","modelId":"amazon.titan-embed-image-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Multimodal Embeddings G1","outputModalities":["EMBEDDING"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-image-generator-v1:0","modelId":"amazon.titan-image-generator-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Image Generator G1","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-image-generator-v1","modelId":"amazon.titan-image-generator-v1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Image Generator G1","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED","ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-image-generator-v2:0","modelId":"amazon.titan-image-generator-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan + Image Generator G1 v2","outputModalities":["IMAGE"],"providerName":"Amazon","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.rerank-v1:0","modelId":"amazon.rerank-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Rerank + 1.0","outputModalities":["TEXT"],"providerName":"Amazon","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/stability.stable-diffusion-xl-v1:0","modelId":"stability.stable-diffusion-xl-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"SDXL + 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/stability.stable-diffusion-xl-v1","modelId":"stability.stable-diffusion-xl-v1","modelLifecycle":{"status":"LEGACY"},"modelName":"SDXL + 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/stability.sd3-large-v1:0","modelId":"stability.sd3-large-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"SD3 + Large 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/stability.sd3-5-large-v1:0","modelId":"stability.sd3-5-large-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable Diffusion 3.5 Large","outputModalities":["IMAGE"],"providerName":"Stability - AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-core-v1:0","modelId":"stability.stable-image-core-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Stable - Image Core 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-core-v1:1","modelId":"stability.stable-image-core-v1:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable - Image Core 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-ultra-v1:0","modelId":"stability.stable-image-ultra-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Stable - Image Ultra 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/stability.stable-image-ultra-v1:1","modelId":"stability.stable-image-ultra-v1:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable - Image Ultra 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:18k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:18k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:51k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:51k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:200k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-7-sonnet-20250219-v1:0","modelId":"anthropic.claude-3-7-sonnet-20250219-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3.7 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-haiku-20241022-v1:0","modelId":"anthropic.claude-3-5-haiku-20241022-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3.5 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-instant-v1:2:100k","modelId":"anthropic.claude-instant-v1:2:100k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude - Instant","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-instant-v1","modelId":"anthropic.claude-instant-v1","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude - Instant","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:0:18k","modelId":"anthropic.claude-v2:0:18k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:0:100k","modelId":"anthropic.claude-v2:0:100k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:1:18k","modelId":"anthropic.claude-v2:1:18k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:1:200k","modelId":"anthropic.claude-v2:1:200k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2:1","modelId":"anthropic.claude-v2:1","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-v2","modelId":"anthropic.claude-v2","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0:28k","modelId":"anthropic.claude-3-sonnet-20240229-v1:0:28k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude - 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0:200k","modelId":"anthropic.claude-3-sonnet-20240229-v1:0:200k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude - 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0","modelId":"anthropic.claude-3-sonnet-20240229-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude - 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-haiku-20240307-v1:0:48k","modelId":"anthropic.claude-3-haiku-20240307-v1:0:48k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-haiku-20240307-v1:0:200k","modelId":"anthropic.claude-3-haiku-20240307-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-haiku-20240307-v1:0","modelId":"anthropic.claude-3-haiku-20240307-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0:12k","modelId":"anthropic.claude-3-opus-20240229-v1:0:12k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0:28k","modelId":"anthropic.claude-3-opus-20240229-v1:0:28k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0:200k","modelId":"anthropic.claude-3-opus-20240229-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-opus-20240229-v1:0","modelId":"anthropic.claude-3-opus-20240229-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:18k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:18k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:51k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:51k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:200k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND","INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude - 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-text-v14:7:4k","modelId":"cohere.command-text-v14:7:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-text-v14","modelId":"cohere.command-text-v14","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-r-v1:0","modelId":"cohere.command-r-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command - R","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-r-plus-v1:0","modelId":"cohere.command-r-plus-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command - R+","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-light-text-v14:7:4k","modelId":"cohere.command-light-text-v14:7:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command - Light","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.command-light-text-v14","modelId":"cohere.command-light-text-v14","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command - Light","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-english-v3:0:512","modelId":"cohere.embed-english-v3:0:512","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed - English","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-english-v3","modelId":"cohere.embed-english-v3","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed - English","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-multilingual-v3:0:512","modelId":"cohere.embed-multilingual-v3:0:512","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed - Multilingual","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.embed-multilingual-v3","modelId":"cohere.embed-multilingual-v3","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed - Multilingual","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/cohere.rerank-v3-5:0","modelId":"cohere.rerank-v3-5:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Rerank - 3.5","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/deepseek.r1-v1:0","modelId":"deepseek.r1-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"DeepSeek-R1","outputModalities":["TEXT"],"providerName":"DeepSeek","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-8b-instruct-v1:0","modelId":"meta.llama3-8b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-70b-instruct-v1:0","modelId":"meta.llama3-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-8b-instruct-v1:0:128k","modelId":"meta.llama3-1-8b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.1 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-8b-instruct-v1:0","modelId":"meta.llama3-1-8b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.1 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-70b-instruct-v1:0:128k","modelId":"meta.llama3-1-70b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.1 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-70b-instruct-v1:0","modelId":"meta.llama3-1-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.1 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-1-405b-instruct-v1:0","modelId":"meta.llama3-1-405b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.1 405B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-11b-instruct-v1:0:128k","modelId":"meta.llama3-2-11b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.2 11B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-11b-instruct-v1:0","modelId":"meta.llama3-2-11b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.2 11B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-90b-instruct-v1:0:128k","modelId":"meta.llama3-2-90b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.2 90B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-90b-instruct-v1:0","modelId":"meta.llama3-2-90b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.2 90B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-1b-instruct-v1:0:128k","modelId":"meta.llama3-2-1b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.2 1B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-1b-instruct-v1:0","modelId":"meta.llama3-2-1b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.2 1B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-3b-instruct-v1:0:128k","modelId":"meta.llama3-2-3b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.2 3B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-2-3b-instruct-v1:0","modelId":"meta.llama3-2-3b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.2 3B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/meta.llama3-3-70b-instruct-v1:0","modelId":"meta.llama3-3-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama - 3.3 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mistral-7b-instruct-v0:2","modelId":"mistral.mistral-7b-instruct-v0:2","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral - 7B Instruct","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mixtral-8x7b-instruct-v0:1","modelId":"mistral.mixtral-8x7b-instruct-v0:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mixtral - 8x7B Instruct","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mistral-large-2402-v1:0","modelId":"mistral.mistral-large-2402-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral - Large (24.02)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/mistral.mistral-large-2407-v1:0","modelId":"mistral.mistral-large-2407-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral - Large (24.07)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:us-west-2::foundation-model/luma.ray-v2:0","modelId":"luma.ray-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Ray + AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/stability.stable-image-core-v1:0","modelId":"stability.stable-image-core-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Stable + Image Core 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/stability.stable-image-core-v1:1","modelId":"stability.stable-image-core-v1:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable + Image Core 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/stability.stable-image-ultra-v1:0","modelId":"stability.stable-image-ultra-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Stable + Image Ultra 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/stability.stable-image-ultra-v1:1","modelId":"stability.stable-image-ultra-v1:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Stable + Image Ultra 1.0","outputModalities":["IMAGE"],"providerName":"Stability AI","responseStreamingSupported":null},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:18k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:18k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:51k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:51k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0:200k","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-5-sonnet-20241022-v2:0","modelId":"anthropic.claude-3-5-sonnet-20241022-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet v2","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-7-sonnet-20250219-v1:0","modelId":"anthropic.claude-3-7-sonnet-20250219-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.7 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":true},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-5-haiku-20241022-v1:0","modelId":"anthropic.claude-3-5-haiku-20241022-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-instant-v1:2:100k","modelId":"anthropic.claude-instant-v1:2:100k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + Instant","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-instant-v1","modelId":"anthropic.claude-instant-v1","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + Instant","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-v2:0:18k","modelId":"anthropic.claude-v2:0:18k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-v2:0:100k","modelId":"anthropic.claude-v2:0:100k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-v2:1:18k","modelId":"anthropic.claude-v2:1:18k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-v2:1:200k","modelId":"anthropic.claude-v2:1:200k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-v2:1","modelId":"anthropic.claude-v2:1","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-v2","modelId":"anthropic.claude-v2","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0:28k","modelId":"anthropic.claude-3-sonnet-20240229-v1:0:28k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0:200k","modelId":"anthropic.claude-3-sonnet-20240229-v1:0:200k","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-sonnet-20240229-v1:0","modelId":"anthropic.claude-3-sonnet-20240229-v1:0","modelLifecycle":{"status":"LEGACY"},"modelName":"Claude + 3 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-haiku-20240307-v1:0:48k","modelId":"anthropic.claude-3-haiku-20240307-v1:0:48k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-haiku-20240307-v1:0:200k","modelId":"anthropic.claude-3-haiku-20240307-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-haiku-20240307-v1:0","modelId":"anthropic.claude-3-haiku-20240307-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Haiku","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-opus-20240229-v1:0:12k","modelId":"anthropic.claude-3-opus-20240229-v1:0:12k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-opus-20240229-v1:0:28k","modelId":"anthropic.claude-3-opus-20240229-v1:0:28k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-opus-20240229-v1:0:200k","modelId":"anthropic.claude-3-opus-20240229-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-opus-20240229-v1:0","modelId":"anthropic.claude-3-opus-20240229-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3 Opus","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:18k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:18k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:51k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:51k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0:200k","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0:200k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND","INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:::foundation-model/anthropic.claude-3-5-sonnet-20240620-v1:0","modelId":"anthropic.claude-3-5-sonnet-20240620-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Claude + 3.5 Sonnet","outputModalities":["TEXT"],"providerName":"Anthropic","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/cohere.command-text-v14:7:4k","modelId":"cohere.command-text-v14:7:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/cohere.command-text-v14","modelId":"cohere.command-text-v14","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/cohere.command-r-v1:0","modelId":"cohere.command-r-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + R","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/cohere.command-r-plus-v1:0","modelId":"cohere.command-r-plus-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + R+","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/cohere.command-light-text-v14:7:4k","modelId":"cohere.command-light-text-v14:7:4k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + Light","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/cohere.command-light-text-v14","modelId":"cohere.command-light-text-v14","modelLifecycle":{"status":"ACTIVE"},"modelName":"Command + Light","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/cohere.embed-english-v3:0:512","modelId":"cohere.embed-english-v3:0:512","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + English","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/cohere.embed-english-v3","modelId":"cohere.embed-english-v3","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + English","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/cohere.embed-multilingual-v3:0:512","modelId":"cohere.embed-multilingual-v3:0:512","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + Multilingual","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/cohere.embed-multilingual-v3","modelId":"cohere.embed-multilingual-v3","modelLifecycle":{"status":"ACTIVE"},"modelName":"Embed + Multilingual","outputModalities":["EMBEDDING"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/cohere.rerank-v3-5:0","modelId":"cohere.rerank-v3-5:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Rerank + 3.5","outputModalities":["TEXT"],"providerName":"Cohere","responseStreamingSupported":false},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/deepseek.r1-v1:0","modelId":"deepseek.r1-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"DeepSeek-R1","outputModalities":["TEXT"],"providerName":"DeepSeek","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-8b-instruct-v1:0","modelId":"meta.llama3-8b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-70b-instruct-v1:0","modelId":"meta.llama3-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-1-8b-instruct-v1:0:128k","modelId":"meta.llama3-1-8b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-1-8b-instruct-v1:0","modelId":"meta.llama3-1-8b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 8B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING","DISTILLATION"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-1-70b-instruct-v1:0:128k","modelId":"meta.llama3-1-70b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-1-70b-instruct-v1:0","modelId":"meta.llama3-1-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-1-405b-instruct-v1:0","modelId":"meta.llama3-1-405b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.1 405B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-2-11b-instruct-v1:0:128k","modelId":"meta.llama3-2-11b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 11B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-2-11b-instruct-v1:0","modelId":"meta.llama3-2-11b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 11B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-2-90b-instruct-v1:0:128k","modelId":"meta.llama3-2-90b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 90B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-2-90b-instruct-v1:0","modelId":"meta.llama3-2-90b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 90B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-2-1b-instruct-v1:0:128k","modelId":"meta.llama3-2-1b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 1B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-2-1b-instruct-v1:0","modelId":"meta.llama3-2-1b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 1B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":["FINE_TUNING"],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["PROVISIONED"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-2-3b-instruct-v1:0:128k","modelId":"meta.llama3-2-3b-instruct-v1:0:128k","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 3B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-2-3b-instruct-v1:0","modelId":"meta.llama3-2-3b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.2 3B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":true},"modelArn":"arn:aws:bedrock:::foundation-model/meta.llama3-3-70b-instruct-v1:0","modelId":"meta.llama3-3-70b-instruct-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Llama + 3.3 70B Instruct","outputModalities":["TEXT"],"providerName":"Meta","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/mistral.mistral-7b-instruct-v0:2","modelId":"mistral.mistral-7b-instruct-v0:2","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral + 7B Instruct","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/mistral.mixtral-8x7b-instruct-v0:1","modelId":"mistral.mixtral-8x7b-instruct-v0:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mixtral + 8x7B Instruct","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/mistral.mistral-large-2402-v1:0","modelId":"mistral.mistral-large-2402-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral + Large (24.02)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/mistral.mistral-large-2407-v1:0","modelId":"mistral.mistral-large-2407-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral + Large (24.07)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/luma.ray-v2:0","modelId":"luma.ray-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Ray v2","outputModalities":["VIDEO"],"providerName":"Luma AI","responseStreamingSupported":false}]}' - recorded_at: Tue, 25 Mar 2025 17:15:40 GMT + recorded_at: Wed, 02 Apr 2025 17:53:40 GMT recorded_with: VCR 6.3.1 From 45aaf1c8d5abccafc5b5e29bbc03c12607eed513 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 17 Apr 2025 10:14:30 -0300 Subject: [PATCH 47/55] HACK: manually add in gpt-4.1-nano to model list response After tests were changed to use `gpt-4.1-nano` in 7017dcf, these cassettes were not refreshed: - `spec/fixtures/vcr_cassettes/models_refresh_updates_models_and_returns_a_chainable_models_instance.yml` - `spec/fixtures/vcr_cassettes/models_refresh_works_as_a_class_method_too.yml` My branch does `models.refresh!` into a cassette named `spec/fixtures/vcr_cassettes/initial_model_refresh.yml` where I have been copying responses from the above original files, but right now I don't have the model list responses for the new `gpt-4.1-nano` ones and tests can't run with unknown models. The proper solution is to delete all these files then re-run the tests to get fresh data from each source, but meanwhile, this commit jury-rigs nano into the response. --- spec/fixtures/vcr_cassettes/initial_model_refresh.yml | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/spec/fixtures/vcr_cassettes/initial_model_refresh.yml b/spec/fixtures/vcr_cassettes/initial_model_refresh.yml index 0741f946..00b0b732 100644 --- a/spec/fixtures/vcr_cassettes/initial_model_refresh.yml +++ b/spec/fixtures/vcr_cassettes/initial_model_refresh.yml @@ -464,6 +464,12 @@ http_interactions: "object": "model", "created": 1725648979, "owned_by": "system" + }, + { + "id": "gpt-4.1-nano", + "object": "model", + "created": 1725648979, + "owned_by": "system" } ] } From cafac0942854042a07d45879bbd57e1ff98062a6 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 17 Apr 2025 10:45:17 -0300 Subject: [PATCH 48/55] Use a low temperature for tool specs Llama-3.1 has trouble with tool usage with default temperatures; it will sometimes use available tools but most times it will opt not to and hallucinate instead, making the tests brittle. And lower temp mitigates this and will probably reflect real world usage anyway. --- spec/ruby_llm/chat_tools_spec.rb | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/spec/ruby_llm/chat_tools_spec.rb b/spec/ruby_llm/chat_tools_spec.rb index a00ac3ed..d9fb51df 100644 --- a/spec/ruby_llm/chat_tools_spec.rb +++ b/spec/ruby_llm/chat_tools_spec.rb @@ -43,6 +43,7 @@ def execute provider = RubyLLM::Models.provider_for(model).slug it "#{provider}/#{model} can use tools" do # rubocop:disable RSpec/MultipleExpectations chat = RubyLLM.chat(model: model) + .with_temperature(0.1) .with_tool(Weather) response = chat.ask("What's the weather in Berlin? (52.5200, 13.4050)") @@ -55,6 +56,7 @@ def execute provider = RubyLLM::Models.provider_for(model).slug it "#{provider}/#{model} can use tools in multi-turn conversations" do # rubocop:disable RSpec/ExampleLength,RSpec/MultipleExpectations chat = RubyLLM.chat(model: model) + .with_temperature(0.1) .with_tool(Weather) response = chat.ask("What's the weather in Berlin? (52.5200, 13.4050)") @@ -79,7 +81,9 @@ def execute chat_models.each do |model| # rubocop:disable Style/CombinableLoops provider = RubyLLM::Models.provider_for(model).slug it "#{provider}/#{model} can use tools without parameters in multi-turn streaming conversations" do # rubocop:disable RSpec/ExampleLength,RSpec/MultipleExpectations - chat = RubyLLM.chat(model: model).with_tool(BestLanguageToLearn) + chat = RubyLLM.chat(model: model) + .with_temperature(0.1) + .with_tool(BestLanguageToLearn) chunks = [] response = chat.ask("What's the best language to learn?") do |chunk| @@ -104,6 +108,7 @@ def execute provider = RubyLLM::Models.provider_for(model).slug it "#{provider}/#{model} can use tools with multi-turn streaming conversations" do # rubocop:disable RSpec/ExampleLength,RSpec/MultipleExpectations chat = RubyLLM.chat(model: model) + .with_temperature(0.1) .with_tool(Weather) chunks = [] From 1667851cdb38e6ba4bcc79e8289d3bb9500a2797 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 17 Apr 2025 10:43:07 -0300 Subject: [PATCH 49/55] Refresh cassettes --- ...8b_can_handle_multi-turn_conversations.yml | 89 +++++++++------- ...ma3_1_8b_can_have_a_basic_conversation.yml | 10 +- ...ious_system_messages_when_replace_true.yml | 18 ++-- ...8b_successfully_uses_the_system_prompt.yml | 8 +- ...lling_ollama_llama3_1_8b_can_use_tools.yml | 18 ++-- ..._use_tools_in_multi-turn_conversations.yml | 52 ++++----- ...ith_multi-turn_streaming_conversations.yml | 52 +++++---- ..._1_8b_can_use_tools_without_parameters.yml | 31 +++--- ..._in_multi-turn_streaming_conversations.yml | 100 ++++++++++++------ ...ama3_1_8b_supports_streaming_responses.yml | 30 +++--- ...ite3_2-vision_2b_can_understand_images.yml | 13 ++- ...tic-embed_22m_can_handle_a_single_text.yml | 6 +- ...ic-embed_22m_can_handle_multiple_texts.yml | 6 +- 13 files changed, 233 insertions(+), 200 deletions(-) diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_handle_multi-turn_conversations.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_handle_multi-turn_conversations.yml index dd5b93b4..5be1f6a6 100644 --- a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_handle_multi-turn_conversations.yml +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_handle_multi-turn_conversations.yml @@ -24,30 +24,34 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:25:22 GMT + - Thu, 17 Apr 2025 13:21:31 GMT Server: - Caddy Vary: - Accept-Encoding Content-Length: - - '1253' + - '1619' body: encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:22.619412823Z","message":{"role":"assistant","content":"The - creator of the Ruby programming language is Yukihiro Matsumoto, a Japanese - computer programmer. He began working on Ruby in 1993 and released the first - version, Ruby 1.0, in December 1995.\n\nMatsumoto, who is also known as \"Matz,\" - was born in 1960 in Nagoya, Japan. He studied computer science at Nagoya University - and later worked for several companies in Japan before starting his work on - Ruby.\n\nMatsumoto''s goal with Ruby was to create a language that combined - the features of Perl, Smalltalk, and Ada, which he considered the best aspects - of each language. He wanted to create a language that was easy to use, flexible, - and could be used for rapid development and prototyping.\n\nToday, Ruby is - widely used in web development, scripting, and other areas, thanks to its - simplicity, flexibility, and powerful libraries such as Rails. Matsumoto continues - to contribute to the Ruby community and is still involved with the language''s - development."},"done_reason":"stop","done":true,"total_duration":2083117838,"load_duration":15975913,"prompt_eval_count":17,"prompt_eval_duration":25655133,"eval_count":206,"eval_duration":2041201259}' - recorded_at: Fri, 11 Apr 2025 20:25:19 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:21:31.076435262Z","message":{"role":"assistant","content":"The + creator of the Ruby programming language is Yukihiro Matsumoto, also known + as \"Matz\". He is a Japanese computer programmer and software developer who + developed Ruby in the mid-1990s. Matsumoto''s goal was to create a language + that was more enjoyable to use than other languages available at the time, + with a focus on ease of use, simplicity, and flexibility.\n\nMatsumoto began + working on Ruby in 1993 while he was working for the Japanese telecommunications + company SGI (Silicon Graphics Inc.). He released the first version of Ruby, + known as \"Ruby 0.95,\" in December 1995. Over the years, Matsumoto continued + to develop and improve Ruby, releasing new versions and features.\n\nToday, + Ruby is a popular language used for web development, scripting, and other + applications, thanks in large part to its simplicity, ease of use, and flexibility. + The Ruby community has also developed numerous libraries and frameworks, such + as Rails (Ruby on Rails), which have helped to further establish Ruby''s position + as a major player in the programming world.\n\nYukihiro Matsumoto is still + involved with the Ruby project, but he has passed on the leadership role to + other developers within the community. Despite this, his legacy lives on through + the language itself and its widespread adoption by developers around the world!"},"done_reason":"stop","done":true,"total_duration":2662940512,"load_duration":14914899,"prompt_eval_count":17,"prompt_eval_duration":4056466,"eval_count":271,"eval_duration":2643548421}' + recorded_at: Thu, 17 Apr 2025 13:21:23 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -55,19 +59,24 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Who was the creator of Ruby?"},{"role":"assistant","content":"The creator of the Ruby - programming language is Yukihiro Matsumoto, a Japanese computer programmer. - He began working on Ruby in 1993 and released the first version, Ruby 1.0, - in December 1995.\n\nMatsumoto, who is also known as \"Matz,\" was born in - 1960 in Nagoya, Japan. He studied computer science at Nagoya University and - later worked for several companies in Japan before starting his work on Ruby.\n\nMatsumoto''s - goal with Ruby was to create a language that combined the features of Perl, - Smalltalk, and Ada, which he considered the best aspects of each language. - He wanted to create a language that was easy to use, flexible, and could be - used for rapid development and prototyping.\n\nToday, Ruby is widely used - in web development, scripting, and other areas, thanks to its simplicity, - flexibility, and powerful libraries such as Rails. Matsumoto continues to - contribute to the Ruby community and is still involved with the language''s - development."},{"role":"user","content":"What year did he create Ruby?"}],"options":{"temperature":0.7},"stream":false}' + programming language is Yukihiro Matsumoto, also known as \"Matz\". He is + a Japanese computer programmer and software developer who developed Ruby in + the mid-1990s. Matsumoto''s goal was to create a language that was more enjoyable + to use than other languages available at the time, with a focus on ease of + use, simplicity, and flexibility.\n\nMatsumoto began working on Ruby in 1993 + while he was working for the Japanese telecommunications company SGI (Silicon + Graphics Inc.). He released the first version of Ruby, known as \"Ruby 0.95,\" + in December 1995. Over the years, Matsumoto continued to develop and improve + Ruby, releasing new versions and features.\n\nToday, Ruby is a popular language + used for web development, scripting, and other applications, thanks in large + part to its simplicity, ease of use, and flexibility. The Ruby community has + also developed numerous libraries and frameworks, such as Rails (Ruby on Rails), + which have helped to further establish Ruby''s position as a major player + in the programming world.\n\nYukihiro Matsumoto is still involved with the + Ruby project, but he has passed on the leadership role to other developers + within the community. Despite this, his legacy lives on through the language + itself and its widespread adoption by developers around the world!"},{"role":"user","content":"What + year did he create Ruby?"}],"options":{"temperature":0.7},"stream":false}' headers: User-Agent: - Faraday v2.12.2 @@ -85,20 +94,22 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:25:23 GMT + - Thu, 17 Apr 2025 13:21:32 GMT Server: - Caddy Vary: - Accept-Encoding Content-Length: - - '697' + - '814' body: encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:23.592467715Z","message":{"role":"assistant","content":"Yukihiro - Matsumoto started working on Ruby in 1993, but it was first released in 1995 - under the name \"Ruby\" (although initially called \"Pearl\" before being - changed to avoid a trademark conflict with the company Gemstone Systems).\n\nHowever, - if you''re asking when he began conceptualizing and designing Ruby, that would - be around 1992-1993.\n\nThe first public release of Ruby was in December 1995."},"done_reason":"stop","done":true,"total_duration":969542955,"load_duration":14935414,"prompt_eval_count":239,"prompt_eval_duration":4486434,"eval_count":93,"eval_duration":949351502}' - recorded_at: Fri, 11 Apr 2025 20:25:20 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:21:32.445899232Z","message":{"role":"assistant","content":"Yukihiro + Matsumoto started working on Ruby in 1993, but it wasn''t released until December + 1995.\n\nHere''s a brief timeline:\n\n* 1993: Yukihiro Matsumoto begins working + on the language that will eventually become Ruby.\n* May 1995: The first public + version of Ruby is released, known as \"Ruby 0.95\".\n* December 1995: The + first official version of Ruby is released, known as \"Ruby 1.0\".\n\nSo, + while Matsumoto started working on the language in 1993, the first public + and official versions were released in 1995."},"done_reason":"stop","done":true,"total_duration":1365542477,"load_duration":14586907,"prompt_eval_count":304,"prompt_eval_duration":4233642,"eval_count":132,"eval_duration":1345840272}' + recorded_at: Thu, 17 Apr 2025 13:21:25 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_have_a_basic_conversation.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_have_a_basic_conversation.yml index a0c6f0ec..1b023fe7 100644 --- a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_have_a_basic_conversation.yml +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_can_have_a_basic_conversation.yml @@ -22,16 +22,16 @@ http_interactions: message: OK headers: Content-Length: - - '310' + - '309' Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:24:03 GMT + - Thu, 17 Apr 2025 13:21:28 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:24:03.848130137Z","message":{"role":"assistant","content":"The - answer is: 4!"},"done_reason":"stop","done":true,"total_duration":132852925,"load_duration":18835949,"prompt_eval_count":18,"prompt_eval_duration":31501211,"eval_count":8,"eval_duration":82031197}' - recorded_at: Fri, 11 Apr 2025 20:24:00 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:21:28.409524352Z","message":{"role":"assistant","content":"The + answer is 4."},"done_reason":"stop","done":true,"total_duration":133443334,"load_duration":18094446,"prompt_eval_count":18,"prompt_eval_duration":34383870,"eval_count":7,"eval_duration":80424039}' + recorded_at: Thu, 17 Apr 2025 13:21:21 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_replaces_previous_system_messages_when_replace_true.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_replaces_previous_system_messages_when_replace_true.yml index 1b7aea84..b2429c45 100644 --- a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_replaces_previous_system_messages_when_replace_true.yml +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_replaces_previous_system_messages_when_replace_true.yml @@ -25,16 +25,16 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:24:10 GMT + - Thu, 17 Apr 2025 13:21:36 GMT Server: - Caddy Vary: - Accept-Encoding Content-Length: - - '1169' + - '1168' body: encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:24:10.088054586Z","message":{"role":"assistant","content":"The + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:21:36.33027316Z","message":{"role":"assistant","content":"The weather! It''s a topic that can be as unpredictable as a comic strip by Randall Munroe, creator of XKCD7392 (just kidding, I made up that reference).\n\nBut seriously, the weather is a complex and dynamic system that can vary greatly @@ -46,8 +46,8 @@ http_interactions: local news or weather reports on TV or radio.\n3. Use a voice assistant like Siri, Google Assistant, or Alexa to get the latest weather updates.\n\nRemember to always check the forecast before heading out, especially if you have outdoor - plans!"},"done_reason":"stop","done":true,"total_duration":1855020675,"load_duration":14571739,"prompt_eval_count":39,"prompt_eval_duration":2653810,"eval_count":186,"eval_duration":1837339473}' - recorded_at: Fri, 11 Apr 2025 20:24:06 GMT + plans!"},"done_reason":"stop","done":true,"total_duration":1824917302,"load_duration":14499947,"prompt_eval_count":39,"prompt_eval_duration":2375885,"eval_count":186,"eval_duration":1807538871}' + recorded_at: Thu, 17 Apr 2025 13:21:28 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -85,7 +85,7 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:24:15 GMT + - Thu, 17 Apr 2025 13:21:41 GMT Server: - Caddy Vary: @@ -94,7 +94,7 @@ http_interactions: - chunked body: encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.144612445Z","message":{"role":"assistant","content":"There + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.318281426Z","message":{"role":"assistant","content":"There are so many great books out there, it''s hard to narrow it down. But I''ll give you a few recommendations across various genres:\n\n**Fiction**\n\n1. \"The Hitchhiker''s Guide to the Galaxy\" by Douglas Adams - A comedic science @@ -122,6 +122,6 @@ http_interactions: out there. But if you''re looking for something to get started, I hope this helps!\n\nAnd remember, when it comes to reading, the possibilities are as vast as the number of stars in the universe... or at least, that''s what I''d - like to think, but let''s be real, it''s probably more like PURPLE-ELEPHANT-42."},"done_reason":"stop","done":true,"total_duration":5052746637,"load_duration":14525916,"prompt_eval_count":243,"prompt_eval_duration":15682393,"eval_count":493,"eval_duration":5021731638}' - recorded_at: Fri, 11 Apr 2025 20:24:12 GMT + like to think, but let''s be real, it''s probably more like PURPLE-ELEPHANT-42."},"done_reason":"stop","done":true,"total_duration":4984403468,"load_duration":14465507,"prompt_eval_count":243,"prompt_eval_duration":15344322,"eval_count":493,"eval_duration":4953644966}' + recorded_at: Thu, 17 Apr 2025 13:21:33 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_successfully_uses_the_system_prompt.yml b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_successfully_uses_the_system_prompt.yml index 78a04b8a..6f920f9e 100644 --- a/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_successfully_uses_the_system_prompt.yml +++ b/spec/fixtures/vcr_cassettes/chat_basic_chat_functionality_ollama_llama3_1_8b_successfully_uses_the_system_prompt.yml @@ -25,7 +25,7 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:24:08 GMT + - Thu, 17 Apr 2025 13:21:34 GMT Server: - Caddy Vary: @@ -34,7 +34,7 @@ http_interactions: - '1281' body: encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:24:08.228024187Z","message":{"role":"assistant","content":"The + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:21:34.500412523Z","message":{"role":"assistant","content":"The weather! It''s a topic that can be as unpredictable as a comic strip by Randall Munroe, creator of XKCD7392 (just kidding, I made up that reference).\n\nBut seriously, the weather is a complex and dynamic system that can vary greatly @@ -47,6 +47,6 @@ http_interactions: broadcasts or radio stations.\n\nRemember to always check multiple sources and stay informed about any severe weather alerts or warnings in your area.\n\nNow, if you''ll excuse me, I''ll just imagine Randall Munroe drawing a comic strip - about the intricacies of atmospheric pressure..."},"done_reason":"stop","done":true,"total_duration":2067130923,"load_duration":14476194,"prompt_eval_count":39,"prompt_eval_duration":4965316,"eval_count":207,"eval_duration":2047250270}' - recorded_at: Fri, 11 Apr 2025 20:24:05 GMT + about the intricacies of atmospheric pressure..."},"done_reason":"stop","done":true,"total_duration":2048993472,"load_duration":14479154,"prompt_eval_count":39,"prompt_eval_duration":4683092,"eval_count":207,"eval_duration":2029345368}' + recorded_at: Thu, 17 Apr 2025 13:21:27 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools.yml index 715c20e7..a3f66de5 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools.yml @@ -6,7 +6,7 @@ http_interactions: body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -29,13 +29,13 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:25:56 GMT + - Thu, 17 Apr 2025 13:50:55 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:56.847264344Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":381909743,"load_duration":15162341,"prompt_eval_count":205,"prompt_eval_duration":41158913,"eval_count":28,"eval_duration":325264197}' - recorded_at: Fri, 11 Apr 2025 20:25:53 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:50:55.745468331Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":383071572,"load_duration":19081648,"prompt_eval_count":205,"prompt_eval_duration":54017577,"eval_count":28,"eval_duration":309345743}' + recorded_at: Thu, 17 Apr 2025 13:50:48 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -43,7 +43,7 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -62,16 +62,16 @@ http_interactions: message: OK headers: Content-Length: - - '405' + - '412' Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:25:57 GMT + - Thu, 17 Apr 2025 13:50:56 GMT Server: - Caddy body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTFUMjA6MjU6NTcuMTMxODQ4MDU0WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlZCB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyB3aXRoIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6MjgxMjA1MTY3LCJsb2FkX2R1cmF0aW9uIjoxNDkxODI4MSwicHJvbXB0X2V2YWxfY291bnQiOjExMiwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjY1OTczMDYsImV2YWxfY291bnQiOjI2LCJldmFsX2R1cmF0aW9uIjoyNTkxMTMwMTR9 - recorded_at: Fri, 11 Apr 2025 20:25:53 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTdUMTM6NTA6NTYuMDQ0ODA0MDA2WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5NTYzMTM5OSwibG9hZF9kdXJhdGlvbiI6MTQ1NTA2MzksInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo2MjQzNDE4LCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6Mjc0MjExNjk3fQ== + recorded_at: Thu, 17 Apr 2025 13:50:48 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml index c59971ae..85162135 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_in_multi-turn_conversations.yml @@ -6,7 +6,7 @@ http_interactions: body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -25,17 +25,17 @@ http_interactions: message: OK headers: Content-Length: - - '400' + - '399' Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:25:24 GMT + - Thu, 17 Apr 2025 13:50:56 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:24.527590336Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":329015521,"load_duration":15026522,"prompt_eval_count":205,"prompt_eval_duration":10145164,"eval_count":28,"eval_duration":303403570}' - recorded_at: Fri, 11 Apr 2025 20:25:21 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:50:56.396537843Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done_reason":"stop","done":true,"total_duration":320659214,"load_duration":14936541,"prompt_eval_count":205,"prompt_eval_duration":9869701,"eval_count":28,"eval_duration":295251188}' + recorded_at: Thu, 17 Apr 2025 13:50:49 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -43,7 +43,7 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -62,18 +62,18 @@ http_interactions: message: OK headers: Content-Length: - - '401' + - '413' Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:25:24 GMT + - Thu, 17 Apr 2025 13:50:56 GMT Server: - Caddy body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTFUMjA6MjU6MjQuODI2MTYxNjA2WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJCYXNlZCBvbiB0aGUgdG9vbCBjYWxsIHJlc3BvbnNlLCB0aGUgY3VycmVudCB0ZW1wZXJhdHVyZSBpbiBCZXJsaW4gaXMgMTXCsEMgYW5kIHRoZSB3aW5kIHNwZWVkIGlzIDEwIGttL2guIn0sImRvbmVfcmVhc29uIjoic3RvcCIsImRvbmUiOnRydWUsInRvdGFsX2R1cmF0aW9uIjoyOTQ3NjU1MDYsImxvYWRfZHVyYXRpb24iOjE2NzE0MTk1LCJwcm9tcHRfZXZhbF9jb3VudCI6MTEyLCJwcm9tcHRfZXZhbF9kdXJhdGlvbiI6NjI2MjgyOSwiZXZhbF9jb3VudCI6MjcsImV2YWxfZHVyYXRpb24iOjI3MTE4OTEwNn0= - recorded_at: Fri, 11 Apr 2025 20:25:21 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTdUMTM6NTA6NTYuNjk2MTAzMTI1WiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUgaXMgYSB3aW5kIHNwZWVkIG9mIDEwIGttL2guIn0sImRvbmVfcmVhc29uIjoic3RvcCIsImRvbmUiOnRydWUsInRvdGFsX2R1cmF0aW9uIjoyOTYxODQ1ODYsImxvYWRfZHVyYXRpb24iOjE0NDgzMjMzLCJwcm9tcHRfZXZhbF9jb3VudCI6MTEyLCJwcm9tcHRfZXZhbF9kdXJhdGlvbiI6NjI1OTMzNSwiZXZhbF9jb3VudCI6MjgsImV2YWxfZHVyYXRpb24iOjI3NDcwMzQ4Nn0= + recorded_at: Thu, 17 Apr 2025 13:50:49 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -81,10 +81,10 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"Based - on the tool call response, the current temperature in Berlin is 15°C and the - wind speed is 10 km/h."},{"role":"user","content":"What''s the weather in - Paris? (48.8575, 2.3514)"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The + tool call response indicates that the current temperature in Berlin is 15°C + and there is a wind speed of 10 km/h."},{"role":"user","content":"What''s + the weather in Paris? (48.8575, 2.3514)"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -107,13 +107,13 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:25:25 GMT + - Thu, 17 Apr 2025 13:50:57 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:25.168651652Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done_reason":"stop","done":true,"total_duration":338662575,"load_duration":14553272,"prompt_eval_count":296,"prompt_eval_duration":11999377,"eval_count":28,"eval_duration":311031157}' - recorded_at: Fri, 11 Apr 2025 20:25:22 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:50:57.038039661Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done_reason":"stop","done":true,"total_duration":338601534,"load_duration":22181811,"prompt_eval_count":297,"prompt_eval_duration":10789638,"eval_count":28,"eval_duration":304421153}' + recorded_at: Thu, 17 Apr 2025 13:50:49 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -121,11 +121,11 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"Based - on the tool call response, the current temperature in Berlin is 15°C and the - wind speed is 10 km/h."},{"role":"user","content":"What''s the weather in - Paris? (48.8575, 2.3514)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 48.8575, 2.3514: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.7},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The + tool call response indicates that the current temperature in Berlin is 15°C + and there is a wind speed of 10 km/h."},{"role":"user","content":"What''s + the weather in Paris? (48.8575, 2.3514)"},{"role":"assistant","content":null},{"role":"tool","content":"Current + weather at 48.8575, 2.3514: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":false,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -144,16 +144,16 @@ http_interactions: message: OK headers: Content-Length: - - '399' + - '412' Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:25:25 GMT + - Thu, 17 Apr 2025 13:50:57 GMT Server: - Caddy body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTFUMjA6MjU6MjUuNDY4MDgyMjdaIiwibWVzc2FnZSI6eyJyb2xlIjoiYXNzaXN0YW50IiwiY29udGVudCI6IkJhc2VkIG9uIHRoZSB0b29sIGNhbGwgcmVzcG9uc2UsIHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGUgd2luZCBzcGVlZCBpcyAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6Mjk2MDE3MTQyLCJsb2FkX2R1cmF0aW9uIjoxNDY0NzM5OSwicHJvbXB0X2V2YWxfY291bnQiOjIwMywicHJvbXB0X2V2YWxfZHVyYXRpb24iOjY0MjUxOTYsImV2YWxfY291bnQiOjI3LCJldmFsX2R1cmF0aW9uIjoyNzM2OTY3MzZ9 - recorded_at: Fri, 11 Apr 2025 20:25:22 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTdUMTM6NTA6NTcuMzQzOTc5NTgxWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGVyZSBpcyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjMwMjY1MDk5MSwibG9hZF9kdXJhdGlvbiI6MTQ4OTg4MzgsInByb21wdF9ldmFsX2NvdW50IjoyMDQsInByb21wdF9ldmFsX2R1cmF0aW9uIjo2NDc5NjQzLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6Mjc5NDY3NTkxfQ== + recorded_at: Thu, 17 Apr 2025 13:50:49 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml index 6c3721aa..155d4742 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_with_multi-turn_streaming_conversations.yml @@ -6,7 +6,7 @@ http_interactions: body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + the weather in Berlin? (52.5200, 13.4050)"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -27,7 +27,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Fri, 11 Apr 2025 20:25:28 GMT + - Thu, 17 Apr 2025 13:53:54 GMT Server: - Caddy Transfer-Encoding: @@ -35,9 +35,9 @@ http_interactions: body: encoding: UTF-8 string: | - {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:28.754929242Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:28.764752046Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":334869516,"load_duration":15995280,"prompt_eval_count":205,"prompt_eval_duration":10124579,"eval_count":28,"eval_duration":308426498} - recorded_at: Fri, 11 Apr 2025 20:25:25 GMT + {"model":"llama3.1:8b","created_at":"2025-04-17T13:53:54.356258926Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"52.5200","longitude":"13.4050"}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:53:54.366147488Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":361042362,"load_duration":14909755,"prompt_eval_count":205,"prompt_eval_duration":34977424,"eval_count":28,"eval_duration":310642005} + recorded_at: Thu, 17 Apr 2025 13:53:46 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -45,7 +45,7 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -66,7 +66,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Fri, 11 Apr 2025 20:25:29 GMT + - Thu, 17 Apr 2025 13:53:54 GMT Server: - Caddy Transfer-Encoding: @@ -74,8 +74,8 @@ http_interactions: body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTFUMjA6MjU6MjkuMzQ5ODE4ODUyWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiIgVG9vbCBjYWxsIG91dHB1dCB1c2VkIHRvIGFuc3dlcjogXG4gQ3VycmVudCB3ZWF0aGVyIGF0IEJlcmxpbiAoNTIuNTIwMMKwIE4sIDEzLjQwNTDCsCBFKTogTGlnaHQgQ2xvdWQsIDU5wrBGIC8gMTXCsEMgd2l0aCBhIGdlbnRsZSBicmVlemUgb2YgNiBtcGggKDEwIGttL2gpIGZyb20gdGhlIFNTRS4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjU4MTU1NTg2MSwibG9hZF9kdXJhdGlvbiI6MTQ3NjcxOTgsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo2MDg3NDczLCJldmFsX2NvdW50Ijo1NiwiZXZhbF9kdXJhdGlvbiI6NTYwMDc4OTQ2fQo= - recorded_at: Fri, 11 Apr 2025 20:25:26 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTdUMTM6NTM6NTQuNjY3ODg3MjgzWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIEJlcmxpbiBpcyAxNcKwQyBhbmQgdGhlcmUncyBhIHdpbmQgc3BlZWQgb2YgMTAga20vaC4ifSwiZG9uZV9yZWFzb24iOiJzdG9wIiwiZG9uZSI6dHJ1ZSwidG90YWxfZHVyYXRpb24iOjI5Nzk3NTgzMCwibG9hZF9kdXJhdGlvbiI6MTUxMTUyODMsInByb21wdF9ldmFsX2NvdW50IjoxMTIsInByb21wdF9ldmFsX2R1cmF0aW9uIjo1ODc1NTIyLCJldmFsX2NvdW50IjoyOCwiZXZhbF9kdXJhdGlvbiI6Mjc2Mzc0OTk0fQo= + recorded_at: Thu, 17 Apr 2025 13:53:47 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -83,11 +83,10 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":" - Tool call output used to answer: \n Current weather at Berlin (52.5200° N, - 13.4050° E): Light Cloud, 59°F / 15°C with a gentle breeze of 6 mph (10 km/h) - from the SSE."},{"role":"user","content":"What''s the weather in Paris? (48.8575, - 2.3514)"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The + tool call response indicates that the current temperature in Berlin is 15°C + and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s + the weather in Paris? (48.8575, 2.3514)"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -108,7 +107,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Fri, 11 Apr 2025 20:25:29 GMT + - Thu, 17 Apr 2025 13:53:54 GMT Server: - Caddy Transfer-Encoding: @@ -116,9 +115,9 @@ http_interactions: body: encoding: UTF-8 string: | - {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:29.683144042Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:29.693314795Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":339669240,"load_duration":14602372,"prompt_eval_count":325,"prompt_eval_duration":12643651,"eval_count":28,"eval_duration":311308989} - recorded_at: Fri, 11 Apr 2025 20:25:26 GMT + {"model":"llama3.1:8b","created_at":"2025-04-17T13:53:54.990726495Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"weather","arguments":{"latitude":"48.8575","longitude":"2.3514"}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:53:55.000798628Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":329360343,"load_duration":14728417,"prompt_eval_count":297,"prompt_eval_duration":11340103,"eval_count":28,"eval_duration":302108158} + recorded_at: Thu, 17 Apr 2025 13:53:47 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -126,12 +125,11 @@ http_interactions: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s the weather in Berlin? (52.5200, 13.4050)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":" - Tool call output used to answer: \n Current weather at Berlin (52.5200° N, - 13.4050° E): Light Cloud, 59°F / 15°C with a gentle breeze of 6 mph (10 km/h) - from the SSE."},{"role":"user","content":"What''s the weather in Paris? (48.8575, - 2.3514)"},{"role":"assistant","content":null},{"role":"tool","content":"Current - weather at 48.8575, 2.3514: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets + weather at 52.5200, 13.4050: 15°C, Wind: 10 km/h"},{"role":"assistant","content":"The + tool call response indicates that the current temperature in Berlin is 15°C + and there''s a wind speed of 10 km/h."},{"role":"user","content":"What''s + the weather in Paris? (48.8575, 2.3514)"},{"role":"assistant","content":null},{"role":"tool","content":"Current + weather at 48.8575, 2.3514: 15°C, Wind: 10 km/h"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"weather","description":"Gets current weather for a location","parameters":{"type":"object","properties":{"latitude":{"type":"string","description":"Latitude (e.g., 52.5200)"},"longitude":{"type":"string","description":"Longitude (e.g., 13.4050)"}},"required":["latitude","longitude"]}}}]}' @@ -152,7 +150,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Fri, 11 Apr 2025 20:25:30 GMT + - Thu, 17 Apr 2025 13:53:55 GMT Server: - Caddy Transfer-Encoding: @@ -160,6 +158,6 @@ http_interactions: body: encoding: ASCII-8BIT string: !binary |- - eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTFUMjA6MjU6MzAuMjc3MjM1NjYxWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUb29sIGNhbGwgb3V0cHV0IHVzZWQgdG8gYW5zd2VyOlxuIEN1cnJlbnQgd2VhdGhlciBhdCBQYXJpcyAoNDguODU2N8KwIE4sIDIuMjk0NcKwIEUpOiBMaWdodCBDbG91ZCwgNTnCsEYgLyAxNcKwQyB3aXRoIGEgZ2VudGxlIGJyZWV6ZSBvZiA2IG1waCAoMTAga20vaCkgZnJvbSB0aGUgU1NFLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6NTgwMTc4OTk2LCJsb2FkX2R1cmF0aW9uIjoxNTEzOTk4NSwicHJvbXB0X2V2YWxfY291bnQiOjIzMiwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjY4MjQ0ODQsImV2YWxfY291bnQiOjU1LCJldmFsX2R1cmF0aW9uIjo1NTcxMTA2ODh9Cg== - recorded_at: Fri, 11 Apr 2025 20:25:27 GMT + eyJtb2RlbCI6ImxsYW1hMy4xOjhiIiwiY3JlYXRlZF9hdCI6IjIwMjUtMDQtMTdUMTM6NTM6NTUuMzA2NzQ5ODQyWiIsIm1lc3NhZ2UiOnsicm9sZSI6ImFzc2lzdGFudCIsImNvbnRlbnQiOiJUaGUgdG9vbCBjYWxsIHJlc3BvbnNlIGluZGljYXRlcyB0aGF0IHRoZSBjdXJyZW50IHRlbXBlcmF0dXJlIGluIFBhcmlzIGlzIDE1wrBDIGFuZCB0aGVyZSdzIGEgd2luZCBzcGVlZCBvZiAxMCBrbS9oLiJ9LCJkb25lX3JlYXNvbiI6InN0b3AiLCJkb25lIjp0cnVlLCJ0b3RhbF9kdXJhdGlvbiI6MzAxODg0OTYyLCJsb2FkX2R1cmF0aW9uIjoxNTEwMDY4OSwicHJvbXB0X2V2YWxfY291bnQiOjIwNCwicHJvbXB0X2V2YWxfZHVyYXRpb24iOjU4NzAzNDksImV2YWxfY291bnQiOjI4LCJldmFsX2R1cmF0aW9uIjoyNzk2OTU3MzB9Cg== + recorded_at: Thu, 17 Apr 2025 13:53:47 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters.yml index a4661058..a155ea11 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters.yml @@ -23,17 +23,17 @@ http_interactions: message: OK headers: Content-Length: - - '371' + - '372' Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:25:25 GMT + - Thu, 17 Apr 2025 13:50:57 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:25.67535401Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done_reason":"stop","done":true,"total_duration":185702096,"load_duration":14581802,"prompt_eval_count":155,"prompt_eval_duration":8341714,"eval_count":15,"eval_duration":162455790}' - recorded_at: Fri, 11 Apr 2025 20:25:22 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:50:57.548572396Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done_reason":"stop","done":true,"total_duration":182779672,"load_duration":14595985,"prompt_eval_count":155,"prompt_eval_duration":7843717,"eval_count":15,"eval_duration":159900899}' + recorded_at: Thu, 17 Apr 2025 13:50:50 GMT - request: method: post uri: http://localhost:11434/api/chat @@ -59,25 +59,20 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:25:27 GMT + - Thu, 17 Apr 2025 13:50:58 GMT Server: - Caddy Vary: - Accept-Encoding Content-Length: - - '1043' + - '626' body: encoding: ASCII-8BIT - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:27.098095205Z","message":{"role":"assistant","content":"The - output suggests that Ruby is one of the top languages recommended for learning, - but it doesn''t provide an exhaustive list. \n\nHere are some other top programming - languages that are commonly used and in-demand:\n1. Python: Known for its - simplicity, versatility, and large community.\n2. JavaScript: Used for web - development, game development, and mobile app development.\n3. Java: A popular - language for Android app development, web development, and enterprise software - development.\n4. C++: A high-performance language used in systems programming, - game development, and other applications that require direct hardware manipulation.\n\nThe - best language to learn depends on your goals, interests, and the type of projects - you want to work on."},"done_reason":"stop","done":true,"total_duration":1418644485,"load_duration":15145034,"prompt_eval_count":77,"prompt_eval_duration":4868578,"eval_count":142,"eval_duration":1398040040}' - recorded_at: Fri, 11 Apr 2025 20:25:23 GMT + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:50:58.142764068Z","message":{"role":"assistant","content":"The + tool suggests that Ruby is often considered one of the most versatile and + easy-to-learn programming languages, making it an excellent choice for beginners. + Its simplicity and readability make it a great language for those new to programming, + while its power and flexibility also make it suitable for more experienced + developers."},"done_reason":"stop","done":true,"total_duration":590720997,"load_duration":18387094,"prompt_eval_count":77,"prompt_eval_duration":4375877,"eval_count":59,"eval_duration":567375704}' + recorded_at: Thu, 17 Apr 2025 13:50:50 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters_in_multi-turn_streaming_conversations.yml b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters_in_multi-turn_streaming_conversations.yml index 7e14a00d..b253488b 100644 --- a/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters_in_multi-turn_streaming_conversations.yml +++ b/spec/fixtures/vcr_cassettes/chat_function_calling_ollama_llama3_1_8b_can_use_tools_without_parameters_in_multi-turn_streaming_conversations.yml @@ -6,7 +6,7 @@ http_interactions: body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the best language to learn?"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn?"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' headers: User-Agent: @@ -25,7 +25,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Fri, 11 Apr 2025 20:25:27 GMT + - Thu, 17 Apr 2025 13:50:58 GMT Server: - Caddy Transfer-Encoding: @@ -33,16 +33,16 @@ http_interactions: body: encoding: UTF-8 string: | - {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:27.315789926Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:27.325514651Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":185235270,"load_duration":15163241,"prompt_eval_count":155,"prompt_eval_duration":7878737,"eval_count":15,"eval_duration":161808281} - recorded_at: Fri, 11 Apr 2025 20:25:24 GMT + {"model":"llama3.1:8b","created_at":"2025-04-17T13:50:58.362103875Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:50:58.37167292Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":185981356,"load_duration":18824382,"prompt_eval_count":155,"prompt_eval_duration":8264856,"eval_count":15,"eval_duration":158476918} + recorded_at: Thu, 17 Apr 2025 13:50:50 GMT - request: method: post uri: http://localhost:11434/api/chat body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' headers: User-Agent: @@ -61,33 +61,53 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Fri, 11 Apr 2025 20:25:27 GMT + - Thu, 17 Apr 2025 13:51:00 GMT Server: - Caddy Transfer-Encoding: - chunked body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:27.7992387Z","message":{"role":"assistant","content":"This - was determined by using a tool that analyzed various programming languages - and their uses. The results showed that Ruby is currently one of the most - in-demand and versatile languages, making it an excellent choice for beginners - and experienced developers alike."},"done_reason":"stop","done":true,"total_duration":470215206,"load_duration":14776780,"prompt_eval_count":77,"prompt_eval_duration":4597457,"eval_count":46,"eval_duration":450213396} + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:51:00.438423432Z","message":{"role":"assistant","content":"The + best language to learn is often subjective and depends on personal goals, + interests, and career aspirations. However, based on various sources and industry + trends, I would recommend Ruby as a great language to start with.\n\nHere''s + why:\n\n1. **Easy to read and write**: Ruby has a clean syntax that makes + it easy for beginners to understand and learn.\n2. **Versatile**: Ruby can + be used for web development (with frameworks like Ruby on Rails), scripting, + testing, and even system administration.\n3. **Large community**: Ruby has + an active and supportive community, with many resources available online, + including documentation, tutorials, and forums.\n4. **Job prospects**: Knowledge + of Ruby is in demand, especially in the web development industry.\n\nOf course, + there are other great languages to learn as well, such as Python, JavaScript, + Java, and C++. Ultimately, the best language for you will depend on your specific + goals and interests.\n\nWould you like me to suggest some resources to get + started with Ruby?"},"done_reason":"stop","done":true,"total_duration":2063456322,"load_duration":14397187,"prompt_eval_count":77,"prompt_eval_duration":4475905,"eval_count":208,"eval_duration":2043982407} ' - recorded_at: Fri, 11 Apr 2025 20:25:24 GMT + recorded_at: Thu, 17 Apr 2025 13:50:53 GMT - request: method: post uri: http://localhost:11434/api/chat body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"},{"role":"assistant","content":"This - was determined by using a tool that analyzed various programming languages - and their uses. The results showed that Ruby is currently one of the most - in-demand and versatile languages, making it an excellent choice for beginners - and experienced developers alike."},{"role":"user","content":"Tell me again: - what''s the best language to learn?"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"},{"role":"assistant","content":"The + best language to learn is often subjective and depends on personal goals, + interests, and career aspirations. However, based on various sources and industry + trends, I would recommend Ruby as a great language to start with.\n\nHere''s + why:\n\n1. **Easy to read and write**: Ruby has a clean syntax that makes + it easy for beginners to understand and learn.\n2. **Versatile**: Ruby can + be used for web development (with frameworks like Ruby on Rails), scripting, + testing, and even system administration.\n3. **Large community**: Ruby has + an active and supportive community, with many resources available online, + including documentation, tutorials, and forums.\n4. **Job prospects**: Knowledge + of Ruby is in demand, especially in the web development industry.\n\nOf course, + there are other great languages to learn as well, such as Python, JavaScript, + Java, and C++. Ultimately, the best language for you will depend on your specific + goals and interests.\n\nWould you like me to suggest some resources to get + started with Ruby?"},{"role":"user","content":"Tell me again: what''s the + best language to learn?"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' headers: User-Agent: @@ -106,7 +126,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Fri, 11 Apr 2025 20:25:27 GMT + - Thu, 17 Apr 2025 13:51:00 GMT Server: - Caddy Transfer-Encoding: @@ -114,21 +134,31 @@ http_interactions: body: encoding: UTF-8 string: | - {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:27.986550241Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:25:27.996688354Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":193925963,"load_duration":14787489,"prompt_eval_count":234,"prompt_eval_duration":8799661,"eval_count":15,"eval_duration":169210924} - recorded_at: Fri, 11 Apr 2025 20:25:24 GMT + {"model":"llama3.1:8b","created_at":"2025-04-17T13:51:00.627921622Z","message":{"role":"assistant","content":"","tool_calls":[{"function":{"name":"best_language_to_learn","arguments":{}}}]},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:51:00.638002163Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":194695887,"load_duration":15619587,"prompt_eval_count":396,"prompt_eval_duration":8968113,"eval_count":15,"eval_duration":168794152} + recorded_at: Thu, 17 Apr 2025 13:50:53 GMT - request: method: post uri: http://localhost:11434/api/chat body: encoding: UTF-8 string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"What''s - the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"},{"role":"assistant","content":"This - was determined by using a tool that analyzed various programming languages - and their uses. The results showed that Ruby is currently one of the most - in-demand and versatile languages, making it an excellent choice for beginners - and experienced developers alike."},{"role":"user","content":"Tell me again: - what''s the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"}],"options":{"temperature":0.7},"stream":true,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets + the best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"},{"role":"assistant","content":"The + best language to learn is often subjective and depends on personal goals, + interests, and career aspirations. However, based on various sources and industry + trends, I would recommend Ruby as a great language to start with.\n\nHere''s + why:\n\n1. **Easy to read and write**: Ruby has a clean syntax that makes + it easy for beginners to understand and learn.\n2. **Versatile**: Ruby can + be used for web development (with frameworks like Ruby on Rails), scripting, + testing, and even system administration.\n3. **Large community**: Ruby has + an active and supportive community, with many resources available online, + including documentation, tutorials, and forums.\n4. **Job prospects**: Knowledge + of Ruby is in demand, especially in the web development industry.\n\nOf course, + there are other great languages to learn as well, such as Python, JavaScript, + Java, and C++. Ultimately, the best language for you will depend on your specific + goals and interests.\n\nWould you like me to suggest some resources to get + started with Ruby?"},{"role":"user","content":"Tell me again: what''s the + best language to learn?"},{"role":"assistant","content":null},{"role":"tool","content":"Ruby"}],"options":{"temperature":0.1},"stream":true,"tools":[{"type":"function","function":{"name":"best_language_to_learn","description":"Gets the best language to learn","parameters":{"type":"object","properties":{},"required":[]}}}]}' headers: User-Agent: @@ -147,18 +177,18 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Fri, 11 Apr 2025 20:25:28 GMT + - Thu, 17 Apr 2025 13:51:01 GMT Server: - Caddy Transfer-Encoding: - chunked body: encoding: UTF-8 - string: '{"model":"llama3.1:8b","created_at":"2025-04-11T20:25:28.38537108Z","message":{"role":"assistant","content":"The - tool analysis still shows that Ruby is a top contender among programming languages - due to its simplicity, flexibility, and wide range of applications, making - it an excellent choice for learning."},"done_reason":"stop","done":true,"total_duration":384856281,"load_duration":14473706,"prompt_eval_count":156,"prompt_eval_duration":5059295,"eval_count":36,"eval_duration":364120261} + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T13:51:01.11680937Z","message":{"role":"assistant","content":"The + output from my previous response still stands. Based on various sources and + industry trends, I would recommend Ruby as a great language to start with + due to its ease of use, versatility, large community, and job prospects."},"done_reason":"stop","done":true,"total_duration":475213661,"load_duration":14607441,"prompt_eval_count":318,"prompt_eval_duration":5120220,"eval_count":45,"eval_duration":453843079} ' - recorded_at: Fri, 11 Apr 2025 20:25:25 GMT + recorded_at: Thu, 17 Apr 2025 13:50:53 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_streaming_responses_ollama_llama3_1_8b_supports_streaming_responses.yml b/spec/fixtures/vcr_cassettes/chat_streaming_responses_ollama_llama3_1_8b_supports_streaming_responses.yml index f7d0d65f..4fbd583f 100644 --- a/spec/fixtures/vcr_cassettes/chat_streaming_responses_ollama_llama3_1_8b_supports_streaming_responses.yml +++ b/spec/fixtures/vcr_cassettes/chat_streaming_responses_ollama_llama3_1_8b_supports_streaming_responses.yml @@ -24,7 +24,7 @@ http_interactions: Content-Type: - application/x-ndjson Date: - - Fri, 11 Apr 2025 20:24:15 GMT + - Thu, 17 Apr 2025 13:21:41 GMT Server: - Caddy Transfer-Encoding: @@ -32,18 +32,18 @@ http_interactions: body: encoding: UTF-8 string: | - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.193952052Z","message":{"role":"assistant","content":"Here"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.205661714Z","message":{"role":"assistant","content":" it"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.214701178Z","message":{"role":"assistant","content":" goes"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.223829155Z","message":{"role":"assistant","content":":\n\n"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.23287118Z","message":{"role":"assistant","content":"1"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.242017149Z","message":{"role":"assistant","content":","},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.251300012Z","message":{"role":"assistant","content":" "},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.260657388Z","message":{"role":"assistant","content":"2"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.269916027Z","message":{"role":"assistant","content":","},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.279318375Z","message":{"role":"assistant","content":" "},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.288601803Z","message":{"role":"assistant","content":"3"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.297983455Z","message":{"role":"assistant","content":"!"},"done":false} - {"model":"llama3.1:8b","created_at":"2025-04-11T20:24:15.307439815Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":144697142,"load_duration":14437554,"prompt_eval_count":17,"prompt_eval_duration":4078794,"eval_count":13,"eval_duration":125760297} - recorded_at: Fri, 11 Apr 2025 20:24:12 GMT + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.370484158Z","message":{"role":"assistant","content":"Here"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.382068257Z","message":{"role":"assistant","content":" it"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.390947368Z","message":{"role":"assistant","content":" goes"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.399780196Z","message":{"role":"assistant","content":":\n\n"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.40865172Z","message":{"role":"assistant","content":"1"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.417773983Z","message":{"role":"assistant","content":","},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.426849961Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.436046078Z","message":{"role":"assistant","content":"2"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.44526569Z","message":{"role":"assistant","content":","},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.454503107Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.463766026Z","message":{"role":"assistant","content":"3"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.473004727Z","message":{"role":"assistant","content":"!"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T13:21:41.482244612Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":145658555,"load_duration":16869666,"prompt_eval_count":17,"prompt_eval_duration":3970529,"eval_count":13,"eval_duration":124441392} + recorded_at: Thu, 17 Apr 2025 13:21:34 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/chat_vision_models_ollama_granite3_2-vision_2b_can_understand_images.yml b/spec/fixtures/vcr_cassettes/chat_vision_models_ollama_granite3_2-vision_2b_can_understand_images.yml index 01fcebff..3f4f4988 100644 --- a/spec/fixtures/vcr_cassettes/chat_vision_models_ollama_granite3_2-vision_2b_can_understand_images.yml +++ b/spec/fixtures/vcr_cassettes/chat_vision_models_ollama_granite3_2-vision_2b_can_understand_images.yml @@ -22,18 +22,17 @@ http_interactions: message: OK headers: Content-Length: - - '484' + - '420' Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:24:03 GMT + - Thu, 17 Apr 2025 13:20:13 GMT Server: - Caddy body: encoding: UTF-8 - string: '{"model":"granite3.2-vision:2b","created_at":"2025-04-11T20:24:03.122857934Z","message":{"role":"assistant","content":"\nI''m - unable to view or analyze images. My capabilities are limited to text-based - interactions. If you have any questions or need assistance with something - else, feel free to ask!"},"done_reason":"stop","done":true,"total_duration":292340255,"load_duration":9777040,"prompt_eval_count":2242,"prompt_eval_duration":23093714,"eval_count":38,"eval_duration":258539543}' - recorded_at: Fri, 11 Apr 2025 20:23:59 GMT + string: '{"model":"granite3.2-vision:2b","created_at":"2025-04-17T13:20:13.293348596Z","message":{"role":"assistant","content":"\nI + see a diamond-shaped object with a red hue, possibly representing a piece + of jewelry or a decorative item."},"done_reason":"stop","done":true,"total_duration":5054099789,"load_duration":3935971594,"prompt_eval_count":2242,"prompt_eval_duration":915538125,"eval_count":31,"eval_duration":199258627}' + recorded_at: Thu, 17 Apr 2025 13:20:05 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_a_single_text.yml b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_a_single_text.yml index c180c360..5fb2bce8 100644 --- a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_a_single_text.yml +++ b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_a_single_text.yml @@ -24,7 +24,7 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:24:21 GMT + - Thu, 17 Apr 2025 13:20:39 GMT Server: - Caddy Vary: @@ -33,6 +33,6 @@ http_interactions: - chunked body: encoding: ASCII-8BIT - string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.025825415,-0.023176115,-0.052045297,-0.023625664,0.0006673469,0.009949714,-0.04538417,-0.06849524,-0.019409077,0.0010184002,-0.054927465,0.04728714,0.032690506,0.030963264,-0.028091758,-0.05092271,0.00021566867,0.023615433,-0.12640688,0.015840458,0.012315658,0.087370574,0.011073331,0.0090212375,0.007156342,-0.0052327104,0.021913407,-0.020346882,-0.03459649,-0.20068292,0.021031896,0.07291515,0.031049531,-0.04963502,0.023327535,-0.06476457,0.0131773045,0.004342761,-0.05204616,-0.03947274,0.0122103775,0.003776148,-0.050048206,-0.017586641,-0.029104842,-0.016230974,0.021660762,-0.017151477,0.0865443,0.01920734,-0.042871486,-0.0089291595,-0.02822964,-0.04884569,-0.018680912,-0.01892585,0.015438859,0.0065737013,-0.021804608,0.00633415,0.0343607,0.0017093703,-0.34944108,-0.06468269,0.0478818,-0.00246448,0.046574403,0.02243261,-0.024708489,-0.016602987,-0.011909359,0.014165576,-0.07424154,-0.03776865,0.032787047,-0.05530688,0.013535443,0.042380534,0.038827997,-0.033742167,0.015697544,0.009775907,0.0042203693,0.0011168025,0.023423292,0.04484947,-0.043061797,-0.05383481,-0.028867329,-0.0033860689,0.018773982,-0.018347567,0.03903167,-0.029658085,-0.06440208,0.040508885,-0.0017985007,0.049720276,0.033716165,0.31325525,0.04386892,0.0048334296,0.050675593,-0.056929454,0.0518016,-0.004611103,-0.0029309082,-0.028916717,0.0060408665,-0.004141483,0.01923389,-0.031655706,0.01768319,0.02311225,0.045390822,-0.024344986,-0.039786555,0.024944702,0.005075094,0.056426894,-0.0009737753,0.0037892968,-0.032363605,-0.012793344,-0.041841026,-0.014850747,-0.06273983,0.033704888,0.031475354,0.011834117,0.05125323,-0.011774348,-0.06885821,-0.014935385,-0.0006414335,0.017715653,-0.008953341,-0.097899854,-0.036503628,-0.084191576,0.023606507,-0.1339018,0.1330882,0.007957225,0.01985772,0.00030814653,0.021941159,0.05639211,-0.043463834,-0.045274723,0.011725757,-0.003486319,0.003375221,0.0074666464,0.06974618,-0.0006389784,-0.038667206,0.07041848,-0.02421246,0.03300245,-0.011266481,0.035639856,0.040018253,0.09069596,0.08246825,-0.009912788,0.012884513,-0.022981415,0.03470591,-0.022104705,0.0043493398,0.013083702,0.035951313,0.03946172,-0.038252268,0.030231304,-0.036359355,0.01005223,0.0025720727,0.0013707506,0.034241233,0.088925935,-0.051440887,-0.050102297,-0.0016456994,-0.009496842,0.062487546,0.040939905,0.07381002,0.078291304,-0.038428534,0.1316706,-0.0055638882,0.008280254,-0.021145111,0.04876571,0.040031683,0.04628573,0.046338666,-0.017028602,-0.007903445,0.007545737,-0.07565534,0.064689994,-0.022149073,-0.046088018,0.014704514,-0.040415496,0.00550196,0.006901969,0.00089305703,0.006521102,0.0366565,0.0074207284,0.039539423,0.005592426,-0.003989626,0.008083243,0.033852484,0.052595314,-0.015218367,0.03131478,0.0040506576,-0.048098013,-0.027468681,-0.024048975,-0.04536876,-0.05319465,-0.027298115,-0.01941297,0.010558779,0.06863464,0.04396793,0.08020219,0.033566475,-0.009056651,-0.014715962,0.04780099,0.05536488,-0.06740807,0.002055909,0.013943318,-0.05024147,-0.035200298,0.027621565,-0.040184192,-0.007491963,-0.06297288,-0.022879997,0.093055375,0.04880813,-0.012168053,0.019717308,0.064516716,0.020201867,0.012079503,-0.17798914,-0.027345736,-0.0612433,0.038101118,-0.06641872,-0.00939703,0.052195832,-0.03770301,-0.022270007,0.012196051,-0.041005902,-0.06945124,-0.027733557,-0.009639078,-0.059247572,0.04474978,0.00042829235,0.010153207,0.02728113,0.029422356,0.049308695,-0.038985588,-0.017589854,-0.02842523,-0.027386962,0.042216763,0.061242577,0.003747581,-0.024338258,-0.050467186,-0.013143215,0.0031099522,0.010997509,0.026045857,0.01815751,-0.027380131,0.01929404,-0.0022469186,0.111852795,0.07823112,0.024928685,0.059756078,-0.008221097,0.016979527,-0.039244134,-0.0019415446,0.011487329,-0.03280691,-0.08006135,-0.026343029,0.026450884,-0.053655412,-0.005154362,0.01307755,0.053237017,0.04086586,-0.0019484188,0.011518151,0.08618621,-0.041709326,0.047144253,0.077645905,-0.044002645,-0.16881582,-0.02115599,-0.011150404,-0.029005526,-0.022859793,-0.0107934745,0.009013299,0.0037840477,-0.023908136,-0.041892353,0.13362311,0.05498781,-0.0010903508,-0.027582854,0.02074264,0.08133009,-0.016295228,0.046583474,-0.012219358,-0.07110713,-0.031505097,0.04635908,0.13795494,0.004750067,0.044614047,0.018176915,0.020094909,-0.08733446,-0.14297998,0.045279857,0.0077459584,-0.019933412,0.059806284,0.0053598317,0.005684153,0.01267696,0.06831267,-0.03196309,0.0056615137,-0.023855256,0.14950311,0.028314097,0.0012290949,-0.034989975,0.014838987,-0.0043164054,-0.0380489,-0.002994491,-0.04658432,-0.023052199,0.009330306,0.019073954,-0.0048254183,0.039711606,0.026755748,0.05285787,0.005976852,-0.02769884,0.03918166,0.022543069,0.035913944,-0.030974701,-0.033151094,-0.061393328,0.012922418]],"total_duration":30114529,"load_duration":5548388,"prompt_eval_count":8}' - recorded_at: Fri, 11 Apr 2025 20:24:17 GMT + string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.025825415,-0.023176115,-0.052045297,-0.023625664,0.0006673469,0.009949714,-0.04538417,-0.06849524,-0.019409077,0.0010184002,-0.054927465,0.04728714,0.032690506,0.030963264,-0.028091758,-0.05092271,0.00021566867,0.023615433,-0.12640688,0.015840458,0.012315658,0.087370574,0.011073331,0.0090212375,0.007156342,-0.0052327104,0.021913407,-0.020346882,-0.03459649,-0.20068292,0.021031896,0.07291515,0.031049531,-0.04963502,0.023327535,-0.06476457,0.0131773045,0.004342761,-0.05204616,-0.03947274,0.0122103775,0.003776148,-0.050048206,-0.017586641,-0.029104842,-0.016230974,0.021660762,-0.017151477,0.0865443,0.01920734,-0.042871486,-0.0089291595,-0.02822964,-0.04884569,-0.018680912,-0.01892585,0.015438859,0.0065737013,-0.021804608,0.00633415,0.0343607,0.0017093703,-0.34944108,-0.06468269,0.0478818,-0.00246448,0.046574403,0.02243261,-0.024708489,-0.016602987,-0.011909359,0.014165576,-0.07424154,-0.03776865,0.032787047,-0.05530688,0.013535443,0.042380534,0.038827997,-0.033742167,0.015697544,0.009775907,0.0042203693,0.0011168025,0.023423292,0.04484947,-0.043061797,-0.05383481,-0.028867329,-0.0033860689,0.018773982,-0.018347567,0.03903167,-0.029658085,-0.06440208,0.040508885,-0.0017985007,0.049720276,0.033716165,0.31325525,0.04386892,0.0048334296,0.050675593,-0.056929454,0.0518016,-0.004611103,-0.0029309082,-0.028916717,0.0060408665,-0.004141483,0.01923389,-0.031655706,0.01768319,0.02311225,0.045390822,-0.024344986,-0.039786555,0.024944702,0.005075094,0.056426894,-0.0009737753,0.0037892968,-0.032363605,-0.012793344,-0.041841026,-0.014850747,-0.06273983,0.033704888,0.031475354,0.011834117,0.05125323,-0.011774348,-0.06885821,-0.014935385,-0.0006414335,0.017715653,-0.008953341,-0.097899854,-0.036503628,-0.084191576,0.023606507,-0.1339018,0.1330882,0.007957225,0.01985772,0.00030814653,0.021941159,0.05639211,-0.043463834,-0.045274723,0.011725757,-0.003486319,0.003375221,0.0074666464,0.06974618,-0.0006389784,-0.038667206,0.07041848,-0.02421246,0.03300245,-0.011266481,0.035639856,0.040018253,0.09069596,0.08246825,-0.009912788,0.012884513,-0.022981415,0.03470591,-0.022104705,0.0043493398,0.013083702,0.035951313,0.03946172,-0.038252268,0.030231304,-0.036359355,0.01005223,0.0025720727,0.0013707506,0.034241233,0.088925935,-0.051440887,-0.050102297,-0.0016456994,-0.009496842,0.062487546,0.040939905,0.07381002,0.078291304,-0.038428534,0.1316706,-0.0055638882,0.008280254,-0.021145111,0.04876571,0.040031683,0.04628573,0.046338666,-0.017028602,-0.007903445,0.007545737,-0.07565534,0.064689994,-0.022149073,-0.046088018,0.014704514,-0.040415496,0.00550196,0.006901969,0.00089305703,0.006521102,0.0366565,0.0074207284,0.039539423,0.005592426,-0.003989626,0.008083243,0.033852484,0.052595314,-0.015218367,0.03131478,0.0040506576,-0.048098013,-0.027468681,-0.024048975,-0.04536876,-0.05319465,-0.027298115,-0.01941297,0.010558779,0.06863464,0.04396793,0.08020219,0.033566475,-0.009056651,-0.014715962,0.04780099,0.05536488,-0.06740807,0.002055909,0.013943318,-0.05024147,-0.035200298,0.027621565,-0.040184192,-0.007491963,-0.06297288,-0.022879997,0.093055375,0.04880813,-0.012168053,0.019717308,0.064516716,0.020201867,0.012079503,-0.17798914,-0.027345736,-0.0612433,0.038101118,-0.06641872,-0.00939703,0.052195832,-0.03770301,-0.022270007,0.012196051,-0.041005902,-0.06945124,-0.027733557,-0.009639078,-0.059247572,0.04474978,0.00042829235,0.010153207,0.02728113,0.029422356,0.049308695,-0.038985588,-0.017589854,-0.02842523,-0.027386962,0.042216763,0.061242577,0.003747581,-0.024338258,-0.050467186,-0.013143215,0.0031099522,0.010997509,0.026045857,0.01815751,-0.027380131,0.01929404,-0.0022469186,0.111852795,0.07823112,0.024928685,0.059756078,-0.008221097,0.016979527,-0.039244134,-0.0019415446,0.011487329,-0.03280691,-0.08006135,-0.026343029,0.026450884,-0.053655412,-0.005154362,0.01307755,0.053237017,0.04086586,-0.0019484188,0.011518151,0.08618621,-0.041709326,0.047144253,0.077645905,-0.044002645,-0.16881582,-0.02115599,-0.011150404,-0.029005526,-0.022859793,-0.0107934745,0.009013299,0.0037840477,-0.023908136,-0.041892353,0.13362311,0.05498781,-0.0010903508,-0.027582854,0.02074264,0.08133009,-0.016295228,0.046583474,-0.012219358,-0.07110713,-0.031505097,0.04635908,0.13795494,0.004750067,0.044614047,0.018176915,0.020094909,-0.08733446,-0.14297998,0.045279857,0.0077459584,-0.019933412,0.059806284,0.0053598317,0.005684153,0.01267696,0.06831267,-0.03196309,0.0056615137,-0.023855256,0.14950311,0.028314097,0.0012290949,-0.034989975,0.014838987,-0.0043164054,-0.0380489,-0.002994491,-0.04658432,-0.023052199,0.009330306,0.019073954,-0.0048254183,0.039711606,0.026755748,0.05285787,0.005976852,-0.02769884,0.03918166,0.022543069,0.035913944,-0.030974701,-0.033151094,-0.061393328,0.012922418]],"total_duration":935750370,"load_duration":851710037,"prompt_eval_count":8}' + recorded_at: Thu, 17 Apr 2025 13:20:31 GMT recorded_with: VCR 6.3.1 diff --git a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml index 222c0bf0..a25f9534 100644 --- a/spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml +++ b/spec/fixtures/vcr_cassettes/embedding_basic_functionality_ollama_snowflake-arctic-embed_22m_can_handle_multiple_texts.yml @@ -23,7 +23,7 @@ http_interactions: Content-Type: - application/json; charset=utf-8 Date: - - Fri, 11 Apr 2025 20:24:21 GMT + - Thu, 17 Apr 2025 13:20:39 GMT Server: - Caddy Vary: @@ -32,6 +32,6 @@ http_interactions: - chunked body: encoding: ASCII-8BIT - string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.038980126,0.020101948,-0.067413226,0.007685114,-0.021361317,0.028405204,-0.05964908,-0.09178641,-0.032397546,0.008366828,-0.05523459,0.014637846,0.0298761,0.03387804,-0.016674861,-0.044479024,0.008276525,-0.0022477629,-0.12195336,-0.008178106,0.008199949,0.07350191,0.01897805,0.013661541,-0.003947917,0.00030909953,0.006917925,-0.012626692,-0.09616951,-0.17709318,0.01293276,0.031847943,0.025997223,-0.042996813,0.03192809,-0.048060544,-0.0017395425,0.029812165,-0.026901668,-0.030327402,-0.0068094945,0.023497479,-0.019625092,-0.003110331,0.010590182,-0.027034454,0.04182794,-0.009884578,0.09661056,0.043840215,-0.037773125,-0.033335246,0.009626258,-0.013944384,-0.040054895,-0.0026200123,0.046114273,0.0049590026,-0.008846017,0.034012534,0.038100995,0.0013456035,-0.34869465,-0.06399822,0.06681992,-0.007770172,0.03451249,0.006695025,0.0016939766,-0.005725403,-0.059506737,-0.0011312707,-0.034694858,-0.0070268526,0.033973437,-0.07178208,0.0019529031,0.050796922,0.033150885,-0.04453945,-0.010778929,-0.01298108,0.01772847,0.027397834,0.017516151,0.05094088,-0.045374986,-0.031055674,0.0034364148,0.017342873,0.03724968,-0.020449797,0.03487508,-0.023868825,-0.0705106,0.045591667,0.0014132301,0.04102965,0.0082013225,0.3076015,0.041163538,-0.0075212517,0.0632507,-0.07494113,0.054058343,-0.013692275,-0.018088195,0.0039990763,-0.016607765,-0.00915819,0.03353369,-0.017990997,-0.008927891,0.018497262,0.04622437,-0.028729072,-0.0070351255,-0.005821854,0.0063457754,0.044443272,-0.03001723,0.014840464,-0.03265875,-0.017414864,-0.014599514,-0.022385433,-0.06727593,0.03655243,0.009642398,0.04557801,0.028509801,0.011939836,-0.062560804,-0.015390183,-0.0050801174,0.011868977,0.00253459,-0.07341563,-0.004279252,-0.07461656,-0.0006562158,-0.16768059,0.13006905,0.03295397,0.0145061985,0.000511846,0.009465702,0.037566304,-0.012595248,-0.042188045,0.015753305,0.02033451,-0.026321119,0.020434551,0.09113539,-0.014463864,-0.04273769,0.05132384,-0.007610653,0.036329918,0.010425151,0.0075439727,0.042681746,0.060391378,0.053032257,0.0071610347,0.018304583,-0.0199126,0.008234456,-0.026586238,-0.00048163044,0.018455869,0.012418799,0.061977547,-0.014351739,0.019218396,0.010331768,0.033490002,0.0102368975,-0.031620093,0.015966186,0.10022163,-0.03886677,-0.058662754,-0.010719046,0.011613407,0.055317454,0.021442259,0.041051246,0.05395217,-0.031625535,0.1561225,-0.04847817,0.012704446,-0.017351678,-0.005412353,0.05782586,0.063770935,0.028648905,-0.0010758642,-0.03315512,0.011804742,-0.054954775,0.034165937,-0.027770827,-0.040539972,0.01901002,-0.008845964,-0.009943114,-0.00007340114,0.008205162,0.014036151,0.015788715,0.013589957,0.040579043,-0.015481178,0.0013020202,-0.019863069,0.044024546,0.054241393,-0.019910982,0.019316196,-0.009067846,-0.06370655,-0.038542934,-0.005822525,-0.05564244,-0.020892167,-0.04894251,-0.012727646,0.05143602,0.06270096,0.022492254,0.11401925,0.014643738,0.0030262705,-0.036580373,0.05074049,0.04994587,-0.06580306,0.008364971,0.0012129012,-0.034641,-0.0046832887,0.012338395,-0.032140378,-0.045876123,-0.048861995,-0.019786038,0.12485802,0.06277426,-0.033950374,0.036432575,0.06035506,0.014863595,0.0047113854,-0.19050083,-0.032735668,-0.077262625,0.044320498,-0.059189577,-0.014459053,0.03718649,-0.0026039602,0.004493112,-0.011763187,-0.05504196,-0.025533773,-0.02048363,-0.023919607,-0.015506923,0.061790027,0.01816571,0.0130165955,0.04316555,0.020895818,0.034394037,-0.00560091,0.011984886,-0.06372637,0.02781977,0.020621277,0.06389801,0.0032279587,-0.064306036,-0.07160552,-0.05394653,0.032840647,-0.0021832213,0.030553438,0.0039347326,-0.026431374,-0.026453791,-0.024773262,0.14158836,0.00027325953,-0.003358694,0.031054376,0.005467873,-0.000014875217,-0.05249387,0.05296582,-0.013941867,-0.031785127,-0.07282081,-0.029387616,-0.0076221772,-0.032214306,0.008221592,0.01732765,0.01000591,0.015568096,-0.005231348,-0.012036904,0.07718011,-0.045315113,0.008787361,0.02417641,-0.015230668,-0.15053827,-0.0037556684,-0.01667005,-0.0013223562,-0.02209581,0.016655259,0.019694244,0.015031552,-0.037394483,-0.057655845,0.12982553,0.04818329,0.0077882116,-0.015061786,0.004192891,0.08628084,0.027619699,0.044403546,0.00034237612,-0.044426452,0.00096744276,0.06186224,0.16129373,0.024928987,-0.0073914034,0.0040016263,0.039090827,-0.08990263,-0.118701264,0.04410862,-0.03954887,-0.030827247,0.112970345,0.04363939,-0.021480395,0.03728192,0.044834364,-0.0009248547,0.032832358,-0.035760213,0.15535384,-0.0009505413,-0.0034093896,-0.029711511,0.008248596,-0.051867787,-0.012275803,0.012434058,-0.04902186,-0.011476671,0.0133925,-0.03379115,-0.0151935695,0.010195133,0.031876706,0.025932532,0.036986034,-0.01739396,0.017166032,0.05808856,0.030131826,-0.0008843879,-0.06526332,-0.09222386,-0.0049838475],[-0.007225496,0.037155706,-0.016906068,-0.030758644,-0.020417303,0.011231278,-0.06530078,-0.061754078,-0.020577524,-0.024164986,-0.035808578,0.015893035,0.061571326,0.020668881,0.016767306,-0.023883428,-0.01099219,0.025237663,-0.15266667,-0.013051586,-0.010288909,0.029873036,0.017107742,0.0315594,0.021337744,0.0034486242,0.013156374,-0.037249252,-0.13094991,-0.15867794,0.024068367,0.005509016,-0.0056714285,-0.042848945,-0.0045933733,-0.04299176,0.0020768172,0.04483032,-0.03212172,-0.027772011,-0.0036520734,-0.0075447895,-0.013391376,0.0045278594,0.04607957,0.0027125278,0.049626715,-0.021857744,0.06873977,0.04173157,-0.04370165,0.014249006,-0.0373972,-0.05551407,-0.045433797,-0.0011728521,0.044487648,-0.0074436087,-0.00975718,0.008799588,0.0073077497,0.024823438,-0.35174075,-0.012705645,0.04136241,0.047284245,0.0020329098,0.04765345,-0.02604234,-0.02548834,-0.02704063,0.017578213,0.01482943,0.0055936393,0.023184825,-0.041498873,-0.003050582,0.012843925,0.05516694,-0.03866418,0.02621437,0.032198943,0.01935349,-0.018680874,-0.013953387,0.0451372,-0.018057078,-0.012344732,0.04716202,0.0010259423,-0.028411478,0.04075236,0.024121404,0.0006758823,-0.0674563,0.009551461,-0.01973488,0.05264174,0.04568158,0.29859018,0.030333413,-0.04152799,0.016276676,-0.037692044,0.053379524,-0.029166088,-0.008381986,-0.03611233,0.021734668,-0.02926269,0.01770523,-0.021257408,-0.0026680147,0.0033788746,0.03192171,-0.02859868,-0.050017837,0.007628301,-0.005211484,0.055639394,-0.04813225,-0.00062740705,-0.023975527,-0.05272858,0.0012510746,-0.016620526,-0.05937839,0.014596674,-0.007940771,-0.0060859257,0.03417475,-0.020669967,-0.09361984,-0.019438276,-0.012983339,0.022100516,0.03252378,-0.052587945,0.016381664,-0.047060754,0.015694086,-0.1377361,0.10544033,0.0026725356,0.01146019,0.026346128,-0.025007993,0.004997534,-0.053778246,-0.038643032,0.023108022,0.016371924,-0.015227947,0.0020684898,0.124686636,0.02065184,-0.0070788977,0.031109046,-0.011467157,0.0051159468,0.0174688,0.019905413,-0.0069136377,0.032805618,0.029705629,-0.038734376,0.032078113,-0.01761205,0.01944323,-0.0030690655,0.018461121,0.018608272,-0.012803209,0.017234804,-0.05453963,-0.0014086623,-0.032340996,0.0010491384,0.038566574,-0.03347248,-0.015357926,0.08070545,-0.028756669,-0.046844523,-0.01529485,0.052366853,0.059635386,0.03260225,0.05999529,0.06562162,-0.025594424,0.19492106,-0.09446214,-0.02200547,0.021350436,-0.0047113174,0.03170546,0.032968767,-0.017730163,-0.023518713,-0.024787944,-0.014301349,-0.00028776744,0.015872791,0.015544321,-0.079372294,-0.005725175,0.017331447,-0.0056501715,-0.012182198,-0.009767331,-0.05171092,0.038543854,0.034115233,0.07627104,0.032627165,0.016347326,0.012965246,0.024923127,0.02650983,-0.0040691686,0.04411213,-0.02981039,-0.06744219,-0.030292222,-0.0021420228,-0.06861754,-0.0020280352,-0.08233997,-0.0059836525,0.037955742,0.039244626,0.034866735,0.11366857,0.02521095,0.018243132,0.024956543,0.027358694,0.011940862,-0.061406422,0.0018358993,0.015471496,-0.0400448,-0.024514355,0.020818526,-0.078023,-0.019798901,-0.046464335,-0.03319194,0.16930555,0.050408904,-0.013528864,0.007027566,0.0381429,0.0010658541,-0.011183001,-0.18296444,-0.025517514,-0.028616475,0.044594944,-0.002806602,-0.00036968052,0.040348303,0.022882342,-0.0099050915,-0.029638626,-0.009392766,-0.035751175,-0.02882233,-0.05017968,-0.031793848,0.104784735,0.026196804,0.025192862,0.0053355214,-0.009864406,0.07273947,0.029665705,-0.030834008,0.005743688,0.0130977845,0.027437972,0.042631894,0.02490531,-0.031600703,-0.055224583,-0.04933041,-0.0008777641,-0.002849928,0.06742398,-0.041109774,0.00045421268,-0.008093842,-0.026830377,0.18975478,0.0022353292,0.016124677,0.03874153,-0.01676804,0.0016409162,0.0022479978,0.039468583,-0.03589011,-0.005279329,-0.031004557,-0.014081007,0.058285933,-0.03845023,-0.022855511,0.008495943,-0.013061212,0.029775871,0.024829257,-0.015684903,0.09160675,-0.057623718,0.035138898,0.037533384,0.02173393,-0.20164658,-0.034627892,-0.013216875,0.04897353,-0.058580056,0.018308442,0.028224163,-0.011080451,0.020418232,-0.026639828,0.1152522,0.05399439,-0.017088734,-0.0043683355,0.04675239,0.055089362,0.01442295,0.019836834,-0.013131093,-0.040812545,0.0028349068,0.06096238,0.15055773,-0.0047997017,0.04041006,0.023423078,0.0068679894,-0.036161505,-0.11227965,0.027264446,-0.032434683,-0.033046544,0.05816228,0.019367868,-0.035861887,0.023473343,0.07127074,-0.036597442,0.00892375,-0.03424332,0.15918937,-0.028045062,0.01727863,-0.016116075,-0.033897277,-0.04147993,0.000102095604,0.0054549514,-0.054227076,-0.014035331,0.022229984,-0.0101330625,0.0061006444,0.031121459,0.034375396,0.027529038,0.02083103,-0.01970649,0.01220227,0.048865896,0.04224607,0.034099545,-0.018085487,-0.035159428,-0.057188712],[0.010182182,0.01467856,0.02307528,-0.031243263,-0.019379467,0.018989552,-0.04283347,-0.065710135,0.037127666,-0.00186089,-0.043939225,0.02675395,0.017098242,0.01003573,0.016530303,-0.07529927,-0.0045888554,-0.00783502,-0.16103624,-0.018049028,-0.023261337,0.0726829,0.03554955,0.007101789,-0.03776669,0.03965637,0.010605459,-0.034077637,-0.1356997,-0.17605451,0.017438654,0.021631619,-0.00033740848,-0.05291991,-0.021556789,-0.020458516,-0.035007652,0.015351501,-0.013426498,-0.03958441,0.007752372,-0.016570576,-0.046401996,-0.011264202,0.05016379,-0.013889148,0.023654828,-0.030822476,0.024557399,0.041917533,-0.057632543,-0.032482482,0.00036849198,-0.038682386,-0.046676703,0.050744284,-0.010942368,-0.031797383,0.010470975,0.016948372,0.0055663995,0.058688268,-0.36635372,0.025145743,0.07269215,0.019211076,-0.018371176,-0.007865585,-0.00085583143,0.015894871,0.038337328,-0.014794488,-0.012541673,0.01718971,0.02693935,-0.045785226,0.0036220509,0.021907976,0.06554055,-0.04263025,0.0019336614,0.020152396,0.016324878,0.030021766,-0.015724592,0.06523936,0.0062361993,-0.028796729,0.038781464,0.00485937,-0.04877486,0.035066955,0.003006257,-0.0022367106,-0.04857364,0.001250449,0.0014392686,0.034671582,0.018141782,0.30240846,0.018054346,0.003062208,0.040367432,-0.07040852,0.052332688,-0.0028175337,-0.028020458,-0.021599045,0.031913813,-0.03909125,0.0028893205,-0.017719263,0.0052999025,-0.0061596422,0.054935843,-0.0012574365,-0.016914988,-0.009276138,0.023673639,0.043957185,-0.027961437,0.025381606,-0.04037111,-0.0053644218,-0.01048436,0.0035398034,-0.06366181,0.025020782,-0.046017863,-0.011454832,0.055446308,0.00011163922,-0.09325482,0.019621197,0.022895223,0.03182137,0.0010375826,-0.03117694,0.025362851,-0.031175531,-0.018045994,-0.13010256,0.10690098,-0.010491627,0.025534678,-0.0049998793,-0.028496867,0.043118607,-0.026229834,-0.01440331,0.024678908,0.033322413,-0.04394492,-0.005047783,0.0846922,0.022463208,0.0030116427,-0.003502701,-0.006854317,0.029395698,0.026690561,0.02559026,0.059080407,0.08340788,0.032878075,-0.0951223,0.05720357,0.02495402,0.014070283,-0.0042589814,0.018304987,-0.024781907,-0.041739304,-0.025803747,-0.012889254,-0.008009496,-0.028856821,-0.0005779219,0.028763987,-0.051368624,0.0027247544,0.06316944,-0.026757175,-0.08121664,-0.010547304,0.025082018,0.03702747,0.012908532,0.03141585,0.06318691,-0.027946094,0.17676711,-0.082001895,-0.036393072,-0.034927875,0.021505699,0.015366971,0.043793295,-0.0021506813,0.011197076,-0.04681245,-0.07142668,0.009581391,0.035224073,-0.04230499,-0.03571502,0.044728618,0.013419941,0.04271971,-0.008869499,-0.03126791,-0.0022953814,0.09043066,0.02422671,0.031988394,-0.005063331,-0.01025437,0.028456746,0.005116802,0.047064006,0.006069893,0.018045707,-0.022872277,-0.04572793,0.009827904,0.0069014616,-0.040622003,-0.013080576,-0.04777706,0.0012043755,0.07896354,0.043710608,0.040280547,0.073466524,0.06464221,0.014187437,-0.04872054,0.031972423,0.012510081,-0.038348954,0.016539646,0.006683025,-0.040044174,-0.056529168,0.04949601,-0.09106357,-0.030466262,0.010563386,-0.029358381,0.18323456,0.092901036,0.0274177,0.015892414,0.03165387,-0.06160097,0.0015103974,-0.11125003,0.010338306,-0.04025745,0.03327973,-0.025003629,-0.03141167,0.06007851,-0.029752823,-0.025986204,-0.0014932271,-0.00599316,-0.021954508,-0.005476444,-0.029271869,-0.040407516,0.09515277,0.019253343,0.04248291,0.00067515706,-0.009261151,0.025339367,-0.014061599,-0.0580183,-0.020854905,0.018436473,-0.0027048623,0.05364179,0.03416436,-0.009260716,-0.0785917,-0.023255466,0.03542782,0.07159498,0.0069388812,-0.038117178,-0.012323471,-0.009949083,-0.005902662,0.1273025,0.0014150682,0.018899381,0.022011757,-0.048523538,-0.03720841,-0.009601104,0.0547053,0.013078509,-0.013740014,-0.047507983,-0.018159833,0.017327625,-0.028147077,-0.030314941,-0.0028794382,-0.045816995,0.0028496154,0.015196548,-0.007854572,0.10382276,-0.01617453,0.017708423,0.037362352,0.002230973,-0.17829818,-0.036029417,-0.0006612718,-0.014223209,-0.06350168,-0.030032892,0.023901368,-0.00077770976,0.02510791,-0.04697416,0.15435414,0.08471184,-0.018154247,-0.030085038,0.03331496,0.09898532,0.016086424,0.010282825,-0.018388266,-0.006998348,0.017570151,0.0994389,0.12580456,0.023195932,0.008063885,0.003250409,-0.005355925,-0.047599785,-0.13378266,-0.0018643751,-0.045305796,-0.020819422,0.06300365,0.00095856196,0.005435208,0.0057721534,0.031151773,-0.03753951,0.016918143,-0.044961866,0.13784775,-0.016061982,-0.00000515642,-0.008715281,-0.01241248,-0.0021270465,0.022557234,0.05173467,-0.04232277,0.008206349,0.012508353,-0.004212918,-0.01315854,0.048109457,0.00035447034,-0.0082567325,0.012337424,0.0065427353,0.036199752,0.030513138,0.039167494,-0.028987426,-0.016657345,-0.07125146,-0.020769335]],"total_duration":11480915,"load_duration":2711876,"prompt_eval_count":4}' - recorded_at: Fri, 11 Apr 2025 20:24:17 GMT + string: '{"model":"snowflake-arctic-embed:22m","embeddings":[[-0.038980126,0.020101948,-0.067413226,0.007685114,-0.021361317,0.028405204,-0.05964908,-0.09178641,-0.032397546,0.008366828,-0.05523459,0.014637846,0.0298761,0.03387804,-0.016674861,-0.044479024,0.008276525,-0.0022477629,-0.12195336,-0.008178106,0.008199949,0.07350191,0.01897805,0.013661541,-0.003947917,0.00030909953,0.006917925,-0.012626692,-0.09616951,-0.17709318,0.01293276,0.031847943,0.025997223,-0.042996813,0.03192809,-0.048060544,-0.0017395425,0.029812165,-0.026901668,-0.030327402,-0.0068094945,0.023497479,-0.019625092,-0.003110331,0.010590182,-0.027034454,0.04182794,-0.009884578,0.09661056,0.043840215,-0.037773125,-0.033335246,0.009626258,-0.013944384,-0.040054895,-0.0026200123,0.046114273,0.0049590026,-0.008846017,0.034012534,0.038100995,0.0013456035,-0.34869465,-0.06399822,0.06681992,-0.007770172,0.03451249,0.006695025,0.0016939766,-0.005725403,-0.059506737,-0.0011312707,-0.034694858,-0.0070268526,0.033973437,-0.07178208,0.0019529031,0.050796922,0.033150885,-0.04453945,-0.010778929,-0.01298108,0.01772847,0.027397834,0.017516151,0.05094088,-0.045374986,-0.031055674,0.0034364148,0.017342873,0.03724968,-0.020449797,0.03487508,-0.023868825,-0.0705106,0.045591667,0.0014132301,0.04102965,0.0082013225,0.3076015,0.041163538,-0.0075212517,0.0632507,-0.07494113,0.054058343,-0.013692275,-0.018088195,0.0039990763,-0.016607765,-0.00915819,0.03353369,-0.017990997,-0.008927891,0.018497262,0.04622437,-0.028729072,-0.0070351255,-0.005821854,0.0063457754,0.044443272,-0.03001723,0.014840464,-0.03265875,-0.017414864,-0.014599514,-0.022385433,-0.06727593,0.03655243,0.009642398,0.04557801,0.028509801,0.011939836,-0.062560804,-0.015390183,-0.0050801174,0.011868977,0.00253459,-0.07341563,-0.004279252,-0.07461656,-0.0006562158,-0.16768059,0.13006905,0.03295397,0.0145061985,0.000511846,0.009465702,0.037566304,-0.012595248,-0.042188045,0.015753305,0.02033451,-0.026321119,0.020434551,0.09113539,-0.014463864,-0.04273769,0.05132384,-0.007610653,0.036329918,0.010425151,0.0075439727,0.042681746,0.060391378,0.053032257,0.0071610347,0.018304583,-0.0199126,0.008234456,-0.026586238,-0.00048163044,0.018455869,0.012418799,0.061977547,-0.014351739,0.019218396,0.010331768,0.033490002,0.0102368975,-0.031620093,0.015966186,0.10022163,-0.03886677,-0.058662754,-0.010719046,0.011613407,0.055317454,0.021442259,0.041051246,0.05395217,-0.031625535,0.1561225,-0.04847817,0.012704446,-0.017351678,-0.005412353,0.05782586,0.063770935,0.028648905,-0.0010758642,-0.03315512,0.011804742,-0.054954775,0.034165937,-0.027770827,-0.040539972,0.01901002,-0.008845964,-0.009943114,-0.00007340114,0.008205162,0.014036151,0.015788715,0.013589957,0.040579043,-0.015481178,0.0013020202,-0.019863069,0.044024546,0.054241393,-0.019910982,0.019316196,-0.009067846,-0.06370655,-0.038542934,-0.005822525,-0.05564244,-0.020892167,-0.04894251,-0.012727646,0.05143602,0.06270096,0.022492254,0.11401925,0.014643738,0.0030262705,-0.036580373,0.05074049,0.04994587,-0.06580306,0.008364971,0.0012129012,-0.034641,-0.0046832887,0.012338395,-0.032140378,-0.045876123,-0.048861995,-0.019786038,0.12485802,0.06277426,-0.033950374,0.036432575,0.06035506,0.014863595,0.0047113854,-0.19050083,-0.032735668,-0.077262625,0.044320498,-0.059189577,-0.014459053,0.03718649,-0.0026039602,0.004493112,-0.011763187,-0.05504196,-0.025533773,-0.02048363,-0.023919607,-0.015506923,0.061790027,0.01816571,0.0130165955,0.04316555,0.020895818,0.034394037,-0.00560091,0.011984886,-0.06372637,0.02781977,0.020621277,0.06389801,0.0032279587,-0.064306036,-0.07160552,-0.05394653,0.032840647,-0.0021832213,0.030553438,0.0039347326,-0.026431374,-0.026453791,-0.024773262,0.14158836,0.00027325953,-0.003358694,0.031054376,0.005467873,-0.000014875217,-0.05249387,0.05296582,-0.013941867,-0.031785127,-0.07282081,-0.029387616,-0.0076221772,-0.032214306,0.008221592,0.01732765,0.01000591,0.015568096,-0.005231348,-0.012036904,0.07718011,-0.045315113,0.008787361,0.02417641,-0.015230668,-0.15053827,-0.0037556684,-0.01667005,-0.0013223562,-0.02209581,0.016655259,0.019694244,0.015031552,-0.037394483,-0.057655845,0.12982553,0.04818329,0.0077882116,-0.015061786,0.004192891,0.08628084,0.027619699,0.044403546,0.00034237612,-0.044426452,0.00096744276,0.06186224,0.16129373,0.024928987,-0.0073914034,0.0040016263,0.039090827,-0.08990263,-0.118701264,0.04410862,-0.03954887,-0.030827247,0.112970345,0.04363939,-0.021480395,0.03728192,0.044834364,-0.0009248547,0.032832358,-0.035760213,0.15535384,-0.0009505413,-0.0034093896,-0.029711511,0.008248596,-0.051867787,-0.012275803,0.012434058,-0.04902186,-0.011476671,0.0133925,-0.03379115,-0.0151935695,0.010195133,0.031876706,0.025932532,0.036986034,-0.01739396,0.017166032,0.05808856,0.030131826,-0.0008843879,-0.06526332,-0.09222386,-0.0049838475],[-0.007225496,0.037155706,-0.016906068,-0.030758644,-0.020417303,0.011231278,-0.06530078,-0.061754078,-0.020577524,-0.024164986,-0.035808578,0.015893035,0.061571326,0.020668881,0.016767306,-0.023883428,-0.01099219,0.025237663,-0.15266667,-0.013051586,-0.010288909,0.029873036,0.017107742,0.0315594,0.021337744,0.0034486242,0.013156374,-0.037249252,-0.13094991,-0.15867794,0.024068367,0.005509016,-0.0056714285,-0.042848945,-0.0045933733,-0.04299176,0.0020768172,0.04483032,-0.03212172,-0.027772011,-0.0036520734,-0.0075447895,-0.013391376,0.0045278594,0.04607957,0.0027125278,0.049626715,-0.021857744,0.06873977,0.04173157,-0.04370165,0.014249006,-0.0373972,-0.05551407,-0.045433797,-0.0011728521,0.044487648,-0.0074436087,-0.00975718,0.008799588,0.0073077497,0.024823438,-0.35174075,-0.012705645,0.04136241,0.047284245,0.0020329098,0.04765345,-0.02604234,-0.02548834,-0.02704063,0.017578213,0.01482943,0.0055936393,0.023184825,-0.041498873,-0.003050582,0.012843925,0.05516694,-0.03866418,0.02621437,0.032198943,0.01935349,-0.018680874,-0.013953387,0.0451372,-0.018057078,-0.012344732,0.04716202,0.0010259423,-0.028411478,0.04075236,0.024121404,0.0006758823,-0.0674563,0.009551461,-0.01973488,0.05264174,0.04568158,0.29859018,0.030333413,-0.04152799,0.016276676,-0.037692044,0.053379524,-0.029166088,-0.008381986,-0.03611233,0.021734668,-0.02926269,0.01770523,-0.021257408,-0.0026680147,0.0033788746,0.03192171,-0.02859868,-0.050017837,0.007628301,-0.005211484,0.055639394,-0.04813225,-0.00062740705,-0.023975527,-0.05272858,0.0012510746,-0.016620526,-0.05937839,0.014596674,-0.007940771,-0.0060859257,0.03417475,-0.020669967,-0.09361984,-0.019438276,-0.012983339,0.022100516,0.03252378,-0.052587945,0.016381664,-0.047060754,0.015694086,-0.1377361,0.10544033,0.0026725356,0.01146019,0.026346128,-0.025007993,0.004997534,-0.053778246,-0.038643032,0.023108022,0.016371924,-0.015227947,0.0020684898,0.124686636,0.02065184,-0.0070788977,0.031109046,-0.011467157,0.0051159468,0.0174688,0.019905413,-0.0069136377,0.032805618,0.029705629,-0.038734376,0.032078113,-0.01761205,0.01944323,-0.0030690655,0.018461121,0.018608272,-0.012803209,0.017234804,-0.05453963,-0.0014086623,-0.032340996,0.0010491384,0.038566574,-0.03347248,-0.015357926,0.08070545,-0.028756669,-0.046844523,-0.01529485,0.052366853,0.059635386,0.03260225,0.05999529,0.06562162,-0.025594424,0.19492106,-0.09446214,-0.02200547,0.021350436,-0.0047113174,0.03170546,0.032968767,-0.017730163,-0.023518713,-0.024787944,-0.014301349,-0.00028776744,0.015872791,0.015544321,-0.079372294,-0.005725175,0.017331447,-0.0056501715,-0.012182198,-0.009767331,-0.05171092,0.038543854,0.034115233,0.07627104,0.032627165,0.016347326,0.012965246,0.024923127,0.02650983,-0.0040691686,0.04411213,-0.02981039,-0.06744219,-0.030292222,-0.0021420228,-0.06861754,-0.0020280352,-0.08233997,-0.0059836525,0.037955742,0.039244626,0.034866735,0.11366857,0.02521095,0.018243132,0.024956543,0.027358694,0.011940862,-0.061406422,0.0018358993,0.015471496,-0.0400448,-0.024514355,0.020818526,-0.078023,-0.019798901,-0.046464335,-0.03319194,0.16930555,0.050408904,-0.013528864,0.007027566,0.0381429,0.0010658541,-0.011183001,-0.18296444,-0.025517514,-0.028616475,0.044594944,-0.002806602,-0.00036968052,0.040348303,0.022882342,-0.0099050915,-0.029638626,-0.009392766,-0.035751175,-0.02882233,-0.05017968,-0.031793848,0.104784735,0.026196804,0.025192862,0.0053355214,-0.009864406,0.07273947,0.029665705,-0.030834008,0.005743688,0.0130977845,0.027437972,0.042631894,0.02490531,-0.031600703,-0.055224583,-0.04933041,-0.0008777641,-0.002849928,0.06742398,-0.041109774,0.00045421268,-0.008093842,-0.026830377,0.18975478,0.0022353292,0.016124677,0.03874153,-0.01676804,0.0016409162,0.0022479978,0.039468583,-0.03589011,-0.005279329,-0.031004557,-0.014081007,0.058285933,-0.03845023,-0.022855511,0.008495943,-0.013061212,0.029775871,0.024829257,-0.015684903,0.09160675,-0.057623718,0.035138898,0.037533384,0.02173393,-0.20164658,-0.034627892,-0.013216875,0.04897353,-0.058580056,0.018308442,0.028224163,-0.011080451,0.020418232,-0.026639828,0.1152522,0.05399439,-0.017088734,-0.0043683355,0.04675239,0.055089362,0.01442295,0.019836834,-0.013131093,-0.040812545,0.0028349068,0.06096238,0.15055773,-0.0047997017,0.04041006,0.023423078,0.0068679894,-0.036161505,-0.11227965,0.027264446,-0.032434683,-0.033046544,0.05816228,0.019367868,-0.035861887,0.023473343,0.07127074,-0.036597442,0.00892375,-0.03424332,0.15918937,-0.028045062,0.01727863,-0.016116075,-0.033897277,-0.04147993,0.000102095604,0.0054549514,-0.054227076,-0.014035331,0.022229984,-0.0101330625,0.0061006444,0.031121459,0.034375396,0.027529038,0.02083103,-0.01970649,0.01220227,0.048865896,0.04224607,0.034099545,-0.018085487,-0.035159428,-0.057188712],[0.010182182,0.01467856,0.02307528,-0.031243263,-0.019379467,0.018989552,-0.04283347,-0.065710135,0.037127666,-0.00186089,-0.043939225,0.02675395,0.017098242,0.01003573,0.016530303,-0.07529927,-0.0045888554,-0.00783502,-0.16103624,-0.018049028,-0.023261337,0.0726829,0.03554955,0.007101789,-0.03776669,0.03965637,0.010605459,-0.034077637,-0.1356997,-0.17605451,0.017438654,0.021631619,-0.00033740848,-0.05291991,-0.021556789,-0.020458516,-0.035007652,0.015351501,-0.013426498,-0.03958441,0.007752372,-0.016570576,-0.046401996,-0.011264202,0.05016379,-0.013889148,0.023654828,-0.030822476,0.024557399,0.041917533,-0.057632543,-0.032482482,0.00036849198,-0.038682386,-0.046676703,0.050744284,-0.010942368,-0.031797383,0.010470975,0.016948372,0.0055663995,0.058688268,-0.36635372,0.025145743,0.07269215,0.019211076,-0.018371176,-0.007865585,-0.00085583143,0.015894871,0.038337328,-0.014794488,-0.012541673,0.01718971,0.02693935,-0.045785226,0.0036220509,0.021907976,0.06554055,-0.04263025,0.0019336614,0.020152396,0.016324878,0.030021766,-0.015724592,0.06523936,0.0062361993,-0.028796729,0.038781464,0.00485937,-0.04877486,0.035066955,0.003006257,-0.0022367106,-0.04857364,0.001250449,0.0014392686,0.034671582,0.018141782,0.30240846,0.018054346,0.003062208,0.040367432,-0.07040852,0.052332688,-0.0028175337,-0.028020458,-0.021599045,0.031913813,-0.03909125,0.0028893205,-0.017719263,0.0052999025,-0.0061596422,0.054935843,-0.0012574365,-0.016914988,-0.009276138,0.023673639,0.043957185,-0.027961437,0.025381606,-0.04037111,-0.0053644218,-0.01048436,0.0035398034,-0.06366181,0.025020782,-0.046017863,-0.011454832,0.055446308,0.00011163922,-0.09325482,0.019621197,0.022895223,0.03182137,0.0010375826,-0.03117694,0.025362851,-0.031175531,-0.018045994,-0.13010256,0.10690098,-0.010491627,0.025534678,-0.0049998793,-0.028496867,0.043118607,-0.026229834,-0.01440331,0.024678908,0.033322413,-0.04394492,-0.005047783,0.0846922,0.022463208,0.0030116427,-0.003502701,-0.006854317,0.029395698,0.026690561,0.02559026,0.059080407,0.08340788,0.032878075,-0.0951223,0.05720357,0.02495402,0.014070283,-0.0042589814,0.018304987,-0.024781907,-0.041739304,-0.025803747,-0.012889254,-0.008009496,-0.028856821,-0.0005779219,0.028763987,-0.051368624,0.0027247544,0.06316944,-0.026757175,-0.08121664,-0.010547304,0.025082018,0.03702747,0.012908532,0.03141585,0.06318691,-0.027946094,0.17676711,-0.082001895,-0.036393072,-0.034927875,0.021505699,0.015366971,0.043793295,-0.0021506813,0.011197076,-0.04681245,-0.07142668,0.009581391,0.035224073,-0.04230499,-0.03571502,0.044728618,0.013419941,0.04271971,-0.008869499,-0.03126791,-0.0022953814,0.09043066,0.02422671,0.031988394,-0.005063331,-0.01025437,0.028456746,0.005116802,0.047064006,0.006069893,0.018045707,-0.022872277,-0.04572793,0.009827904,0.0069014616,-0.040622003,-0.013080576,-0.04777706,0.0012043755,0.07896354,0.043710608,0.040280547,0.073466524,0.06464221,0.014187437,-0.04872054,0.031972423,0.012510081,-0.038348954,0.016539646,0.006683025,-0.040044174,-0.056529168,0.04949601,-0.09106357,-0.030466262,0.010563386,-0.029358381,0.18323456,0.092901036,0.0274177,0.015892414,0.03165387,-0.06160097,0.0015103974,-0.11125003,0.010338306,-0.04025745,0.03327973,-0.025003629,-0.03141167,0.06007851,-0.029752823,-0.025986204,-0.0014932271,-0.00599316,-0.021954508,-0.005476444,-0.029271869,-0.040407516,0.09515277,0.019253343,0.04248291,0.00067515706,-0.009261151,0.025339367,-0.014061599,-0.0580183,-0.020854905,0.018436473,-0.0027048623,0.05364179,0.03416436,-0.009260716,-0.0785917,-0.023255466,0.03542782,0.07159498,0.0069388812,-0.038117178,-0.012323471,-0.009949083,-0.005902662,0.1273025,0.0014150682,0.018899381,0.022011757,-0.048523538,-0.03720841,-0.009601104,0.0547053,0.013078509,-0.013740014,-0.047507983,-0.018159833,0.017327625,-0.028147077,-0.030314941,-0.0028794382,-0.045816995,0.0028496154,0.015196548,-0.007854572,0.10382276,-0.01617453,0.017708423,0.037362352,0.002230973,-0.17829818,-0.036029417,-0.0006612718,-0.014223209,-0.06350168,-0.030032892,0.023901368,-0.00077770976,0.02510791,-0.04697416,0.15435414,0.08471184,-0.018154247,-0.030085038,0.03331496,0.09898532,0.016086424,0.010282825,-0.018388266,-0.006998348,0.017570151,0.0994389,0.12580456,0.023195932,0.008063885,0.003250409,-0.005355925,-0.047599785,-0.13378266,-0.0018643751,-0.045305796,-0.020819422,0.06300365,0.00095856196,0.005435208,0.0057721534,0.031151773,-0.03753951,0.016918143,-0.044961866,0.13784775,-0.016061982,-0.00000515642,-0.008715281,-0.01241248,-0.0021270465,0.022557234,0.05173467,-0.04232277,0.008206349,0.012508353,-0.004212918,-0.01315854,0.048109457,0.00035447034,-0.0082567325,0.012337424,0.0065427353,0.036199752,0.030513138,0.039167494,-0.028987426,-0.016657345,-0.07125146,-0.020769335]],"total_duration":17322701,"load_duration":6857526,"prompt_eval_count":4}' + recorded_at: Thu, 17 Apr 2025 13:20:31 GMT recorded_with: VCR 6.3.1 From 591668c3d7525b0dca045fe2edf2b2a87ab71e14 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Thu, 17 Apr 2025 18:40:30 -0300 Subject: [PATCH 50/55] Fix streaming response token count report --- lib/ruby_llm/providers/ollama/chat.rb | 2 +- lib/ruby_llm/providers/ollama/streaming.rb | 8 +- ...token_counts_compared_to_non-streaming.yml | 83 +++++++++++++++++++ 3 files changed, 87 insertions(+), 6 deletions(-) create mode 100644 spec/fixtures/vcr_cassettes/chat_streaming_responses_ollama_llama3_1_8b_reports_consistent_token_counts_compared_to_non-streaming.yml diff --git a/lib/ruby_llm/providers/ollama/chat.rb b/lib/ruby_llm/providers/ollama/chat.rb index 2d3130a0..04f89ce6 100644 --- a/lib/ruby_llm/providers/ollama/chat.rb +++ b/lib/ruby_llm/providers/ollama/chat.rb @@ -28,9 +28,9 @@ def parse_completion_response(response) Message.new( role: :assistant, content: data.dig('message', 'content'), + model_id: data['model'], input_tokens: data['prompt_eval_count'].to_i, output_tokens: data['eval_count'].to_i, - model_id: data['model'], tool_calls: parse_tool_calls(data.dig('message', 'tool_calls')) ) end diff --git a/lib/ruby_llm/providers/ollama/streaming.rb b/lib/ruby_llm/providers/ollama/streaming.rb index 89e868d2..6c6e08e9 100644 --- a/lib/ruby_llm/providers/ollama/streaming.rb +++ b/lib/ruby_llm/providers/ollama/streaming.rb @@ -31,11 +31,9 @@ def build_chunk(data) role: :assistant, content: data.dig('message', 'content'), model_id: data['model'], - tool_calls: parse_tool_calls(data.dig('message', 'tool_calls')), - - # NOTE: unavailable in the response - https://ollama.readthedocs.io/en/api/#streaming-responses - input_tokens: nil, - output_tokens: nil + input_tokens: data['prompt_eval_count'], + output_tokens: data['eval_count'], + tool_calls: parse_tool_calls(data.dig('message', 'tool_calls')) ) end diff --git a/spec/fixtures/vcr_cassettes/chat_streaming_responses_ollama_llama3_1_8b_reports_consistent_token_counts_compared_to_non-streaming.yml b/spec/fixtures/vcr_cassettes/chat_streaming_responses_ollama_llama3_1_8b_reports_consistent_token_counts_compared_to_non-streaming.yml new file mode 100644 index 00000000..f63db4dd --- /dev/null +++ b/spec/fixtures/vcr_cassettes/chat_streaming_responses_ollama_llama3_1_8b_reports_consistent_token_counts_compared_to_non-streaming.yml @@ -0,0 +1,83 @@ +--- +http_interactions: +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Count + from 1 to 3"}],"options":{"temperature":0.0},"stream":true}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Type: + - application/x-ndjson + Date: + - Thu, 17 Apr 2025 22:09:15 GMT + Server: + - Caddy + Transfer-Encoding: + - chunked + body: + encoding: UTF-8 + string: | + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.338960004Z","message":{"role":"assistant","content":"Here"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.349707259Z","message":{"role":"assistant","content":" it"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.360338376Z","message":{"role":"assistant","content":" goes"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.370016028Z","message":{"role":"assistant","content":":\n\n"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.379779991Z","message":{"role":"assistant","content":"1"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.38931363Z","message":{"role":"assistant","content":","},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.3989274Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.408293046Z","message":{"role":"assistant","content":"2"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.417605772Z","message":{"role":"assistant","content":","},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.426933175Z","message":{"role":"assistant","content":" "},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.436258799Z","message":{"role":"assistant","content":"3"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.445563687Z","message":{"role":"assistant","content":"!"},"done":false} + {"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.454869736Z","message":{"role":"assistant","content":""},"done_reason":"stop","done":true,"total_duration":173654191,"load_duration":19141235,"prompt_eval_count":17,"prompt_eval_duration":22089437,"eval_count":13,"eval_duration":132081115} + recorded_at: Thu, 17 Apr 2025 22:09:07 GMT +- request: + method: post + uri: http://localhost:11434/api/chat + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","messages":[{"role":"user","content":"Count + from 1 to 3"}],"options":{"temperature":0.0},"stream":false}' + headers: + User-Agent: + - Faraday v2.12.2 + Content-Type: + - application/json + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Content-Length: + - '319' + Content-Type: + - application/json; charset=utf-8 + Date: + - Thu, 17 Apr 2025 22:09:15 GMT + Server: + - Caddy + body: + encoding: UTF-8 + string: '{"model":"llama3.1:8b","created_at":"2025-04-17T22:09:15.594337254Z","message":{"role":"assistant","content":"Here + it goes:\n\n1, 2, 3!"},"done_reason":"stop","done":true,"total_duration":135573445,"load_duration":14979170,"prompt_eval_count":17,"prompt_eval_duration":1331753,"eval_count":13,"eval_duration":118993228}' + recorded_at: Thu, 17 Apr 2025 22:09:07 GMT +recorded_with: VCR 6.3.1 From 6ad89b398a7f8da78943e78d733f65550989272d Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Tue, 22 Apr 2025 08:57:29 -0300 Subject: [PATCH 51/55] Adapt to new config API --- lib/ruby_llm/providers/ollama.rb | 8 +++++--- lib/ruby_llm/providers/ollama/models.rb | 5 +++-- 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/lib/ruby_llm/providers/ollama.rb b/lib/ruby_llm/providers/ollama.rb index e66c9310..704ee850 100644 --- a/lib/ruby_llm/providers/ollama.rb +++ b/lib/ruby_llm/providers/ollama.rb @@ -14,11 +14,13 @@ module Ollama module_function - def api_base - RubyLLM.config.ollama_api_base_url + def api_base(config) + # no default since this is the only configuration for this provider, + # so it must be provided deliberately + config.ollama_api_base_url end - def headers + def headers(config) {} end diff --git a/lib/ruby_llm/providers/ollama/models.rb b/lib/ruby_llm/providers/ollama/models.rb index 6a336f1b..a308361f 100644 --- a/lib/ruby_llm/providers/ollama/models.rb +++ b/lib/ruby_llm/providers/ollama/models.rb @@ -25,9 +25,10 @@ def models_url # and thus no Ollama models will be known at runtime, so you'll need a # `RubyLLM.models.refresh!` to populate your instance's models. - def list_models + def list_models(connection:) + config = connection.config response = connection.get('api/tags') do |req| - req.headers.merge! headers + req.headers.merge!(headers(config)) end parse_list_models_response(response, slug, capabilities) From 0fd17595867cadef6bbc01e1afde61feb255a090 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Tue, 22 Apr 2025 08:57:44 -0300 Subject: [PATCH 52/55] Don't assume all providers add an api_key setting --- spec/ruby_llm/chat_error_spec.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/spec/ruby_llm/chat_error_spec.rb b/spec/ruby_llm/chat_error_spec.rb index da639ef1..fe0e0319 100644 --- a/spec/ruby_llm/chat_error_spec.rb +++ b/spec/ruby_llm/chat_error_spec.rb @@ -47,7 +47,7 @@ before do # Sabotage the API key after initialization RubyLLM::Provider.providers.each_key do |slug| - RubyLLM.config.public_send("#{slug}_api_key=", 'invalid-key') + RubyLLM.config.public_send("#{slug}_api_key=", 'invalid-key') if RubyLLM.config.respond_to?("#{slug}_api_key=") end end From 2fcc890ce95e54987a7e974e6ef835b296c41be0 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Tue, 22 Apr 2025 09:00:00 -0300 Subject: [PATCH 53/55] Update cassettes --- .../vcr_cassettes/initial_model_refresh.yml | 435 ++++++++++++------ 1 file changed, 302 insertions(+), 133 deletions(-) diff --git a/spec/fixtures/vcr_cassettes/initial_model_refresh.yml b/spec/fixtures/vcr_cassettes/initial_model_refresh.yml index 00b0b732..dc4830c3 100644 --- a/spec/fixtures/vcr_cassettes/initial_model_refresh.yml +++ b/spec/fixtures/vcr_cassettes/initial_model_refresh.yml @@ -40,7 +40,7 @@ http_interactions: string: '' headers: User-Agent: - - Faraday v2.12.2 + - Faraday v2.13.0 Authorization: - Bearer Accept-Encoding: @@ -53,7 +53,7 @@ http_interactions: message: OK headers: Date: - - Wed, 02 Apr 2025 17:53:38 GMT + - Fri, 18 Apr 2025 18:38:41 GMT Content-Type: - application/json Transfer-Encoding: @@ -65,7 +65,7 @@ http_interactions: X-Request-Id: - "" Openai-Processing-Ms: - - '492' + - '1143' Strict-Transport-Security: - max-age=31536000; includeSubDomains; preload Cf-Cache-Status: @@ -87,12 +87,6 @@ http_interactions: { "object": "list", "data": [ - { - "id": "gpt-4o-realtime-preview-2024-12-17", - "object": "model", - "created": 1733945430, - "owned_by": "system" - }, { "id": "gpt-4o-audio-preview-2024-12-17", "object": "model", @@ -105,6 +99,12 @@ http_interactions: "created": 1698785189, "owned_by": "system" }, + { + "id": "text-embedding-3-large", + "object": "model", + "created": 1705953180, + "owned_by": "system" + }, { "id": "dall-e-2", "object": "model", @@ -112,69 +112,69 @@ http_interactions: "owned_by": "system" }, { - "id": "gpt-4o-audio-preview-2024-10-01", + "id": "o4-mini-2025-04-16", "object": "model", - "created": 1727389042, + "created": 1744133506, "owned_by": "system" }, { - "id": "gpt-4o-mini-realtime-preview-2024-12-17", + "id": "gpt-4o-audio-preview-2024-10-01", "object": "model", - "created": 1734112601, + "created": 1727389042, "owned_by": "system" }, { - "id": "gpt-4o-mini-realtime-preview", + "id": "o4-mini", "object": "model", - "created": 1734387380, + "created": 1744225351, "owned_by": "system" }, { - "id": "gpt-4o-realtime-preview-2024-10-01", + "id": "o3-mini", "object": "model", - "created": 1727131766, + "created": 1737146383, "owned_by": "system" }, { - "id": "gpt-4o-transcribe", + "id": "gpt-4.1-nano", "object": "model", - "created": 1742068463, + "created": 1744321707, "owned_by": "system" }, { - "id": "gpt-4o-mini-transcribe", + "id": "o3-mini-2025-01-31", "object": "model", - "created": 1742068596, + "created": 1738010200, "owned_by": "system" }, { - "id": "gpt-4o-realtime-preview", + "id": "gpt-4.1-nano-2025-04-14", "object": "model", - "created": 1727659998, + "created": 1744321025, "owned_by": "system" }, { - "id": "babbage-002", + "id": "gpt-4o-realtime-preview-2024-10-01", "object": "model", - "created": 1692634615, + "created": 1727131766, "owned_by": "system" }, { - "id": "gpt-4o-mini-tts", + "id": "gpt-4o-realtime-preview", "object": "model", - "created": 1742403959, + "created": 1727659998, "owned_by": "system" }, { - "id": "tts-1-hd-1106", + "id": "babbage-002", "object": "model", - "created": 1699053533, + "created": 1692634615, "owned_by": "system" }, { - "id": "text-embedding-3-large", + "id": "tts-1-hd-1106", "object": "model", - "created": 1705953180, + "created": 1699053533, "owned_by": "system" }, { @@ -190,9 +190,21 @@ http_interactions: "owned_by": "openai-internal" }, { - "id": "omni-moderation-latest", + "id": "o1-2024-12-17", "object": "model", - "created": 1731689265, + "created": 1734326976, + "owned_by": "system" + }, + { + "id": "o1-pro-2025-03-19", + "object": "model", + "created": 1742251504, + "owned_by": "system" + }, + { + "id": "o1", + "object": "model", + "created": 1734375816, "owned_by": "system" }, { @@ -207,6 +219,12 @@ http_interactions: "created": 1734387424, "owned_by": "system" }, + { + "id": "o1-pro", + "object": "model", + "created": 1742251791, + "owned_by": "system" + }, { "id": "gpt-4o-audio-preview", "object": "model", @@ -219,6 +237,24 @@ http_interactions: "created": 1725648865, "owned_by": "system" }, + { + "id": "gpt-4o-mini-realtime-preview", + "object": "model", + "created": 1734387380, + "owned_by": "system" + }, + { + "id": "gpt-4.1-mini", + "object": "model", + "created": 1744318173, + "owned_by": "system" + }, + { + "id": "gpt-4o-mini-realtime-preview-2024-12-17", + "object": "model", + "created": 1734112601, + "owned_by": "system" + }, { "id": "gpt-3.5-turbo-instruct-0914", "object": "model", @@ -231,12 +267,24 @@ http_interactions: "created": 1741391161, "owned_by": "system" }, + { + "id": "gpt-4.1-mini-2025-04-14", + "object": "model", + "created": 1744317547, + "owned_by": "system" + }, { "id": "tts-1-1106", "object": "model", "created": 1699053241, "owned_by": "system" }, + { + "id": "chatgpt-4o-latest", + "object": "model", + "created": 1723515131, + "owned_by": "system" + }, { "id": "davinci-002", "object": "model", @@ -249,6 +297,12 @@ http_interactions: "created": 1698959748, "owned_by": "system" }, + { + "id": "gpt-4o-search-preview", + "object": "model", + "created": 1741388720, + "owned_by": "system" + }, { "id": "gpt-4-turbo", "object": "model", @@ -256,9 +310,9 @@ http_interactions: "owned_by": "system" }, { - "id": "gpt-4-0125-preview", + "id": "gpt-4o-realtime-preview-2024-12-17", "object": "model", - "created": 1706037612, + "created": 1733945430, "owned_by": "system" }, { @@ -280,15 +334,15 @@ http_interactions: "owned_by": "system" }, { - "id": "chatgpt-4o-latest", + "id": "gpt-4o-mini-search-preview-2025-03-11", "object": "model", - "created": 1723515131, + "created": 1741390858, "owned_by": "system" }, { - "id": "gpt-4o-mini-search-preview-2025-03-11", + "id": "gpt-4-0125-preview", "object": "model", - "created": 1741390858, + "created": 1706037612, "owned_by": "system" }, { @@ -303,24 +357,12 @@ http_interactions: "created": 1677532384, "owned_by": "openai-internal" }, - { - "id": "gpt-3.5-turbo-0125", - "object": "model", - "created": 1706048358, - "owned_by": "system" - }, { "id": "gpt-4o-2024-05-13", "object": "model", "created": 1715368132, "owned_by": "system" }, - { - "id": "gpt-3.5-turbo-16k", - "object": "model", - "created": 1683758102, - "owned_by": "openai-internal" - }, { "id": "gpt-4-turbo-2024-04-09", "object": "model", @@ -328,10 +370,10 @@ http_interactions: "owned_by": "system" }, { - "id": "gpt-4-1106-preview", + "id": "gpt-3.5-turbo-16k", "object": "model", - "created": 1698957206, - "owned_by": "system" + "created": 1683758102, + "owned_by": "openai-internal" }, { "id": "o1-preview", @@ -345,12 +387,6 @@ http_interactions: "created": 1686588896, "owned_by": "openai" }, - { - "id": "gpt-4o-search-preview", - "object": "model", - "created": 1741388720, - "owned_by": "system" - }, { "id": "gpt-4.5-preview", "object": "model", @@ -381,24 +417,6 @@ http_interactions: "created": 1732734466, "owned_by": "system" }, - { - "id": "o1-2024-12-17", - "object": "model", - "created": 1734326976, - "owned_by": "system" - }, - { - "id": "o1", - "object": "model", - "created": 1734375816, - "owned_by": "system" - }, - { - "id": "o1-pro", - "object": "model", - "created": 1742251791, - "owned_by": "system" - }, { "id": "text-embedding-3-small", "object": "model", @@ -406,9 +424,9 @@ http_interactions: "owned_by": "system" }, { - "id": "o1-pro-2025-03-19", + "id": "gpt-4o-mini-tts", "object": "model", - "created": 1742251504, + "created": 1742403959, "owned_by": "system" }, { @@ -424,21 +442,27 @@ http_interactions: "owned_by": "system" }, { - "id": "o3-mini", + "id": "gpt-4o-2024-08-06", "object": "model", - "created": 1737146383, + "created": 1722814719, "owned_by": "system" }, { - "id": "gpt-4o-2024-08-06", + "id": "gpt-4.1", "object": "model", - "created": 1722814719, + "created": 1744316542, "owned_by": "system" }, { - "id": "o3-mini-2025-01-31", + "id": "gpt-4o-transcribe", "object": "model", - "created": 1738010200, + "created": 1742068463, + "owned_by": "system" + }, + { + "id": "gpt-4.1-2025-04-14", + "object": "model", + "created": 1744315746, "owned_by": "system" }, { @@ -447,6 +471,12 @@ http_interactions: "created": 1721172717, "owned_by": "system" }, + { + "id": "gpt-4o-mini-transcribe", + "object": "model", + "created": 1742068596, + "owned_by": "system" + }, { "id": "o1-mini", "object": "model", @@ -459,6 +489,12 @@ http_interactions: "created": 1734115920, "owned_by": "system" }, + { + "id": "gpt-3.5-turbo-0125", + "object": "model", + "created": 1706048358, + "owned_by": "system" + }, { "id": "o1-mini-2024-09-12", "object": "model", @@ -466,14 +502,20 @@ http_interactions: "owned_by": "system" }, { - "id": "gpt-4.1-nano", + "id": "gpt-4-1106-preview", "object": "model", - "created": 1725648979, + "created": 1698957206, + "owned_by": "system" + }, + { + "id": "omni-moderation-latest", + "object": "model", + "created": 1731689265, "owned_by": "system" } ] } - recorded_at: Wed, 02 Apr 2025 17:53:38 GMT + recorded_at: Fri, 18 Apr 2025 18:38:41 GMT - request: method: get uri: https://api.anthropic.com/v1/models @@ -482,7 +524,7 @@ http_interactions: string: '' headers: User-Agent: - - Faraday v2.12.2 + - Faraday v2.13.0 X-Api-Key: - "" Anthropic-Version: @@ -497,7 +539,7 @@ http_interactions: message: OK headers: Date: - - Wed, 02 Apr 2025 17:53:39 GMT + - Fri, 18 Apr 2025 18:38:42 GMT Content-Type: - application/json Transfer-Encoding: @@ -530,7 +572,7 @@ http_interactions: 3 Sonnet","created_at":"2024-02-29T00:00:00Z"},{"type":"model","id":"claude-2.1","display_name":"Claude 2.1","created_at":"2023-11-21T00:00:00Z"},{"type":"model","id":"claude-2.0","display_name":"Claude 2.0","created_at":"2023-07-11T00:00:00Z"}],"has_more":false,"first_id":"claude-3-7-sonnet-20250219","last_id":"claude-2.0"}' - recorded_at: Wed, 02 Apr 2025 17:53:39 GMT + recorded_at: Fri, 18 Apr 2025 18:38:42 GMT - request: method: get uri: https://generativelanguage.googleapis.com/v1beta/models @@ -539,7 +581,7 @@ http_interactions: string: '' headers: User-Agent: - - Faraday v2.12.2 + - Faraday v2.13.0 X-Goog-Api-Key: - "" Accept-Encoding: @@ -558,7 +600,7 @@ http_interactions: - Referer - X-Origin Date: - - Wed, 02 Apr 2025 17:53:39 GMT + - Fri, 18 Apr 2025 18:38:42 GMT Server: - scaffolding on HTTPServer2 X-Xss-Protection: @@ -568,7 +610,7 @@ http_interactions: X-Content-Type-Options: - nosniff Server-Timing: - - gfet4t7; dur=86 + - gfet4t7; dur=81 Alt-Svc: - h3=":443"; ma=2592000,h3-29=":443"; ma=2592000 Transfer-Encoding: @@ -892,7 +934,42 @@ http_interactions: "outputTokenLimit": 65536, "supportedGenerationMethods": [ "generateContent", - "countTokens" + "countTokens", + "createCachedContent" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.5-pro-preview-03-25", + "version": "2.5-preview-03-25", + "displayName": "Gemini 2.5 Pro Preview 03-25", + "description": "Gemini 2.5 Pro Preview 03-25", + "inputTokenLimit": 1048576, + "outputTokenLimit": 65536, + "supportedGenerationMethods": [ + "generateContent", + "countTokens", + "createCachedContent" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemini-2.5-flash-preview-04-17", + "version": "2.5-preview-04-17", + "displayName": "Gemini 2.5 Flash Preview 04-17", + "description": "Preview release (April 17th, 2025) of Gemini 2.5 Flash", + "inputTokenLimit": 1048576, + "outputTokenLimit": 65536, + "supportedGenerationMethods": [ + "generateContent", + "countTokens", + "createCachedContent" ], "temperature": 1, "topP": 0.95, @@ -925,7 +1002,8 @@ http_interactions: "outputTokenLimit": 8192, "supportedGenerationMethods": [ "generateContent", - "countTokens" + "countTokens", + "createCachedContent" ], "temperature": 1, "topP": 0.95, @@ -939,26 +1017,10 @@ http_interactions: "description": "Stable version of Gemini 2.0 Flash, our fast and versatile multimodal model for scaling across diverse tasks, released in January of 2025.", "inputTokenLimit": 1048576, "outputTokenLimit": 8192, - "supportedGenerationMethods": [ - "generateContent", - "countTokens" - ], - "temperature": 1, - "topP": 0.95, - "topK": 40, - "maxTemperature": 2 - }, - { - "name": "models/gemini-2.0-flash-exp-image-generation", - "version": "2.0", - "displayName": "Gemini 2.0 Flash (Image Generation) Experimental", - "description": "Gemini 2.0 Flash (Image Generation) Experimental", - "inputTokenLimit": 1048576, - "outputTokenLimit": 8192, "supportedGenerationMethods": [ "generateContent", "countTokens", - "bidiGenerateContent" + "createCachedContent" ], "temperature": 1, "topP": 0.95, @@ -1038,7 +1100,8 @@ http_interactions: "outputTokenLimit": 65536, "supportedGenerationMethods": [ "generateContent", - "countTokens" + "countTokens", + "createCachedContent" ], "temperature": 1, "topP": 0.95, @@ -1054,7 +1117,8 @@ http_interactions: "outputTokenLimit": 65536, "supportedGenerationMethods": [ "generateContent", - "countTokens" + "countTokens", + "createCachedContent" ], "temperature": 1, "topP": 0.95, @@ -1070,7 +1134,8 @@ http_interactions: "outputTokenLimit": 65536, "supportedGenerationMethods": [ "generateContent", - "countTokens" + "countTokens", + "createCachedContent" ], "temperature": 1, "topP": 0.95, @@ -1141,6 +1206,36 @@ http_interactions: "topK": 64, "maxTemperature": 2 }, + { + "name": "models/learnlm-2.0-flash-experimental", + "version": "2.0", + "displayName": "LearnLM 2.0 Flash Experimental", + "description": "LearnLM 2.0 Flash Experimental", + "inputTokenLimit": 1048576, + "outputTokenLimit": 32768, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 + }, + { + "name": "models/gemma-3-1b-it", + "version": "001", + "displayName": "Gemma 3 1B", + "inputTokenLimit": 32768, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "generateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64 + }, { "name": "models/gemma-3-4b-it", "version": "001", @@ -1213,7 +1308,8 @@ http_interactions: "inputTokenLimit": 8192, "outputTokenLimit": 1, "supportedGenerationMethods": [ - "embedContent" + "embedContent", + "countTextTokens" ] }, { @@ -1224,7 +1320,8 @@ http_interactions: "inputTokenLimit": 8192, "outputTokenLimit": 1, "supportedGenerationMethods": [ - "embedContent" + "embedContent", + "countTextTokens" ] }, { @@ -1251,10 +1348,37 @@ http_interactions: "supportedGenerationMethods": [ "predict" ] + }, + { + "name": "models/veo-2.0-generate-001", + "version": "2.0", + "displayName": "Veo 2", + "description": "Vertex served Veo 2 model.", + "inputTokenLimit": 480, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "predictLongRunning" + ] + }, + { + "name": "models/gemini-2.0-flash-live-001", + "version": "001", + "displayName": "Gemini 2.0 Flash 001", + "description": "Gemini 2.0 Flash 001", + "inputTokenLimit": 131072, + "outputTokenLimit": 8192, + "supportedGenerationMethods": [ + "bidiGenerateContent", + "countTokens" + ], + "temperature": 1, + "topP": 0.95, + "topK": 64, + "maxTemperature": 2 } ] } - recorded_at: Wed, 02 Apr 2025 17:53:39 GMT + recorded_at: Fri, 18 Apr 2025 18:38:42 GMT - request: method: get uri: https://api.deepseek.com/models @@ -1263,7 +1387,7 @@ http_interactions: string: '' headers: User-Agent: - - Faraday v2.12.2 + - Faraday v2.13.0 Authorization: - Bearer Accept-Encoding: @@ -1276,7 +1400,7 @@ http_interactions: message: OK headers: Date: - - Wed, 02 Apr 2025 17:53:39 GMT + - Fri, 18 Apr 2025 18:38:42 GMT Content-Type: - application/json Transfer-Encoding: @@ -1288,7 +1412,7 @@ http_interactions: Access-Control-Allow-Credentials: - 'true' X-Ds-Trace-Id: - - eb9c177a0c3141beac66e5213c60ac6a + - fbb25c39e2bc649c91a644041e454d2b Strict-Transport-Security: - max-age=31536000; includeSubDomains; preload X-Content-Type-Options: @@ -1304,7 +1428,7 @@ http_interactions: body: encoding: ASCII-8BIT string: '{"object":"list","data":[{"id":"deepseek-chat","object":"model","owned_by":"deepseek"},{"id":"deepseek-reasoner","object":"model","owned_by":"deepseek"}]}' - recorded_at: Wed, 02 Apr 2025 17:53:39 GMT + recorded_at: Fri, 18 Apr 2025 18:38:42 GMT - request: method: get uri: http://localhost:11434/api/tags @@ -1341,16 +1465,16 @@ http_interactions: string: '' headers: User-Agent: - - Faraday v2.12.2 + - Faraday v2.13.0 Host: - bedrock..amazonaws.com X-Amz-Date: - - 20250402T175339Z + - 20250418T183842Z X-Amz-Content-Sha256: - e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 Authorization: - - AWS4-HMAC-SHA256 Credential=/20250402//bedrock/aws4_request, - SignedHeaders=host;x-amz-content-sha256;x-amz-date, Signature=5f69d324c05740f272e7c07046b973076335bd284cd150f03901ba9b30a62f4e + - AWS4-HMAC-SHA256 Credential=/20250418//bedrock/aws4_request, + SignedHeaders=host;x-amz-content-sha256;x-amz-date, Signature=cb5126823897aeb4f060c8d7e6049074ec8435c6baed641158c2d920723acb89 Accept-Encoding: - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 Accept: @@ -1361,15 +1485,15 @@ http_interactions: message: OK headers: Date: - - Wed, 02 Apr 2025 17:53:40 GMT + - Fri, 18 Apr 2025 18:38:43 GMT Content-Type: - application/json Content-Length: - - '45253' + - '45785' Connection: - keep-alive X-Amzn-Requestid: - - 62d4de6c-de54-44b7-b02e-51731449128a + - c1553dca-65ed-4b3e-968c-31905a47ff81 body: encoding: UTF-8 string: '{"modelSummaries":[{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/amazon.titan-tg1-large","modelId":"amazon.titan-tg1-large","modelLifecycle":{"status":"ACTIVE"},"modelName":"Titan @@ -1450,7 +1574,52 @@ http_interactions: 7B Instruct","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/mistral.mixtral-8x7b-instruct-v0:1","modelId":"mistral.mixtral-8x7b-instruct-v0:1","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mixtral 8x7B Instruct","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/mistral.mistral-large-2402-v1:0","modelId":"mistral.mistral-large-2402-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral Large (24.02)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/mistral.mistral-large-2407-v1:0","modelId":"mistral.mistral-large-2407-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Mistral - Large (24.07)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/luma.ray-v2:0","modelId":"luma.ray-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Ray + Large (24.07)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":true,"inferenceTypesSupported":["INFERENCE_PROFILE"],"inputModalities":["TEXT","IMAGE"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/mistral.pixtral-large-2502-v1:0","modelId":"mistral.pixtral-large-2502-v1:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Pixtral + Large (25.02)","outputModalities":["TEXT"],"providerName":"Mistral AI","responseStreamingSupported":true},{"customizationsSupported":[],"explicitPromptCaching":{"isSupported":false},"guardrailsSupported":false,"inferenceTypesSupported":["ON_DEMAND"],"inputModalities":["TEXT"],"intelligentPromptRouting":{"isSupported":false},"modelArn":"arn:aws:bedrock:::foundation-model/luma.ray-v2:0","modelId":"luma.ray-v2:0","modelLifecycle":{"status":"ACTIVE"},"modelName":"Ray v2","outputModalities":["VIDEO"],"providerName":"Luma AI","responseStreamingSupported":false}]}' - recorded_at: Wed, 02 Apr 2025 17:53:40 GMT + recorded_at: Fri, 18 Apr 2025 18:38:43 GMT +- request: + method: get + uri: https://openrouter.ai/api/v1/models + body: + encoding: US-ASCII + string: '' + headers: + User-Agent: + - Faraday v2.13.0 + Authorization: + - Bearer + Accept-Encoding: + - gzip;q=1.0,deflate;q=0.6,identity;q=0.3 + Accept: + - "*/*" + response: + status: + code: 200 + message: OK + headers: + Date: + - Mon, 21 Apr 2025 11:25:26 GMT + Content-Type: + - application/json + Transfer-Encoding: + - chunked + Connection: + - keep-alive + Access-Control-Allow-Origin: + - "*" + Cdn-Cache-Control: + - max-age=300 + Vary: + - Accept-Encoding + Server: + - cloudflare + Cf-Ray: + - "" + body: + encoding: ASCII-8BIT + string: !binary |- + {"data":[{"id":"google/gemini-2.5-pro-preview-03-25","name":"Google: Gemini 2.5 Pro Preview","created":1744924206,"description":"Gemini 2.5 Pro is Google’s state-of-the-art AI model designed for advanced reasoning, coding, mathematics, and scientific tasks. It employs “thinking” capabilities, enabling it to reason through responses with enhanced accuracy and nuanced context handling. Gemini 2.5 Pro achieves top-tier performance on multiple benchmarks, including first-place positioning on the LMArena leaderboard, reflecting superior human-preference alignment and complex problem-solving abilities.","context_length":1048576,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0.00000125","completion":"0.00001","request":"0","image":"0.00516","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000003125","input_cache_write":"0"},"top_provider":{"context_length":1048576,"max_completion_tokens":65535,"is_moderated":false},"per_request_limits":null},{"id":"thudm/glm-z1-32b:free","name":"THUDM: GLM Z1 32B (free)","created":1744924148,"description":"GLM-Z1-32B-0414 is an enhanced reasoning variant of GLM-4-32B, built for deep mathematical, logical, and code-oriented problem solving. It applies extended reinforcement learning—both task-specific and general pairwise preference-based—to improve performance on complex multi-step tasks. Compared to the base GLM-4-32B model, Z1 significantly boosts capabilities in structured reasoning and formal domains.\n\nThe model supports enforced “thinking” steps via prompt engineering and offers improved coherence for long-form outputs. It’s optimized for use in agentic workflows, and includes support for long context (via YaRN), JSON tool calling, and fine-grained sampling configuration for stable inference. Ideal for use cases requiring deliberate, multi-step reasoning or formal derivations.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"thudm/glm-4-32b:free","name":"THUDM: GLM 4 32B (free)","created":1744920915,"description":"GLM-4-32B-0414 is a 32B bilingual (Chinese-English) open-weight language model optimized for code generation, function calling, and agent-style tasks. Pretrained on 15T of high-quality and reasoning-heavy data, it was further refined using human preference alignment, rejection sampling, and reinforcement learning. The model excels in complex reasoning, artifact generation, and structured output tasks, achieving performance comparable to GPT-4o and DeepSeek-V3-0324 across several benchmarks.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-2.5-flash-preview","name":"Google: Gemini 2.5 Flash Preview","created":1744914667,"description":"Gemini 2.5 Flash is Google's state-of-the-art workhorse model, specifically designed for advanced reasoning, coding, mathematics, and scientific tasks. It includes built-in \"thinking\" capabilities, enabling it to provide responses with greater accuracy and nuanced context handling. \n\nNote: This model is available in two variants: thinking and non-thinking. The output pricing varies significantly depending on whether the thinking capability is active. If you select the standard variant (without the \":thinking\" suffix), the model will explicitly avoid generating thinking tokens. \n\nTo utilize the thinking capability and receive thinking tokens, you must choose the \":thinking\" variant, which will then incur the higher thinking-output pricing. \n\nAdditionally, Gemini 2.5 Flash is configurable through the \"max tokens for reasoning\" parameter, as described in the documentation (https://openrouter.ai/docs/use-cases/reasoning-tokens#max-tokens-for-reasoning).","context_length":1048576,"architecture":{"modality":"text+image->text","input_modalities":["image","text"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0.00000015","completion":"0.0000006","request":"0","image":"0.0006192","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":1048576,"max_completion_tokens":65535,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-2.5-flash-preview:thinking","name":"Google: Gemini 2.5 Flash Preview (thinking)","created":1744914667,"description":"Gemini 2.5 Flash is Google's state-of-the-art workhorse model, specifically designed for advanced reasoning, coding, mathematics, and scientific tasks. It includes built-in \"thinking\" capabilities, enabling it to provide responses with greater accuracy and nuanced context handling. \n\nNote: This model is available in two variants: thinking and non-thinking. The output pricing varies significantly depending on whether the thinking capability is active. If you select the standard variant (without the \":thinking\" suffix), the model will explicitly avoid generating thinking tokens. \n\nTo utilize the thinking capability and receive thinking tokens, you must choose the \":thinking\" variant, which will then incur the higher thinking-output pricing. \n\nAdditionally, Gemini 2.5 Flash is configurable through the \"max tokens for reasoning\" parameter, as described in the documentation (https://openrouter.ai/docs/use-cases/reasoning-tokens#max-tokens-for-reasoning).","context_length":1048576,"architecture":{"modality":"text+image->text","input_modalities":["image","text"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0.00000015","completion":"0.0000035","request":"0","image":"0.0006192","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":1048576,"max_completion_tokens":65535,"is_moderated":false},"per_request_limits":null},{"id":"openai/o4-mini-high","name":"OpenAI: o4 Mini High","created":1744824212,"description":"OpenAI o4-mini-high is the same model as [o4-mini](/openai/o4-mini) with reasoning_effort set to high. \n\nOpenAI o4-mini is a compact reasoning model in the o-series, optimized for fast, cost-efficient performance while retaining strong multimodal and agentic capabilities. It supports tool use and demonstrates competitive reasoning and coding performance across benchmarks like AIME (99.5% with Python) and SWE-bench, outperforming its predecessor o3-mini and even approaching o3 in some domains.\n\nDespite its smaller size, o4-mini exhibits high accuracy in STEM tasks, visual problem solving (e.g., MathVista, MMMU), and code editing. It is especially well-suited for high-throughput scenarios where latency or cost is critical. Thanks to its efficient architecture and refined reinforcement learning training, o4-mini can chain tools, generate structured outputs, and solve multi-step tasks with minimal delay—often in under a minute.","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["image","text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000011","completion":"0.0000044","request":"0","image":"0.0008415","web_search":"0","internal_reasoning":"0","input_cache_read":"0.000000275"},"top_provider":{"context_length":200000,"max_completion_tokens":100000,"is_moderated":true},"per_request_limits":null},{"id":"openai/o3","name":"OpenAI: o3","created":1744823457,"description":"o3 is a well-rounded and powerful model across domains. It sets a new standard for math, science, coding, and visual reasoning tasks. It also excels at technical writing and instruction-following. Use it to think through multi-step problems that involve analysis across text, code, and images. Note that BYOK is required for this model. Set up here: https://openrouter.ai/settings/integrations","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["image","text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.00001","completion":"0.00004","request":"0","image":"0.00765","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000025"},"top_provider":{"context_length":200000,"max_completion_tokens":100000,"is_moderated":true},"per_request_limits":null},{"id":"openai/o4-mini","name":"OpenAI: o4 Mini","created":1744820942,"description":"OpenAI o4-mini is a compact reasoning model in the o-series, optimized for fast, cost-efficient performance while retaining strong multimodal and agentic capabilities. It supports tool use and demonstrates competitive reasoning and coding performance across benchmarks like AIME (99.5% with Python) and SWE-bench, outperforming its predecessor o3-mini and even approaching o3 in some domains.\n\nDespite its smaller size, o4-mini exhibits high accuracy in STEM tasks, visual problem solving (e.g., MathVista, MMMU), and code editing. It is especially well-suited for high-throughput scenarios where latency or cost is critical. Thanks to its efficient architecture and refined reinforcement learning training, o4-mini can chain tools, generate structured outputs, and solve multi-step tasks with minimal delay—often in under a minute.","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["image","text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000011","completion":"0.0000044","request":"0","image":"0.0008415","web_search":"0","internal_reasoning":"0","input_cache_read":"0.000000275"},"top_provider":{"context_length":200000,"max_completion_tokens":100000,"is_moderated":true},"per_request_limits":null},{"id":"shisa-ai/shisa-v2-llama3.3-70b:free","name":"Shisa AI: Shisa V2 Llama 3.3 70B  (free)","created":1744754858,"description":"Shisa V2 Llama 3.3 70B is a bilingual Japanese-English chat model fine-tuned by Shisa.AI on Meta’s Llama-3.3-70B-Instruct base. It prioritizes Japanese language performance while retaining strong English capabilities. The model was optimized entirely through post-training, using a refined mix of supervised fine-tuning (SFT) and DPO datasets including regenerated ShareGPT-style data, translation tasks, roleplaying conversations, and instruction-following prompts. Unlike earlier Shisa releases, this version avoids tokenizer modifications or extended pretraining.\n\nShisa V2 70B achieves leading Japanese task performance across a wide range of custom and public benchmarks, including JA MT Bench, ELYZA 100, and Rakuda. It supports a 128K token context length and integrates smoothly with inference frameworks like vLLM and SGLang. While it inherits safety characteristics from its base model, no additional alignment was applied. The model is intended for high-performance bilingual chat, instruction following, and translation tasks across JA/EN.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen2.5-coder-7b-instruct","name":"Qwen: Qwen2.5 Coder 7B Instruct","created":1744734887,"description":"Qwen2.5-Coder-7B-Instruct is a 7B parameter instruction-tuned language model optimized for code-related tasks such as code generation, reasoning, and bug fixing. Based on the Qwen2.5 architecture, it incorporates enhancements like RoPE, SwiGLU, RMSNorm, and GQA attention with support for up to 128K tokens using YaRN-based extrapolation. It is trained on a large corpus of source code, synthetic data, and text-code grounding, providing robust performance across programming languages and agentic coding workflows.\n\nThis model is part of the Qwen2.5-Coder family and offers strong compatibility with tools like vLLM for efficient deployment. Released under the Apache 2.0 license.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0.0000002","completion":"0.0000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":32768,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-4.1","name":"OpenAI: GPT-4.1","created":1744651385,"description":"GPT-4.1 is a flagship large language model optimized for advanced instruction following, real-world software engineering, and long-context reasoning. It supports a 1 million token context window and outperforms GPT-4o and GPT-4.5 across coding (54.6% SWE-bench Verified), instruction compliance (87.4% IFEval), and multimodal understanding benchmarks. It is tuned for precise code diffs, agent reliability, and high recall in large document contexts, making it ideal for agents, IDE tooling, and enterprise knowledge retrieval.","context_length":1047576,"architecture":{"modality":"text+image->text","input_modalities":["image","text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.000002","completion":"0.000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000005"},"top_provider":{"context_length":1047576,"max_completion_tokens":32768,"is_moderated":true},"per_request_limits":null},{"id":"openai/gpt-4.1-mini","name":"OpenAI: GPT-4.1 Mini","created":1744651381,"description":"GPT-4.1 Mini is a mid-sized model delivering performance competitive with GPT-4o at substantially lower latency and cost. It retains a 1 million token context window and scores 45.1% on hard instruction evals, 35.8% on MultiChallenge, and 84.1% on IFEval. Mini also shows strong coding ability (e.g., 31.6% on Aider’s polyglot diff benchmark) and vision understanding, making it suitable for interactive applications with tight performance constraints.","context_length":1047576,"architecture":{"modality":"text+image->text","input_modalities":["image","text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.0000004","completion":"0.0000016","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000001"},"top_provider":{"context_length":1047576,"max_completion_tokens":32768,"is_moderated":true},"per_request_limits":null},{"id":"openai/gpt-4.1-nano","name":"OpenAI: GPT-4.1 Nano","created":1744651369,"description":"For tasks that demand low latency, GPT‑4.1 nano is the fastest and cheapest model in the GPT-4.1 series. It delivers exceptional performance at a small size with its 1 million token context window, and scores 80.1% on MMLU, 50.3% on GPQA, and 9.8% on Aider polyglot coding – even higher than GPT‑4o mini. It’s ideal for tasks like classification or autocompletion.","context_length":1047576,"architecture":{"modality":"text+image->text","input_modalities":["image","text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.0000001","completion":"0.0000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.000000025"},"top_provider":{"context_length":1047576,"max_completion_tokens":32768,"is_moderated":true},"per_request_limits":null},{"id":"eleutherai/llemma_7b","name":"EleutherAI: Llemma 7b","created":1744643225,"description":"Llemma 7B is a language model for mathematics. It was initialized with Code Llama 7B weights, and trained on the Proof-Pile-2 for 200B tokens. Llemma models are particularly strong at chain-of-thought mathematical reasoning and using computational tools for mathematics, such as Python and formal theorem provers.","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000008","completion":"0.0000012","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"alfredpros/codellama-7b-instruct-solidity","name":"AlfredPros: CodeLLaMa 7B Instruct Solidity","created":1744641874,"description":"A finetuned 7 billion parameters Code LLaMA - Instruct model to generate Solidity smart contract using 4-bit QLoRA finetuning provided by PEFT library.","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000008","completion":"0.0000012","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"arliai/qwq-32b-arliai-rpr-v1:free","name":"ArliAI: QwQ 32B RpR v1 (free)","created":1744555982,"description":"QwQ-32B-ArliAI-RpR-v1 is a 32B parameter model fine-tuned from Qwen/QwQ-32B using a curated creative writing and roleplay dataset originally developed for the RPMax series. It is designed to maintain coherence and reasoning across long multi-turn conversations by introducing explicit reasoning steps per dialogue turn, generated and refined using the base model itself.\n\nThe model was trained using RS-QLORA+ on 8K sequence lengths and supports up to 128K context windows (with practical performance around 32K). It is optimized for creative roleplay and dialogue generation, with an emphasis on minimizing cross-context repetition while preserving stylistic diversity.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"agentica-org/deepcoder-14b-preview:free","name":"Agentica: Deepcoder 14B Preview (free)","created":1744555395,"description":"DeepCoder-14B-Preview is a 14B parameter code generation model fine-tuned from DeepSeek-R1-Distill-Qwen-14B using reinforcement learning with GRPO+ and iterative context lengthening. It is optimized for long-context program synthesis and achieves strong performance across coding benchmarks, including 60.6% on LiveCodeBench v5, competitive with models like o3-Mini","context_length":96000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":96000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"moonshotai/kimi-vl-a3b-thinking:free","name":"Moonshot AI: Kimi VL A3B Thinking (free)","created":1744304841,"description":"Kimi-VL is a lightweight Mixture-of-Experts vision-language model that activates only 2.8B parameters per step while delivering strong performance on multimodal reasoning and long-context tasks. The Kimi-VL-A3B-Thinking variant, fine-tuned with chain-of-thought and reinforcement learning, excels in math and visual reasoning benchmarks like MathVision, MMMU, and MathVista, rivaling much larger models such as Qwen2.5-VL-7B and Gemma-3-12B. It supports 128K context and high-resolution input via its MoonViT encoder.","context_length":131072,"architecture":{"modality":"text+image->text","input_modalities":["image","text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"x-ai/grok-3-mini-beta","name":"xAI: Grok 3 Mini Beta","created":1744240195,"description":"Grok 3 Mini is a lightweight, smaller thinking model. Unlike traditional models that generate answers immediately, Grok 3 Mini thinks before responding. It’s ideal for reasoning-heavy tasks that don’t demand extensive domain knowledge, and shines in math-specific and quantitative use cases, such as solving challenging puzzles or math problems.\n\nTransparent \"thinking\" traces accessible. Defaults to low reasoning, can boost with setting `reasoning: { effort: \"high\" }`\n\nNote: That there are two xAI endpoints for this model. By default when using this model we will always route you to the base endpoint. If you want the fast endpoint you can add `provider: { sort: throughput}`, to sort by throughput instead. \n","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Grok","instruct_type":null},"pricing":{"prompt":"0.0000003","completion":"0.0000005","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"x-ai/grok-3-beta","name":"xAI: Grok 3 Beta","created":1744240068,"description":"Grok 3 is the latest model from xAI. It's their flagship model that excels at enterprise use cases like data extraction, coding, and text summarization. Possesses deep domain knowledge in finance, healthcare, law, and science.\n\nExcels in structured tasks and benchmarks like GPQA, LCB, and MMLU-Pro where it outperforms Grok 3 Mini even on high thinking. \n\nNote: That there are two xAI endpoints for this model. By default when using this model we will always route you to the base endpoint. If you want the fast endpoint you can add `provider: { sort: throughput}`, to sort by throughput instead. \n","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Grok","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"nvidia/llama-3.1-nemotron-nano-8b-v1:free","name":"NVIDIA: Llama 3.1 Nemotron Nano 8B v1 (free)","created":1744123873,"description":"Llama-3.1-Nemotron-Nano-8B-v1 is a compact large language model (LLM) derived from Meta's Llama-3.1-8B-Instruct, specifically optimized for reasoning tasks, conversational interactions, retrieval-augmented generation (RAG), and tool-calling applications. It balances accuracy and efficiency, fitting comfortably onto a single consumer-grade RTX GPU for local deployment. The model supports extended context lengths of up to 128K tokens.\n\nNote: you must include `detailed thinking on` in the system prompt to enable reasoning. Please see [Usage Recommendations](https://huggingface.co/nvidia/Llama-3_1-Nemotron-Ultra-253B-v1#quick-start-and-usage-recommendations) for more.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"nvidia/llama-3.3-nemotron-super-49b-v1:free","name":"NVIDIA: Llama 3.3 Nemotron Super 49B v1 (free)","created":1744119494,"description":"Llama-3.3-Nemotron-Super-49B-v1 is a large language model (LLM) optimized for advanced reasoning, conversational interactions, retrieval-augmented generation (RAG), and tool-calling tasks. Derived from Meta's Llama-3.3-70B-Instruct, it employs a Neural Architecture Search (NAS) approach, significantly enhancing efficiency and reducing memory requirements. This allows the model to support a context length of up to 128K tokens and fit efficiently on single high-performance GPUs, such as NVIDIA H200.\n\nNote: you must include `detailed thinking on` in the system prompt to enable reasoning. Please see [Usage Recommendations](https://huggingface.co/nvidia/Llama-3_1-Nemotron-Ultra-253B-v1#quick-start-and-usage-recommendations) for more.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"nvidia/llama-3.1-nemotron-ultra-253b-v1:free","name":"NVIDIA: Llama 3.1 Nemotron Ultra 253B v1 (free)","created":1744115059,"description":"Llama-3.1-Nemotron-Ultra-253B-v1 is a large language model (LLM) optimized for advanced reasoning, human-interactive chat, retrieval-augmented generation (RAG), and tool-calling tasks. Derived from Meta’s Llama-3.1-405B-Instruct, it has been significantly customized using Neural Architecture Search (NAS), resulting in enhanced efficiency, reduced memory usage, and improved inference latency. The model supports a context length of up to 128K tokens and can operate efficiently on an 8x NVIDIA H100 node.\n\nNote: you must include `detailed thinking on` in the system prompt to enable reasoning. Please see [Usage Recommendations](https://huggingface.co/nvidia/Llama-3_1-Nemotron-Ultra-253B-v1#quick-start-and-usage-recommendations) for more.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-4-maverick:free","name":"Meta: Llama 4 Maverick (free)","created":1743881822,"description":"Llama 4 Maverick 17B Instruct (128E) is a high-capacity multimodal language model from Meta, built on a mixture-of-experts (MoE) architecture with 128 experts and 17 billion active parameters per forward pass (400B total). It supports multilingual text and image input, and produces multilingual text and code output across 12 supported languages. Optimized for vision-language tasks, Maverick is instruction-tuned for assistant-like behavior, image reasoning, and general-purpose multimodal interaction.\n\nMaverick features early fusion for native multimodality and a 1 million token context window. It was trained on a curated mixture of public, licensed, and Meta-platform data, covering ~22 trillion tokens, with a knowledge cutoff in August 2024. Released on April 5, 2025 under the Llama 4 Community License, Maverick is suited for research and commercial applications requiring advanced multimodal understanding and high model throughput.","context_length":256000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":256000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-4-maverick","name":"Meta: Llama 4 Maverick","created":1743881822,"description":"Llama 4 Maverick 17B Instruct (128E) is a high-capacity multimodal language model from Meta, built on a mixture-of-experts (MoE) architecture with 128 experts and 17 billion active parameters per forward pass (400B total). It supports multilingual text and image input, and produces multilingual text and code output across 12 supported languages. Optimized for vision-language tasks, Maverick is instruction-tuned for assistant-like behavior, image reasoning, and general-purpose multimodal interaction.\n\nMaverick features early fusion for native multimodality and a 1 million token context window. It was trained on a curated mixture of public, licensed, and Meta-platform data, covering ~22 trillion tokens, with a knowledge cutoff in August 2024. Released on April 5, 2025 under the Llama 4 Community License, Maverick is suited for research and commercial applications requiring advanced multimodal understanding and high model throughput.","context_length":1048576,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.00000017","completion":"0.00000085","request":"0","image":"0.0006684","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":1048576,"max_completion_tokens":1048576,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-4-scout:free","name":"Meta: Llama 4 Scout (free)","created":1743881519,"description":"Llama 4 Scout 17B Instruct (16E) is a mixture-of-experts (MoE) language model developed by Meta, activating 17 billion parameters out of a total of 109B. It supports native multimodal input (text and image) and multilingual output (text and code) across 12 supported languages. Designed for assistant-style interaction and visual reasoning, Scout uses 16 experts per forward pass and features a context length of 10 million tokens, with a training corpus of ~40 trillion tokens.\n\nBuilt for high efficiency and local or commercial deployment, Llama 4 Scout incorporates early fusion for seamless modality integration. It is instruction-tuned for use in multilingual chat, captioning, and image understanding tasks. Released under the Llama 4 Community License, it was last trained on data up to August 2024 and launched publicly on April 5, 2025.","context_length":512000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":512000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-4-scout","name":"Meta: Llama 4 Scout","created":1743881519,"description":"Llama 4 Scout 17B Instruct (16E) is a mixture-of-experts (MoE) language model developed by Meta, activating 17 billion parameters out of a total of 109B. It supports native multimodal input (text and image) and multilingual output (text and code) across 12 supported languages. Designed for assistant-style interaction and visual reasoning, Scout uses 16 experts per forward pass and features a context length of 10 million tokens, with a training corpus of ~40 trillion tokens.\n\nBuilt for high efficiency and local or commercial deployment, Llama 4 Scout incorporates early fusion for seamless modality integration. It is instruction-tuned for use in multilingual chat, captioning, and image understanding tasks. Released under the Llama 4 Community License, it was last trained on data up to August 2024 and launched publicly on April 5, 2025.","context_length":327680,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.00000008","completion":"0.0000003","request":"0","image":"0.0003342","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":327680,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"all-hands/openhands-lm-32b-v0.1","name":"OpenHands LM 32B V0.1","created":1743613013,"description":"OpenHands LM v0.1 is a 32B open-source coding model fine-tuned from Qwen2.5-Coder-32B-Instruct using reinforcement learning techniques outlined in SWE-Gym. It is optimized for autonomous software development agents and achieves strong performance on SWE-Bench Verified, with a 37.2% resolve rate. The model supports a 128K token context window, making it well-suited for long-horizon code reasoning and large codebase tasks.\n\nOpenHands LM is designed for local deployment and runs on consumer-grade GPUs such as a single 3090. It enables fully offline agent workflows without dependency on proprietary APIs. This release is intended as a research preview, and future updates aim to improve generalizability, reduce repetition, and offer smaller variants.","context_length":16384,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000026","completion":"0.0000034","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"mistral/ministral-8b","name":"Mistral: Ministral 8B","created":1743430021,"description":"Ministral 8B is a state-of-the-art language model optimized for on-device and edge computing. Designed for efficiency in knowledge-intensive tasks, commonsense reasoning, and function-calling, it features a specialized interleaved sliding-window attention mechanism, enabling faster and more memory-efficient inference. Ministral 8B excels in local, low-latency applications such as offline translation, smart assistants, autonomous robotics, and local analytics.\n\nThe model supports up to 128k context length and can function as a performant intermediary in multi-step agentic workflows, efficiently handling tasks like input parsing, API calls, and task routing. It consistently outperforms comparable models like Mistral 7B across benchmarks, making it particularly suitable for compute-efficient, privacy-focused scenarios.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.0000001","completion":"0.0000001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-v3-base:free","name":"DeepSeek: DeepSeek V3 Base (free)","created":1743272023,"description":"Note that this is a base model mostly meant for testing, you need to provide detailed prompts for the model to return useful responses. \n\nDeepSeek-V3 Base is a 671B parameter open Mixture-of-Experts (MoE) language model with 37B active parameters per forward pass and a context length of 128K tokens. Trained on 14.8T tokens using FP8 mixed precision, it achieves high training efficiency and stability, with strong performance across language, reasoning, math, and coding tasks. \n\nDeepSeek-V3 Base is the pre-trained model behind [DeepSeek V3](/deepseek/deepseek-chat-v3)","context_length":163840,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"DeepSeek","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":163840,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"scb10x/llama3.1-typhoon2-8b-instruct","name":"Typhoon2 8B Instruct","created":1743196511,"description":"Llama3.1-Typhoon2-8B-Instruct is a Thai-English instruction-tuned model with 8 billion parameters, built on Llama 3.1. It significantly improves over its base model in Thai reasoning, instruction-following, and function-calling tasks, while maintaining competitive English performance. The model is optimized for bilingual interaction and performs well on Thai-English code-switching, MT-Bench, IFEval, and tool-use benchmarks.\n\nDespite its smaller size, it demonstrates strong generalization across math, coding, and multilingual benchmarks, outperforming comparable 8B models across most Thai-specific tasks. Full benchmark results and methodology are available in the [technical report.](https://arxiv.org/abs/2412.13702)","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.00000018","completion":"0.00000018","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"scb10x/llama3.1-typhoon2-70b-instruct","name":"Typhoon2 70B Instruct","created":1743196170,"description":"Llama3.1-Typhoon2-70B-Instruct is a Thai-English instruction-tuned language model with 70 billion parameters, built on Llama 3.1. It demonstrates strong performance across general instruction-following, math, coding, and tool-use tasks, with state-of-the-art results in Thai-specific benchmarks such as IFEval, MT-Bench, and Thai-English code-switching.\n\nThe model excels in bilingual reasoning and function-calling scenarios, offering high accuracy across diverse domains. Comparative evaluations show consistent improvements over prior Thai LLMs and other Llama-based baselines. Full results and methodology are available in the [technical report.](https://arxiv.org/abs/2412.13702)","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.00000088","completion":"0.00000088","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"allenai/molmo-7b-d:free","name":"AllenAI: Molmo 7B D (free)","created":1743023247,"description":"Molmo is a family of open vision-language models developed by the Allen Institute for AI. Molmo models are trained on PixMo, a dataset of 1 million, highly-curated image-text pairs. It has state-of-the-art performance among multimodal models with a similar size while being fully open-source. You can find all models in the Molmo family [here](https://huggingface.co/collections/allenai/molmo-66f379e6fe3b8ef090a8ca19). Learn more about the Molmo family [in the announcement blog post](https://molmo.allenai.org/blog) or the [paper](https://huggingface.co/papers/2409.17146).\n\nMolmo 7B-D is based on [Qwen2-7B](https://huggingface.co/Qwen/Qwen2-7B) and uses [OpenAI CLIP](https://huggingface.co/openai/clip-vit-large-patch14-336) as vision backbone. It performs comfortably between GPT-4V and GPT-4o on both academic benchmarks and human evaluation.\n\nThis checkpoint is a preview of the Molmo release. All artifacts used in creating Molmo (PixMo dataset, training code, evaluations, intermediate checkpoints) will be made available at a later date, furthering our commitment to open-source AI development and reproducibility.","context_length":4096,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"bytedance-research/ui-tars-72b:free","name":"Bytedance: UI-TARS 72B  (free)","created":1743020065,"description":"UI-TARS 72B is an open-source multimodal AI model designed specifically for automating browser and desktop tasks through visual interaction and control. The model is built with a specialized vision architecture enabling accurate interpretation and manipulation of on-screen visual data. It supports automation tasks within web browsers as well as desktop applications, including Microsoft Office and VS Code.\n\nCore capabilities include intelligent screen detection, predictive action modeling, and efficient handling of repetitive interactions. UI-TARS employs supervised fine-tuning (SFT) tailored explicitly for computer control scenarios. It can be deployed locally or accessed via Hugging Face for demonstration purposes. Intended use cases encompass workflow automation, task scripting, and interactive desktop control applications.","context_length":32768,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen2.5-vl-3b-instruct:free","name":"Qwen: Qwen2.5 VL 3B Instruct (free)","created":1743014573,"description":"Qwen2.5 VL 3B is a multimodal LLM from the Qwen Team with the following key enhancements:\n\n- SoTA understanding of images of various resolution & ratio: Qwen2.5-VL achieves state-of-the-art performance on visual understanding benchmarks, including MathVista, DocVQA, RealWorldQA, MTVQA, etc.\n\n- Agent that can operate your mobiles, robots, etc.: with the abilities of complex reasoning and decision making, Qwen2.5-VL can be integrated with devices like mobile phones, robots, etc., for automatic operation based on visual environment and text instructions.\n\n- Multilingual Support: to serve global users, besides English and Chinese, Qwen2.5-VL now supports the understanding of texts in different languages inside images, including most European languages, Japanese, Korean, Arabic, Vietnamese, etc.\n\nFor more details, see this [blog post](https://qwenlm.github.io/blog/qwen2-vl/) and [GitHub repo](https://github.com/QwenLM/Qwen2-VL).\n\nUsage of this model is subject to [Tongyi Qianwen LICENSE AGREEMENT](https://huggingface.co/Qwen/Qwen1.5-110B-Chat/blob/main/LICENSE).","context_length":64000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":64000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-2.5-pro-exp-03-25:free","name":"Google: Gemini 2.5 Pro Experimental (free)","created":1742922099,"description":"Gemini 2.5 Pro is Google’s state-of-the-art AI model designed for advanced reasoning, coding, mathematics, and scientific tasks. It employs “thinking” capabilities, enabling it to reason through responses with enhanced accuracy and nuanced context handling. Gemini 2.5 Pro achieves top-tier performance on multiple benchmarks, including first-place positioning on the LMArena leaderboard, reflecting superior human-preference alignment and complex problem-solving abilities.","context_length":1000000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":1000000,"max_completion_tokens":65535,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen2.5-vl-32b-instruct:free","name":"Qwen: Qwen2.5 VL 32B Instruct (free)","created":1742839838,"description":"Qwen2.5-VL-32B is a multimodal vision-language model fine-tuned through reinforcement learning for enhanced mathematical reasoning, structured outputs, and visual problem-solving capabilities. It excels at visual analysis tasks, including object recognition, textual interpretation within images, and precise event localization in extended videos. Qwen2.5-VL-32B demonstrates state-of-the-art performance across multimodal benchmarks such as MMMU, MathVista, and VideoMME, while maintaining strong reasoning and clarity in text-based tasks like MMLU, mathematical problem-solving, and code generation.","context_length":8192,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen2.5-vl-32b-instruct","name":"Qwen: Qwen2.5 VL 32B Instruct","created":1742839838,"description":"Qwen2.5-VL-32B is a multimodal vision-language model fine-tuned through reinforcement learning for enhanced mathematical reasoning, structured outputs, and visual problem-solving capabilities. It excels at visual analysis tasks, including object recognition, textual interpretation within images, and precise event localization in extended videos. Qwen2.5-VL-32B demonstrates state-of-the-art performance across multimodal benchmarks such as MMMU, MathVista, and VideoMME, while maintaining strong reasoning and clarity in text-based tasks like MMLU, mathematical problem-solving, and code generation.","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0.0000009","completion":"0.0000009","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-chat-v3-0324:free","name":"DeepSeek: DeepSeek V3 0324 (free)","created":1742824755,"description":"DeepSeek V3, a 685B-parameter, mixture-of-experts model, is the latest iteration of the flagship chat model family from the DeepSeek team.\n\nIt succeeds the [DeepSeek V3](/deepseek/deepseek-chat-v3) model and performs really well on a variety of tasks.","context_length":163840,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"DeepSeek","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":163840,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-chat-v3-0324","name":"DeepSeek: DeepSeek V3 0324","created":1742824755,"description":"DeepSeek V3, a 685B-parameter, mixture-of-experts model, is the latest iteration of the flagship chat model family from the DeepSeek team.\n\nIt succeeds the [DeepSeek V3](/deepseek/deepseek-chat-v3) model and performs really well on a variety of tasks.","context_length":64000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"DeepSeek","instruct_type":null},"pricing":{"prompt":"0.00000027","completion":"0.0000011","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000007"},"top_provider":{"context_length":64000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"featherless/qwerky-72b:free","name":"Qwerky 72B (free)","created":1742481597,"description":"Qwerky-72B is a linear-attention RWKV variant of the Qwen 2.5 72B model, optimized to significantly reduce computational cost at scale. Leveraging linear attention, it achieves substantial inference speedups (>1000x) while retaining competitive accuracy on common benchmarks like ARC, HellaSwag, Lambada, and MMLU. It inherits knowledge and language support from Qwen 2.5, supporting approximately 30 languages, making it suitable for efficient inference in large-context applications.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"openai/o1-pro","name":"OpenAI: o1-pro","created":1742423211,"description":"The o1 series of models are trained with reinforcement learning to think before they answer and perform complex reasoning. The o1-pro model uses more compute to think harder and provide consistently better answers.","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.00015","completion":"0.0006","request":"0","image":"0.21675","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":200000,"max_completion_tokens":100000,"is_moderated":true},"per_request_limits":null},{"id":"mistralai/mistral-small-3.1-24b-instruct:free","name":"Mistral: Mistral Small 3.1 24B (free)","created":1742238937,"description":"Mistral Small 3.1 24B Instruct is an upgraded variant of Mistral Small 3 (2501), featuring 24 billion parameters with advanced multimodal capabilities. It provides state-of-the-art performance in text-based reasoning and vision tasks, including image analysis, programming, mathematical reasoning, and multilingual support across dozens of languages. Equipped with an extensive 128k token context window and optimized for efficient local inference, it supports use cases such as conversational agents, function calling, long-document comprehension, and privacy-sensitive deployments.","context_length":96000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":96000,"max_completion_tokens":96000,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-small-3.1-24b-instruct","name":"Mistral: Mistral Small 3.1 24B","created":1742238937,"description":"Mistral Small 3.1 24B Instruct is an upgraded variant of Mistral Small 3 (2501), featuring 24 billion parameters with advanced multimodal capabilities. It provides state-of-the-art performance in text-based reasoning and vision tasks, including image analysis, programming, mathematical reasoning, and multilingual support across dozens of languages. Equipped with an extensive 128k token context window and optimized for efficient local inference, it supports use cases such as conversational agents, function calling, long-document comprehension, and privacy-sensitive deployments.","context_length":32768,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.0000001","completion":"0.0000003","request":"0","image":"0.0009264","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"open-r1/olympiccoder-7b:free","name":"OlympicCoder 7B (free)","created":1742078265,"description":"OlympicCoder-7B is an open-source language model fine-tuned on the CodeForces-CoTs dataset, consisting of nearly 100,000 high-quality chain-of-thought examples from competitive programming contexts. Optimized specifically for olympiad-level coding problems, this model demonstrates strong chain-of-thought reasoning and competitive code generation capabilities, achieving performance competitive with frontier closed-source models on tasks from the IOI 2024 and similar coding contests.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"open-r1/olympiccoder-32b:free","name":"OlympicCoder 32B (free)","created":1742077228,"description":"OlympicCoder-32B is a high-performing open-source model fine-tuned using the CodeForces-CoTs dataset, containing approximately 100,000 chain-of-thought programming samples. It excels at complex competitive programming benchmarks, such as IOI 2024 and Codeforces-style challenges, frequently surpassing state-of-the-art closed-source models. OlympicCoder-32B provides advanced reasoning, coherent multi-step problem-solving, and robust code generation capabilities, demonstrating significant potential for olympiad-level competitive programming applications.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"steelskull/l3.3-electra-r1-70b","name":"SteelSkull: L3.3 Electra R1 70B","created":1742067611,"description":"L3.3-Electra-R1-70 is the newest release of the Unnamed series. Built on a DeepSeek R1 Distill base, Electra-R1 integrates various models together to provide an intelligent and coherent model capable of providing deep character insights. Through proper prompting, the model demonstrates advanced reasoning capabilities and unprompted exploration of character inner thoughts and motivations. Read more about the model and [prompting here](https://huggingface.co/Steelskull/L3.3-Electra-R1-70b)","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0.0000007","completion":"0.00000095","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":131072,"is_moderated":false},"per_request_limits":null},{"id":"google/gemma-3-1b-it:free","name":"Google: Gemma 3 1B (free)","created":1741963556,"description":"Gemma 3 1B is the smallest of the new Gemma 3 family. It handles context windows up to 32k tokens, understands over 140 languages, and offers improved math, reasoning, and chat capabilities, including structured outputs and function calling. Note: Gemma 3 1B is not multimodal. For the smallest multimodal Gemma 3 model, please see [Gemma 3 4B](google/gemma-3-4b-it)","context_length":32768,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":"gemma"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"google/gemma-3-4b-it:free","name":"Google: Gemma 3 4B (free)","created":1741905510,"description":"Gemma 3 introduces multimodality, supporting vision-language input and text outputs. It handles context windows up to 128k tokens, understands over 140 languages, and offers improved math, reasoning, and chat capabilities, including structured outputs and function calling.","context_length":131072,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":"gemma"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"google/gemma-3-4b-it","name":"Google: Gemma 3 4B","created":1741905510,"description":"Gemma 3 introduces multimodality, supporting vision-language input and text outputs. It handles context windows up to 128k tokens, understands over 140 languages, and offers improved math, reasoning, and chat capabilities, including structured outputs and function calling.","context_length":131072,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":"gemma"},"pricing":{"prompt":"0.00000002","completion":"0.00000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"ai21/jamba-1.6-large","name":"AI21: Jamba 1.6 Large","created":1741905173,"description":"AI21 Jamba Large 1.6 is a high-performance hybrid foundation model combining State Space Models (Mamba) with Transformer attention mechanisms. Developed by AI21, it excels in extremely long-context handling (256K tokens), demonstrates superior inference efficiency (up to 2.5x faster than comparable models), and supports structured JSON output and tool-use capabilities. It has 94 billion active parameters (398 billion total), optimized quantization support (ExpertsInt8), and multilingual proficiency in languages such as English, Spanish, French, Portuguese, Italian, Dutch, German, Arabic, and Hebrew.\n\nUsage of this model is subject to the [Jamba Open Model License](https://www.ai21.com/licenses/jamba-open-model-license).","context_length":256000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.000002","completion":"0.000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":256000,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"ai21/jamba-1.6-mini","name":"AI21: Jamba Mini 1.6","created":1741905171,"description":"AI21 Jamba Mini 1.6 is a hybrid foundation model combining State Space Models (Mamba) with Transformer attention mechanisms. With 12 billion active parameters (52 billion total), this model excels in extremely long-context tasks (up to 256K tokens) and achieves superior inference efficiency, outperforming comparable open models on tasks such as retrieval-augmented generation (RAG) and grounded question answering. Jamba Mini 1.6 supports multilingual tasks across English, Spanish, French, Portuguese, Italian, Dutch, German, Arabic, and Hebrew, along with structured JSON output and tool-use capabilities.\n\nUsage of this model is subject to the [Jamba Open Model License](https://www.ai21.com/licenses/jamba-open-model-license).","context_length":256000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000002","completion":"0.0000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":256000,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"google/gemma-3-12b-it:free","name":"Google: Gemma 3 12B (free)","created":1741902625,"description":"Gemma 3 introduces multimodality, supporting vision-language input and text outputs. It handles context windows up to 128k tokens, understands over 140 languages, and offers improved math, reasoning, and chat capabilities, including structured outputs and function calling. Gemma 3 12B is the second largest in the family of Gemma 3 models after [Gemma 3 27B](google/gemma-3-27b-it)","context_length":131072,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":"gemma"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"google/gemma-3-12b-it","name":"Google: Gemma 3 12B","created":1741902625,"description":"Gemma 3 introduces multimodality, supporting vision-language input and text outputs. It handles context windows up to 128k tokens, understands over 140 languages, and offers improved math, reasoning, and chat capabilities, including structured outputs and function calling. Gemma 3 12B is the second largest in the family of Gemma 3 models after [Gemma 3 27B](google/gemma-3-27b-it)","context_length":131072,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":"gemma"},"pricing":{"prompt":"0.00000005","completion":"0.0000001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"cohere/command-a","name":"Cohere: Command A","created":1741894342,"description":"Command A is an open-weights 111B parameter model with a 256k context window focused on delivering great performance across agentic, multilingual, and coding use cases.\nCompared to other leading proprietary and open-weights models Command A delivers maximum performance with minimum hardware costs, excelling on business-critical agentic and multilingual tasks.","context_length":256000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000025","completion":"0.00001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":256000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-4o-mini-search-preview","name":"OpenAI: GPT-4o-mini Search Preview","created":1741818122,"description":"GPT-4o mini Search Preview is a specialized model for web search in Chat Completions. It is trained to understand and execute web search queries.","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.00000015","completion":"0.0000006","request":"0.0275","image":"0.000217","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":16384,"is_moderated":true},"per_request_limits":null},{"id":"openai/gpt-4o-search-preview","name":"OpenAI: GPT-4o Search Preview","created":1741817949,"description":"GPT-4o Search Previewis a specialized model for web search in Chat Completions. It is trained to understand and execute web search queries.","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.0000025","completion":"0.00001","request":"0.035","image":"0.003613","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":16384,"is_moderated":true},"per_request_limits":null},{"id":"rekaai/reka-flash-3:free","name":"Reka: Flash 3 (free)","created":1741812813,"description":"Reka Flash 3 is a general-purpose, instruction-tuned large language model with 21 billion parameters, developed by Reka. It excels at general chat, coding tasks, instruction-following, and function calling. Featuring a 32K context length and optimized through reinforcement learning (RLOO), it provides competitive performance comparable to proprietary models within a smaller parameter footprint. Ideal for low-latency, local, or on-device deployments, Reka Flash 3 is compact, supports efficient quantization (down to 11GB at 4-bit precision), and employs explicit reasoning tags (\"<reasoning>\") to indicate its internal thought process.\n\nReka Flash 3 is primarily an English model with limited multilingual understanding capabilities. The model weights are released under the Apache 2.0 license.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"google/gemma-3-27b-it:free","name":"Google: Gemma 3 27B (free)","created":1741756359,"description":"Gemma 3 introduces multimodality, supporting vision-language input and text outputs. It handles context windows up to 128k tokens, understands over 140 languages, and offers improved math, reasoning, and chat capabilities, including structured outputs and function calling. Gemma 3 27B is Google's latest open source model, successor to [Gemma 2](google/gemma-2-27b-it)","context_length":96000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":"gemma"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":96000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"google/gemma-3-27b-it","name":"Google: Gemma 3 27B","created":1741756359,"description":"Gemma 3 introduces multimodality, supporting vision-language input and text outputs. It handles context windows up to 128k tokens, understands over 140 languages, and offers improved math, reasoning, and chat capabilities, including structured outputs and function calling. Gemma 3 27B is Google's latest open source model, successor to [Gemma 2](google/gemma-2-27b-it)","context_length":131072,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":"gemma"},"pricing":{"prompt":"0.0000001","completion":"0.0000002","request":"0","image":"0.0000256","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"thedrummer/anubis-pro-105b-v1","name":"TheDrummer: Anubis Pro 105B V1","created":1741642290,"description":"Anubis Pro 105B v1 is an expanded and refined variant of Meta’s Llama 3.3 70B, featuring 50% additional layers and further fine-tuning to leverage its increased capacity. Designed for advanced narrative, roleplay, and instructional tasks, it demonstrates enhanced emotional intelligence, creativity, nuanced character portrayal, and superior prompt adherence compared to smaller models. Its larger parameter count allows for deeper contextual understanding and extended reasoning capabilities, optimized for engaging, intelligent, and coherent interactions.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000008","completion":"0.000001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":131072,"is_moderated":false},"per_request_limits":null},{"id":"latitudegames/wayfarer-large-70b-llama-3.3","name":"LatitudeGames: Wayfarer Large 70B Llama 3.3","created":1741636885,"description":"Wayfarer Large 70B is a roleplay and text-adventure model fine-tuned from Meta’s Llama-3.3-70B-Instruct. Specifically optimized for narrative-driven, challenging scenarios, it introduces realistic stakes, conflicts, and consequences often avoided by standard RLHF-aligned models. Trained using a curated blend of adventure, roleplay, and instructive fiction datasets, Wayfarer emphasizes tense storytelling, authentic player failure scenarios, and robust narrative immersion, making it uniquely suited for interactive fiction and gaming experiences.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":null},"pricing":{"prompt":"0.0000008","completion":"0.0000009","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":131072,"is_moderated":false},"per_request_limits":null},{"id":"thedrummer/skyfall-36b-v2","name":"TheDrummer: Skyfall 36B V2","created":1741636566,"description":"Skyfall 36B v2 is an enhanced iteration of Mistral Small 2501, specifically fine-tuned for improved creativity, nuanced writing, role-playing, and coherent storytelling.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000005","completion":"0.0000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":32768,"is_moderated":false},"per_request_limits":null},{"id":"microsoft/phi-4-multimodal-instruct","name":"Microsoft: Phi 4 Multimodal Instruct","created":1741396284,"description":"Phi-4 Multimodal Instruct is a versatile 5.6B parameter foundation model that combines advanced reasoning and instruction-following capabilities across both text and visual inputs, providing accurate text outputs. The unified architecture enables efficient, low-latency inference, suitable for edge and mobile deployments. Phi-4 Multimodal Instruct supports text inputs in multiple languages including Arabic, Chinese, English, French, German, Japanese, Spanish, and more, with visual input optimized primarily for English. It delivers impressive performance on multimodal tasks involving mathematical, scientific, and document reasoning, providing developers and enterprises a powerful yet compact model for sophisticated interactive applications. For more information, see the [Phi-4 Multimodal blog post](https://azure.microsoft.com/en-us/blog/empowering-innovation-the-next-generation-of-the-phi-family/).\n","context_length":131072,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.00000005","completion":"0.0000001","request":"0","image":"0.00017685","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"perplexity/sonar-reasoning-pro","name":"Perplexity: Sonar Reasoning Pro","created":1741313308,"description":"Note: Sonar Pro pricing includes Perplexity search pricing. See [details here](https://docs.perplexity.ai/guides/pricing#detailed-pricing-breakdown-for-sonar-reasoning-pro-and-sonar-pro)\n\nSonar Reasoning Pro is a premier reasoning model powered by DeepSeek R1 with Chain of Thought (CoT). Designed for advanced use cases, it supports in-depth, multi-step queries with a larger context window and can surface more citations per search, enabling more comprehensive and extensible responses.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0.000002","completion":"0.000008","request":"0","image":"0","web_search":"0.005","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"perplexity/sonar-pro","name":"Perplexity: Sonar Pro","created":1741312423,"description":"Note: Sonar Pro pricing includes Perplexity search pricing. See [details here](https://docs.perplexity.ai/guides/pricing#detailed-pricing-breakdown-for-sonar-reasoning-pro-and-sonar-pro)\n\nFor enterprises seeking more advanced capabilities, the Sonar Pro API can handle in-depth, multi-step queries with added extensibility, like double the number of citations per search as Sonar on average. Plus, with a larger context window, it can handle longer and more nuanced searches and follow-up questions. ","context_length":200000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0","web_search":"0.005","internal_reasoning":"0"},"top_provider":{"context_length":200000,"max_completion_tokens":8000,"is_moderated":false},"per_request_limits":null},{"id":"perplexity/sonar-deep-research","name":"Perplexity: Sonar Deep Research","created":1741311246,"description":"Sonar Deep Research is a research-focused model designed for multi-step retrieval, synthesis, and reasoning across complex topics. It autonomously searches, reads, and evaluates sources, refining its approach as it gathers information. This enables comprehensive report generation across domains like finance, technology, health, and current events.\n\nNotes on Pricing ([Source](https://docs.perplexity.ai/guides/pricing#detailed-pricing-breakdown-for-sonar-deep-research)) \n- Input tokens comprise of Prompt tokens (user prompt) + Citation tokens (these are processed tokens from running searches)\n- Deep Research runs multiple searches to conduct exhaustive research. Searches are priced at $5/1000 searches. A request that does 30 searches will cost $0.15 in this step.\n- Reasoning is a distinct step in Deep Research since it does extensive automated reasoning through all the material it gathers during its research phase. Reasoning tokens here are a bit different than the CoTs in the answer - these are tokens that we use to reason through the research material prior to generating the outputs via the CoTs. Reasoning tokens are priced at $3/1M tokens","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0.000002","completion":"0.000008","request":"0","image":"0","web_search":"0.005","internal_reasoning":"0.000003"},"top_provider":{"context_length":128000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-r1-zero:free","name":"DeepSeek: DeepSeek R1 Zero (free)","created":1741297434,"description":"DeepSeek-R1-Zero is a model trained via large-scale reinforcement learning (RL) without supervised fine-tuning (SFT) as a preliminary step. It's 671B parameters in size, with 37B active in an inference pass.\n\nIt demonstrates remarkable performance on reasoning. With RL, DeepSeek-R1-Zero naturally emerged with numerous powerful and interesting reasoning behaviors.\n\nDeepSeek-R1-Zero encounters challenges such as endless repetition, poor readability, and language mixing. See [DeepSeek R1](/deepseek/deepseek-r1) for the SFT model.\n\n","context_length":163840,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":163840,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwq-32b:free","name":"Qwen: QwQ 32B (free)","created":1741208814,"description":"QwQ is the reasoning model of the Qwen series. Compared with conventional instruction-tuned models, QwQ, which is capable of thinking and reasoning, can achieve significantly enhanced performance in downstream tasks, especially hard problems. QwQ-32B is the medium-sized reasoning model, which is capable of achieving competitive performance against state-of-the-art reasoning models, e.g., DeepSeek-R1, o1-mini.","context_length":40000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"qwq"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":40000,"max_completion_tokens":40000,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwq-32b","name":"Qwen: QwQ 32B","created":1741208814,"description":"QwQ is the reasoning model of the Qwen series. Compared with conventional instruction-tuned models, QwQ, which is capable of thinking and reasoning, can achieve significantly enhanced performance in downstream tasks, especially hard problems. QwQ-32B is the medium-sized reasoning model, which is capable of achieving competitive performance against state-of-the-art reasoning models, e.g., DeepSeek-R1, o1-mini.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"qwq"},"pricing":{"prompt":"0.00000015","completion":"0.0000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"moonshotai/moonlight-16b-a3b-instruct:free","name":"Moonshot AI: Moonlight 16B A3B Instruct (free)","created":1740719801,"description":"Moonlight-16B-A3B-Instruct is a 16B-parameter Mixture-of-Experts (MoE) language model developed by Moonshot AI. It is optimized for instruction-following tasks with 3B activated parameters per inference. The model advances the Pareto frontier in performance per FLOP across English, coding, math, and Chinese benchmarks. It outperforms comparable models like Llama3-3B and Deepseek-v2-Lite while maintaining efficient deployment capabilities through Hugging Face integration and compatibility with popular inference engines like vLLM12.","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"nousresearch/deephermes-3-llama-3-8b-preview:free","name":"Nous: DeepHermes 3 Llama 3 8B Preview (free)","created":1740719372,"description":"DeepHermes 3 Preview is the latest version of our flagship Hermes series of LLMs by Nous Research, and one of the first models in the world to unify Reasoning (long chains of thought that improve answer accuracy) and normal LLM response modes into one model. We have also improved LLM annotation, judgement, and function calling.\n\nDeepHermes 3 Preview is one of the first LLM models to unify both \"intuitive\", traditional mode responses and long chain of thought reasoning responses into a single model, toggled by a system prompt.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-4.5-preview","name":"OpenAI: GPT-4.5 (Preview)","created":1740687810,"description":"GPT-4.5 (Preview) is a research preview of OpenAI’s latest language model, designed to advance capabilities in reasoning, creativity, and multi-turn conversation. It builds on previous iterations with improvements in world knowledge, contextual coherence, and the ability to follow user intent more effectively.\n\nThe model demonstrates enhanced performance in tasks that require open-ended thinking, problem-solving, and communication. Early testing suggests it is better at generating nuanced responses, maintaining long-context coherence, and reducing hallucinations compared to earlier versions.\n\nThis research preview is intended to help evaluate GPT-4.5’s strengths and limitations in real-world use cases as OpenAI continues to refine and develop future models. Read more at the [blog post here.](https://openai.com/index/introducing-gpt-4-5/)","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.000075","completion":"0.00015","request":"0","image":"0.108375","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000375"},"top_provider":{"context_length":128000,"max_completion_tokens":16384,"is_moderated":true},"per_request_limits":null},{"id":"google/gemini-2.0-flash-lite-001","name":"Google: Gemini 2.0 Flash Lite","created":1740506212,"description":"Gemini 2.0 Flash Lite offers a significantly faster time to first token (TTFT) compared to [Gemini Flash 1.5](/google/gemini-flash-1.5), while maintaining quality on par with larger models like [Gemini Pro 1.5](/google/gemini-pro-1.5), all at extremely economical token prices.","context_length":1048576,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0.000000075","completion":"0.0000003","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":1048576,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3.7-sonnet","name":"Anthropic: Claude 3.7 Sonnet","created":1740422110,"description":"Claude 3.7 Sonnet is an advanced large language model with improved reasoning, coding, and problem-solving capabilities. It introduces a hybrid reasoning approach, allowing users to choose between rapid responses and extended, step-by-step processing for complex tasks. The model demonstrates notable improvements in coding, particularly in front-end development and full-stack updates, and excels in agentic workflows, where it can autonomously navigate multi-step processes. \n\nClaude 3.7 Sonnet maintains performance parity with its predecessor in standard mode while offering an extended reasoning mode for enhanced accuracy in math, coding, and instruction-following tasks.\n\nRead more at the [blog post here](https://www.anthropic.com/news/claude-3-7-sonnet)","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0.0048","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000003","input_cache_write":"0.00000375"},"top_provider":{"context_length":200000,"max_completion_tokens":64000,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3.7-sonnet:thinking","name":"Anthropic: Claude 3.7 Sonnet (thinking)","created":1740422110,"description":"Claude 3.7 Sonnet is an advanced large language model with improved reasoning, coding, and problem-solving capabilities. It introduces a hybrid reasoning approach, allowing users to choose between rapid responses and extended, step-by-step processing for complex tasks. The model demonstrates notable improvements in coding, particularly in front-end development and full-stack updates, and excels in agentic workflows, where it can autonomously navigate multi-step processes. \n\nClaude 3.7 Sonnet maintains performance parity with its predecessor in standard mode while offering an extended reasoning mode for enhanced accuracy in math, coding, and instruction-following tasks.\n\nRead more at the [blog post here](https://www.anthropic.com/news/claude-3-7-sonnet)","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0.0048","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000003","input_cache_write":"0.00000375"},"top_provider":{"context_length":200000,"max_completion_tokens":64000,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3.7-sonnet:beta","name":"Anthropic: Claude 3.7 Sonnet (self-moderated)","created":1740422110,"description":"Claude 3.7 Sonnet is an advanced large language model with improved reasoning, coding, and problem-solving capabilities. It introduces a hybrid reasoning approach, allowing users to choose between rapid responses and extended, step-by-step processing for complex tasks. The model demonstrates notable improvements in coding, particularly in front-end development and full-stack updates, and excels in agentic workflows, where it can autonomously navigate multi-step processes. \n\nClaude 3.7 Sonnet maintains performance parity with its predecessor in standard mode while offering an extended reasoning mode for enhanced accuracy in math, coding, and instruction-following tasks.\n\nRead more at the [blog post here](https://www.anthropic.com/news/claude-3-7-sonnet)","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0.0048","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000003","input_cache_write":"0.00000375"},"top_provider":{"context_length":200000,"max_completion_tokens":128000,"is_moderated":false},"per_request_limits":null},{"id":"perplexity/r1-1776","name":"Perplexity: R1 1776","created":1740004929,"description":"R1 1776 is a version of DeepSeek-R1 that has been post-trained to remove censorship constraints related to topics restricted by the Chinese government. The model retains its original reasoning capabilities while providing direct responses to a wider range of queries. R1 1776 is an offline chat model that does not use the perplexity search subsystem.\n\nThe model was tested on a multilingual dataset of over 1,000 examples covering sensitive topics to measure its likelihood of refusal or overly filtered responses. [Evaluation Results](https://cdn-uploads.huggingface.co/production/uploads/675c8332d01f593dc90817f5/GiN2VqC5hawUgAGJ6oHla.png) Its performance on math and reasoning benchmarks remains similar to the base R1 model. [Reasoning Performance](https://cdn-uploads.huggingface.co/production/uploads/675c8332d01f593dc90817f5/n4Z9Byqp2S7sKUvCvI40R.png)\n\nRead more on the [Blog Post](https://perplexity.ai/hub/blog/open-sourcing-r1-1776)","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"DeepSeek","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0.000002","completion":"0.000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-saba","name":"Mistral: Saba","created":1739803239,"description":"Mistral Saba is a 24B-parameter language model specifically designed for the Middle East and South Asia, delivering accurate and contextually relevant responses while maintaining efficient performance. Trained on curated regional datasets, it supports multiple Indian-origin languages—including Tamil and Malayalam—alongside Arabic. This makes it a versatile option for a range of regional and multilingual applications. Read more at the blog post [here](https://mistral.ai/en/news/mistral-saba)","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.0000002","completion":"0.0000006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"cognitivecomputations/dolphin3.0-r1-mistral-24b:free","name":"Dolphin3.0 R1 Mistral 24B (free)","created":1739462498,"description":"Dolphin 3.0 R1 is the next generation of the Dolphin series of instruct-tuned models.  Designed to be the ultimate general purpose local model, enabling coding, math, agentic, function calling, and general use cases.\n\nThe R1 version has been trained for 3 epochs to reason using 800k reasoning traces from the Dolphin-R1 dataset.\n\nDolphin aims to be a general purpose reasoning instruct model, similar to the models behind ChatGPT, Claude, Gemini.\n\nPart of the [Dolphin 3.0 Collection](https://huggingface.co/collections/cognitivecomputations/dolphin-30-677ab47f73d7ff66743979a3) Curated and trained by [Eric Hartford](https://huggingface.co/ehartford), [Ben Gitter](https://huggingface.co/bigstorm), [BlouseJury](https://huggingface.co/BlouseJury) and [Cognitive Computations](https://huggingface.co/cognitivecomputations)","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"cognitivecomputations/dolphin3.0-mistral-24b:free","name":"Dolphin3.0 Mistral 24B (free)","created":1739462019,"description":"Dolphin 3.0 is the next generation of the Dolphin series of instruct-tuned models.  Designed to be the ultimate general purpose local model, enabling coding, math, agentic, function calling, and general use cases.\n\nDolphin aims to be a general purpose instruct model, similar to the models behind ChatGPT, Claude, Gemini. \n\nPart of the [Dolphin 3.0 Collection](https://huggingface.co/collections/cognitivecomputations/dolphin-30-677ab47f73d7ff66743979a3) Curated and trained by [Eric Hartford](https://huggingface.co/ehartford), [Ben Gitter](https://huggingface.co/bigstorm), [BlouseJury](https://huggingface.co/BlouseJury) and [Cognitive Computations](https://huggingface.co/cognitivecomputations)","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-guard-3-8b","name":"Llama Guard 3 8B","created":1739401318,"description":"Llama Guard 3 is a Llama-3.1-8B pretrained model, fine-tuned for content safety classification. Similar to previous versions, it can be used to classify content in both LLM inputs (prompt classification) and in LLM responses (response classification). It acts as an LLM – it generates text in its output that indicates whether a given prompt or response is safe or unsafe, and if unsafe, it also lists the content categories violated.\n\nLlama Guard 3 was aligned to safeguard against the MLCommons standardized hazards taxonomy and designed to support Llama 3.1 capabilities. Specifically, it provides content moderation in 8 languages, and was optimized to support safety and security for search and code interpreter tool calls.\n","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"none"},"pricing":{"prompt":"0.0000001","completion":"0.0000001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"openai/o3-mini-high","name":"OpenAI: o3 Mini High","created":1739372611,"description":"OpenAI o3-mini-high is the same model as [o3-mini](/openai/o3-mini) with reasoning_effort set to high. \n\no3-mini is a cost-efficient language model optimized for STEM reasoning tasks, particularly excelling in science, mathematics, and coding. The model features three adjustable reasoning effort levels and supports key developer capabilities including function calling, structured outputs, and streaming, though it does not include vision processing capabilities.\n\nThe model demonstrates significant improvements over its predecessor, with expert testers preferring its responses 56% of the time and noting a 39% reduction in major errors on complex questions. With medium reasoning effort settings, o3-mini matches the performance of the larger o1 model on challenging reasoning evaluations like AIME and GPQA, while maintaining lower latency and cost.","context_length":200000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000011","completion":"0.0000044","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000055"},"top_provider":{"context_length":200000,"max_completion_tokens":100000,"is_moderated":true},"per_request_limits":null},{"id":"deepseek/deepseek-r1-distill-llama-8b","name":"DeepSeek: R1 Distill Llama 8B","created":1738937718,"description":"DeepSeek R1 Distill Llama 8B is a distilled large language model based on [Llama-3.1-8B-Instruct](/meta-llama/llama-3.1-8b-instruct), using outputs from [DeepSeek R1](/deepseek/deepseek-r1). The model combines advanced distillation techniques to achieve high performance across multiple benchmarks, including:\n\n- AIME 2024 pass@1: 50.4\n- MATH-500 pass@1: 89.1\n- CodeForces Rating: 1205\n\nThe model leverages fine-tuning from DeepSeek R1's outputs, enabling competitive performance comparable to larger frontier models.\n\nHugging Face: \n- [Llama-3.1-8B](https://huggingface.co/meta-llama/Llama-3.1-8B) \n- [DeepSeek-R1-Distill-Llama-8B](https://huggingface.co/deepseek-ai/DeepSeek-R1-Distill-Llama-8B)   |","context_length":32000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0.00000004","completion":"0.00000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32000,"max_completion_tokens":32000,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-2.0-flash-001","name":"Google: Gemini 2.0 Flash","created":1738769413,"description":"Gemini Flash 2.0 offers a significantly faster time to first token (TTFT) compared to [Gemini Flash 1.5](/google/gemini-flash-1.5), while maintaining quality on par with larger models like [Gemini Pro 1.5](/google/gemini-pro-1.5). It introduces notable enhancements in multimodal understanding, coding capabilities, complex instruction following, and function calling. These advancements come together to deliver more seamless and robust agentic experiences.","context_length":1000000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0.0000001","completion":"0.0000004","request":"0","image":"0.0000258","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":1000000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-vl-plus","name":"Qwen: Qwen VL Plus","created":1738731255,"description":"Qwen's Enhanced Large Visual Language Model. Significantly upgraded for detailed recognition capabilities and text recognition abilities, supporting ultra-high pixel resolutions up to millions of pixels and extreme aspect ratios for image input. It delivers significant performance across a broad range of visual tasks.\n","context_length":7500,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0.00000021","completion":"0.00000063","request":"0","image":"0.0002688","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":7500,"max_completion_tokens":1500,"is_moderated":false},"per_request_limits":null},{"id":"aion-labs/aion-1.0","name":"AionLabs: Aion-1.0","created":1738697557,"description":"Aion-1.0 is a multi-model system designed for high performance across various tasks, including reasoning and coding. It is built on DeepSeek-R1, augmented with additional models and techniques such as Tree of Thoughts (ToT) and Mixture of Experts (MoE). It is Aion Lab's most powerful reasoning model.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.000004","completion":"0.000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":32768,"is_moderated":false},"per_request_limits":null},{"id":"aion-labs/aion-1.0-mini","name":"AionLabs: Aion-1.0-Mini","created":1738697107,"description":"Aion-1.0-Mini 32B parameter model is a distilled version of the DeepSeek-R1 model, designed for strong performance in reasoning domains such as mathematics, coding, and logic. It is a modified variant of a FuseAI model that outperforms R1-Distill-Qwen-32B and R1-Distill-Llama-70B, with benchmark results available on its [Hugging Face page](https://huggingface.co/FuseAI/FuseO1-DeepSeekR1-QwQ-SkyT1-32B-Preview), independently replicated for verification.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000007","completion":"0.0000014","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":32768,"is_moderated":false},"per_request_limits":null},{"id":"aion-labs/aion-rp-llama-3.1-8b","name":"AionLabs: Aion-RP 1.0 (8B)","created":1738696718,"description":"Aion-RP-Llama-3.1-8B ranks the highest in the character evaluation portion of the RPBench-Auto benchmark, a roleplaying-specific variant of Arena-Hard-Auto, where LLMs evaluate each other’s responses. It is a fine-tuned base model rather than an instruct model, designed to produce more natural and varied writing.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000002","completion":"0.0000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":32768,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-vl-max","name":"Qwen: Qwen VL Max","created":1738434304,"description":"Qwen VL Max is a visual understanding model with 7500 tokens context length. It excels in delivering optimal performance for a broader spectrum of complex tasks.\n","context_length":7500,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0.0000008","completion":"0.0000032","request":"0","image":"0.001024","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":7500,"max_completion_tokens":1500,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-turbo","name":"Qwen: Qwen-Turbo","created":1738410974,"description":"Qwen-Turbo, based on Qwen2.5, is a 1M context model that provides fast speed and low cost, suitable for simple tasks.","context_length":1000000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0.00000005","completion":"0.0000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":1000000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen2.5-vl-72b-instruct:free","name":"Qwen: Qwen2.5 VL 72B Instruct (free)","created":1738410311,"description":"Qwen2.5-VL is proficient in recognizing common objects such as flowers, birds, fish, and insects. It is also highly capable of analyzing texts, charts, icons, graphics, and layouts within images.","context_length":131072,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen2.5-vl-72b-instruct","name":"Qwen: Qwen2.5 VL 72B Instruct","created":1738410311,"description":"Qwen2.5-VL is proficient in recognizing common objects such as flowers, birds, fish, and insects. It is also highly capable of analyzing texts, charts, icons, graphics, and layouts within images.","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0.0000007","completion":"0.0000007","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":128000,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-plus","name":"Qwen: Qwen-Plus","created":1738409840,"description":"Qwen-Plus, based on the Qwen2.5 foundation model, is a 131K context model with a balanced performance, speed, and cost combination.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0.0000004","completion":"0.0000012","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-max","name":"Qwen: Qwen-Max ","created":1738402289,"description":"Qwen-Max, based on Qwen2.5, provides the best inference performance among [Qwen models](/qwen), especially for complex multi-step tasks. It's a large-scale MoE model that has been pretrained on over 20 trillion tokens and further post-trained with curated Supervised Fine-Tuning (SFT) and Reinforcement Learning from Human Feedback (RLHF) methodologies. The parameter count is unknown.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0.0000016","completion":"0.0000064","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"openai/o3-mini","name":"OpenAI: o3 Mini","created":1738351721,"description":"OpenAI o3-mini is a cost-efficient language model optimized for STEM reasoning tasks, particularly excelling in science, mathematics, and coding.\n\nThis model supports the `reasoning_effort` parameter, which can be set to \"high\", \"medium\", or \"low\" to control the thinking time of the model. The default is \"medium\". OpenRouter also offers the model slug `openai/o3-mini-high` to default the parameter to \"high\".\n\nThe model features three adjustable reasoning effort levels and supports key developer capabilities including function calling, structured outputs, and streaming, though it does not include vision processing capabilities.\n\nThe model demonstrates significant improvements over its predecessor, with expert testers preferring its responses 56% of the time and noting a 39% reduction in major errors on complex questions. With medium reasoning effort settings, o3-mini matches the performance of the larger o1 model on challenging reasoning evaluations like AIME and GPQA, while maintaining lower latency and cost.","context_length":200000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000011","completion":"0.0000044","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000055"},"top_provider":{"context_length":200000,"max_completion_tokens":100000,"is_moderated":true},"per_request_limits":null},{"id":"deepseek/deepseek-r1-distill-qwen-1.5b","name":"DeepSeek: R1 Distill Qwen 1.5B","created":1738328067,"description":"DeepSeek R1 Distill Qwen 1.5B is a distilled large language model based on  [Qwen 2.5 Math 1.5B](https://huggingface.co/Qwen/Qwen2.5-Math-1.5B), using outputs from [DeepSeek R1](/deepseek/deepseek-r1). It's a very small and efficient model which outperforms [GPT 4o 0513](/openai/gpt-4o-2024-05-13) on Math Benchmarks.\n\nOther benchmark results include:\n\n- AIME 2024 pass@1: 28.9\n- AIME 2024 cons@64: 52.7\n- MATH-500 pass@1: 83.9\n\nThe model leverages fine-tuning from DeepSeek R1's outputs, enabling competitive performance comparable to larger frontier models.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0.00000018","completion":"0.00000018","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":32768,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-small-24b-instruct-2501:free","name":"Mistral: Mistral Small 3 (free)","created":1738255409,"description":"Mistral Small 3 is a 24B-parameter language model optimized for low-latency performance across common AI tasks. Released under the Apache 2.0 license, it features both pre-trained and instruction-tuned versions designed for efficient local deployment.\n\nThe model achieves 81% accuracy on the MMLU benchmark and performs competitively with larger models like Llama 3.3 70B and Qwen 32B, while operating at three times the speed on equivalent hardware. [Read the blog post about the model here.](https://mistral.ai/news/mistral-small-3/)","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-small-24b-instruct-2501","name":"Mistral: Mistral Small 3","created":1738255409,"description":"Mistral Small 3 is a 24B-parameter language model optimized for low-latency performance across common AI tasks. Released under the Apache 2.0 license, it features both pre-trained and instruction-tuned versions designed for efficient local deployment.\n\nThe model achieves 81% accuracy on the MMLU benchmark and performs competitively with larger models like Llama 3.3 70B and Qwen 32B, while operating at three times the speed on equivalent hardware. [Read the blog post about the model here.](https://mistral.ai/news/mistral-small-3/)","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.00000007","completion":"0.00000014","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-r1-distill-qwen-32b:free","name":"DeepSeek: R1 Distill Qwen 32B (free)","created":1738194830,"description":"DeepSeek R1 Distill Qwen 32B is a distilled large language model based on [Qwen 2.5 32B](https://huggingface.co/Qwen/Qwen2.5-32B), using outputs from [DeepSeek R1](/deepseek/deepseek-r1). It outperforms OpenAI's o1-mini across various benchmarks, achieving new state-of-the-art results for dense models.\n\nOther benchmark results include:\n\n- AIME 2024 pass@1: 72.6\n- MATH-500 pass@1: 94.3\n- CodeForces Rating: 1691\n\nThe model leverages fine-tuning from DeepSeek R1's outputs, enabling competitive performance comparable to larger frontier models.","context_length":16000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16000,"max_completion_tokens":16000,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-r1-distill-qwen-32b","name":"DeepSeek: R1 Distill Qwen 32B","created":1738194830,"description":"DeepSeek R1 Distill Qwen 32B is a distilled large language model based on [Qwen 2.5 32B](https://huggingface.co/Qwen/Qwen2.5-32B), using outputs from [DeepSeek R1](/deepseek/deepseek-r1). It outperforms OpenAI's o1-mini across various benchmarks, achieving new state-of-the-art results for dense models.\n\nOther benchmark results include:\n\n- AIME 2024 pass@1: 72.6\n- MATH-500 pass@1: 94.3\n- CodeForces Rating: 1691\n\nThe model leverages fine-tuning from DeepSeek R1's outputs, enabling competitive performance comparable to larger frontier models.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0.00000012","completion":"0.00000018","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-r1-distill-qwen-14b:free","name":"DeepSeek: R1 Distill Qwen 14B (free)","created":1738193940,"description":"DeepSeek R1 Distill Qwen 14B is a distilled large language model based on [Qwen 2.5 14B](https://huggingface.co/deepseek-ai/DeepSeek-R1-Distill-Qwen-14B), using outputs from [DeepSeek R1](/deepseek/deepseek-r1). It outperforms OpenAI's o1-mini across various benchmarks, achieving new state-of-the-art results for dense models.\n\nOther benchmark results include:\n\n- AIME 2024 pass@1: 69.7\n- MATH-500 pass@1: 93.9\n- CodeForces Rating: 1481\n\nThe model leverages fine-tuning from DeepSeek R1's outputs, enabling competitive performance comparable to larger frontier models.","context_length":64000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":64000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-r1-distill-qwen-14b","name":"DeepSeek: R1 Distill Qwen 14B","created":1738193940,"description":"DeepSeek R1 Distill Qwen 14B is a distilled large language model based on [Qwen 2.5 14B](https://huggingface.co/deepseek-ai/DeepSeek-R1-Distill-Qwen-14B), using outputs from [DeepSeek R1](/deepseek/deepseek-r1). It outperforms OpenAI's o1-mini across various benchmarks, achieving new state-of-the-art results for dense models.\n\nOther benchmark results include:\n\n- AIME 2024 pass@1: 69.7\n- MATH-500 pass@1: 93.9\n- CodeForces Rating: 1481\n\nThe model leverages fine-tuning from DeepSeek R1's outputs, enabling competitive performance comparable to larger frontier models.","context_length":64000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0.00000015","completion":"0.00000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":64000,"max_completion_tokens":64000,"is_moderated":false},"per_request_limits":null},{"id":"perplexity/sonar-reasoning","name":"Perplexity: Sonar Reasoning","created":1738131107,"description":"Sonar Reasoning is a reasoning model provided by Perplexity based on [DeepSeek R1](/deepseek/deepseek-r1).\n\nIt allows developers to utilize long chain of thought with built-in web search. Sonar Reasoning is uncensored and hosted in US datacenters. ","context_length":127000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0.000001","completion":"0.000005","request":"0.005","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":127000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"perplexity/sonar","name":"Perplexity: Sonar","created":1738013808,"description":"Sonar is lightweight, affordable, fast, and simple to use — now featuring citations and the ability to customize sources. It is designed for companies seeking to integrate lightweight question-and-answer features optimized for speed.","context_length":127072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.000001","completion":"0.000001","request":"0.005","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":127072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"liquid/lfm-7b","name":"Liquid: LFM 7B","created":1737806883,"description":"LFM-7B, a new best-in-class language model. LFM-7B is designed for exceptional chat capabilities, including languages like Arabic and Japanese. Powered by the Liquid Foundation Model (LFM) architecture, it exhibits unique features like low memory footprint and fast inference speed. \n\nLFM-7B is the world’s best-in-class multilingual language model in English, Arabic, and Japanese.\n\nSee the [launch announcement](https://www.liquid.ai/lfm-7b) for benchmarks and more info.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"chatml"},"pricing":{"prompt":"0.00000001","completion":"0.00000001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"liquid/lfm-3b","name":"Liquid: LFM 3B","created":1737806501,"description":"Liquid's LFM 3B delivers incredible performance for its size. It positions itself as first place among 3B parameter transformers, hybrids, and RNN models It is also on par with Phi-3.5-mini on multiple benchmarks, while being 18.4% smaller.\n\nLFM-3B is the ideal choice for mobile and other edge text-based applications.\n\nSee the [launch announcement](https://www.liquid.ai/liquid-foundation-models) for benchmarks and more info.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"chatml"},"pricing":{"prompt":"0.00000002","completion":"0.00000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-r1-distill-llama-70b:free","name":"DeepSeek: R1 Distill Llama 70B (free)","created":1737663169,"description":"DeepSeek R1 Distill Llama 70B is a distilled large language model based on [Llama-3.3-70B-Instruct](/meta-llama/llama-3.3-70b-instruct), using outputs from [DeepSeek R1](/deepseek/deepseek-r1). The model combines advanced distillation techniques to achieve high performance across multiple benchmarks, including:\n\n- AIME 2024 pass@1: 70.0\n- MATH-500 pass@1: 94.5\n- CodeForces Rating: 1633\n\nThe model leverages fine-tuning from DeepSeek R1's outputs, enabling competitive performance comparable to larger frontier models.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-r1-distill-llama-70b","name":"DeepSeek: R1 Distill Llama 70B","created":1737663169,"description":"DeepSeek R1 Distill Llama 70B is a distilled large language model based on [Llama-3.3-70B-Instruct](/meta-llama/llama-3.3-70b-instruct), using outputs from [DeepSeek R1](/deepseek/deepseek-r1). The model combines advanced distillation techniques to achieve high performance across multiple benchmarks, including:\n\n- AIME 2024 pass@1: 70.0\n- MATH-500 pass@1: 94.5\n- CodeForces Rating: 1633\n\nThe model leverages fine-tuning from DeepSeek R1's outputs, enabling competitive performance comparable to larger frontier models.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0.0000001","completion":"0.0000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":16384,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-2.0-flash-thinking-exp:free","name":"Google: Gemini 2.0 Flash Thinking Experimental 01-21 (free)","created":1737547899,"description":"Gemini 2.0 Flash Thinking Experimental (01-21) is a snapshot of Gemini 2.0 Flash Thinking Experimental.\n\nGemini 2.0 Flash Thinking Mode is an experimental model that's trained to generate the \"thinking process\" the model goes through as part of its response. As a result, Thinking Mode is capable of stronger reasoning capabilities in its responses than the [base Gemini 2.0 Flash model](/google/gemini-2.0-flash-exp).","context_length":1048576,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":1048576,"max_completion_tokens":65536,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-r1:free","name":"DeepSeek: R1 (free)","created":1737381095,"description":"DeepSeek R1 is here: Performance on par with [OpenAI o1](/openai/o1), but open-sourced and with fully open reasoning tokens. It's 671B parameters in size, with 37B active in an inference pass.\n\nFully open-source model & [technical report](https://api-docs.deepseek.com/news/news250120).\n\nMIT licensed: Distill & commercialize freely!","context_length":163840,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"DeepSeek","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":163840,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-r1","name":"DeepSeek: R1","created":1737381095,"description":"DeepSeek R1 is here: Performance on par with [OpenAI o1](/openai/o1), but open-sourced and with fully open reasoning tokens. It's 671B parameters in size, with 37B active in an inference pass.\n\nFully open-source model & [technical report](https://api-docs.deepseek.com/news/news250120).\n\nMIT licensed: Distill & commercialize freely!","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"DeepSeek","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0.0000005","completion":"0.000003","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":32768,"is_moderated":false},"per_request_limits":null},{"id":"sophosympatheia/rogue-rose-103b-v0.2:free","name":"Rogue Rose 103B v0.2 (free)","created":1737195189,"description":"Rogue Rose demonstrates strong capabilities in roleplaying and storytelling applications, potentially surpassing other models in the 103-120B parameter range. While it occasionally exhibits inconsistencies with scene logic, the overall interaction quality represents an advancement in natural language processing for creative applications.\n\nIt is a 120-layer frankenmerge model combining two custom 70B architectures from November 2023, derived from the [xwin-stellarbright-erp-70b-v2](https://huggingface.co/sophosympatheia/xwin-stellarbright-erp-70b-v2) base.\n","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"vicuna"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"minimax/minimax-01","name":"MiniMax: MiniMax-01","created":1736915462,"description":"MiniMax-01 is a combines MiniMax-Text-01 for text generation and MiniMax-VL-01 for image understanding. It has 456 billion parameters, with 45.9 billion parameters activated per inference, and can handle a context of up to 4 million tokens.\n\nThe text model adopts a hybrid architecture that combines Lightning Attention, Softmax Attention, and Mixture-of-Experts (MoE). The image model adopts the “ViT-MLP-LLM” framework and is trained on top of the text model.\n\nTo read more about the release, see: https://www.minimaxi.com/en/news/minimax-01-series-2","context_length":1000192,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000002","completion":"0.0000011","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":1000192,"max_completion_tokens":1000192,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/codestral-2501","name":"Mistral: Codestral 2501","created":1736895522,"description":"[Mistral](/mistralai)'s cutting-edge language model for coding. Codestral specializes in low-latency, high-frequency tasks such as fill-in-the-middle (FIM), code correction and test generation. \n\nLearn more on their blog post: https://mistral.ai/news/codestral-2501/","context_length":262144,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.0000003","completion":"0.0000009","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":262144,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"microsoft/phi-4","name":"Microsoft: Phi 4","created":1736489872,"description":"[Microsoft Research](/microsoft) Phi-4 is designed to perform well in complex reasoning tasks and can operate efficiently in situations with limited memory or where quick responses are needed. \n\nAt 14 billion parameters, it was trained on a mix of high-quality synthetic datasets, data from curated websites, and academic materials. It has undergone careful improvement to follow instructions accurately and maintain strong safety standards. It works best with English language inputs.\n\nFor more information, please see [Phi-4 Technical Report](https://arxiv.org/pdf/2412.08905)\n","context_length":16384,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.00000007","completion":"0.00000014","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-chat:free","name":"DeepSeek: DeepSeek V3 (free)","created":1735241320,"description":"DeepSeek-V3 is the latest model from the DeepSeek team, building upon the instruction following and coding abilities of the previous versions. Pre-trained on nearly 15 trillion tokens, the reported evaluations reveal that the model outperforms other open-source models and rivals leading closed-source models.\n\nFor model details, please visit [the DeepSeek-V3 repo](https://github.com/deepseek-ai/DeepSeek-V3) for more information, or see the [launch announcement](https://api-docs.deepseek.com/news/news1226).","context_length":163840,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"DeepSeek","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":163840,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"deepseek/deepseek-chat","name":"DeepSeek: DeepSeek V3","created":1735241320,"description":"DeepSeek-V3 is the latest model from the DeepSeek team, building upon the instruction following and coding abilities of the previous versions. Pre-trained on nearly 15 trillion tokens, the reported evaluations reveal that the model outperforms other open-source models and rivals leading closed-source models.\n\nFor model details, please visit [the DeepSeek-V3 repo](https://github.com/deepseek-ai/DeepSeek-V3) for more information, or see the [launch announcement](https://api-docs.deepseek.com/news/news1226).","context_length":163840,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"DeepSeek","instruct_type":null},"pricing":{"prompt":"0.00000038","completion":"0.00000089","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":163840,"max_completion_tokens":163840,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-2.0-flash-thinking-exp-1219:free","name":"Google: Gemini 2.0 Flash Thinking Experimental (free)","created":1734650026,"description":"Gemini 2.0 Flash Thinking Mode is an experimental model that's trained to generate the \"thinking process\" the model goes through as part of its response. As a result, Thinking Mode is capable of stronger reasoning capabilities in its responses than the [base Gemini 2.0 Flash model](/google/gemini-2.0-flash-exp).","context_length":40000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":40000,"max_completion_tokens":8000,"is_moderated":false},"per_request_limits":null},{"id":"sao10k/l3.3-euryale-70b","name":"Sao10K: Llama 3.3 Euryale 70B","created":1734535928,"description":"Euryale L3.3 70B is a model focused on creative roleplay from [Sao10k](https://ko-fi.com/sao10k). It is the successor of [Euryale L3 70B v2.2](/models/sao10k/l3-euryale-70b).","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.0000007","completion":"0.0000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"openai/o1","name":"OpenAI: o1","created":1734459999,"description":"The latest and strongest model family from OpenAI, o1 is designed to spend more time thinking before responding. The o1 model series is trained with large-scale reinforcement learning to reason using chain of thought. \n\nThe o1 models are optimized for math, science, programming, and other STEM-related tasks. They consistently exhibit PhD-level accuracy on benchmarks in physics, chemistry, and biology. Learn more in the [launch announcement](https://openai.com/o1).\n","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.000015","completion":"0.00006","request":"0","image":"0.021675","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000075"},"top_provider":{"context_length":200000,"max_completion_tokens":100000,"is_moderated":true},"per_request_limits":null},{"id":"eva-unit-01/eva-llama-3.33-70b","name":"EVA Llama 3.33 70B","created":1734377303,"description":"EVA Llama 3.33 70b is a roleplay and storywriting specialist model. It is a full-parameter finetune of [Llama-3.3-70B-Instruct](https://openrouter.ai/meta-llama/llama-3.3-70b-instruct) on mixture of synthetic and natural data.\n\nIt uses Celeste 70B 0.1 data mixture, greatly expanding it to improve versatility, creativity and \"flavor\" of the resulting model\n\nThis model was built with Llama by Meta.\n","context_length":16384,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.000004","completion":"0.000006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"x-ai/grok-2-vision-1212","name":"xAI: Grok 2 Vision 1212","created":1734237338,"description":"Grok 2 Vision 1212 advances image-based AI with stronger visual comprehension, refined instruction-following, and multilingual support. From object recognition to style analysis, it empowers developers to build more intuitive, visually aware applications. Its enhanced steerability and reasoning establish a robust foundation for next-generation image solutions.\n\nTo read more about this model, check out [xAI's announcement](https://x.ai/blog/grok-1212).","context_length":32768,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Grok","instruct_type":null},"pricing":{"prompt":"0.000002","completion":"0.00001","request":"0","image":"0.0036","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"x-ai/grok-2-1212","name":"xAI: Grok 2 1212","created":1734232814,"description":"Grok 2 1212 introduces significant enhancements to accuracy, instruction adherence, and multilingual support, making it a powerful and flexible choice for developers seeking a highly steerable, intelligent model.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Grok","instruct_type":null},"pricing":{"prompt":"0.000002","completion":"0.00001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"cohere/command-r7b-12-2024","name":"Cohere: Command R7B (12-2024)","created":1734158152,"description":"Command R7B (12-2024) is a small, fast update of the Command R+ model, delivered in December 2024. It excels at RAG, tool use, agents, and similar tasks requiring complex reasoning and multiple steps.\n\nUse of this model is subject to Cohere's [Usage Policy](https://docs.cohere.com/docs/usage-policy) and [SaaS Agreement](https://cohere.com/saas-agreement).","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Cohere","instruct_type":null},"pricing":{"prompt":"0.0000000375","completion":"0.00000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":4000,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-2.0-flash-exp:free","name":"Google: Gemini 2.0 Flash Experimental (free)","created":1733937523,"description":"Gemini Flash 2.0 offers a significantly faster time to first token (TTFT) compared to [Gemini Flash 1.5](/google/gemini-flash-1.5), while maintaining quality on par with larger models like [Gemini Pro 1.5](/google/gemini-pro-1.5). It introduces notable enhancements in multimodal understanding, coding capabilities, complex instruction following, and function calling. These advancements come together to deliver more seamless and robust agentic experiences.","context_length":1048576,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":1048576,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.3-70b-instruct:free","name":"Meta: Llama 3.3 70B Instruct (free)","created":1733506137,"description":"The Meta Llama 3.3 multilingual large language model (LLM) is a pretrained and instruction tuned generative model in 70B (text in/text out). The Llama 3.3 instruction tuned text only model is optimized for multilingual dialogue use cases and outperforms many of the available open source and closed chat models on common industry benchmarks.\n\nSupported languages: English, German, French, Italian, Portuguese, Hindi, Spanish, and Thai.\n\n[Model Card](https://github.com/meta-llama/llama-models/blob/main/models/llama3_3/MODEL_CARD.md)","context_length":8000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8000,"max_completion_tokens":8000,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.3-70b-instruct","name":"Meta: Llama 3.3 70B Instruct","created":1733506137,"description":"The Meta Llama 3.3 multilingual large language model (LLM) is a pretrained and instruction tuned generative model in 70B (text in/text out). The Llama 3.3 instruction tuned text only model is optimized for multilingual dialogue use cases and outperforms many of the available open source and closed chat models on common industry benchmarks.\n\nSupported languages: English, German, French, Italian, Portuguese, Hindi, Spanish, and Thai.\n\n[Model Card](https://github.com/meta-llama/llama-models/blob/main/models/llama3_3/MODEL_CARD.md)","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.0000001","completion":"0.00000025","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":16384,"is_moderated":false},"per_request_limits":null},{"id":"amazon/nova-lite-v1","name":"Amazon: Nova Lite 1.0","created":1733437363,"description":"Amazon Nova Lite 1.0 is a very low-cost multimodal model from Amazon that focused on fast processing of image, video, and text inputs to generate text output. Amazon Nova Lite can handle real-time customer interactions, document analysis, and visual question-answering tasks with high accuracy.\n\nWith an input context of 300K tokens, it can analyze multiple images or up to 30 minutes of video in a single input.","context_length":300000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Nova","instruct_type":null},"pricing":{"prompt":"0.00000006","completion":"0.00000024","request":"0","image":"0.00009","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":300000,"max_completion_tokens":5120,"is_moderated":false},"per_request_limits":null},{"id":"amazon/nova-micro-v1","name":"Amazon: Nova Micro 1.0","created":1733437237,"description":"Amazon Nova Micro 1.0 is a text-only model that delivers the lowest latency responses in the Amazon Nova family of models at a very low cost. With a context length of 128K tokens and optimized for speed and cost, Amazon Nova Micro excels at tasks such as text summarization, translation, content classification, interactive chat, and brainstorming. It has  simple mathematical reasoning and coding abilities.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Nova","instruct_type":null},"pricing":{"prompt":"0.000000035","completion":"0.00000014","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":5120,"is_moderated":false},"per_request_limits":null},{"id":"amazon/nova-pro-v1","name":"Amazon: Nova Pro 1.0","created":1733436303,"description":"Amazon Nova Pro 1.0 is a capable multimodal model from Amazon focused on providing a combination of accuracy, speed, and cost for a wide range of tasks. As of December 2024, it achieves state-of-the-art performance on key benchmarks including visual question answering (TextVQA) and video understanding (VATEX).\n\nAmazon Nova Pro demonstrates strong capabilities in processing both visual and textual information and at analyzing financial documents.\n\n**NOTE**: Video input is not supported at this time.","context_length":300000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Nova","instruct_type":null},"pricing":{"prompt":"0.0000008","completion":"0.0000032","request":"0","image":"0.0012","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":300000,"max_completion_tokens":5120,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwq-32b-preview:free","name":"Qwen: QwQ 32B Preview (free)","created":1732754541,"description":"QwQ-32B-Preview is an experimental research model focused on AI reasoning capabilities developed by the Qwen Team. As a preview release, it demonstrates promising analytical abilities while having several important limitations:\n\n1. **Language Mixing and Code-Switching**: The model may mix languages or switch between them unexpectedly, affecting response clarity.\n2. **Recursive Reasoning Loops**: The model may enter circular reasoning patterns, leading to lengthy responses without a conclusive answer.\n3. **Safety and Ethical Considerations**: The model requires enhanced safety measures to ensure reliable and secure performance, and users should exercise caution when deploying it.\n4. **Performance and Benchmark Limitations**: The model excels in math and coding but has room for improvement in other areas, such as common sense reasoning and nuanced language understanding.\n\n","context_length":16384,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwq-32b-preview","name":"Qwen: QwQ 32B Preview","created":1732754541,"description":"QwQ-32B-Preview is an experimental research model focused on AI reasoning capabilities developed by the Qwen Team. As a preview release, it demonstrates promising analytical abilities while having several important limitations:\n\n1. **Language Mixing and Code-Switching**: The model may mix languages or switch between them unexpectedly, affecting response clarity.\n2. **Recursive Reasoning Loops**: The model may enter circular reasoning patterns, leading to lengthy responses without a conclusive answer.\n3. **Safety and Ethical Considerations**: The model requires enhanced safety measures to ensure reliable and secure performance, and users should exercise caution when deploying it.\n4. **Performance and Benchmark Limitations**: The model excels in math and coding but has room for improvement in other areas, such as common sense reasoning and nuanced language understanding.\n\n","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"deepseek-r1"},"pricing":{"prompt":"0.0000002","completion":"0.0000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"google/learnlm-1.5-pro-experimental:free","name":"Google: LearnLM 1.5 Pro Experimental (free)","created":1732216551,"description":"An experimental version of [Gemini 1.5 Pro](/google/gemini-pro-1.5) from Google.","context_length":40960,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":40960,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"eva-unit-01/eva-qwen-2.5-72b","name":"EVA Qwen2.5 72B","created":1732210606,"description":"EVA Qwen2.5 72B is a roleplay and storywriting specialist model. It's a full-parameter finetune of Qwen2.5-72B on mixture of synthetic and natural data.\n\nIt uses Celeste 70B 0.1 data mixture, greatly expanding it to improve versatility, creativity and \"flavor\" of the resulting model.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0.0000009","completion":"0.0000012","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":131072,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-4o-2024-11-20","name":"OpenAI: GPT-4o (2024-11-20)","created":1732127594,"description":"The 2024-11-20 version of GPT-4o offers a leveled-up creative writing ability with more natural, engaging, and tailored writing to improve relevance & readability. It’s also better at working with uploaded files, providing deeper insights & more thorough responses.\n\nGPT-4o (\"o\" for \"omni\") is OpenAI's latest AI model, supporting both text and image inputs with text outputs. It maintains the intelligence level of [GPT-4 Turbo](/models/openai/gpt-4-turbo) while being twice as fast and 50% more cost-effective. GPT-4o also offers improved performance in processing non-English languages and enhanced visual capabilities.","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.0000025","completion":"0.00001","request":"0","image":"0.003613","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000125"},"top_provider":{"context_length":128000,"max_completion_tokens":16384,"is_moderated":true},"per_request_limits":null},{"id":"mistralai/mistral-large-2411","name":"Mistral Large 2411","created":1731978685,"description":"Mistral Large 2 2411 is an update of [Mistral Large 2](/mistralai/mistral-large) released together with [Pixtral Large 2411](/mistralai/pixtral-large-2411)\n\nIt provides a significant upgrade on the previous [Mistral Large 24.07](/mistralai/mistral-large-2407), with notable improvements in long context understanding, a new system prompt, and more accurate function calling.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.000002","completion":"0.000006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-large-2407","name":"Mistral Large 2407","created":1731978415,"description":"This is Mistral AI's flagship model, Mistral Large 2 (version mistral-large-2407). It's a proprietary weights-available model and excels at reasoning, code, JSON, chat, and more. Read the launch announcement [here](https://mistral.ai/news/mistral-large-2407/).\n\nIt supports dozens of languages including French, German, Spanish, Italian, Portuguese, Arabic, Hindi, Russian, Chinese, Japanese, and Korean, along with 80+ coding languages including Python, Java, C, C++, JavaScript, and Bash. Its long context window allows precise information recall from large documents.\n","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.000002","completion":"0.000006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/pixtral-large-2411","name":"Mistral: Pixtral Large 2411","created":1731977388,"description":"Pixtral Large is a 124B parameter, open-weight, multimodal model built on top of [Mistral Large 2](/mistralai/mistral-large-2411). The model is able to understand documents, charts and natural images.\n\nThe model is available under the Mistral Research License (MRL) for research and educational use, and the Mistral Commercial License for experimentation, testing, and production for commercial purposes.\n\n","context_length":131072,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.000002","completion":"0.000006","request":"0","image":"0.002888","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"x-ai/grok-vision-beta","name":"xAI: Grok Vision Beta","created":1731976624,"description":"Grok Vision Beta is xAI's experimental language model with vision capability.\n\n","context_length":8192,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Grok","instruct_type":null},"pricing":{"prompt":"0.000005","completion":"0.000015","request":"0","image":"0.009","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"infermatic/mn-inferor-12b","name":"Infermatic: Mistral Nemo Inferor 12B","created":1731464428,"description":"Inferor 12B is a merge of top roleplay models, expert on immersive narratives and storytelling.\n\nThis model was merged using the [Model Stock](https://arxiv.org/abs/2403.19522) merge method using [anthracite-org/magnum-v4-12b](https://openrouter.ai/anthracite-org/magnum-v4-72b) as a base.\n","context_length":16384,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"mistral"},"pricing":{"prompt":"0.0000008","completion":"0.0000012","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-2.5-coder-32b-instruct:free","name":"Qwen2.5 Coder 32B Instruct (free)","created":1731368400,"description":"Qwen2.5-Coder is the latest series of Code-Specific Qwen large language models (formerly known as CodeQwen). Qwen2.5-Coder brings the following improvements upon CodeQwen1.5:\n\n- Significantly improvements in **code generation**, **code reasoning** and **code fixing**. \n- A more comprehensive foundation for real-world applications such as **Code Agents**. Not only enhancing coding capabilities but also maintaining its strengths in mathematics and general competencies.\n\nTo read more about its evaluation results, check out [Qwen 2.5 Coder's blog](https://qwenlm.github.io/blog/qwen2.5-coder-family/).","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-2.5-coder-32b-instruct","name":"Qwen2.5 Coder 32B Instruct","created":1731368400,"description":"Qwen2.5-Coder is the latest series of Code-Specific Qwen large language models (formerly known as CodeQwen). Qwen2.5-Coder brings the following improvements upon CodeQwen1.5:\n\n- Significantly improvements in **code generation**, **code reasoning** and **code fixing**. \n- A more comprehensive foundation for real-world applications such as **Code Agents**. Not only enhancing coding capabilities but also maintaining its strengths in mathematics and general competencies.\n\nTo read more about its evaluation results, check out [Qwen 2.5 Coder's blog](https://qwenlm.github.io/blog/qwen2.5-coder-family/).","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0.00000007","completion":"0.00000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"raifle/sorcererlm-8x22b","name":"SorcererLM 8x22B","created":1731105083,"description":"SorcererLM is an advanced RP and storytelling model, built as a Low-rank 16-bit LoRA fine-tuned on [WizardLM-2 8x22B](/microsoft/wizardlm-2-8x22b).\n\n- Advanced reasoning and emotional intelligence for engaging and immersive interactions\n- Vivid writing capabilities enriched with spatial and contextual awareness\n- Enhanced narrative depth, promoting creative and dynamic storytelling","context_length":16000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"vicuna"},"pricing":{"prompt":"0.0000045","completion":"0.0000045","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"eva-unit-01/eva-qwen-2.5-32b","name":"EVA Qwen2.5 32B","created":1731104847,"description":"EVA Qwen2.5 32B is a roleplaying/storywriting specialist model. It's a full-parameter finetune of Qwen2.5-32B on mixture of synthetic and natural data.\n\nIt uses Celeste 70B 0.1 data mixture, greatly expanding it to improve versatility, creativity and \"flavor\" of the resulting model.","context_length":16384,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0.0000026","completion":"0.0000034","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"thedrummer/unslopnemo-12b","name":"Unslopnemo 12B","created":1731103448,"description":"UnslopNemo v4.1 is the latest addition from the creator of Rocinante, designed for adventure writing and role-play scenarios.","context_length":32000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"mistral"},"pricing":{"prompt":"0.0000005","completion":"0.0000005","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3.5-haiku:beta","name":"Anthropic: Claude 3.5 Haiku (self-moderated)","created":1730678400,"description":"Claude 3.5 Haiku features offers enhanced capabilities in speed, coding accuracy, and tool use. Engineered to excel in real-time applications, it delivers quick response times that are essential for dynamic tasks such as chat interactions and immediate coding suggestions.\n\nThis makes it highly suitable for environments that demand both speed and precision, such as software development, customer service bots, and data management systems.\n\nThis model is currently pointing to [Claude 3.5 Haiku (2024-10-22)](/anthropic/claude-3-5-haiku-20241022).","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.0000008","completion":"0.000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000008","input_cache_write":"0.000001"},"top_provider":{"context_length":200000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3.5-haiku","name":"Anthropic: Claude 3.5 Haiku","created":1730678400,"description":"Claude 3.5 Haiku features offers enhanced capabilities in speed, coding accuracy, and tool use. Engineered to excel in real-time applications, it delivers quick response times that are essential for dynamic tasks such as chat interactions and immediate coding suggestions.\n\nThis makes it highly suitable for environments that demand both speed and precision, such as software development, customer service bots, and data management systems.\n\nThis model is currently pointing to [Claude 3.5 Haiku (2024-10-22)](/anthropic/claude-3-5-haiku-20241022).","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.0000008","completion":"0.000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000008","input_cache_write":"0.000001"},"top_provider":{"context_length":200000,"max_completion_tokens":8192,"is_moderated":true},"per_request_limits":null},{"id":"anthropic/claude-3.5-haiku-20241022:beta","name":"Anthropic: Claude 3.5 Haiku (2024-10-22) (self-moderated)","created":1730678400,"description":"Claude 3.5 Haiku features enhancements across all skill sets including coding, tool use, and reasoning. As the fastest model in the Anthropic lineup, it offers rapid response times suitable for applications that require high interactivity and low latency, such as user-facing chatbots and on-the-fly code completions. It also excels in specialized tasks like data extraction and real-time content moderation, making it a versatile tool for a broad range of industries.\n\nIt does not support image inputs.\n\nSee the launch announcement and benchmark results [here](https://www.anthropic.com/news/3-5-models-and-computer-use)","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.0000008","completion":"0.000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000008","input_cache_write":"0.000001"},"top_provider":{"context_length":200000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3.5-haiku-20241022","name":"Anthropic: Claude 3.5 Haiku (2024-10-22)","created":1730678400,"description":"Claude 3.5 Haiku features enhancements across all skill sets including coding, tool use, and reasoning. As the fastest model in the Anthropic lineup, it offers rapid response times suitable for applications that require high interactivity and low latency, such as user-facing chatbots and on-the-fly code completions. It also excels in specialized tasks like data extraction and real-time content moderation, making it a versatile tool for a broad range of industries.\n\nIt does not support image inputs.\n\nSee the launch announcement and benchmark results [here](https://www.anthropic.com/news/3-5-models-and-computer-use)","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.0000008","completion":"0.000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000008","input_cache_write":"0.000001"},"top_provider":{"context_length":200000,"max_completion_tokens":8192,"is_moderated":true},"per_request_limits":null},{"id":"neversleep/llama-3.1-lumimaid-70b","name":"NeverSleep: Lumimaid v0.2 70B","created":1729555200,"description":"Lumimaid v0.2 70B is a finetune of [Llama 3.1 70B](/meta-llama/llama-3.1-70b-instruct) with a \"HUGE step up dataset wise\" compared to Lumimaid v0.1. Sloppy chats output were purged.\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":16384,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.0000015","completion":"0.00000225","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"anthracite-org/magnum-v4-72b","name":"Magnum v4 72B","created":1729555200,"description":"This is a series of models designed to replicate the prose quality of the Claude 3 models, specifically Sonnet(https://openrouter.ai/anthropic/claude-3.5-sonnet) and Opus(https://openrouter.ai/anthropic/claude-3-opus).\n\nThe model is fine-tuned on top of [Qwen2.5 72B](https://openrouter.ai/qwen/qwen-2.5-72b-instruct).","context_length":16384,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0.0000015","completion":"0.00000225","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":1024,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3.5-sonnet:beta","name":"Anthropic: Claude 3.5 Sonnet (self-moderated)","created":1729555200,"description":"New Claude 3.5 Sonnet delivers better-than-Opus capabilities, faster-than-Sonnet speeds, at the same Sonnet prices. Sonnet is particularly good at:\n\n- Coding: Scores ~49% on SWE-Bench Verified, higher than the last best score, and without any fancy prompt scaffolding\n- Data science: Augments human data science expertise; navigates unstructured data while using multiple tools for insights\n- Visual processing: excelling at interpreting charts, graphs, and images, accurately transcribing text to derive insights beyond just the text alone\n- Agentic tasks: exceptional tool use, making it great at agentic tasks (i.e. complex, multi-step problem solving tasks that require engaging with other systems)\n\n#multimodal","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0.0048","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000003","input_cache_write":"0.00000375"},"top_provider":{"context_length":200000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3.5-sonnet","name":"Anthropic: Claude 3.5 Sonnet","created":1729555200,"description":"New Claude 3.5 Sonnet delivers better-than-Opus capabilities, faster-than-Sonnet speeds, at the same Sonnet prices. Sonnet is particularly good at:\n\n- Coding: Scores ~49% on SWE-Bench Verified, higher than the last best score, and without any fancy prompt scaffolding\n- Data science: Augments human data science expertise; navigates unstructured data while using multiple tools for insights\n- Visual processing: excelling at interpreting charts, graphs, and images, accurately transcribing text to derive insights beyond just the text alone\n- Agentic tasks: exceptional tool use, making it great at agentic tasks (i.e. complex, multi-step problem solving tasks that require engaging with other systems)\n\n#multimodal","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0.0048","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000003","input_cache_write":"0.00000375"},"top_provider":{"context_length":200000,"max_completion_tokens":8192,"is_moderated":true},"per_request_limits":null},{"id":"x-ai/grok-beta","name":"xAI: Grok Beta","created":1729382400,"description":"Grok Beta is xAI's experimental language model with state-of-the-art reasoning capabilities, best for complex and multi-step use cases.\n\nIt is the successor of [Grok 2](https://x.ai/blog/grok-2) with enhanced context length.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Grok","instruct_type":null},"pricing":{"prompt":"0.000005","completion":"0.000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/ministral-8b","name":"Mistral: Ministral 8B","created":1729123200,"description":"Ministral 8B is an 8B parameter model featuring a unique interleaved sliding-window attention pattern for faster, memory-efficient inference. Designed for edge use cases, it supports up to 128k context length and excels in knowledge and reasoning tasks. It outperforms peers in the sub-10B category, making it perfect for low-latency, privacy-first applications.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.0000001","completion":"0.0000001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/ministral-3b","name":"Mistral: Ministral 3B","created":1729123200,"description":"Ministral 3B is a 3B parameter model optimized for on-device and edge computing. It excels in knowledge, commonsense reasoning, and function-calling, outperforming larger models like Mistral 7B on most benchmarks. Supporting up to 128k context length, it’s ideal for orchestrating agentic workflows and specialist tasks with efficient inference.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.00000004","completion":"0.00000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-2.5-7b-instruct:free","name":"Qwen2.5 7B Instruct (free)","created":1729036800,"description":"Qwen2.5 7B is the latest series of Qwen large language models. Qwen2.5 brings the following improvements upon Qwen2:\n\n- Significantly more knowledge and has greatly improved capabilities in coding and mathematics, thanks to our specialized expert models in these domains.\n\n- Significant improvements in instruction following, generating long texts (over 8K tokens), understanding structured data (e.g, tables), and generating structured outputs especially JSON. More resilient to the diversity of system prompts, enhancing role-play implementation and condition-setting for chatbots.\n\n- Long-context Support up to 128K tokens and can generate up to 8K tokens.\n\n- Multilingual support for over 29 languages, including Chinese, English, French, Spanish, Portuguese, German, Italian, Russian, Japanese, Korean, Vietnamese, Thai, Arabic, and more.\n\nUsage of this model is subject to [Tongyi Qianwen LICENSE AGREEMENT](https://huggingface.co/Qwen/Qwen1.5-110B-Chat/blob/main/LICENSE).","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":32768,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-2.5-7b-instruct","name":"Qwen2.5 7B Instruct","created":1729036800,"description":"Qwen2.5 7B is the latest series of Qwen large language models. Qwen2.5 brings the following improvements upon Qwen2:\n\n- Significantly more knowledge and has greatly improved capabilities in coding and mathematics, thanks to our specialized expert models in these domains.\n\n- Significant improvements in instruction following, generating long texts (over 8K tokens), understanding structured data (e.g, tables), and generating structured outputs especially JSON. More resilient to the diversity of system prompts, enhancing role-play implementation and condition-setting for chatbots.\n\n- Long-context Support up to 128K tokens and can generate up to 8K tokens.\n\n- Multilingual support for over 29 languages, including Chinese, English, French, Spanish, Portuguese, German, Italian, Russian, Japanese, Korean, Vietnamese, Thai, Arabic, and more.\n\nUsage of this model is subject to [Tongyi Qianwen LICENSE AGREEMENT](https://huggingface.co/Qwen/Qwen1.5-110B-Chat/blob/main/LICENSE).","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0.00000005","completion":"0.0000001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"nvidia/llama-3.1-nemotron-70b-instruct:free","name":"NVIDIA: Llama 3.1 Nemotron 70B Instruct (free)","created":1728950400,"description":"NVIDIA's Llama 3.1 Nemotron 70B is a language model designed for generating precise and useful responses. Leveraging [Llama 3.1 70B](/models/meta-llama/llama-3.1-70b-instruct) architecture and Reinforcement Learning from Human Feedback (RLHF), it excels in automatic alignment benchmarks. This model is tailored for applications requiring high accuracy in helpfulness and response generation, suitable for diverse user queries across multiple domains.\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://www.llama.com/llama3/use-policy/).","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"nvidia/llama-3.1-nemotron-70b-instruct","name":"NVIDIA: Llama 3.1 Nemotron 70B Instruct","created":1728950400,"description":"NVIDIA's Llama 3.1 Nemotron 70B is a language model designed for generating precise and useful responses. Leveraging [Llama 3.1 70B](/models/meta-llama/llama-3.1-70b-instruct) architecture and Reinforcement Learning from Human Feedback (RLHF), it excels in automatic alignment benchmarks. This model is tailored for applications requiring high accuracy in helpfulness and response generation, suitable for diverse user queries across multiple domains.\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://www.llama.com/llama3/use-policy/).","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.00000012","completion":"0.0000003","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":131072,"is_moderated":false},"per_request_limits":null},{"id":"inflection/inflection-3-productivity","name":"Inflection: Inflection 3 Productivity","created":1728604800,"description":"Inflection 3 Productivity is optimized for following instructions. It is better for tasks requiring JSON output or precise adherence to provided guidelines. It has access to recent news.\n\nFor emotional intelligence similar to Pi, see [Inflect 3 Pi](/inflection/inflection-3-pi)\n\nSee [Inflection's announcement](https://inflection.ai/blog/enterprise) for more details.","context_length":8000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000025","completion":"0.00001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8000,"max_completion_tokens":1024,"is_moderated":false},"per_request_limits":null},{"id":"inflection/inflection-3-pi","name":"Inflection: Inflection 3 Pi","created":1728604800,"description":"Inflection 3 Pi powers Inflection's [Pi](https://pi.ai) chatbot, including backstory, emotional intelligence, productivity, and safety. It has access to recent news, and excels in scenarios like customer support and roleplay.\n\nPi has been trained to mirror your tone and style, if you use more emojis, so will Pi! Try experimenting with various prompts and conversation styles.","context_length":8000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000025","completion":"0.00001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8000,"max_completion_tokens":1024,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-flash-1.5-8b","name":"Google: Gemini 1.5 Flash 8B","created":1727913600,"description":"Gemini Flash 1.5 8B is optimized for speed and efficiency, offering enhanced performance in small prompt tasks like chat, transcription, and translation. With reduced latency, it is highly effective for real-time and large-scale operations. This model focuses on cost-effective solutions while maintaining high-quality results.\n\n[Click here to learn more about this model](https://developers.googleblog.com/en/gemini-15-flash-8b-is-now-generally-available-for-use/).\n\nUsage of Gemini is subject to Google's [Gemini Terms of Use](https://ai.google.dev/terms).","context_length":1000000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0.0000000375","completion":"0.00000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000001","input_cache_write":"0.0000000583"},"top_provider":{"context_length":1000000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"thedrummer/rocinante-12b","name":"Rocinante 12B","created":1727654400,"description":"Rocinante 12B is designed for engaging storytelling and rich prose.\n\nEarly testers have reported:\n- Expanded vocabulary with unique and expressive word choices\n- Enhanced creativity for vivid narratives\n- Adventure-filled and captivating stories","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0.00000025","completion":"0.0000005","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"anthracite-org/magnum-v2-72b","name":"Magnum v2 72B","created":1727654400,"description":"From the maker of [Goliath](https://openrouter.ai/models/alpindale/goliath-120b), Magnum 72B is the seventh in a family of models designed to achieve the prose quality of the Claude 3 models, notably Opus & Sonnet.\n\nThe model is based on [Qwen2 72B](https://openrouter.ai/models/qwen/qwen-2-72b-instruct) and trained with 55 million tokens of highly curated roleplay (RP) data.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0.000003","completion":"0.000003","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"liquid/lfm-40b","name":"Liquid: LFM 40B MoE","created":1727654400,"description":"Liquid's 40.3B Mixture of Experts (MoE) model. Liquid Foundation Models (LFMs) are large neural networks built with computational units rooted in dynamic systems.\n\nLFMs are general-purpose AI models that can be used to model any kind of sequential data, including video, audio, text, time series, and signals.\n\nSee the [launch announcement](https://www.liquid.ai/liquid-foundation-models) for benchmarks and more info.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"chatml"},"pricing":{"prompt":"0.00000015","completion":"0.00000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.2-3b-instruct:free","name":"Meta: Llama 3.2 3B Instruct (free)","created":1727222400,"description":"Llama 3.2 3B is a 3-billion-parameter multilingual large language model, optimized for advanced natural language processing tasks like dialogue generation, reasoning, and summarization. Designed with the latest transformer architecture, it supports eight languages, including English, Spanish, and Hindi, and is adaptable for additional languages.\n\nTrained on 9 trillion tokens, the Llama 3.2 3B model excels in instruction-following, complex reasoning, and tool use. Its balanced performance makes it ideal for applications needing accuracy and efficiency in text generation across multilingual settings.\n\nClick here for the [original model card](https://github.com/meta-llama/llama-models/blob/main/models/llama3_2/MODEL_CARD.md).\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://www.llama.com/llama3/use-policy/).","context_length":20000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":20000,"max_completion_tokens":20000,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.2-3b-instruct","name":"Meta: Llama 3.2 3B Instruct","created":1727222400,"description":"Llama 3.2 3B is a 3-billion-parameter multilingual large language model, optimized for advanced natural language processing tasks like dialogue generation, reasoning, and summarization. Designed with the latest transformer architecture, it supports eight languages, including English, Spanish, and Hindi, and is adaptable for additional languages.\n\nTrained on 9 trillion tokens, the Llama 3.2 3B model excels in instruction-following, complex reasoning, and tool use. Its balanced performance makes it ideal for applications needing accuracy and efficiency in text generation across multilingual settings.\n\nClick here for the [original model card](https://github.com/meta-llama/llama-models/blob/main/models/llama3_2/MODEL_CARD.md).\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://www.llama.com/llama3/use-policy/).","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.000000015","completion":"0.000000025","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":131072,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.2-1b-instruct:free","name":"Meta: Llama 3.2 1B Instruct (free)","created":1727222400,"description":"Llama 3.2 1B is a 1-billion-parameter language model focused on efficiently performing natural language tasks, such as summarization, dialogue, and multilingual text analysis. Its smaller size allows it to operate efficiently in low-resource environments while maintaining strong task performance.\n\nSupporting eight core languages and fine-tunable for more, Llama 1.3B is ideal for businesses or developers seeking lightweight yet powerful AI solutions that can operate in diverse multilingual settings without the high computational demand of larger models.\n\nClick here for the [original model card](https://github.com/meta-llama/llama-models/blob/main/models/llama3_2/MODEL_CARD.md).\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://www.llama.com/llama3/use-policy/).","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":131072,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.2-1b-instruct","name":"Meta: Llama 3.2 1B Instruct","created":1727222400,"description":"Llama 3.2 1B is a 1-billion-parameter language model focused on efficiently performing natural language tasks, such as summarization, dialogue, and multilingual text analysis. Its smaller size allows it to operate efficiently in low-resource environments while maintaining strong task performance.\n\nSupporting eight core languages and fine-tunable for more, Llama 1.3B is ideal for businesses or developers seeking lightweight yet powerful AI solutions that can operate in diverse multilingual settings without the high computational demand of larger models.\n\nClick here for the [original model card](https://github.com/meta-llama/llama-models/blob/main/models/llama3_2/MODEL_CARD.md).\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://www.llama.com/llama3/use-policy/).","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.00000001","completion":"0.00000001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.2-90b-vision-instruct","name":"Meta: Llama 3.2 90B Vision Instruct","created":1727222400,"description":"The Llama 90B Vision model is a top-tier, 90-billion-parameter multimodal model designed for the most challenging visual reasoning and language tasks. It offers unparalleled accuracy in image captioning, visual question answering, and advanced image-text comprehension. Pre-trained on vast multimodal datasets and fine-tuned with human feedback, the Llama 90B Vision is engineered to handle the most demanding image-based AI tasks.\n\nThis model is perfect for industries requiring cutting-edge multimodal AI capabilities, particularly those dealing with complex, real-time visual and textual analysis.\n\nClick here for the [original model card](https://github.com/meta-llama/llama-models/blob/main/models/llama3_2/MODEL_CARD_VISION.md).\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://www.llama.com/llama3/use-policy/).","context_length":131072,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.0000009","completion":"0.0000009","request":"0","image":"0.001301","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.2-11b-vision-instruct:free","name":"Meta: Llama 3.2 11B Vision Instruct (free)","created":1727222400,"description":"Llama 3.2 11B Vision is a multimodal model with 11 billion parameters, designed to handle tasks combining visual and textual data. It excels in tasks such as image captioning and visual question answering, bridging the gap between language generation and visual reasoning. Pre-trained on a massive dataset of image-text pairs, it performs well in complex, high-accuracy image analysis.\n\nIts ability to integrate visual understanding with language processing makes it an ideal solution for industries requiring comprehensive visual-linguistic AI applications, such as content creation, AI-driven customer service, and research.\n\nClick here for the [original model card](https://github.com/meta-llama/llama-models/blob/main/models/llama3_2/MODEL_CARD_VISION.md).\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://www.llama.com/llama3/use-policy/).","context_length":131072,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.2-11b-vision-instruct","name":"Meta: Llama 3.2 11B Vision Instruct","created":1727222400,"description":"Llama 3.2 11B Vision is a multimodal model with 11 billion parameters, designed to handle tasks combining visual and textual data. It excels in tasks such as image captioning and visual question answering, bridging the gap between language generation and visual reasoning. Pre-trained on a massive dataset of image-text pairs, it performs well in complex, high-accuracy image analysis.\n\nIts ability to integrate visual understanding with language processing makes it an ideal solution for industries requiring comprehensive visual-linguistic AI applications, such as content creation, AI-driven customer service, and research.\n\nClick here for the [original model card](https://github.com/meta-llama/llama-models/blob/main/models/llama3_2/MODEL_CARD_VISION.md).\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://www.llama.com/llama3/use-policy/).","context_length":131072,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.000000049","completion":"0.000000049","request":"0","image":"0.00007948","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-2.5-72b-instruct:free","name":"Qwen2.5 72B Instruct (free)","created":1726704000,"description":"Qwen2.5 72B is the latest series of Qwen large language models. Qwen2.5 brings the following improvements upon Qwen2:\n\n- Significantly more knowledge and has greatly improved capabilities in coding and mathematics, thanks to our specialized expert models in these domains.\n\n- Significant improvements in instruction following, generating long texts (over 8K tokens), understanding structured data (e.g, tables), and generating structured outputs especially JSON. More resilient to the diversity of system prompts, enhancing role-play implementation and condition-setting for chatbots.\n\n- Long-context Support up to 128K tokens and can generate up to 8K tokens.\n\n- Multilingual support for over 29 languages, including Chinese, English, French, Spanish, Portuguese, German, Italian, Russian, Japanese, Korean, Vietnamese, Thai, Arabic, and more.\n\nUsage of this model is subject to [Tongyi Qianwen LICENSE AGREEMENT](https://huggingface.co/Qwen/Qwen1.5-110B-Chat/blob/main/LICENSE).","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-2.5-72b-instruct","name":"Qwen2.5 72B Instruct","created":1726704000,"description":"Qwen2.5 72B is the latest series of Qwen large language models. Qwen2.5 brings the following improvements upon Qwen2:\n\n- Significantly more knowledge and has greatly improved capabilities in coding and mathematics, thanks to our specialized expert models in these domains.\n\n- Significant improvements in instruction following, generating long texts (over 8K tokens), understanding structured data (e.g, tables), and generating structured outputs especially JSON. More resilient to the diversity of system prompts, enhancing role-play implementation and condition-setting for chatbots.\n\n- Long-context Support up to 128K tokens and can generate up to 8K tokens.\n\n- Multilingual support for over 29 languages, including Chinese, English, French, Spanish, Portuguese, German, Italian, Russian, Japanese, Korean, Vietnamese, Thai, Arabic, and more.\n\nUsage of this model is subject to [Tongyi Qianwen LICENSE AGREEMENT](https://huggingface.co/Qwen/Qwen1.5-110B-Chat/blob/main/LICENSE).","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0.00000012","completion":"0.00000039","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-2.5-vl-72b-instruct","name":"Qwen: Qwen2.5-VL 72B Instruct","created":1726617600,"description":"Qwen2.5 VL 72B is a multimodal LLM from the Qwen Team with the following key enhancements:\n\n- SoTA understanding of images of various resolution & ratio: Qwen2.5-VL achieves state-of-the-art performance on visual understanding benchmarks, including MathVista, DocVQA, RealWorldQA, MTVQA, etc.\n\n- Understanding videos of 20min+: Qwen2.5-VL can understand videos over 20 minutes for high-quality video-based question answering, dialog, content creation, etc.\n\n- Agent that can operate your mobiles, robots, etc.: with the abilities of complex reasoning and decision making, Qwen2.5-VL can be integrated with devices like mobile phones, robots, etc., for automatic operation based on visual environment and text instructions.\n\n- Multilingual Support: to serve global users, besides English and Chinese, Qwen2.5-VL now supports the understanding of texts in different languages inside images, including most European languages, Japanese, Korean, Arabic, Vietnamese, etc.\n\nFor more details, see this [blog post](https://qwenlm.github.io/blog/qwen2-vl/) and [GitHub repo](https://github.com/QwenLM/Qwen2-VL).\n\nUsage of this model is subject to [Tongyi Qianwen LICENSE AGREEMENT](https://huggingface.co/Qwen/Qwen1.5-110B-Chat/blob/main/LICENSE).","context_length":32768,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0.0000006","completion":"0.0000006","request":"0","image":"0.000578","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"neversleep/llama-3.1-lumimaid-8b","name":"NeverSleep: Lumimaid v0.2 8B","created":1726358400,"description":"Lumimaid v0.2 8B is a finetune of [Llama 3.1 8B](/models/meta-llama/llama-3.1-8b-instruct) with a \"HUGE step up dataset wise\" compared to Lumimaid v0.1. Sloppy chats output were purged.\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.00000009375","completion":"0.00000075","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"openai/o1-preview","name":"OpenAI: o1-preview","created":1726099200,"description":"The latest and strongest model family from OpenAI, o1 is designed to spend more time thinking before responding.\n\nThe o1 models are optimized for math, science, programming, and other STEM-related tasks. They consistently exhibit PhD-level accuracy on benchmarks in physics, chemistry, and biology. Learn more in the [launch announcement](https://openai.com/o1).\n\nNote: This model is currently experimental and not suitable for production use-cases, and may be heavily rate-limited.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.000015","completion":"0.00006","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000075"},"top_provider":{"context_length":128000,"max_completion_tokens":32768,"is_moderated":true},"per_request_limits":null},{"id":"openai/o1-preview-2024-09-12","name":"OpenAI: o1-preview (2024-09-12)","created":1726099200,"description":"The latest and strongest model family from OpenAI, o1 is designed to spend more time thinking before responding.\n\nThe o1 models are optimized for math, science, programming, and other STEM-related tasks. They consistently exhibit PhD-level accuracy on benchmarks in physics, chemistry, and biology. Learn more in the [launch announcement](https://openai.com/o1).\n\nNote: This model is currently experimental and not suitable for production use-cases, and may be heavily rate-limited.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.000015","completion":"0.00006","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000075"},"top_provider":{"context_length":128000,"max_completion_tokens":32768,"is_moderated":true},"per_request_limits":null},{"id":"openai/o1-mini","name":"OpenAI: o1-mini","created":1726099200,"description":"The latest and strongest model family from OpenAI, o1 is designed to spend more time thinking before responding.\n\nThe o1 models are optimized for math, science, programming, and other STEM-related tasks. They consistently exhibit PhD-level accuracy on benchmarks in physics, chemistry, and biology. Learn more in the [launch announcement](https://openai.com/o1).\n\nNote: This model is currently experimental and not suitable for production use-cases, and may be heavily rate-limited.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.0000011","completion":"0.0000044","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000055"},"top_provider":{"context_length":128000,"max_completion_tokens":65536,"is_moderated":true},"per_request_limits":null},{"id":"openai/o1-mini-2024-09-12","name":"OpenAI: o1-mini (2024-09-12)","created":1726099200,"description":"The latest and strongest model family from OpenAI, o1 is designed to spend more time thinking before responding.\n\nThe o1 models are optimized for math, science, programming, and other STEM-related tasks. They consistently exhibit PhD-level accuracy on benchmarks in physics, chemistry, and biology. Learn more in the [launch announcement](https://openai.com/o1).\n\nNote: This model is currently experimental and not suitable for production use-cases, and may be heavily rate-limited.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.0000011","completion":"0.0000044","request":"0","image":"0","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000055"},"top_provider":{"context_length":128000,"max_completion_tokens":65536,"is_moderated":true},"per_request_limits":null},{"id":"mistralai/pixtral-12b","name":"Mistral: Pixtral 12B","created":1725926400,"description":"The first multi-modal, text+image-to-text model from Mistral AI. Its weights were launched via torrent: https://x.com/mistralai/status/1833758285167722836.","context_length":32768,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.0000001","completion":"0.0000001","request":"0","image":"0.0001445","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"cohere/command-r-plus-08-2024","name":"Cohere: Command R+ (08-2024)","created":1724976000,"description":"command-r-plus-08-2024 is an update of the [Command R+](/models/cohere/command-r-plus) with roughly 50% higher throughput and 25% lower latencies as compared to the previous Command R+ version, while keeping the hardware footprint the same.\n\nRead the launch post [here](https://docs.cohere.com/changelog/command-gets-refreshed).\n\nUse of this model is subject to Cohere's [Usage Policy](https://docs.cohere.com/docs/usage-policy) and [SaaS Agreement](https://cohere.com/saas-agreement).","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Cohere","instruct_type":null},"pricing":{"prompt":"0.0000025","completion":"0.00001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":4000,"is_moderated":false},"per_request_limits":null},{"id":"cohere/command-r-08-2024","name":"Cohere: Command R (08-2024)","created":1724976000,"description":"command-r-08-2024 is an update of the [Command R](/models/cohere/command-r) with improved performance for multilingual retrieval-augmented generation (RAG) and tool use. More broadly, it is better at math, code and reasoning and is competitive with the previous version of the larger Command R+ model.\n\nRead the launch post [here](https://docs.cohere.com/changelog/command-gets-refreshed).\n\nUse of this model is subject to Cohere's [Usage Policy](https://docs.cohere.com/docs/usage-policy) and [SaaS Agreement](https://cohere.com/saas-agreement).","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Cohere","instruct_type":null},"pricing":{"prompt":"0.00000015","completion":"0.0000006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":4000,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-2.5-vl-7b-instruct:free","name":"Qwen: Qwen2.5-VL 7B Instruct (free)","created":1724803200,"description":"Qwen2.5 VL 7B is a multimodal LLM from the Qwen Team with the following key enhancements:\n\n- SoTA understanding of images of various resolution & ratio: Qwen2.5-VL achieves state-of-the-art performance on visual understanding benchmarks, including MathVista, DocVQA, RealWorldQA, MTVQA, etc.\n\n- Understanding videos of 20min+: Qwen2.5-VL can understand videos over 20 minutes for high-quality video-based question answering, dialog, content creation, etc.\n\n- Agent that can operate your mobiles, robots, etc.: with the abilities of complex reasoning and decision making, Qwen2.5-VL can be integrated with devices like mobile phones, robots, etc., for automatic operation based on visual environment and text instructions.\n\n- Multilingual Support: to serve global users, besides English and Chinese, Qwen2.5-VL now supports the understanding of texts in different languages inside images, including most European languages, Japanese, Korean, Arabic, Vietnamese, etc.\n\nFor more details, see this [blog post](https://qwenlm.github.io/blog/qwen2-vl/) and [GitHub repo](https://github.com/QwenLM/Qwen2-VL).\n\nUsage of this model is subject to [Tongyi Qianwen LICENSE AGREEMENT](https://huggingface.co/Qwen/Qwen1.5-110B-Chat/blob/main/LICENSE).","context_length":64000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":64000,"max_completion_tokens":64000,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-2.5-vl-7b-instruct","name":"Qwen: Qwen2.5-VL 7B Instruct","created":1724803200,"description":"Qwen2.5 VL 7B is a multimodal LLM from the Qwen Team with the following key enhancements:\n\n- SoTA understanding of images of various resolution & ratio: Qwen2.5-VL achieves state-of-the-art performance on visual understanding benchmarks, including MathVista, DocVQA, RealWorldQA, MTVQA, etc.\n\n- Understanding videos of 20min+: Qwen2.5-VL can understand videos over 20 minutes for high-quality video-based question answering, dialog, content creation, etc.\n\n- Agent that can operate your mobiles, robots, etc.: with the abilities of complex reasoning and decision making, Qwen2.5-VL can be integrated with devices like mobile phones, robots, etc., for automatic operation based on visual environment and text instructions.\n\n- Multilingual Support: to serve global users, besides English and Chinese, Qwen2.5-VL now supports the understanding of texts in different languages inside images, including most European languages, Japanese, Korean, Arabic, Vietnamese, etc.\n\nFor more details, see this [blog post](https://qwenlm.github.io/blog/qwen2-vl/) and [GitHub repo](https://github.com/QwenLM/Qwen2-VL).\n\nUsage of this model is subject to [Tongyi Qianwen LICENSE AGREEMENT](https://huggingface.co/Qwen/Qwen1.5-110B-Chat/blob/main/LICENSE).","context_length":32768,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":null},"pricing":{"prompt":"0.0000002","completion":"0.0000002","request":"0","image":"0.0001445","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"sao10k/l3.1-euryale-70b","name":"Sao10K: Llama 3.1 Euryale 70B v2.2","created":1724803200,"description":"Euryale L3.1 70B v2.2 is a model focused on creative roleplay from [Sao10k](https://ko-fi.com/sao10k). It is the successor of [Euryale L3 70B v2.1](/models/sao10k/l3-euryale-70b).","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.0000007","completion":"0.0000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-flash-1.5-8b-exp","name":"Google: Gemini 1.5 Flash 8B Experimental","created":1724803200,"description":"Gemini Flash 1.5 8B Experimental is an experimental, 8B parameter version of the [Gemini Flash 1.5](/models/google/gemini-flash-1.5) model.\n\nUsage of Gemini is subject to Google's [Gemini Terms of Use](https://ai.google.dev/terms).\n\n#multimodal\n\nNote: This model is currently experimental and not suitable for production use-cases, and may be heavily rate-limited.","context_length":1000000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":1000000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"ai21/jamba-1-5-mini","name":"AI21: Jamba 1.5 Mini","created":1724371200,"description":"Jamba 1.5 Mini is the world's first production-grade Mamba-based model, combining SSM and Transformer architectures for a 256K context window and high efficiency.\n\nIt works with 9 languages and can handle various writing and analysis tasks as well as or better than similar small models.\n\nThis model uses less computer memory and works faster with longer texts than previous designs.\n\nRead their [announcement](https://www.ai21.com/blog/announcing-jamba-model-family) to learn more.","context_length":256000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000002","completion":"0.0000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":256000,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"ai21/jamba-1-5-large","name":"AI21: Jamba 1.5 Large","created":1724371200,"description":"Jamba 1.5 Large is part of AI21's new family of open models, offering superior speed, efficiency, and quality.\n\nIt features a 256K effective context window, the longest among open models, enabling improved performance on tasks like document summarization and analysis.\n\nBuilt on a novel SSM-Transformer architecture, it outperforms larger models like Llama 3.1 70B on benchmarks while maintaining resource efficiency.\n\nRead their [announcement](https://www.ai21.com/blog/announcing-jamba-model-family) to learn more.","context_length":256000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.000002","completion":"0.000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":256000,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"microsoft/phi-3.5-mini-128k-instruct","name":"Microsoft: Phi-3.5 Mini 128K Instruct","created":1724198400,"description":"Phi-3.5 models are lightweight, state-of-the-art open models. These models were trained with Phi-3 datasets that include both synthetic data and the filtered, publicly available websites data, with a focus on high quality and reasoning-dense properties. Phi-3.5 Mini uses 3.8B parameters, and is a dense decoder-only transformer model using the same tokenizer as [Phi-3 Mini](/models/microsoft/phi-3-mini-128k-instruct).\n\nThe models underwent a rigorous enhancement process, incorporating both supervised fine-tuning, proximal policy optimization, and direct preference optimization to ensure precise instruction adherence and robust safety measures. When assessed against benchmarks that test common sense, language understanding, math, code, long context and logical reasoning, Phi-3.5 models showcased robust and state-of-the-art performance among models with less than 13 billion parameters.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"phi3"},"pricing":{"prompt":"0.0000001","completion":"0.0000001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"nousresearch/hermes-3-llama-3.1-70b","name":"Nous: Hermes 3 70B Instruct","created":1723939200,"description":"Hermes 3 is a generalist language model with many improvements over [Hermes 2](/models/nousresearch/nous-hermes-2-mistral-7b-dpo), including advanced agentic capabilities, much better roleplaying, reasoning, multi-turn conversation, long context coherence, and improvements across the board.\n\nHermes 3 70B is a competitive, if not superior finetune of the [Llama-3.1 70B foundation model](/models/meta-llama/llama-3.1-70b-instruct), focused on aligning LLMs to the user, with powerful steering capabilities and control given to the end user.\n\nThe Hermes 3 series builds and expands on the Hermes 2 set of capabilities, including more powerful and reliable function calling and structured output capabilities, generalist assistant capabilities, and improved code generation skills.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"chatml"},"pricing":{"prompt":"0.00000012","completion":"0.0000003","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":131072,"is_moderated":false},"per_request_limits":null},{"id":"nousresearch/hermes-3-llama-3.1-405b","name":"Nous: Hermes 3 405B Instruct","created":1723766400,"description":"Hermes 3 is a generalist language model with many improvements over Hermes 2, including advanced agentic capabilities, much better roleplaying, reasoning, multi-turn conversation, long context coherence, and improvements across the board.\n\nHermes 3 405B is a frontier-level, full-parameter finetune of the Llama-3.1 405B foundation model, focused on aligning LLMs to the user, with powerful steering capabilities and control given to the end user.\n\nThe Hermes 3 series builds and expands on the Hermes 2 set of capabilities, including more powerful and reliable function calling and structured output capabilities, generalist assistant capabilities, and improved code generation skills.\n\nHermes 3 is competitive, if not superior, to Llama-3.1 Instruct models at general capabilities, with varying strengths and weaknesses attributable between the two.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"chatml"},"pricing":{"prompt":"0.0000008","completion":"0.0000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":131072,"is_moderated":false},"per_request_limits":null},{"id":"openai/chatgpt-4o-latest","name":"OpenAI: ChatGPT-4o","created":1723593600,"description":"OpenAI ChatGPT 4o is continually updated by OpenAI to point to the current version of GPT-4o used by ChatGPT. It therefore differs slightly from the API version of [GPT-4o](/models/openai/gpt-4o) in that it has additional RLHF. It is intended for research and evaluation.\n\nOpenAI notes that this model is not suited for production use-cases as it may be removed or redirected to another model in the future.","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.000005","completion":"0.000015","request":"0","image":"0.007225","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":16384,"is_moderated":true},"per_request_limits":null},{"id":"sao10k/l3-lunaris-8b","name":"Sao10K: Llama 3 8B Lunaris","created":1723507200,"description":"Lunaris 8B is a versatile generalist and roleplaying model based on Llama 3. It's a strategic merge of multiple models, designed to balance creativity with improved logic and general knowledge.\n\nCreated by [Sao10k](https://huggingface.co/Sao10k), this model aims to offer an improved experience over Stheno v3.2, with enhanced creativity and logical reasoning.\n\nFor best results, use with Llama 3 Instruct context template, temperature 1.4, and min_p 0.1.","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.00000002","completion":"0.00000005","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"aetherwiing/mn-starcannon-12b","name":"Aetherwiing: Starcannon 12B","created":1723507200,"description":"Starcannon 12B v2 is a creative roleplay and story writing model, based on Mistral Nemo, using [nothingiisreal/mn-celeste-12b](/nothingiisreal/mn-celeste-12b) as a base, with [intervitens/mini-magnum-12b-v1.1](https://huggingface.co/intervitens/mini-magnum-12b-v1.1) merged in using the [TIES](https://arxiv.org/abs/2306.01708) method.\n\nAlthough more similar to Magnum overall, the model remains very creative, with a pleasant writing style. It is recommended for people wanting more variety than Magnum, and yet more verbose prose than Celeste.","context_length":16384,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"chatml"},"pricing":{"prompt":"0.0000008","completion":"0.0000012","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-4o-2024-08-06","name":"OpenAI: GPT-4o (2024-08-06)","created":1722902400,"description":"The 2024-08-06 version of GPT-4o offers improved performance in structured outputs, with the ability to supply a JSON schema in the respone_format. Read more [here](https://openai.com/index/introducing-structured-outputs-in-the-api/).\n\nGPT-4o (\"o\" for \"omni\") is OpenAI's latest AI model, supporting both text and image inputs with text outputs. It maintains the intelligence level of [GPT-4 Turbo](/models/openai/gpt-4-turbo) while being twice as fast and 50% more cost-effective. GPT-4o also offers improved performance in processing non-English languages and enhanced visual capabilities.\n\nFor benchmarking against other models, it was briefly called [\"im-also-a-good-gpt2-chatbot\"](https://twitter.com/LiamFedus/status/1790064963966370209)","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.0000025","completion":"0.00001","request":"0","image":"0.003613","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000125"},"top_provider":{"context_length":128000,"max_completion_tokens":16384,"is_moderated":true},"per_request_limits":null},{"id":"meta-llama/llama-3.1-405b:free","name":"Meta: Llama 3.1 405B (base) (free)","created":1722556800,"description":"Meta's latest class of model (Llama 3.1) launched with a variety of sizes & flavors. This is the base 405B pre-trained version.\n\nIt has demonstrated strong performance compared to leading closed-source models in human evaluations.\n\nTo read more about the model release, [click here](https://ai.meta.com/blog/meta-llama-3/). Usage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":64000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"none"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":64000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.1-405b","name":"Meta: Llama 3.1 405B (base)","created":1722556800,"description":"Meta's latest class of model (Llama 3.1) launched with a variety of sizes & flavors. This is the base 405B pre-trained version.\n\nIt has demonstrated strong performance compared to leading closed-source models in human evaluations.\n\nTo read more about the model release, [click here](https://ai.meta.com/blog/meta-llama-3/). Usage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"none"},"pricing":{"prompt":"0.000002","completion":"0.000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"nothingiisreal/mn-celeste-12b","name":"Mistral Nemo 12B Celeste","created":1722556800,"description":"A specialized story writing and roleplaying model based on Mistral's NeMo 12B Instruct. Fine-tuned on curated datasets including Reddit Writing Prompts and Opus Instruct 25K.\n\nThis model excels at creative writing, offering improved NSFW capabilities, with smarter and more active narration. It demonstrates remarkable versatility in both SFW and NSFW scenarios, with strong Out of Character (OOC) steering capabilities, allowing fine-tuned control over narrative direction and character behavior.\n\nCheck out the model's [HuggingFace page](https://huggingface.co/nothingiisreal/MN-12B-Celeste-V1.9) for details on what parameters and prompts work best!","context_length":16384,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"chatml"},"pricing":{"prompt":"0.0000008","completion":"0.0000012","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"perplexity/llama-3.1-sonar-small-128k-online","name":"Perplexity: Llama 3.1 Sonar 8B Online","created":1722470400,"description":"Llama 3.1 Sonar is Perplexity's latest model family. It surpasses their earlier Sonar models in cost-efficiency, speed, and performance.\n\nThis is the online version of the [offline chat model](/models/perplexity/llama-3.1-sonar-small-128k-chat). It is focused on delivering helpful, up-to-date, and factual responses. #online","context_length":127072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":null},"pricing":{"prompt":"0.0000002","completion":"0.0000002","request":"0.005","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":127072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"perplexity/llama-3.1-sonar-large-128k-online","name":"Perplexity: Llama 3.1 Sonar 70B Online","created":1722470400,"description":"Llama 3.1 Sonar is Perplexity's latest model family. It surpasses their earlier Sonar models in cost-efficiency, speed, and performance.\n\nThis is the online version of the [offline chat model](/models/perplexity/llama-3.1-sonar-large-128k-chat). It is focused on delivering helpful, up-to-date, and factual responses. #online","context_length":127072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":null},"pricing":{"prompt":"0.000001","completion":"0.000001","request":"0.005","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":127072,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.1-8b-instruct:free","name":"Meta: Llama 3.1 8B Instruct (free)","created":1721692800,"description":"Meta's latest class of model (Llama 3.1) launched with a variety of sizes & flavors. This 8B instruct-tuned version is fast and efficient.\n\nIt has demonstrated strong performance compared to leading closed-source models in human evaluations.\n\nTo read more about the model release, [click here](https://ai.meta.com/blog/meta-llama-3-1/). Usage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.1-8b-instruct","name":"Meta: Llama 3.1 8B Instruct","created":1721692800,"description":"Meta's latest class of model (Llama 3.1) launched with a variety of sizes & flavors. This 8B instruct-tuned version is fast and efficient.\n\nIt has demonstrated strong performance compared to leading closed-source models in human evaluations.\n\nTo read more about the model release, [click here](https://ai.meta.com/blog/meta-llama-3-1/). Usage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":16384,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.00000002","completion":"0.00000003","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":16384,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.1-405b-instruct","name":"Meta: Llama 3.1 405B Instruct","created":1721692800,"description":"The highly anticipated 400B class of Llama3 is here! Clocking in at 128k context with impressive eval scores, the Meta AI team continues to push the frontier of open-source LLMs.\n\nMeta's latest class of model (Llama 3.1) launched with a variety of sizes & flavors. This 405B instruct-tuned version is optimized for high quality dialogue usecases.\n\nIt has demonstrated strong performance compared to leading closed-source models including GPT-4o and Claude 3.5 Sonnet in evaluations.\n\nTo read more about the model release, [click here](https://ai.meta.com/blog/meta-llama-3-1/). Usage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.0000008","completion":"0.0000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3.1-70b-instruct","name":"Meta: Llama 3.1 70B Instruct","created":1721692800,"description":"Meta's latest class of model (Llama 3.1) launched with a variety of sizes & flavors. This 70B instruct-tuned version is optimized for high quality dialogue usecases.\n\nIt has demonstrated strong performance compared to leading closed-source models in human evaluations.\n\nTo read more about the model release, [click here](https://ai.meta.com/blog/meta-llama-3-1/). Usage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.000000119","completion":"0.00000039","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":32768,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/codestral-mamba","name":"Mistral: Codestral Mamba","created":1721347200,"description":"A 7.3B parameter Mamba-based model designed for code and reasoning tasks.\n\n- Linear time inference, allowing for theoretically infinite sequence lengths\n- 256k token context window\n- Optimized for quick responses, especially beneficial for code productivity\n- Performs comparably to state-of-the-art transformer models in code and reasoning tasks\n- Available under the Apache 2.0 license for free use, modification, and distribution","context_length":262144,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.00000025","completion":"0.00000025","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":262144,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-nemo:free","name":"Mistral: Mistral Nemo (free)","created":1721347200,"description":"A 12B parameter model with a 128k token context length built by Mistral in collaboration with NVIDIA.\n\nThe model is multilingual, supporting English, French, German, Spanish, Italian, Portuguese, Chinese, Japanese, Korean, Arabic, and Hindi.\n\nIt supports function calling and is released under the Apache 2.0 license.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"mistral"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":128000,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-nemo","name":"Mistral: Mistral Nemo","created":1721347200,"description":"A 12B parameter model with a 128k token context length built by Mistral in collaboration with NVIDIA.\n\nThe model is multilingual, supporting English, French, German, Spanish, Italian, Portuguese, Chinese, Japanese, Korean, Arabic, and Hindi.\n\nIt supports function calling and is released under the Apache 2.0 license.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"mistral"},"pricing":{"prompt":"0.000000035","completion":"0.00000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-4o-mini","name":"OpenAI: GPT-4o-mini","created":1721260800,"description":"GPT-4o mini is OpenAI's newest model after [GPT-4 Omni](/models/openai/gpt-4o), supporting both text and image inputs with text outputs.\n\nAs their most advanced small model, it is many multiples more affordable than other recent frontier models, and more than 60% cheaper than [GPT-3.5 Turbo](/models/openai/gpt-3.5-turbo). It maintains SOTA intelligence, while being significantly more cost-effective.\n\nGPT-4o mini achieves an 82% score on MMLU and presently ranks higher than GPT-4 on chat preferences [common leaderboards](https://arena.lmsys.org/).\n\nCheck out the [launch announcement](https://openai.com/index/gpt-4o-mini-advancing-cost-efficient-intelligence/) to learn more.\n\n#multimodal","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.00000015","completion":"0.0000006","request":"0","image":"0.000217","web_search":"0","internal_reasoning":"0","input_cache_read":"0.000000075"},"top_provider":{"context_length":128000,"max_completion_tokens":16384,"is_moderated":true},"per_request_limits":null},{"id":"openai/gpt-4o-mini-2024-07-18","name":"OpenAI: GPT-4o-mini (2024-07-18)","created":1721260800,"description":"GPT-4o mini is OpenAI's newest model after [GPT-4 Omni](/models/openai/gpt-4o), supporting both text and image inputs with text outputs.\n\nAs their most advanced small model, it is many multiples more affordable than other recent frontier models, and more than 60% cheaper than [GPT-3.5 Turbo](/models/openai/gpt-3.5-turbo). It maintains SOTA intelligence, while being significantly more cost-effective.\n\nGPT-4o mini achieves an 82% score on MMLU and presently ranks higher than GPT-4 on chat preferences [common leaderboards](https://arena.lmsys.org/).\n\nCheck out the [launch announcement](https://openai.com/index/gpt-4o-mini-advancing-cost-efficient-intelligence/) to learn more.\n\n#multimodal","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.00000015","completion":"0.0000006","request":"0","image":"0.007225","web_search":"0","internal_reasoning":"0","input_cache_read":"0.000000075"},"top_provider":{"context_length":128000,"max_completion_tokens":16384,"is_moderated":true},"per_request_limits":null},{"id":"google/gemma-2-27b-it","name":"Google: Gemma 2 27B","created":1720828800,"description":"Gemma 2 27B by Google is an open model built from the same research and technology used to create the [Gemini models](/models?q=gemini).\n\nGemma models are well-suited for a variety of text generation tasks, including question answering, summarization, and reasoning.\n\nSee the [launch announcement](https://blog.google/technology/developers/google-gemma-2/) for more details. Usage of Gemma is subject to Google's [Gemma Terms of Use](https://ai.google.dev/gemma/terms).","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":"gemma"},"pricing":{"prompt":"0.0000008","completion":"0.0000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"alpindale/magnum-72b","name":"Magnum 72B","created":1720656000,"description":"From the maker of [Goliath](https://openrouter.ai/models/alpindale/goliath-120b), Magnum 72B is the first in a new family of models designed to achieve the prose quality of the Claude 3 models, notably Opus & Sonnet.\n\nThe model is based on [Qwen2 72B](https://openrouter.ai/models/qwen/qwen-2-72b-instruct) and trained with 55 million tokens of highly curated roleplay (RP) data.","context_length":16384,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0.000004","completion":"0.000006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"google/gemma-2-9b-it:free","name":"Google: Gemma 2 9B (free)","created":1719532800,"description":"Gemma 2 9B by Google is an advanced, open-source language model that sets a new standard for efficiency and performance in its size class.\n\nDesigned for a wide variety of tasks, it empowers developers and researchers to build innovative applications, while maintaining accessibility, safety, and cost-effectiveness.\n\nSee the [launch announcement](https://blog.google/technology/developers/google-gemma-2/) for more details. Usage of Gemma is subject to Google's [Gemma Terms of Use](https://ai.google.dev/gemma/terms).","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":"gemma"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"google/gemma-2-9b-it","name":"Google: Gemma 2 9B","created":1719532800,"description":"Gemma 2 9B by Google is an advanced, open-source language model that sets a new standard for efficiency and performance in its size class.\n\nDesigned for a wide variety of tasks, it empowers developers and researchers to build innovative applications, while maintaining accessibility, safety, and cost-effectiveness.\n\nSee the [launch announcement](https://blog.google/technology/developers/google-gemma-2/) for more details. Usage of Gemma is subject to Google's [Gemma Terms of Use](https://ai.google.dev/gemma/terms).","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":"gemma"},"pricing":{"prompt":"0.00000007","completion":"0.00000007","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"01-ai/yi-large","name":"01.AI: Yi Large","created":1719273600,"description":"The Yi Large model was designed by 01.AI with the following usecases in mind: knowledge search, data classification, human-like chat bots, and customer service.\n\nIt stands out for its multilingual proficiency, particularly in Spanish, Chinese, Japanese, German, and French.\n\nCheck out the [launch announcement](https://01-ai.github.io/blog/01.ai-yi-large-llm-launch) to learn more.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Yi","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000003","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"ai21/jamba-instruct","name":"AI21: Jamba Instruct","created":1719273600,"description":"The Jamba-Instruct model, introduced by AI21 Labs, is an instruction-tuned variant of their hybrid SSM-Transformer Jamba model, specifically optimized for enterprise applications.\n\n- 256K Context Window: It can process extensive information, equivalent to a 400-page novel, which is beneficial for tasks involving large documents such as financial reports or legal documents\n- Safety and Accuracy: Jamba-Instruct is designed with enhanced safety features to ensure secure deployment in enterprise environments, reducing the risk and cost of implementation\n\nRead their [announcement](https://www.ai21.com/blog/announcing-jamba) to learn more.\n\nJamba has a knowledge cutoff of February 2024.","context_length":256000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":null},"pricing":{"prompt":"0.0000005","completion":"0.0000007","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":256000,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3.5-sonnet-20240620:beta","name":"Anthropic: Claude 3.5 Sonnet (2024-06-20) (self-moderated)","created":1718841600,"description":"Claude 3.5 Sonnet delivers better-than-Opus capabilities, faster-than-Sonnet speeds, at the same Sonnet prices. Sonnet is particularly good at:\n\n- Coding: Autonomously writes, edits, and runs code with reasoning and troubleshooting\n- Data science: Augments human data science expertise; navigates unstructured data while using multiple tools for insights\n- Visual processing: excelling at interpreting charts, graphs, and images, accurately transcribing text to derive insights beyond just the text alone\n- Agentic tasks: exceptional tool use, making it great at agentic tasks (i.e. complex, multi-step problem solving tasks that require engaging with other systems)\n\nFor the latest version (2024-10-23), check out [Claude 3.5 Sonnet](/anthropic/claude-3.5-sonnet).\n\n#multimodal","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0.0048","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000003","input_cache_write":"0.00000375"},"top_provider":{"context_length":200000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3.5-sonnet-20240620","name":"Anthropic: Claude 3.5 Sonnet (2024-06-20)","created":1718841600,"description":"Claude 3.5 Sonnet delivers better-than-Opus capabilities, faster-than-Sonnet speeds, at the same Sonnet prices. Sonnet is particularly good at:\n\n- Coding: Autonomously writes, edits, and runs code with reasoning and troubleshooting\n- Data science: Augments human data science expertise; navigates unstructured data while using multiple tools for insights\n- Visual processing: excelling at interpreting charts, graphs, and images, accurately transcribing text to derive insights beyond just the text alone\n- Agentic tasks: exceptional tool use, making it great at agentic tasks (i.e. complex, multi-step problem solving tasks that require engaging with other systems)\n\nFor the latest version (2024-10-23), check out [Claude 3.5 Sonnet](/anthropic/claude-3.5-sonnet).\n\n#multimodal","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0.0048","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000003","input_cache_write":"0.00000375"},"top_provider":{"context_length":200000,"max_completion_tokens":8192,"is_moderated":true},"per_request_limits":null},{"id":"sao10k/l3-euryale-70b","name":"Sao10k: Llama 3 Euryale 70B v2.1","created":1718668800,"description":"Euryale 70B v2.1 is a model focused on creative roleplay from [Sao10k](https://ko-fi.com/sao10k).\n\n- Better prompt adherence.\n- Better anatomy / spatial awareness.\n- Adapts much better to unique and custom formatting / reply formats.\n- Very creative, lots of unique swipes.\n- Is not restrictive during roleplays.","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.00000148","completion":"0.00000148","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"cognitivecomputations/dolphin-mixtral-8x22b","name":"Dolphin 2.9.2 Mixtral 8x22B 🐬","created":1717804800,"description":"Dolphin 2.9 is designed for instruction following, conversational, and coding. This model is a finetune of [Mixtral 8x22B Instruct](/models/mistralai/mixtral-8x22b-instruct). It features a 64k context length and was fine-tuned with a 16k sequence length using ChatML templates.\n\nThis model is a successor to [Dolphin Mixtral 8x7B](/models/cognitivecomputations/dolphin-mixtral-8x7b).\n\nThe model is uncensored and is stripped of alignment and bias. It requires an external alignment layer for ethical use. Users are cautioned to use this highly compliant model responsibly, as detailed in a blog post about uncensored models at [erichartford.com/uncensored-models](https://erichartford.com/uncensored-models).\n\n#moe #uncensored","context_length":16000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"chatml"},"pricing":{"prompt":"0.0000009","completion":"0.0000009","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"qwen/qwen-2-72b-instruct","name":"Qwen 2 72B Instruct","created":1717718400,"description":"Qwen2 72B is a transformer-based model that excels in language understanding, multilingual capabilities, coding, mathematics, and reasoning.\n\nIt features SwiGLU activation, attention QKV bias, and group query attention. It is pretrained on extensive data with supervised finetuning and direct preference optimization.\n\nFor more details, see this [blog post](https://qwenlm.github.io/blog/qwen2/) and [GitHub repo](https://github.com/QwenLM/Qwen2).\n\nUsage of this model is subject to [Tongyi Qianwen LICENSE AGREEMENT](https://huggingface.co/Qwen/Qwen1.5-110B-Chat/blob/main/LICENSE).","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Qwen","instruct_type":"chatml"},"pricing":{"prompt":"0.0000009","completion":"0.0000009","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-7b-instruct:free","name":"Mistral: Mistral 7B Instruct (free)","created":1716768000,"description":"A high-performing, industry-standard 7.3B parameter model, with optimizations for speed and context length.\n\n*Mistral 7B Instruct has multiple version variants, and this is intended to be the latest version.*","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"mistral"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-7b-instruct","name":"Mistral: Mistral 7B Instruct","created":1716768000,"description":"A high-performing, industry-standard 7.3B parameter model, with optimizations for speed and context length.\n\n*Mistral 7B Instruct has multiple version variants, and this is intended to be the latest version.*","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"mistral"},"pricing":{"prompt":"0.000000029","completion":"0.000000059","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-7b-instruct-v0.3","name":"Mistral: Mistral 7B Instruct v0.3","created":1716768000,"description":"A high-performing, industry-standard 7.3B parameter model, with optimizations for speed and context length.\n\nAn improved version of [Mistral 7B Instruct v0.2](/models/mistralai/mistral-7b-instruct-v0.2), with the following changes:\n\n- Extended vocabulary to 32768\n- Supports v3 Tokenizer\n- Supports function calling\n\nNOTE: Support for function calling depends on the provider.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"mistral"},"pricing":{"prompt":"0.000000029","completion":"0.000000059","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"nousresearch/hermes-2-pro-llama-3-8b","name":"NousResearch: Hermes 2 Pro - Llama-3 8B","created":1716768000,"description":"Hermes 2 Pro is an upgraded, retrained version of Nous Hermes 2, consisting of an updated and cleaned version of the OpenHermes 2.5 Dataset, as well as a newly introduced Function Calling and JSON Mode dataset developed in-house.","context_length":131072,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"chatml"},"pricing":{"prompt":"0.000000025","completion":"0.00000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":131072,"max_completion_tokens":131072,"is_moderated":false},"per_request_limits":null},{"id":"microsoft/phi-3-mini-128k-instruct","name":"Microsoft: Phi-3 Mini 128K Instruct","created":1716681600,"description":"Phi-3 Mini is a powerful 3.8B parameter model designed for advanced language understanding, reasoning, and instruction following. Optimized through supervised fine-tuning and preference adjustments, it excels in tasks involving common sense, mathematics, logical reasoning, and code processing.\n\nAt time of release, Phi-3 Medium demonstrated state-of-the-art performance among lightweight models. This model is static, trained on an offline dataset with an October 2023 cutoff date.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"phi3"},"pricing":{"prompt":"0.0000001","completion":"0.0000001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"microsoft/phi-3-medium-128k-instruct","name":"Microsoft: Phi-3 Medium 128K Instruct","created":1716508800,"description":"Phi-3 128K Medium is a powerful 14-billion parameter model designed for advanced language understanding, reasoning, and instruction following. Optimized through supervised fine-tuning and preference adjustments, it excels in tasks involving common sense, mathematics, logical reasoning, and code processing.\n\nAt time of release, Phi-3 Medium demonstrated state-of-the-art performance among lightweight models. In the MMLU-Pro eval, the model even comes close to a Llama3 70B level of performance.\n\nFor 4k context length, try [Phi-3 Medium 4K](/models/microsoft/phi-3-medium-4k-instruct).","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Other","instruct_type":"phi3"},"pricing":{"prompt":"0.000001","completion":"0.000001","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"neversleep/llama-3-lumimaid-70b","name":"NeverSleep: Llama 3 Lumimaid 70B","created":1715817600,"description":"The NeverSleep team is back, with a Llama 3 70B finetune trained on their curated roleplay data. Striking a balance between eRP and RP, Lumimaid was designed to be serious, yet uncensored when necessary.\n\nTo enhance it's overall intelligence and chat capability, roughly 40% of the training data was not roleplay. This provides a breadth of knowledge to access, while still keeping roleplay as the primary strength.\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.000004","completion":"0.000006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-flash-1.5","name":"Google: Gemini 1.5 Flash ","created":1715644800,"description":"Gemini 1.5 Flash is a foundation model that performs well at a variety of multimodal tasks such as visual understanding, classification, summarization, and creating content from image, audio and video. It's adept at processing visual and text inputs such as photographs, documents, infographics, and screenshots.\n\nGemini 1.5 Flash is designed for high-volume, high-frequency tasks where cost and latency matter. On most common tasks, Flash achieves comparable quality to other Gemini Pro models at a significantly reduced cost. Flash is well-suited for applications like chat assistants and on-demand content generation where speed and scale matter.\n\nUsage of Gemini is subject to Google's [Gemini Terms of Use](https://ai.google.dev/terms).\n\n#multimodal","context_length":1000000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0.000000075","completion":"0.0000003","request":"0","image":"0.00004","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000001875","input_cache_write":"0.0000001583"},"top_provider":{"context_length":1000000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-4o","name":"OpenAI: GPT-4o","created":1715558400,"description":"GPT-4o (\"o\" for \"omni\") is OpenAI's latest AI model, supporting both text and image inputs with text outputs. It maintains the intelligence level of [GPT-4 Turbo](/models/openai/gpt-4-turbo) while being twice as fast and 50% more cost-effective. GPT-4o also offers improved performance in processing non-English languages and enhanced visual capabilities.\n\nFor benchmarking against other models, it was briefly called [\"im-also-a-good-gpt2-chatbot\"](https://twitter.com/LiamFedus/status/1790064963966370209)\n\n#multimodal","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.0000025","completion":"0.00001","request":"0","image":"0.003613","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000125"},"top_provider":{"context_length":128000,"max_completion_tokens":16384,"is_moderated":true},"per_request_limits":null},{"id":"openai/gpt-4o:extended","name":"OpenAI: GPT-4o (extended)","created":1715558400,"description":"GPT-4o (\"o\" for \"omni\") is OpenAI's latest AI model, supporting both text and image inputs with text outputs. It maintains the intelligence level of [GPT-4 Turbo](/models/openai/gpt-4-turbo) while being twice as fast and 50% more cost-effective. GPT-4o also offers improved performance in processing non-English languages and enhanced visual capabilities.\n\nFor benchmarking against other models, it was briefly called [\"im-also-a-good-gpt2-chatbot\"](https://twitter.com/LiamFedus/status/1790064963966370209)\n\n#multimodal","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.000006","completion":"0.000018","request":"0","image":"0.007225","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":64000,"is_moderated":true},"per_request_limits":null},{"id":"openai/gpt-4o-2024-05-13","name":"OpenAI: GPT-4o (2024-05-13)","created":1715558400,"description":"GPT-4o (\"o\" for \"omni\") is OpenAI's latest AI model, supporting both text and image inputs with text outputs. It maintains the intelligence level of [GPT-4 Turbo](/models/openai/gpt-4-turbo) while being twice as fast and 50% more cost-effective. GPT-4o also offers improved performance in processing non-English languages and enhanced visual capabilities.\n\nFor benchmarking against other models, it was briefly called [\"im-also-a-good-gpt2-chatbot\"](https://twitter.com/LiamFedus/status/1790064963966370209)\n\n#multimodal","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.000005","completion":"0.000015","request":"0","image":"0.007225","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"meta-llama/llama-guard-2-8b","name":"Meta: LlamaGuard 2 8B","created":1715558400,"description":"This safeguard model has 8B parameters and is based on the Llama 3 family. Just like is predecessor, [LlamaGuard 1](https://huggingface.co/meta-llama/LlamaGuard-7b), it can do both prompt and response classification.\n\nLlamaGuard 2 acts as a normal LLM would, generating text that indicates whether the given input/output is safe/unsafe. If deemed unsafe, it will also share the content categories violated.\n\nFor best results, please use raw prompt input or the `/completions` endpoint, instead of the chat API.\n\nIt has demonstrated strong performance compared to leading closed-source models in human evaluations.\n\nTo read more about the model release, [click here](https://ai.meta.com/blog/meta-llama-3/). Usage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"none"},"pricing":{"prompt":"0.0000002","completion":"0.0000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"neversleep/llama-3-lumimaid-8b:extended","name":"NeverSleep: Llama 3 Lumimaid 8B (extended)","created":1714780800,"description":"The NeverSleep team is back, with a Llama 3 8B finetune trained on their curated roleplay data. Striking a balance between eRP and RP, Lumimaid was designed to be serious, yet uncensored when necessary.\n\nTo enhance it's overall intelligence and chat capability, roughly 40% of the training data was not roleplay. This provides a breadth of knowledge to access, while still keeping roleplay as the primary strength.\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":24576,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.00000009375","completion":"0.00000075","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":24576,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"neversleep/llama-3-lumimaid-8b","name":"NeverSleep: Llama 3 Lumimaid 8B","created":1714780800,"description":"The NeverSleep team is back, with a Llama 3 8B finetune trained on their curated roleplay data. Striking a balance between eRP and RP, Lumimaid was designed to be serious, yet uncensored when necessary.\n\nTo enhance it's overall intelligence and chat capability, roughly 40% of the training data was not roleplay. This provides a breadth of knowledge to access, while still keeping roleplay as the primary strength.\n\nUsage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":24576,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.00000009375","completion":"0.00000075","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":24576,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"sao10k/fimbulvetr-11b-v2","name":"Fimbulvetr 11B v2","created":1713657600,"description":"Creative writing model, routed with permission. It's fast, it keeps the conversation going, and it stays in character.\n\nIf you submit a raw prompt, you can use Alpaca or Vicuna formats.","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"alpaca"},"pricing":{"prompt":"0.0000008","completion":"0.0000012","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3-8b-instruct","name":"Meta: Llama 3 8B Instruct","created":1713398400,"description":"Meta's latest class of model (Llama 3) launched with a variety of sizes & flavors. This 8B instruct-tuned version was optimized for high quality dialogue usecases.\n\nIt has demonstrated strong performance compared to leading closed-source models in human evaluations.\n\nTo read more about the model release, [click here](https://ai.meta.com/blog/meta-llama-3/). Usage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.00000003","completion":"0.00000006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-3-70b-instruct","name":"Meta: Llama 3 70B Instruct","created":1713398400,"description":"Meta's latest class of model (Llama 3) launched with a variety of sizes & flavors. This 70B instruct-tuned version was optimized for high quality dialogue usecases.\n\nIt has demonstrated strong performance compared to leading closed-source models in human evaluations.\n\nTo read more about the model release, [click here](https://ai.meta.com/blog/meta-llama-3/). Usage of this model is subject to [Meta's Acceptable Use Policy](https://llama.meta.com/llama3/use-policy/).","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama3","instruct_type":"llama3"},"pricing":{"prompt":"0.0000003","completion":"0.0000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mixtral-8x22b-instruct","name":"Mistral: Mixtral 8x22B Instruct","created":1713312000,"description":"Mistral's official instruct fine-tuned version of [Mixtral 8x22B](/models/mistralai/mixtral-8x22b). It uses 39B active parameters out of 141B, offering unparalleled cost efficiency for its size. Its strengths include:\n- strong math, coding, and reasoning\n- large context length (64k)\n- fluency in English, French, Italian, German, and Spanish\n\nSee benchmarks on the launch announcement [here](https://mistral.ai/news/mixtral-8x22b/).\n#moe","context_length":65536,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"mistral"},"pricing":{"prompt":"0.0000009","completion":"0.0000009","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":65536,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"microsoft/wizardlm-2-8x22b","name":"WizardLM-2 8x22B","created":1713225600,"description":"WizardLM-2 8x22B is Microsoft AI's most advanced Wizard model. It demonstrates highly competitive performance compared to leading proprietary models, and it consistently outperforms all existing state-of-the-art opensource models.\n\nIt is an instruct finetune of [Mixtral 8x22B](/models/mistralai/mixtral-8x22b).\n\nTo read more about the model release, [click here](https://wizardlm.github.io/WizardLM2/).\n\n#moe","context_length":65536,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"vicuna"},"pricing":{"prompt":"0.0000005","completion":"0.0000005","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":65536,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"microsoft/wizardlm-2-7b","name":"WizardLM-2 7B","created":1713225600,"description":"WizardLM-2 7B is the smaller variant of Microsoft AI's latest Wizard model. It is the fastest and achieves comparable performance with existing 10x larger opensource leading models\n\nIt is a finetune of [Mistral 7B Instruct](/models/mistralai/mistral-7b-instruct), using the same technique as [WizardLM-2 8x22B](/models/microsoft/wizardlm-2-8x22b).\n\nTo read more about the model release, [click here](https://wizardlm.github.io/WizardLM2/).\n\n#moe","context_length":32000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"vicuna"},"pricing":{"prompt":"0.00000007","completion":"0.00000007","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-pro-1.5","name":"Google: Gemini 1.5 Pro","created":1712620800,"description":"Google's latest multimodal model, supports image and video[0] in text or chat prompts.\n\nOptimized for language tasks including:\n\n- Code generation\n- Text generation\n- Text editing\n- Problem solving\n- Recommendations\n- Information extraction\n- Data extraction or generation\n- AI agents\n\nUsage of Gemini is subject to Google's [Gemini Terms of Use](https://ai.google.dev/terms).\n\n* [0]: Video input is not available through OpenRouter at this time.","context_length":2000000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0.00000125","completion":"0.000005","request":"0","image":"0.0006575","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":2000000,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-4-turbo","name":"OpenAI: GPT-4 Turbo","created":1712620800,"description":"The latest GPT-4 Turbo model with vision capabilities. Vision requests can now use JSON mode and function calling.\n\nTraining data: up to December 2023.","context_length":128000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.00001","completion":"0.00003","request":"0","image":"0.01445","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"cohere/command-r-plus","name":"Cohere: Command R+","created":1712188800,"description":"Command R+ is a new, 104B-parameter LLM from Cohere. It's useful for roleplay, general consumer usecases, and Retrieval Augmented Generation (RAG).\n\nIt offers multilingual support for ten key languages to facilitate global business operations. See benchmarks and the launch post [here](https://txt.cohere.com/command-r-plus-microsoft-azure/).\n\nUse of this model is subject to Cohere's [Usage Policy](https://docs.cohere.com/docs/usage-policy) and [SaaS Agreement](https://cohere.com/saas-agreement).","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Cohere","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":4000,"is_moderated":false},"per_request_limits":null},{"id":"cohere/command-r-plus-04-2024","name":"Cohere: Command R+ (04-2024)","created":1712016000,"description":"Command R+ is a new, 104B-parameter LLM from Cohere. It's useful for roleplay, general consumer usecases, and Retrieval Augmented Generation (RAG).\n\nIt offers multilingual support for ten key languages to facilitate global business operations. See benchmarks and the launch post [here](https://txt.cohere.com/command-r-plus-microsoft-azure/).\n\nUse of this model is subject to Cohere's [Usage Policy](https://docs.cohere.com/docs/usage-policy) and [SaaS Agreement](https://cohere.com/saas-agreement).","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Cohere","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":4000,"is_moderated":false},"per_request_limits":null},{"id":"sophosympatheia/midnight-rose-70b","name":"Midnight Rose 70B","created":1711065600,"description":"A merge with a complex family tree, this model was crafted for roleplaying and storytelling. Midnight Rose is a successor to Rogue Rose and Aurora Nights and improves upon them both. It wants to produce lengthy output by default and is the best creative writing merge produced so far by sophosympatheia.\n\nDescending from earlier versions of Midnight Rose and [Wizard Tulu Dolphin 70B](https://huggingface.co/sophosympatheia/Wizard-Tulu-Dolphin-70B-v1.0), it inherits the best qualities of each.","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"airoboros"},"pricing":{"prompt":"0.0000008","completion":"0.0000008","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"cohere/command","name":"Cohere: Command","created":1710374400,"description":"Command is an instruction-following conversational model that performs language tasks with high quality, more reliably and with a longer context than our base generative models.\n\nUse of this model is subject to Cohere's [Usage Policy](https://docs.cohere.com/docs/usage-policy) and [SaaS Agreement](https://cohere.com/saas-agreement).","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Cohere","instruct_type":null},"pricing":{"prompt":"0.000001","completion":"0.000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":4000,"is_moderated":false},"per_request_limits":null},{"id":"cohere/command-r","name":"Cohere: Command R","created":1710374400,"description":"Command-R is a 35B parameter model that performs conversational language tasks at a higher quality, more reliably, and with a longer context than previous models. It can be used for complex workflows like code generation, retrieval augmented generation (RAG), tool use, and agents.\n\nRead the launch post [here](https://txt.cohere.com/command-r/).\n\nUse of this model is subject to Cohere's [Usage Policy](https://docs.cohere.com/docs/usage-policy) and [SaaS Agreement](https://cohere.com/saas-agreement).","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Cohere","instruct_type":null},"pricing":{"prompt":"0.0000005","completion":"0.0000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":4000,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3-haiku:beta","name":"Anthropic: Claude 3 Haiku (self-moderated)","created":1710288000,"description":"Claude 3 Haiku is Anthropic's fastest and most compact model for\nnear-instant responsiveness. Quick and accurate targeted performance.\n\nSee the launch announcement and benchmark results [here](https://www.anthropic.com/news/claude-3-haiku)\n\n#multimodal","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.00000025","completion":"0.00000125","request":"0","image":"0.0004","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000003","input_cache_write":"0.0000003"},"top_provider":{"context_length":200000,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3-haiku","name":"Anthropic: Claude 3 Haiku","created":1710288000,"description":"Claude 3 Haiku is Anthropic's fastest and most compact model for\nnear-instant responsiveness. Quick and accurate targeted performance.\n\nSee the launch announcement and benchmark results [here](https://www.anthropic.com/news/claude-3-haiku)\n\n#multimodal","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.00000025","completion":"0.00000125","request":"0","image":"0.0004","web_search":"0","internal_reasoning":"0","input_cache_read":"0.00000003","input_cache_write":"0.0000003"},"top_provider":{"context_length":200000,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"anthropic/claude-3-opus:beta","name":"Anthropic: Claude 3 Opus (self-moderated)","created":1709596800,"description":"Claude 3 Opus is Anthropic's most powerful model for highly complex tasks. It boasts top-level performance, intelligence, fluency, and understanding.\n\nSee the launch announcement and benchmark results [here](https://www.anthropic.com/news/claude-3-family)\n\n#multimodal","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000015","completion":"0.000075","request":"0","image":"0.024","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000015","input_cache_write":"0.00001875"},"top_provider":{"context_length":200000,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3-opus","name":"Anthropic: Claude 3 Opus","created":1709596800,"description":"Claude 3 Opus is Anthropic's most powerful model for highly complex tasks. It boasts top-level performance, intelligence, fluency, and understanding.\n\nSee the launch announcement and benchmark results [here](https://www.anthropic.com/news/claude-3-family)\n\n#multimodal","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000015","completion":"0.000075","request":"0","image":"0.024","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000015","input_cache_write":"0.00001875"},"top_provider":{"context_length":200000,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"anthropic/claude-3-sonnet:beta","name":"Anthropic: Claude 3 Sonnet (self-moderated)","created":1709596800,"description":"Claude 3 Sonnet is an ideal balance of intelligence and speed for enterprise workloads. Maximum utility at a lower price, dependable, balanced for scaled deployments.\n\nSee the launch announcement and benchmark results [here](https://www.anthropic.com/news/claude-3-family)\n\n#multimodal","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0.0048","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000003","input_cache_write":"0.00000375"},"top_provider":{"context_length":200000,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-3-sonnet","name":"Anthropic: Claude 3 Sonnet","created":1709596800,"description":"Claude 3 Sonnet is an ideal balance of intelligence and speed for enterprise workloads. Maximum utility at a lower price, dependable, balanced for scaled deployments.\n\nSee the launch announcement and benchmark results [here](https://www.anthropic.com/news/claude-3-family)\n\n#multimodal","context_length":200000,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000015","request":"0","image":"0.0048","web_search":"0","internal_reasoning":"0","input_cache_read":"0.0000003","input_cache_write":"0.00000375"},"top_provider":{"context_length":200000,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"cohere/command-r-03-2024","name":"Cohere: Command R (03-2024)","created":1709341200,"description":"Command-R is a 35B parameter model that performs conversational language tasks at a higher quality, more reliably, and with a longer context than previous models. It can be used for complex workflows like code generation, retrieval augmented generation (RAG), tool use, and agents.\n\nRead the launch post [here](https://txt.cohere.com/command-r/).\n\nUse of this model is subject to Cohere's [Usage Policy](https://docs.cohere.com/docs/usage-policy) and [SaaS Agreement](https://cohere.com/saas-agreement).","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Cohere","instruct_type":null},"pricing":{"prompt":"0.0000005","completion":"0.0000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":4000,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-large","name":"Mistral Large","created":1708905600,"description":"This is Mistral AI's flagship model, Mistral Large 2 (version `mistral-large-2407`). It's a proprietary weights-available model and excels at reasoning, code, JSON, chat, and more. Read the launch announcement [here](https://mistral.ai/news/mistral-large-2407/).\n\nIt supports dozens of languages including French, German, Spanish, Italian, Portuguese, Arabic, Hindi, Russian, Chinese, Japanese, and Korean, along with 80+ coding languages including Python, Java, C, C++, JavaScript, and Bash. Its long context window allows precise information recall from large documents.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.000002","completion":"0.000006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-3.5-turbo-0613","name":"OpenAI: GPT-3.5 Turbo (older v0613)","created":1706140800,"description":"GPT-3.5 Turbo is OpenAI's fastest model. It can understand and generate natural language or code, and is optimized for chat and traditional completion tasks.\n\nTraining data up to Sep 2021.","context_length":4095,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.000001","completion":"0.000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4095,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-4-turbo-preview","name":"OpenAI: GPT-4 Turbo Preview","created":1706140800,"description":"The preview GPT-4 model with improved instruction following, JSON mode, reproducible outputs, parallel function calling, and more. Training data: up to Dec 2023.\n\n**Note:** heavily rate limited by OpenAI while in preview.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.00001","completion":"0.00003","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"nousresearch/nous-hermes-2-mixtral-8x7b-dpo","name":"Nous: Hermes 2 Mixtral 8x7B DPO","created":1705363200,"description":"Nous Hermes 2 Mixtral 8x7B DPO is the new flagship Nous Research model trained over the [Mixtral 8x7B MoE LLM](/models/mistralai/mixtral-8x7b).\n\nThe model was trained on over 1,000,000 entries of primarily [GPT-4](/models/openai/gpt-4) generated data, as well as other high quality data from open datasets across the AI landscape, achieving state of the art performance on a variety of tasks.\n\n#moe","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"chatml"},"pricing":{"prompt":"0.0000006","completion":"0.0000006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-medium","name":"Mistral Medium","created":1704844800,"description":"This is Mistral AI's closed-source, medium-sided model. It's powered by a closed-source prototype and excels at reasoning, code, JSON, chat, and more. In benchmarks, it compares with many of the flagship models of other companies.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.00000275","completion":"0.0000081","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-small","name":"Mistral Small","created":1704844800,"description":"With 22 billion parameters, Mistral Small v24.09 offers a convenient mid-point between (Mistral NeMo 12B)[/mistralai/mistral-nemo] and (Mistral Large 2)[/mistralai/mistral-large], providing a cost-effective solution that can be deployed across various platforms and environments. It has better reasoning, exhibits more capabilities, can produce and reason about code, and is multiligual, supporting English, French, German, Italian, and Spanish.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.0000002","completion":"0.0000006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-tiny","name":"Mistral Tiny","created":1704844800,"description":"Note: This model is being deprecated. Recommended replacement is the newer [Ministral 8B](/mistral/ministral-8b)\n\nThis model is currently powered by Mistral-7B-v0.2, and incorporates a \"better\" fine-tuning than [Mistral 7B](/models/mistralai/mistral-7b-instruct-v0.1), inspired by community work. It's best used for large batch processing tasks where cost is a significant factor but reasoning capabilities are not crucial.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":null},"pricing":{"prompt":"0.00000025","completion":"0.00000025","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mistral-7b-instruct-v0.2","name":"Mistral: Mistral 7B Instruct v0.2","created":1703721600,"description":"A high-performing, industry-standard 7.3B parameter model, with optimizations for speed and context length.\n\nAn improved version of [Mistral 7B Instruct](/modelsmistralai/mistral-7b-instruct-v0.1), with the following changes:\n\n- 32k context window (vs 8k context in v0.1)\n- Rope-theta = 1e6\n- No Sliding-Window Attention","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"mistral"},"pricing":{"prompt":"0.0000002","completion":"0.0000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"cognitivecomputations/dolphin-mixtral-8x7b","name":"Dolphin 2.6 Mixtral 8x7B 🐬","created":1703116800,"description":"This is a 16k context fine-tune of [Mixtral-8x7b](/models/mistralai/mixtral-8x7b). It excels in coding tasks due to extensive training with coding data and is known for its obedience, although it lacks DPO tuning.\n\nThe model is uncensored and is stripped of alignment and bias. It requires an external alignment layer for ethical use. Users are cautioned to use this highly compliant model responsibly, as detailed in a blog post about uncensored models at [erichartford.com/uncensored-models](https://erichartford.com/uncensored-models).\n\n#moe #uncensored","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"chatml"},"pricing":{"prompt":"0.0000005","completion":"0.0000005","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-pro-vision","name":"Google: Gemini Pro Vision 1.0","created":1702425600,"description":"Google's flagship multimodal model, supporting image and video in text or chat prompts for a text or code response.\n\nSee the benchmarks and prompting guidelines from [Deepmind](https://deepmind.google/technologies/gemini/).\n\nUsage of Gemini is subject to Google's [Gemini Terms of Use](https://ai.google.dev/terms).\n\n#multimodal","context_length":16384,"architecture":{"modality":"text+image->text","input_modalities":["text","image"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0.0000005","completion":"0.0000015","request":"0","image":"0.0025","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16384,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"google/gemini-pro","name":"Google: Gemini Pro 1.0","created":1702425600,"description":"Google's flagship text generation model. Designed to handle natural language tasks, multiturn text and code chat, and code generation.\n\nSee the benchmarks and prompting guidelines from [Deepmind](https://deepmind.google/technologies/gemini/).\n\nUsage of Gemini is subject to Google's [Gemini Terms of Use](https://ai.google.dev/terms).","context_length":32760,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Gemini","instruct_type":null},"pricing":{"prompt":"0.0000005","completion":"0.0000015","request":"0","image":"0.0025","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32760,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"mistralai/mixtral-8x7b-instruct","name":"Mistral: Mixtral 8x7B Instruct","created":1702166400,"description":"Mixtral 8x7B Instruct is a pretrained generative Sparse Mixture of Experts, by Mistral AI, for chat and instruction use. Incorporates 8 experts (feed-forward networks) for a total of 47 billion parameters.\n\nInstruct model fine-tuned by Mistral. #moe","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"mistral"},"pricing":{"prompt":"0.00000024","completion":"0.00000024","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"openchat/openchat-7b","name":"OpenChat 3.5 7B","created":1701129600,"description":"OpenChat 7B is a library of open-source language models, fine-tuned with \"C-RLFT (Conditioned Reinforcement Learning Fine-Tuning)\" - a strategy inspired by offline reinforcement learning. It has been trained on mixed-quality data without preference labels.\n\n- For OpenChat fine-tuned on Mistral 7B, check out [OpenChat 7B](/models/openchat/openchat-7b).\n- For OpenChat fine-tuned on Llama 8B, check out [OpenChat 8B](/models/openchat/openchat-8b).\n\n#open-source","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"openchat"},"pricing":{"prompt":"0.00000007","completion":"0.00000007","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"neversleep/noromaid-20b","name":"Noromaid 20B","created":1700956800,"description":"A collab between IkariDev and Undi. This merge is suitable for RP, ERP, and general knowledge.\n\n#merge #uncensored","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"alpaca"},"pricing":{"prompt":"0.00000075","completion":"0.0000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-2.1:beta","name":"Anthropic: Claude v2.1 (self-moderated)","created":1700611200,"description":"Claude 2 delivers advancements in key capabilities for enterprises—including an industry-leading 200K token context window, significant reductions in rates of model hallucination, system prompts and a new beta feature: tool use.","context_length":200000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000008","completion":"0.000024","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":200000,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-2.1","name":"Anthropic: Claude v2.1","created":1700611200,"description":"Claude 2 delivers advancements in key capabilities for enterprises—including an industry-leading 200K token context window, significant reductions in rates of model hallucination, system prompts and a new beta feature: tool use.","context_length":200000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000008","completion":"0.000024","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":200000,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"anthropic/claude-2:beta","name":"Anthropic: Claude v2 (self-moderated)","created":1700611200,"description":"Claude 2 delivers advancements in key capabilities for enterprises—including an industry-leading 200K token context window, significant reductions in rates of model hallucination, system prompts and a new beta feature: tool use.","context_length":200000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000008","completion":"0.000024","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":200000,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-2","name":"Anthropic: Claude v2","created":1700611200,"description":"Claude 2 delivers advancements in key capabilities for enterprises—including an industry-leading 200K token context window, significant reductions in rates of model hallucination, system prompts and a new beta feature: tool use.","context_length":200000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000008","completion":"0.000024","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":200000,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"undi95/toppy-m-7b","name":"Toppy M 7B","created":1699574400,"description":"A wild 7B parameter model that merges several models using the new task_arithmetic merge method from mergekit.\nList of merged models:\n- NousResearch/Nous-Capybara-7B-V1.9\n- [HuggingFaceH4/zephyr-7b-beta](/models/huggingfaceh4/zephyr-7b-beta)\n- lemonilia/AshhLimaRP-Mistral-7B\n- Vulkane/120-Days-of-Sodom-LoRA-Mistral-7b\n- Undi95/Mistral-pippa-sharegpt-7b-qlora\n\n#merge #uncensored","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"alpaca"},"pricing":{"prompt":"0.00000007","completion":"0.00000007","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"alpindale/goliath-120b","name":"Goliath 120B","created":1699574400,"description":"A large LLM created by combining two fine-tuned Llama 70B models into one 120B model. Combines Xwin and Euryale.\n\nCredits to\n- [@chargoddard](https://huggingface.co/chargoddard) for developing the framework used to merge the model - [mergekit](https://github.com/cg123/mergekit).\n- [@Undi95](https://huggingface.co/Undi95) for helping with the merge ratios.\n\n#merge","context_length":6144,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"airoboros"},"pricing":{"prompt":"0.0000065625","completion":"0.000009375","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":6144,"max_completion_tokens":512,"is_moderated":false},"per_request_limits":null},{"id":"openrouter/auto","name":"Auto Router","created":1699401600,"description":"Your prompt will be processed by a meta-model and routed to one of dozens of models (see below), optimizing for the best possible output.\n\nTo see which model was used, visit [Activity](/activity), or read the `model` attribute of the response. Your response will be priced at the same rate as the routed model.\n\nThe meta-model is powered by [Not Diamond](https://docs.notdiamond.ai/docs/how-not-diamond-works). Learn more in our [docs](/docs/model-routing).\n\nRequests will be routed to the following models:\n- [openai/gpt-4o-2024-08-06](/openai/gpt-4o-2024-08-06)\n- [openai/gpt-4o-2024-05-13](/openai/gpt-4o-2024-05-13)\n- [openai/gpt-4o-mini-2024-07-18](/openai/gpt-4o-mini-2024-07-18)\n- [openai/chatgpt-4o-latest](/openai/chatgpt-4o-latest)\n- [openai/o1-preview-2024-09-12](/openai/o1-preview-2024-09-12)\n- [openai/o1-mini-2024-09-12](/openai/o1-mini-2024-09-12)\n- [anthropic/claude-3.5-sonnet](/anthropic/claude-3.5-sonnet)\n- [anthropic/claude-3.5-haiku](/anthropic/claude-3.5-haiku)\n- [anthropic/claude-3-opus](/anthropic/claude-3-opus)\n- [anthropic/claude-2.1](/anthropic/claude-2.1)\n- [google/gemini-pro-1.5](/google/gemini-pro-1.5)\n- [google/gemini-flash-1.5](/google/gemini-flash-1.5)\n- [mistralai/mistral-large-2407](/mistralai/mistral-large-2407)\n- [mistralai/mistral-nemo](/mistralai/mistral-nemo)\n- [deepseek/deepseek-r1](/deepseek/deepseek-r1)\n- [meta-llama/llama-3.1-70b-instruct](/meta-llama/llama-3.1-70b-instruct)\n- [meta-llama/llama-3.1-405b-instruct](/meta-llama/llama-3.1-405b-instruct)\n- [mistralai/mixtral-8x22b-instruct](/mistralai/mixtral-8x22b-instruct)\n- [cohere/command-r-plus](/cohere/command-r-plus)\n- [cohere/command-r](/cohere/command-r)","context_length":2000000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Router","instruct_type":null},"pricing":{"prompt":"-1","completion":"-1"},"top_provider":{"context_length":null,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-3.5-turbo-1106","name":"OpenAI: GPT-3.5 Turbo 16k (older v1106)","created":1699228800,"description":"An older GPT-3.5 Turbo model with improved instruction following, JSON mode, reproducible outputs, parallel function calling, and more. Training data: up to Sep 2021.","context_length":16385,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.000001","completion":"0.000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16385,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"openai/gpt-4-1106-preview","name":"OpenAI: GPT-4 Turbo (older v1106)","created":1699228800,"description":"The latest GPT-4 Turbo model with vision capabilities. Vision requests can now use JSON mode and function calling.\n\nTraining data: up to April 2023.","context_length":128000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.00001","completion":"0.00003","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":128000,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"google/palm-2-chat-bison-32k","name":"Google: PaLM 2 Chat 32k","created":1698969600,"description":"PaLM 2 is a language model by Google with improved multilingual, reasoning and coding capabilities.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"PaLM","instruct_type":null},"pricing":{"prompt":"0.000001","completion":"0.000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"google/palm-2-codechat-bison-32k","name":"Google: PaLM 2 Code Chat 32k","created":1698969600,"description":"PaLM 2 fine-tuned for chatbot conversations that help with code-related questions.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"PaLM","instruct_type":null},"pricing":{"prompt":"0.000001","completion":"0.000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":8192,"is_moderated":false},"per_request_limits":null},{"id":"jondurbin/airoboros-l2-70b","name":"Airoboros 70B","created":1698537600,"description":"A Llama 2 70B fine-tune using synthetic data (the Airoboros dataset).\n\nCurrently based on [jondurbin/airoboros-l2-70b](https://huggingface.co/jondurbin/airoboros-l2-70b-2.2.1), but might get updated in the future.","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"airoboros"},"pricing":{"prompt":"0.0000005","completion":"0.0000005","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-3.5-turbo-instruct","name":"OpenAI: GPT-3.5 Turbo Instruct","created":1695859200,"description":"This model is a variant of GPT-3.5 Turbo tuned for instructional prompts and omitting chat-related optimizations. Training data: up to Sep 2021.","context_length":4095,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":"chatml"},"pricing":{"prompt":"0.0000015","completion":"0.000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4095,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"mistralai/mistral-7b-instruct-v0.1","name":"Mistral: Mistral 7B Instruct v0.1","created":1695859200,"description":"A 7.3B parameter model that outperforms Llama 2 13B on all benchmarks, with optimizations for speed and context length.","context_length":32768,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"mistral"},"pricing":{"prompt":"0.0000002","completion":"0.0000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32768,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"pygmalionai/mythalion-13b","name":"Pygmalion: Mythalion 13B","created":1693612800,"description":"A blend of the new Pygmalion-13b and MythoMax. #merge","context_length":8192,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"alpaca"},"pricing":{"prompt":"0.0000005625","completion":"0.000001125","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8192,"max_completion_tokens":1024,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-3.5-turbo-16k","name":"OpenAI: GPT-3.5 Turbo 16k","created":1693180800,"description":"This model offers four times the context length of gpt-3.5-turbo, allowing it to support approximately 20 pages of text in a single request at a higher cost. Training data: up to Sep 2021.","context_length":16385,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.000003","completion":"0.000004","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16385,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"openai/gpt-4-32k","name":"OpenAI: GPT-4 32k","created":1693180800,"description":"GPT-4-32k is an extended version of GPT-4, with the same capabilities but quadrupled context length, allowing for processing up to 40 pages of text in a single pass. This is particularly beneficial for handling longer content like interacting with PDFs without an external vector database. Training data: up to Sep 2021.","context_length":32767,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.00006","completion":"0.00012","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32767,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"openai/gpt-4-32k-0314","name":"OpenAI: GPT-4 32k (older v0314)","created":1693180800,"description":"GPT-4-32k is an extended version of GPT-4, with the same capabilities but quadrupled context length, allowing for processing up to 40 pages of text in a single pass. This is particularly beneficial for handling longer content like interacting with PDFs without an external vector database. Training data: up to Sep 2021.","context_length":32767,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.00006","completion":"0.00012","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":32767,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"nousresearch/nous-hermes-llama2-13b","name":"Nous: Hermes 13B","created":1692489600,"description":"A state-of-the-art language model fine-tuned on over 300k instructions by Nous Research, with Teknium and Emozilla leading the fine tuning process.","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"alpaca"},"pricing":{"prompt":"0.00000018","completion":"0.00000018","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"mancer/weaver","name":"Mancer: Weaver (alpha)","created":1690934400,"description":"An attempt to recreate Claude-style verbosity, but don't expect the same level of coherence or memory. Meant for use in roleplay/narrative situations.","context_length":8000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"alpaca"},"pricing":{"prompt":"0.000001125","completion":"0.000001125","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8000,"max_completion_tokens":1000,"is_moderated":false},"per_request_limits":null},{"id":"huggingfaceh4/zephyr-7b-beta:free","name":"Hugging Face: Zephyr 7B (free)","created":1690934400,"description":"Zephyr is a series of language models that are trained to act as helpful assistants. Zephyr-7B-β is the second model in the series, and is a fine-tuned version of [mistralai/Mistral-7B-v0.1](/models/mistralai/mistral-7b-instruct-v0.1) that was trained on a mix of publicly available, synthetic datasets using Direct Preference Optimization (DPO).","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Mistral","instruct_type":"zephyr"},"pricing":{"prompt":"0","completion":"0","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-2.0:beta","name":"Anthropic: Claude v2.0 (self-moderated)","created":1690502400,"description":"Anthropic's flagship model. Superior performance on tasks that require complex reasoning. Supports hundreds of pages of text.","context_length":100000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000008","completion":"0.000024","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":100000,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"anthropic/claude-2.0","name":"Anthropic: Claude v2.0","created":1690502400,"description":"Anthropic's flagship model. Superior performance on tasks that require complex reasoning. Supports hundreds of pages of text.","context_length":100000,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Claude","instruct_type":null},"pricing":{"prompt":"0.000008","completion":"0.000024","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":100000,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"undi95/remm-slerp-l2-13b","name":"ReMM SLERP 13B","created":1689984000,"description":"A recreation trial of the original MythoMax-L2-B13 but with updated models. #merge","context_length":6144,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"alpaca"},"pricing":{"prompt":"0.0000005625","completion":"0.000001125","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":6144,"max_completion_tokens":1024,"is_moderated":false},"per_request_limits":null},{"id":"google/palm-2-chat-bison","name":"Google: PaLM 2 Chat","created":1689811200,"description":"PaLM 2 is a language model by Google with improved multilingual, reasoning and coding capabilities.","context_length":9216,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"PaLM","instruct_type":null},"pricing":{"prompt":"0.000001","completion":"0.000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":9216,"max_completion_tokens":1024,"is_moderated":false},"per_request_limits":null},{"id":"google/palm-2-codechat-bison","name":"Google: PaLM 2 Code Chat","created":1689811200,"description":"PaLM 2 fine-tuned for chatbot conversations that help with code-related questions.","context_length":7168,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"PaLM","instruct_type":null},"pricing":{"prompt":"0.000001","completion":"0.000002","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":7168,"max_completion_tokens":1024,"is_moderated":false},"per_request_limits":null},{"id":"gryphe/mythomax-l2-13b","name":"MythoMax 13B","created":1688256000,"description":"One of the highest performing and most popular fine-tunes of Llama 2 13B, with rich descriptions and roleplay. #merge","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"alpaca"},"pricing":{"prompt":"0.000000065","completion":"0.000000065","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":4096,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-2-13b-chat","name":"Meta: Llama 2 13B Chat","created":1687219200,"description":"A 13 billion parameter language model from Meta, fine tuned for chat completions","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"llama2"},"pricing":{"prompt":"0.00000022","completion":"0.00000022","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":2048,"is_moderated":false},"per_request_limits":null},{"id":"meta-llama/llama-2-70b-chat","name":"Meta: Llama 2 70B Chat","created":1687219200,"description":"The flagship, 70 billion parameter language model from Meta, fine tuned for chat completions. Llama 2 is an auto-regressive language model that uses an optimized transformer architecture. The tuned versions use supervised fine-tuning (SFT) and reinforcement learning with human feedback (RLHF) to align to human preferences for helpfulness and safety.","context_length":4096,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"Llama2","instruct_type":"llama2"},"pricing":{"prompt":"0.0000009","completion":"0.0000009","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":4096,"max_completion_tokens":null,"is_moderated":false},"per_request_limits":null},{"id":"openai/gpt-3.5-turbo","name":"OpenAI: GPT-3.5 Turbo","created":1685232000,"description":"GPT-3.5 Turbo is OpenAI's fastest model. It can understand and generate natural language or code, and is optimized for chat and traditional completion tasks.\n\nTraining data up to Sep 2021.","context_length":16385,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.0000005","completion":"0.0000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16385,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"openai/gpt-3.5-turbo-0125","name":"OpenAI: GPT-3.5 Turbo 16k","created":1685232000,"description":"The latest GPT-3.5 Turbo model with improved instruction following, JSON mode, reproducible outputs, parallel function calling, and more. Training data: up to Sep 2021.\n\nThis version has a higher accuracy at responding in requested formats and a fix for a bug which caused a text encoding issue for non-English language function calls.","context_length":16385,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.0000005","completion":"0.0000015","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":16385,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"openai/gpt-4","name":"OpenAI: GPT-4","created":1685232000,"description":"OpenAI's flagship model, GPT-4 is a large-scale multimodal language model capable of solving difficult problems with greater accuracy than previous models due to its broader general knowledge and advanced reasoning capabilities. Training data: up to Sep 2021.","context_length":8191,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.00003","completion":"0.00006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8191,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null},{"id":"openai/gpt-4-0314","name":"OpenAI: GPT-4 (older v0314)","created":1685232000,"description":"GPT-4-0314 is the first version of GPT-4 released, with a context length of 8,192 tokens, and was supported until June 14. Training data: up to Sep 2021.","context_length":8191,"architecture":{"modality":"text->text","input_modalities":["text"],"output_modalities":["text"],"tokenizer":"GPT","instruct_type":null},"pricing":{"prompt":"0.00003","completion":"0.00006","request":"0","image":"0","web_search":"0","internal_reasoning":"0"},"top_provider":{"context_length":8191,"max_completion_tokens":4096,"is_moderated":true},"per_request_limits":null}]} + recorded_at: Mon, 21 Apr 2025 11:25:26 GMT recorded_with: VCR 6.3.1 + From ad1bb2b9577942ebabc8d00efde8632dcd73898f Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Tue, 22 Apr 2025 09:05:30 -0300 Subject: [PATCH 54/55] Remove stale code from main --- spec/ruby_llm/chat_tools_spec.rb | 4 ---- 1 file changed, 4 deletions(-) diff --git a/spec/ruby_llm/chat_tools_spec.rb b/spec/ruby_llm/chat_tools_spec.rb index 48b27007..f68536c0 100644 --- a/spec/ruby_llm/chat_tools_spec.rb +++ b/spec/ruby_llm/chat_tools_spec.rb @@ -82,10 +82,6 @@ def execute chat_models.each do |model| # rubocop:disable Style/CombinableLoops provider = RubyLLM::Models.provider_for(model).slug it "#{provider}/#{model} can use tools without parameters in multi-turn streaming conversations" do # rubocop:disable RSpec/ExampleLength,RSpec/MultipleExpectations - if provider == 'anthropic' && model == 'claude-3-5-haiku-20241022' - pending('Anthropic frequently returns 529 OverloadedError mid-stream for this specific test. ' \ - 'This appears to be provider-side flakiness. Skipping only for this model to allow release 1.2.0.') - end chat = RubyLLM.chat(model: model) .with_temperature(0.1) .with_tool(BestLanguageToLearn) From 7ab29e010d290eef54a4c8a613a6a7b45d985787 Mon Sep 17 00:00:00 2001 From: Leonardo Mosquera Date: Tue, 22 Apr 2025 09:10:33 -0300 Subject: [PATCH 55/55] Appease rubocop --- lib/ruby_llm/providers/ollama.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/ruby_llm/providers/ollama.rb b/lib/ruby_llm/providers/ollama.rb index 704ee850..eec4fe19 100644 --- a/lib/ruby_llm/providers/ollama.rb +++ b/lib/ruby_llm/providers/ollama.rb @@ -20,7 +20,7 @@ def api_base(config) config.ollama_api_base_url end - def headers(config) + def headers(_config) {} end