UNPKG

weaviate-client

Version:
292 lines (291 loc) 15 kB
var __rest = (this && this.__rest) || function (s, e) { var t = {}; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; } return t; }; const isModuleConfig = (config) => { return config && typeof config === 'object' && 'name' in config && 'config' in config; }; const configure = { /** * Create a `ModuleConfig<'flat', VectorIndexConfigFlatCreate | undefined>` object when defining the configuration of the FLAT vector index. * * Use this method when defining the `options.vectorIndexConfig` argument of the `configure.vectors` method. * * @param {VectorIndexConfigFlatCreateOptions} [opts] The options available for configuring the flat vector index. * @returns {ModuleConfig<'flat', VectorIndexConfigFlatCreate | undefined>} The configuration object. */ flat: (opts) => { const { distanceMetric: distance, vectorCacheMaxObjects, quantizer } = opts || {}; return { name: 'flat', config: { distance, vectorCacheMaxObjects, quantizer: quantizer, type: 'flat', }, }; }, /** * Create a `ModuleConfig<'hnsw', VectorIndexConfigHNSWCreate | undefined>` object when defining the configuration of the HNSW vector index. * * Use this method when defining the `options.vectorIndexConfig` argument of the `configure.vectors` method. * * @param {VectorIndexConfigHNSWCreateOptions} [opts] The options available for configuring the HNSW vector index. * @returns {ModuleConfig<'hnsw', VectorIndexConfigHNSWCreate | undefined>} The configuration object. */ hnsw: (opts) => { const _a = opts || {}, { distanceMetric } = _a, rest = __rest(_a, ["distanceMetric"]); return { name: 'hnsw', config: rest ? Object.assign(Object.assign({}, rest), { distance: distanceMetric, type: 'hnsw' }) : undefined, }; }, /** * Create a `ModuleConfig<'dynamic', VectorIndexConfigDynamicCreate | undefined>` object when defining the configuration of the dynamic vector index. * * Use this method when defining the `options.vectorIndexConfig` argument of the `configure.vectors` method. * * @param {VectorIndexConfigDynamicCreateOptions} [opts] The options available for configuring the dynamic vector index. * @returns {ModuleConfig<'dynamic', VectorIndexConfigDynamicCreate | undefined>} The configuration object. */ dynamic: (opts) => { return { name: 'dynamic', config: opts ? { distance: opts.distanceMetric, threshold: opts.threshold, hnsw: isModuleConfig(opts.hnsw) ? opts.hnsw.config : configure.hnsw(opts.hnsw).config, flat: isModuleConfig(opts.flat) ? opts.flat.config : configure.flat(opts.flat).config, type: 'dynamic', } : undefined, }; }, /** * Define the configuration for a multi-vector index. */ multiVector: { /** * Specify the encoding configuration for a multi-vector index. */ encoding: { /** * Create an object of type `MuveraEncodingConfigCreate` to be used when defining the encoding configuration of a multi-vector index using MUVERA. * * @param {number} [options.ksim] The number of nearest neighbors to consider for similarity. Default is undefined. * @param {number} [options.dprojections] The number of projections to use. Default is undefined. * @param {number} [options.repetitions] The number of repetitions to use. Default is undefined. * @returns {MuveraEncodingConfigCreate} The object of type `MuveraEncodingConfigCreate`. */ muvera: (options) => { return { ksim: options === null || options === void 0 ? void 0 : options.ksim, dprojections: options === null || options === void 0 ? void 0 : options.dprojections, repetitions: options === null || options === void 0 ? void 0 : options.repetitions, type: 'muvera', }; }, }, /** * Create an object of type `MultiVectorConfigCreate` to be used when defining the configuration of a multi-vector index. * * @param {string} [options.aggregation] The aggregation method to use. Default is 'maxSim'. * @param {MultiVectorConfig['encoding']} [options.encoding] The encoding configuration for the multi-vector index. Default is undefined. * @returns {MultiVectorConfigCreate} The object of type `MultiVectorConfigCreate`. */ multiVector: (options) => { return { aggregation: options === null || options === void 0 ? void 0 : options.aggregation, encoding: options === null || options === void 0 ? void 0 : options.encoding, }; }, }, /** * Define the quantizer configuration to use when creating a vector index. */ quantizer: { /** * Create an object of type `BQConfigCreate` to be used when defining the quantizer configuration of a vector index. * * @param {boolean} [options.cache] Whether to cache the quantizer. Default is false. * @param {number} [options.rescoreLimit] The rescore limit. Default is 1000. * @returns {BQConfigCreate} The object of type `BQConfigCreate`. */ bq: (options) => { return { cache: options === null || options === void 0 ? void 0 : options.cache, rescoreLimit: options === null || options === void 0 ? void 0 : options.rescoreLimit, type: 'bq', }; }, /** * Create an object of type `RQConfigCreate` to be used when defining the quantizer configuration of a vector index. * * @param {number} [options.bits] Number of bits to user per vector element. * @param {number} [options.rescoreLimit] The rescore limit. Default is 1000. * @returns {RQConfigCreate} The object of type `RQConfigCreate`. */ rq: (options) => { return { bits: options === null || options === void 0 ? void 0 : options.bits, rescoreLimit: options === null || options === void 0 ? void 0 : options.rescoreLimit, type: 'rq', }; }, /** * Create an object of type `PQConfigCreate` to be used when defining the quantizer configuration of a vector index. * * @param {boolean} [options.bitCompression] Whether to use bit compression. * @param {number} [options.centroids] The number of centroids. * @param {PQEncoderDistribution} [options.encoder.distribution] The encoder distribution. * @param {PQEncoderType} [options.encoder.type] The encoder type. * @param {number} [options.segments] The number of segments. * @param {number} [options.trainingLimit] The training limit. * @returns {PQConfigCreate} The object of type `PQConfigCreate`. */ pq: (options) => { return { bitCompression: options === null || options === void 0 ? void 0 : options.bitCompression, centroids: options === null || options === void 0 ? void 0 : options.centroids, encoder: (options === null || options === void 0 ? void 0 : options.encoder) ? { distribution: options.encoder.distribution, type: options.encoder.type, } : undefined, segments: options === null || options === void 0 ? void 0 : options.segments, trainingLimit: options === null || options === void 0 ? void 0 : options.trainingLimit, type: 'pq', }; }, /** * Create an object of type `SQConfigCreate` to be used when defining the quantizer configuration of a vector index. * * @param {number} [options.rescoreLimit] The rescore limit. * @param {number} [options.trainingLimit] The training limit. * @returns {SQConfigCreate} The object of type `SQConfigCreate`. */ sq: (options) => { return { rescoreLimit: options === null || options === void 0 ? void 0 : options.rescoreLimit, trainingLimit: options === null || options === void 0 ? void 0 : options.trainingLimit, type: 'sq', }; }, }, }; const reconfigure = { /** * Create a `ModuleConfig<'flat', VectorIndexConfigFlatUpdate>` object to update the configuration of the FLAT vector index. * * Use this method when defining the `options.vectorIndexConfig` argument of the `reconfigure.vectors` method. * * @param {VectorDistance} [options.distanceMetric] The distance metric to use. Default is 'cosine'. * @param {number} [options.vectorCacheMaxObjects] The maximum number of objects to cache in the vector cache. Default is 1000000000000. * @param {BQConfigCreate} [options.quantizer] The quantizer configuration to use. Default is `bq`. * @returns {ModuleConfig<'flat', VectorIndexConfigFlatCreate>} The configuration object. */ flat: (options) => { return { name: 'flat', config: options, }; }, /** * Create a `ModuleConfig<'hnsw', VectorIndexConfigHNSWCreate>` object to update the configuration of the HNSW vector index. * * Use this method when defining the `options.vectorIndexConfig` argument of the `reconfigure.vectors` method. * * @param {number} [options.dynamicEfFactor] The dynamic ef factor. Default is 8. * @param {number} [options.dynamicEfMax] The dynamic ef max. Default is 500. * @param {number} [options.dynamicEfMin] The dynamic ef min. Default is 100. * @param {number} [options.ef] The ef parameter. Default is -1. * @param {VectorIndexFilterStrategy} [options.filterStrategy] The filter strategy. Default is 'sweeping'. * @param {number} [options.flatSearchCutoff] The flat search cutoff. Default is 40000. * @param {PQConfigUpdate | BQConfigUpdate | SQConfigUpdate | RQConfigUpdate} [options.quantizer] The quantizer configuration to use. Use `vectorIndex.quantizer.bq` or `vectorIndex.quantizer.pq` to make one. * @param {number} [options.vectorCacheMaxObjects] The maximum number of objects to cache in the vector cache. Default is 1000000000000. * @returns {ModuleConfig<'hnsw', VectorIndexConfigHNSWUpdate>} The configuration object. */ hnsw: (options) => { return { name: 'hnsw', config: options, }; }, /** * Define the quantizer configuration to use when creating a vector index. */ quantizer: { /** * Create an object of type `BQConfigUpdate` to be used when updating the quantizer configuration of a vector index. * * NOTE: If the vector index already has a quantizer configured, you cannot change its quantizer type; only its values. * So if you want to change the quantizer type, you must recreate the collection. * * @param {boolean} [options.cache] Whether to cache the quantizer. * @param {number} [options.rescoreLimit] The new rescore limit. * @returns {BQConfigUpdate} The configuration object. */ bq: (options) => { return Object.assign(Object.assign({}, options), { type: 'bq' }); }, /** * Create an object of type `RQConfigUpdate` to be used when updating the quantizer configuration of a vector index. * * NOTE: If the vector index already has a quantizer configured, you cannot change its quantizer type; only its values. * So if you want to change the quantizer type, you must recreate the collection. * * @param {number} [options.rescoreLimit] The new rescore limit. * @returns {BQConfigUpdate} The configuration object. */ rq: (options) => { return Object.assign(Object.assign({}, options), { type: 'rq' }); }, /** * Create an object of type `PQConfigUpdate` to be used when updating the quantizer configuration of a vector index. * * NOTE: If the vector index already has a quantizer configured, you cannot change its quantizer type; only its values. * So if you want to change the quantizer type, you must recreate the collection. * * @param {number} [options.centroids] The new number of centroids. * @param {PQEncoderDistribution} [options.pqEncoderDistribution] The new encoder distribution. * @param {PQEncoderType} [options.pqEncoderType] The new encoder type. * @param {number} [options.segments] The new number of segments. * @param {number} [options.trainingLimit] The new training limit. * @returns {PQConfigUpdate} The configuration object. */ pq: (options) => { const _a = options || {}, { pqEncoderDistribution, pqEncoderType } = _a, rest = __rest(_a, ["pqEncoderDistribution", "pqEncoderType"]); return Object.assign(Object.assign({}, rest), { encoder: pqEncoderDistribution || pqEncoderType ? { distribution: pqEncoderDistribution, type: pqEncoderType, } : undefined, type: 'pq' }); }, /** * Create an object of type `SQConfigUpdate` to be used when updating the quantizer configuration of a vector index. * * NOTE: If the vector index already has a quantizer configured, you cannot change its quantizer type; only its values. * So if you want to change the quantizer type, you must recreate the collection. * * @param {number} [options.rescoreLimit] The rescore limit. * @param {number} [options.trainingLimit] The training limit. * @returns {SQConfigUpdate} The configuration object. */ sq: (options) => { return Object.assign(Object.assign({}, options), { type: 'sq' }); }, }, }; export { configure, reconfigure };