-
Notifications
You must be signed in to change notification settings - Fork 39
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Also support embedding APIs? #171
Comments
I think that's currently out of scope for elmer, but we might end up implementing in a separate package. What do you need it for? |
I would love to see this as well! Embedding models are very helpful for part of RAG, allowing users to query text-based documents (say, a shiny app that only answers questions based on the embedding models can of course be used alone but are often implemented in concert with a chat (completions) model. |
For RAG applications, the approach elmer uses for tools might be best. I've tried to put RAG into a package ( |
Embeddings are very useful for RAG applications.
See https://ollama.com/blog/embedding-models I have also used this for openai:
I think it would make a lot of sense keep the same interface in elmer:
|
If you're interested, rollama already supports this (R package with a focus on Ollama): https://jbgruber.github.io/rollama/articles/text-embedding.html |
@JBGruber did you consider returning all the embeddings in a single matrix-column? I would suspect that might be faster to work with. |
One reason to do this in elmer is that 90% of HTTP request (e.g. error handling, rate-limiting, ...) will be the same. Implementing it in another package would require either extracting a lot of existing code or duplicating it (neither of which is particularly appealing given how young elmer is). The main reason I'm not sure about implementing in it elmer is that it would require a new API since jamming it into the chat object would be rather forced. The infrastructure is already there (i.e. this would become a new S7 method on the provider generic), but would require exporting a bunch more stuff that's currently internal (making it hard to change in the future). OTOH #202 and #167 already suggest that we need to export this stuff. |
Hi @hadley, I wanted to share my perspective on including OpenAI embeddings support in {ellmer}. I've been actively using embeddings through the {openai} package (https://github.com/irudnyts/openai). However, since that package is now archived, we're increasingly relying on {ellmer} as the go-to R interface for OpenAI's services. From my experience, embeddings are a crucial part of many AI workflows - they enable semantic search, document similarity comparisons, and other text analysis tasks that complement the core LLM capabilities. Having embeddings support directly in {ellmer} would provide a more complete and maintainable solution for the R community, especially now that {openai} is no longer actively maintained. I'd appreciate a decision on this soon, as I need to move forward with my projects. If embeddings won't be included in {ellmer}, I'll create my own wrapper for the embeddings API and could potentially develop it into a standalone package for others who might need this functionality. Thanks for considering this! |
@MarekProkop would you be interested in doing a PR to add embeddings support for at least OpenAI? It would be easier for me to commit to adding to ellmer if I didn't have to be solely responsible for it. |
@hadley I'd love to help with this! It might take me a few weeks though. |
API docs:
Sketch of embeddings with OpenAI API: embed_openai <- function(text,
model = NULL,
api_key = openai_key(),
seed = NULL,
dims = NULL,
api_args = list()) {
check_character(text)
check_string(model, allow_empty = FALSE)
provider <- ProviderOpenAI(
base_url = "https://api.openai.com/v1",
model = "",
extra_args = api_args,
api_key = api_key
)
req <- base_request(provider)
req <- req_url_path_append(req, "/embeddings")
req <- req_body_json(req, list2(
input = as.list(text),
model = model,
dimensions = dims
))
resp <- req_perform(req)
json <- resp_body_json(resp)
embeddings <- map(json$data, "[[", "embedding")
matrix(unlist(embeddings), nrow = length(text), byrow = TRUE)
} Some thoughts:
Overall that makes me think that the simplest path forward would be a separate package (at least initially). |
I recommend adding local models (Sentence Transformers, not Ollama) to that list of providers. As such, integrating reticulate in that standalone package would be great. Did |
I think continue.dev uses transformers.js to run (Though many use cases of embeddings, like the Aside, but it looks like embedding tooling is typically coupled with document parsers and text splitters to prepare strings to for embedding, and with vector stores that can store and retrieve from those. Not sure if we have those parts of the ecosystem on the R side, though obviously overlaps with a lot of non-LLM tooling. |
Hi there, I hope you are doing well
Thank you for this package you are working on, it's great!
Do you have on mind the implementation for interacting with embedding models? Or maybe you have already implemented this but I didn't find it,
Greetings,
Abraham JA
The text was updated successfully, but these errors were encountered: