Skip to content
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

Open
AbrJA opened this issue Nov 21, 2024 · 10 comments
Open

Also support embedding APIs? #171

AbrJA opened this issue Nov 21, 2024 · 10 comments

Comments

@AbrJA
Copy link

AbrJA commented Nov 21, 2024

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

@hadley
Copy link
Member

hadley commented Nov 22, 2024

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?

@cboettig
Copy link

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 elmer documentation, and provides precise citations back to the URLs of doc pages from where it is drawing the answers). nice walkthrough in https://python.langchain.com/docs/tutorials/rag/.

embedding models can of course be used alone but are often implemented in concert with a chat (completions) model.

@JamesHWade
Copy link
Contributor

For RAG applications, the approach elmer uses for tools might be best. chat$register_context() or maybe chat$register_rag().

I've tried to put RAG into a package (gpttools). From that, I can appreciate the care you'd need to get the abstractions right, and I certainly haven't figured those out yet. A dedicated package makes sense. Too bad tidymodels already had the pkg name embed. Speaking of, I bet the tidymodels crew would have great ideas for how to approach it.

@jpmarindiaz
Copy link

Embeddings are very useful for RAG applications.
You can call local embeddings in ollama like this:

curl http://localhost:11434/api/embeddings -d '{
  "model": "mxbai-embed-large",
  "prompt": "Llamas are members of the camelid family"
}'

See https://ollama.com/blog/embedding-models

I have also used this for openai:

openai::create_embedding(model = "text-embedding-3-small",input = txt)

I think it would make a lot of sense keep the same interface in elmer:

chat <- chat_ollama(model = "nomic-embed-text")
chat$chat("hello nomic embedding") or chat$embedding("hello nomic embedding")

chat <- chat_openai(model = "text-embedding-3-small")
chat$chat("hello openai embedding") or chat$embedding("hello openai embedding")

@JBGruber
Copy link

JBGruber commented Dec 7, 2024

If you're interested, rollama already supports this (R package with a focus on Ollama): https://jbgruber.github.io/rollama/articles/text-embedding.html

@hadley
Copy link
Member

hadley commented Dec 9, 2024

@JBGruber did you consider returning all the embeddings in a single matrix-column? I would suspect that might be faster to work with.

@hadley hadley changed the title Embedding model implementation Also support embedding APIs? Dec 9, 2024
@hadley
Copy link
Member

hadley commented Dec 9, 2024

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.

@MarekProkop
Copy link

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!

@hadley
Copy link
Member

hadley commented Jan 5, 2025

@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.

@MarekProkop
Copy link

@hadley I'd love to help with this! It might take me a few weeks though.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

7 participants