anthropic.py 1.2 KB

1234567891011121314151617181920212223242526272829303132333435
  1. import logging
  2. import os
  3. from typing import Optional
  4. from embedchain.config import BaseLlmConfig
  5. from embedchain.helpers.json_serializable import register_deserializable
  6. from embedchain.llm.base import BaseLlm
  7. logger = logging.getLogger(__name__)
  8. @register_deserializable
  9. class AnthropicLlm(BaseLlm):
  10. def __init__(self, config: Optional[BaseLlmConfig] = None):
  11. if "ANTHROPIC_API_KEY" not in os.environ:
  12. raise ValueError("Please set the ANTHROPIC_API_KEY environment variable.")
  13. super().__init__(config=config)
  14. def get_llm_model_answer(self, prompt):
  15. return AnthropicLlm._get_answer(prompt=prompt, config=self.config)
  16. @staticmethod
  17. def _get_answer(prompt: str, config: BaseLlmConfig) -> str:
  18. from langchain_community.chat_models import ChatAnthropic
  19. chat = ChatAnthropic(
  20. anthropic_api_key=os.environ["ANTHROPIC_API_KEY"], temperature=config.temperature, model=config.model
  21. )
  22. if config.max_tokens and config.max_tokens != 1000:
  23. logger.warning("Config option `max_tokens` is not supported by this model.")
  24. messages = BaseLlm._get_messages(prompt, system_prompt=config.system_prompt)
  25. return chat(messages).content