Sha256: 76c1c3968e150a17397188aa2486bfc0d9affba3bac46c55b1d1dd529f5da5ae
Contents?: true
Size: 1.79 KB
Versions: 1
Compression:
Stored size: 1.79 KB
Contents
# frozen_string_literal: true require 'faraday' module GenAI class Image class StabilityAI < Base DEFAULT_SIZE = '256x256' API_BASE_URL = 'https://api.stability.ai' DEFAULT_MODEL = 'stable-diffusion-xl-beta-v2-2-2' def initialize(token:, options: {}) build_client(token) end def generate(prompt, options = {}) model = options[:model] || DEFAULT_MODEL url = "/v1/generation/#{model}/text-to-image" response = client.post url, build_generation_body(prompt, options) build_result( raw: response, model: model, parsed: response['artifacts'].map { |artifact| artifact['base64'] } ) end def edit(image, prompt, options = {}) model = options[:model] || DEFAULT_MODEL url = "/v1/generation/#{model}/image-to-image" response = client.post url, build_edit_body(image, prompt, options), multipart: true build_result( raw: response, model: model, parsed: response['artifacts'].map { |artifact| artifact['base64'] } ) end private def build_client(token) @client = GenAI::Api::Client.new(url: API_BASE_URL, token: token) end def build_generation_body(prompt, options) w, h = size(options) { text_prompts: [{ text: prompt }], height: h, width: w }.merge(options) end def build_edit_body(image, prompt, options) { init_image: File.binread(image), 'text_prompts[0][text]' => prompt, 'text_prompts[0][weight]' => 1.0 }.merge(options) end def size(options) size = options.delete(:size) || DEFAULT_SIZE size.split('x').map(&:to_i) end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
gen-ai-0.2.0 | lib/gen_ai/image/stability_ai.rb |