pub trait EmbeddingModel:
Clone
+ Sync
+ Send {
const MAX_DOCUMENTS: usize;
// Required methods
fn ndims(&self) -> usize;
fn embed_texts(
&self,
texts: impl IntoIterator<Item = String> + Send,
) -> impl Future<Output = Result<Vec<Embedding>, EmbeddingError>> + Send;
// Provided method
fn embed_text(
&self,
text: &str,
) -> impl Future<Output = Result<Embedding, EmbeddingError>> + Send { ... }
}
Expand description
Trait for embedding models that can generate embeddings for documents.
Required Associated Constants§
Sourceconst MAX_DOCUMENTS: usize
const MAX_DOCUMENTS: usize
The maximum number of documents that can be embedded in a single request.
Required Methods§
Sourcefn embed_texts(
&self,
texts: impl IntoIterator<Item = String> + Send,
) -> impl Future<Output = Result<Vec<Embedding>, EmbeddingError>> + Send
fn embed_texts( &self, texts: impl IntoIterator<Item = String> + Send, ) -> impl Future<Output = Result<Vec<Embedding>, EmbeddingError>> + Send
Embed multiple text documents in a single request
Provided Methods§
Sourcefn embed_text(
&self,
text: &str,
) -> impl Future<Output = Result<Embedding, EmbeddingError>> + Send
fn embed_text( &self, text: &str, ) -> impl Future<Output = Result<Embedding, EmbeddingError>> + Send
Embed a single text document.
Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.