Skip to content

Commit

Permalink
Fix PretrainedOptions
Browse files Browse the repository at this point in the history
  • Loading branch information
kungfooman committed Sep 14, 2023
1 parent 75b2e15 commit 18bc805
Show file tree
Hide file tree
Showing 5 changed files with 16 additions and 32 deletions.
9 changes: 2 additions & 7 deletions src/models.js
Original file line number Diff line number Diff line change
Expand Up @@ -81,11 +81,6 @@ import { executionProviders, ONNX } from './backends/onnx.js';
import { medianFilter, round } from './transformers.js';
const { InferenceSession, Tensor: ONNXTensor } = ONNX;

/**
* @typedef {import('./utils/hub.js').PretrainedOptions} PretrainedOptions
*/


//////////////////////////////////////////////////
// Model types: used internally
const MODEL_TYPES = {
Expand All @@ -111,7 +106,7 @@ const MODEL_TYPE_MAPPING = new Map([
* Constructs an InferenceSession using a model file located at the specified path.
* @param {string} pretrained_model_name_or_path The path to the directory containing the model file.
* @param {string} fileName The name of the model file.
* @param {PretrainedOptions} options Additional options for loading the model.
* @param {import('./utils/hub.js').PretrainedOptions} options Additional options for loading the model.
* @returns {Promise<InferenceSession>} A Promise that resolves to an InferenceSession object.
* @private
*/
Expand Down Expand Up @@ -647,7 +642,7 @@ export class PreTrainedModel extends Callable {
* Valid model ids can be located at the root-level, like `bert-base-uncased`, or namespaced under a
* user or organization name, like `dbmdz/bert-base-german-cased`.
* - A path to a *directory* containing model weights, e.g., `./my_model_directory/`.
* @param {PretrainedOptions} options Additional options for loading the model.
* @param {import('./utils/hub.js').PretrainedOptions} options Additional options for loading the model.
*
* @returns {Promise<PreTrainedModel>} A new instance of the `PreTrainedModel` class.
*/
Expand Down
8 changes: 2 additions & 6 deletions src/pipelines.js
Original file line number Diff line number Diff line change
Expand Up @@ -1977,10 +1977,6 @@ const TASK_ALIASES = {
"embeddings": "feature-extraction",
}

/**
* @typedef {import('./utils/hub.js').PretrainedOptions} PretrainedOptions
*/

/**
* Utility factory method to build a [`Pipeline`] object.
*
Expand All @@ -2004,7 +2000,7 @@ const TASK_ALIASES = {
* - `"zero-shot-classification"`: will return a `ZeroShotClassificationPipeline`.
* - `"zero-shot-image-classification"`: will return a `ZeroShotImageClassificationPipeline`.
* @param {string} [model=null] The name of the pre-trained model to use. If not specified, the default model for the task will be used.
* @param {PretrainedOptions} [options] Optional parameters for the pipeline.
* @param {import('./utils/hub.js').PretrainedOptions} [options] Optional parameters for the pipeline.
* @returns {Promise<Pipeline>} A Pipeline object for the specified task.
* @throws {Error} If an unsupported pipeline is requested.
*/
Expand Down Expand Up @@ -2071,7 +2067,7 @@ export async function pipeline(
* Helper function to get applicable model, tokenizer, or processor classes for a given model.
* @param {Map<string, any>} mapping The mapping of names to classes, arrays of classes, or null.
* @param {string} model The name of the model to load.
* @param {PretrainedOptions} pretrainedOptions The options to pass to the `from_pretrained` method.
* @param {import('./utils/hub.js').PretrainedOptions} pretrainedOptions The options to pass to the `from_pretrained` method.
* @private
*/
async function loadItems(mapping, model, pretrainedOptions) {
Expand Down
5 changes: 1 addition & 4 deletions src/processors.js
Original file line number Diff line number Diff line change
Expand Up @@ -1334,9 +1334,6 @@ export class Wav2Vec2ProcessorWithLM extends Processor {
}

//////////////////////////////////////////////////
/**
* @typedef {import('./utils/hub.js').PretrainedOptions} PretrainedOptions
*/
/**
* Helper class which is used to instantiate pretrained processors with the `from_pretrained` function.
* The chosen processor class is determined by the type specified in the processor config.
Expand Down Expand Up @@ -1399,7 +1396,7 @@ export class AutoProcessor {
* Valid model ids can be located at the root-level, like `bert-base-uncased`, or namespaced under a
* user or organization name, like `dbmdz/bert-base-german-cased`.
* - A path to a *directory* containing processor files, e.g., `./my_model_directory/`.
* @param {PretrainedOptions} options Additional options for loading the processor.
* @param {import('./utils/hub.js').PretrainedOptions} options Additional options for loading the processor.
*
* @returns {Promise<Processor>} A new instance of the Processor class.
*/
Expand Down
12 changes: 4 additions & 8 deletions src/tokenizers.js
Original file line number Diff line number Diff line change
Expand Up @@ -41,15 +41,11 @@ import {
CharTrie,
} from './utils/data-structures.js';

/**
* @typedef {import('./utils/hub.js').PretrainedOptions} PretrainedOptions
*/

/**
* Loads a tokenizer from the specified path.
* @param {string} pretrained_model_name_or_path The path to the tokenizer directory.
* @param {PretrainedOptions} options Additional options for loading the tokenizer.
* @returns {Promise<Array>} A promise that resolves with information about the loaded tokenizer.
* @param {import('./utils/hub.js').PretrainedOptions} options Additional options for loading the tokenizer.
* @returns {Promise<any[]>} A promise that resolves with information about the loaded tokenizer.
*/
async function loadTokenizer(pretrained_model_name_or_path, options) {

Expand Down Expand Up @@ -2186,7 +2182,7 @@ export class PreTrainedTokenizer extends Callable {
* Loads a pre-trained tokenizer from the given `pretrained_model_name_or_path`.
*
* @param {string} pretrained_model_name_or_path The path to the pre-trained tokenizer.
* @param {PretrainedOptions} options Additional options for loading the tokenizer.
* @param {import('./utils/hub.js').PretrainedOptions} options Additional options for loading the tokenizer.
*
* @throws {Error} Throws an error if the tokenizer.json or tokenizer_config.json files are not found in the `pretrained_model_name_or_path`.
* @returns {Promise<PreTrainedTokenizer>} A new instance of the `PreTrainedTokenizer` class.
Expand Down Expand Up @@ -3761,7 +3757,7 @@ export class AutoTokenizer {
* Valid model ids can be located at the root-level, like `bert-base-uncased`, or namespaced under a
* user or organization name, like `dbmdz/bert-base-german-cased`.
* - A path to a *directory* containing tokenizer files, e.g., `./my_model_directory/`.
* @param {PretrainedOptions} options Additional options for loading the tokenizer.
* @param {import('./utils/hub.js').PretrainedOptions} options Additional options for loading the tokenizer.
*
* @returns {Promise<PreTrainedTokenizer>} A new instance of the PreTrainedTokenizer class.
*/
Expand Down
14 changes: 7 additions & 7 deletions src/utils/hub.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,17 +19,17 @@ if (!globalThis.ReadableStream) {

/**
* @typedef {Object} PretrainedOptions Options for loading a pretrained model.
* @property {boolean?} [options.quantized=true] Whether to load the 8-bit quantized version of the model (only applicable when loading model files).
* @property {function} [options.progress_callback=null] If specified, this function will be called during model construction, to provide the user with progress updates.
* @property {Object} [options.config=null] Configuration for the model to use instead of an automatically loaded configuration. Configuration can be automatically loaded when:
* @property {boolean?} [quantized=true] Whether to load the 8-bit quantized version of the model (only applicable when loading model files).
* @property {function} [progress_callback=null] If specified, this function will be called during model construction, to provide the user with progress updates.
* @property {Object} [config=null] Configuration for the model to use instead of an automatically loaded configuration. Configuration can be automatically loaded when:
* - The model is a model provided by the library (loaded with the *model id* string of a pretrained model).
* - The model is loaded by supplying a local directory as `pretrained_model_name_or_path` and a configuration JSON file named *config.json* is found in the directory.
* @property {string} [options.cache_dir=null] Path to a directory in which a downloaded pretrained model configuration should be cached if the standard cache should not be used.
* @property {boolean} [options.local_files_only=false] Whether or not to only look at local files (e.g., not try downloading the model).
* @property {string} [options.revision='main'] The specific model version to use. It can be a branch name, a tag name, or a commit id,
* @property {string} [cache_dir=null] Path to a directory in which a downloaded pretrained model configuration should be cached if the standard cache should not be used.
* @property {boolean} [local_files_only=false] Whether or not to only look at local files (e.g., not try downloading the model).
* @property {string} [revision='main'] The specific model version to use. It can be a branch name, a tag name, or a commit id,
* since we use a git-based system for storing models and other artifacts on huggingface.co, so `revision` can be any identifier allowed by git.
* NOTE: This setting is ignored for local requests.
* @property {string} [options.model_file_name=null] If specified, load the model with this name (excluding the .onnx suffix). Currently only valid for encoder- or decoder-only models.
* @property {string} [model_file_name=null] If specified, load the model with this name (excluding the .onnx suffix). Currently only valid for encoder- or decoder-only models.
*/

class FileResponse {
Expand Down

0 comments on commit 18bc805

Please sign in to comment.