[**@lancedb/lancedb**](../../../README.md) • **Docs** *** [@lancedb/lancedb](../../../globals.md) / [embedding](../README.md) / EmbeddingFunctionRegistry # Class: EmbeddingFunctionRegistry This is a singleton class used to register embedding functions and fetch them by name. It also handles serializing and deserializing. You can implement your own embedding function by subclassing EmbeddingFunction or TextEmbeddingFunction and registering it with the registry ## Constructors ### new EmbeddingFunctionRegistry() ```ts new EmbeddingFunctionRegistry(): EmbeddingFunctionRegistry ``` #### Returns [`EmbeddingFunctionRegistry`](EmbeddingFunctionRegistry.md) ## Methods ### functionToMetadata() ```ts functionToMetadata(conf): Record ``` #### Parameters * **conf**: [`EmbeddingFunctionConfig`](../interfaces/EmbeddingFunctionConfig.md) #### Returns `Record`<`string`, `any`> *** ### get() ```ts get(name): undefined | EmbeddingFunctionCreate ``` Fetch an embedding function by name #### Type Parameters • **T** *extends* [`EmbeddingFunction`](EmbeddingFunction.md)<`unknown`, [`FunctionOptions`](../interfaces/FunctionOptions.md)> #### Parameters * **name**: `string` The name of the function #### Returns `undefined` \| [`EmbeddingFunctionCreate`](../interfaces/EmbeddingFunctionCreate.md)<`T`> *** ### getTableMetadata() ```ts getTableMetadata(functions): Map ``` #### Parameters * **functions**: [`EmbeddingFunctionConfig`](../interfaces/EmbeddingFunctionConfig.md)[] #### Returns `Map`<`string`, `string`> *** ### getVar() ```ts getVar(name): undefined | string ``` Get a variable. #### Parameters * **name**: `string` #### Returns `undefined` \| `string` #### See [setVar](EmbeddingFunctionRegistry.md#setvar) *** ### length() ```ts length(): number ``` Get the number of registered functions #### Returns `number` *** ### register() ```ts register(this, alias?): (ctor) => any ``` Register an embedding function #### Type Parameters • **T** *extends* [`EmbeddingFunctionConstructor`](../interfaces/EmbeddingFunctionConstructor.md)<[`EmbeddingFunction`](EmbeddingFunction.md)<`any`, [`FunctionOptions`](../interfaces/FunctionOptions.md)>> = [`EmbeddingFunctionConstructor`](../interfaces/EmbeddingFunctionConstructor.md)<[`EmbeddingFunction`](EmbeddingFunction.md)<`any`, [`FunctionOptions`](../interfaces/FunctionOptions.md)>> #### Parameters * **this**: [`EmbeddingFunctionRegistry`](EmbeddingFunctionRegistry.md) * **alias?**: `string` #### Returns `Function` ##### Parameters * **ctor**: `T` ##### Returns `any` #### Throws Error if the function is already registered *** ### reset() ```ts reset(this): void ``` reset the registry to the initial state #### Parameters * **this**: [`EmbeddingFunctionRegistry`](EmbeddingFunctionRegistry.md) #### Returns `void` *** ### setVar() ```ts setVar(name, value): void ``` Set a variable. These can be accessed in the embedding function configuration using the syntax `$var:variable_name`. If they are not set, an error will be thrown letting you know which key is unset. If you want to supply a default value, you can add an additional part in the configuration like so: `$var:variable_name:default_value`. Default values can be used for runtime configurations that are not sensitive, such as whether to use a GPU for inference. The name must not contain colons. The default value can contain colons. #### Parameters * **name**: `string` * **value**: `string` #### Returns `void`