neurotrace.core.memory¶
            neurotrace.core.memory
¶
    
            NeurotraceMemory
¶
    
              Bases: BaseMemory
A LangChain-compatible memory implementation using a hybrid memory system.
This class implements a memory system that combines short-term memory (STM) and optional long-term memory (LTM) capabilities. It wraps the ShortTermMemory component and integrates with LangChain's memory interface.
Attributes:
| Name | Type | Description | 
|---|---|---|
| session_id | str | Unique identifier for the current chat session. | 
| _stm | ShortTermMemory | Short-term memory component with token limit. | 
| _ltm | LongTermMemory | Optional long-term memory adapter for persistence. | 
Parameters:
| Name | Type | Description | Default | 
|---|---|---|---|
| max_tokens | int | Maximum number of tokens to store in short-term memory. Defaults to 2048. | 2048 | 
| history | BaseChatMessageHistory | LangChain chat history for long-term storage. If provided, enables long-term memory. Defaults to None. | None | 
| session_id | str | Identifier for the chat session. Defaults to "default". | 'default' | 
Source code in neurotrace/core/memory.py
                | 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 |  | 
            memory_variables
  
      property
  
¶
    Gets the list of memory variables used by this memory component.
Returns:
| Type | Description | 
|---|---|
| List[str] | List[str]: List containing "chat_history" as the only memory variable. | 
            clear(delete_history=False)
¶
    Clears the memory state.
Clears the short-term memory and optionally the long-term memory if specified.
Parameters:
| Name | Type | Description | Default | 
|---|---|---|---|
| delete_history | bool | If True, also clears long-term memory if it exists. Defaults to False. | False | 
Source code in neurotrace/core/memory.py
              
            load_memory_variables(inputs)
¶
    Retrieves the current memory state as LangChain messages.
Converts all messages in short-term memory to LangChain's message format for compatibility with the LangChain framework.
Parameters:
| Name | Type | Description | Default | 
|---|---|---|---|
| inputs | Dict[str, Any] | Input variables (unused in this implementation). | required | 
Returns:
| Type | Description | 
|---|---|
| Dict[str, List[BaseMessage]] | Dict[str, List[BaseMessage]]: Dictionary with "chat_history" key containing the list of messages in LangChain format. | 
Source code in neurotrace/core/memory.py
              
            save_context(inputs, outputs)
¶
    Saves the conversation context to both short-term and long-term memory.
Creates Message objects from the input and output and stores them in short-term memory. If long-term memory is enabled, also saves to it.
Parameters:
| Name | Type | Description | Default | 
|---|---|---|---|
| inputs | Dict[str, Any] | Dictionary containing user input with key "input". | required | 
| outputs | Dict[str, Any] | Dictionary containing AI output with key "output". | required |