OpenAIEmbedding
llmfy.llmfy_core.embeddings.openai.openai_embedding
logger = LLMfyLogger('LLMfy').get_logger()
module-attribute
OpenAIEmbedding
Bases: BaseEmbeddingModel
OpenAI embedding client.
Source code in llmfy/llmfy_core/embeddings/openai/openai_embedding.py
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 | |
client = openai.OpenAI(api_key=(os.getenv('OPENAI_API_KEY')))
instance-attribute
provider = ServiceProvider.OPENAI
instance-attribute
model = model
instance-attribute
__init__(model='text-embedding-3-small')
Initialize OpenAI embeddings client
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
model
|
str
|
Model name for OpenAI embeddings. Defaults to "text-embedding-3-small". |
'text-embedding-3-small'
|
api_key
|
str
|
OpenAI API key. If None, will use OPENAI_API_KEY environment variable. |
required |
Source code in llmfy/llmfy_core/embeddings/openai/openai_embedding.py
__call_openai_embedding(model, text)
Source code in llmfy/llmfy_core/embeddings/openai/openai_embedding.py
encode(text)
Get embedding for a single text
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
text
|
str
|
text to embed |
required |
Raises:
| Type | Description |
|---|---|
ValueError
|
If no embedding returned |
OpenAIError
|
For API errors |
Returns:
| Type | Description |
|---|---|
List[float]
|
List[float]: Embedding vector |
Source code in llmfy/llmfy_core/embeddings/openai/openai_embedding.py
encode_batch(texts, batch_size=10, max_retries=3, retry_delay=1.0, show_progress_bar=False)
Encode texts into embedding with batch process.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
texts
|
List[str] | str
|
Text(s) to embed |
required |
batch_size
|
int
|
Number of texts per batch. Defaults to 100. |
10
|
max_retries
|
int
|
Maximum retry attempts. Defaults to 3. |
3
|
retry_delay
|
float
|
Delay between retries in seconds. Defaults to 1.0. |
1.0
|
show_progress_bar
|
bool
|
Whether to show progress. Defaults to False. |
False
|
Returns:
| Type | Description |
|---|---|
|
NDArray[Any]: Array of embeddings |
Source code in llmfy/llmfy_core/embeddings/openai/openai_embedding.py
104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 | |