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

Feature/llm multi prompt #1070

Open
wants to merge 4 commits into
base: main
Choose a base branch
from

Conversation

jubeless
Copy link

@jubeless jubeless commented Nov 21, 2024

This PR introduces support for multi-prompt calls in llms, while maintaining backward compatibility with the LLMChain implementation for the call function. That said we believe the default of LLMChain.Call behaviour should not flatten prompts into a single message.

Key Features

  • Add GenerateFromMultiPrompt support in llms.
  • Ensure backward compatibility for chains.Calls when using GenerateFromMultiPrompt.

Backward Compatibility

No breaking changes have been introduced. Tracing is optional and does not affect existing functionality when disabled.

PR Checklist

  • Read the Contributing documentation.
  • Read the Code of conduct documentation.
  • Name your Pull Request title clearly, concisely, and prefixed with the name of the primarily affected package you changed according to Good commit messages (such as memory: add interfaces for X, Y or util: add whizzbang helpers).
  • Check that there isn't already a PR that solves the problem the same way to avoid creating a duplicate.
  • Provide a description in this PR that addresses what the PR is solving, or reference the issue that it solves (e.g. Fixes #123).
  • Describes the source of new concepts.
  • References existing implementations as appropriate.
  • Contains test coverage for new functions.
  • Passes all golangci-lint checks.

@jubeless jubeless force-pushed the feature/llm-multi-prompt branch from 2492913 to 33faf24 Compare November 22, 2024 01:58
Fix linter errors

FIx linter comment

Added backwards compatibility
@jubeless jubeless force-pushed the feature/llm-multi-prompt branch from 33faf24 to 8724ddd Compare November 22, 2024 02:02
}

return chain
}

func (c *LLMChain) EnableMultiPrompt() {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe this should can be adjusted using a ChainCallOption?

const _llmChainDefaultOutputKey = "text"
const (
_llmChainDefaultOutputKey = "text"
_llmChainMultiPromptOutputKey = "choices"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is it necessary to change the output key of the chain by default when using multipromt?

if err != nil {
return nil, fmt.Errorf("llm generate content: %w", err)
}

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It should be documented somewhere that output parsers does not work with multiprompt.

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

Successfully merging this pull request may close these issues.

2 participants