Skip to content

Commit

Permalink
community[patch],core[minor]: Move in memory cache implementation to …
Browse files Browse the repository at this point in the history
…core (#20753)

This PR moves the InMemoryCache implementation from community to core.
  • Loading branch information
eyurtsev authored Apr 23, 2024
1 parent 4f67ce4 commit ad6b5f8
Show file tree
Hide file tree
Showing 4 changed files with 40 additions and 4 deletions.
36 changes: 35 additions & 1 deletion libs/core/langchain_core/caches.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
from __future__ import annotations

from abc import ABC, abstractmethod
from typing import Any, Optional, Sequence
from typing import Any, Dict, Optional, Sequence, Tuple

from langchain_core.outputs import Generation
from langchain_core.runnables import run_in_executor
Expand Down Expand Up @@ -105,3 +105,37 @@ async def aupdate(
async def aclear(self, **kwargs: Any) -> None:
"""Clear cache that can take additional keyword arguments."""
return await run_in_executor(None, self.clear, **kwargs)


class InMemoryCache(BaseCache):
"""Cache that stores things in memory."""

def __init__(self) -> None:
"""Initialize with empty cache."""
self._cache: Dict[Tuple[str, str], RETURN_VAL_TYPE] = {}

def lookup(self, prompt: str, llm_string: str) -> Optional[RETURN_VAL_TYPE]:
"""Look up based on prompt and llm_string."""
return self._cache.get((prompt, llm_string), None)

def update(self, prompt: str, llm_string: str, return_val: RETURN_VAL_TYPE) -> None:
"""Update cache based on prompt and llm_string."""
self._cache[(prompt, llm_string)] = return_val

def clear(self, **kwargs: Any) -> None:
"""Clear cache."""
self._cache = {}

async def alookup(self, prompt: str, llm_string: str) -> Optional[RETURN_VAL_TYPE]:
"""Look up based on prompt and llm_string."""
return self.lookup(prompt, llm_string)

async def aupdate(
self, prompt: str, llm_string: str, return_val: RETURN_VAL_TYPE
) -> None:
"""Update cache based on prompt and llm_string."""
self.update(prompt, llm_string, return_val)

async def aclear(self, **kwargs: Any) -> None:
"""Clear cache."""
self.clear()
2 changes: 1 addition & 1 deletion libs/langchain/langchain/cache.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@
)

__all__ = [
"InMemoryCache",
"FullLLMCache",
"SQLAlchemyCache",
"SQLiteCache",
Expand All @@ -27,6 +26,7 @@
"RedisSemanticCache",
"GPTCache",
"MomentoCache",
"InMemoryCache",
"CassandraCache",
"CassandraSemanticCache",
"FullMd5LLMCache",
Expand Down
3 changes: 2 additions & 1 deletion libs/langchain/tests/unit_tests/llms/test_base.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,10 @@
except ImportError:
from sqlalchemy.ext.declarative import declarative_base

from langchain_core.caches import InMemoryCache
from langchain_core.outputs import Generation, LLMResult

from langchain.cache import InMemoryCache, SQLAlchemyCache
from langchain.cache import SQLAlchemyCache
from langchain.globals import get_llm_cache, set_llm_cache
from langchain.llms.base import __all__
from tests.unit_tests.llms.fake_llm import FakeLLM
Expand Down
3 changes: 2 additions & 1 deletion libs/langchain/tests/unit_tests/test_cache.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
from _pytest.fixtures import FixtureRequest
from langchain_community.chat_models import FakeListChatModel
from langchain_community.llms import FakeListLLM
from langchain_core.caches import InMemoryCache
from langchain_core.language_models.chat_models import BaseChatModel
from langchain_core.language_models.llms import BaseLLM
from langchain_core.load import dumps
Expand All @@ -14,7 +15,7 @@
from sqlalchemy import create_engine
from sqlalchemy.orm import Session

from langchain.cache import InMemoryCache, SQLAlchemyCache
from langchain.cache import SQLAlchemyCache
from langchain.globals import get_llm_cache, set_llm_cache


Expand Down

0 comments on commit ad6b5f8

Please sign in to comment.