UNPKG

@huggingface/inference

Version:

Typescript client for the Hugging Face Inference Providers and Inference Endpoints

24 lines (21 loc) 1.05 kB
import type { ImageToTextInput, ImageToTextOutput } from "@huggingface/tasks"; import { resolveProvider } from "../../lib/getInferenceProviderMapping"; import { getProviderHelper } from "../../lib/getProviderHelper"; import type { BaseArgs, Options } from "../../types"; import { innerRequest } from "../../utils/request"; import type { LegacyImageInput } from "./utils"; import { preparePayload } from "./utils"; export type ImageToTextArgs = BaseArgs & (ImageToTextInput | LegacyImageInput); /** * This task reads some image input and outputs the text caption. */ export async function imageToText(args: ImageToTextArgs, options?: Options): Promise<ImageToTextOutput> { const provider = await resolveProvider(args.provider, args.model, args.endpointUrl); const providerHelper = getProviderHelper(provider, "image-to-text"); const payload = preparePayload(args); const { data: res } = await innerRequest<[ImageToTextOutput]>(payload, providerHelper, { ...options, task: "image-to-text", }); return providerHelper.getResponse(res[0]); }