@huggingface/inference
Version:
Typescript client for the Hugging Face Inference Providers and Inference Endpoints
27 lines (24 loc) • 1.16 kB
text/typescript
import type { ImageClassificationInput, ImageClassificationOutput } 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 { preparePayload, type LegacyImageInput } from "./utils";
export type ImageClassificationArgs = BaseArgs & (ImageClassificationInput | LegacyImageInput);
/**
* This task reads some image input and outputs the likelihood of classes.
* Recommended model: google/vit-base-patch16-224
*/
export async function imageClassification(
args: ImageClassificationArgs,
options?: Options
): Promise<ImageClassificationOutput> {
const provider = await resolveProvider(args.provider, args.model, args.endpointUrl);
const providerHelper = getProviderHelper(provider, "image-classification");
const payload = preparePayload(args);
const { data: res } = await innerRequest<ImageClassificationOutput>(payload, providerHelper, {
...options,
task: "image-classification",
});
return providerHelper.getResponse(res);
}