feat: 移除记忆图系统插件,优化记忆管理器的初始化和数据目录配置
This commit is contained in:
@@ -821,6 +821,14 @@ class LongTermMemoryManager:
|
||||
if not source_id or not target_id:
|
||||
logger.warning(f"创建边失败: 缺少节点ID ({source_id} -> {target_id})")
|
||||
return
|
||||
|
||||
# 检查节点是否存在
|
||||
if not self.memory_manager.graph_store or not self.memory_manager.graph_store.graph.has_node(source_id):
|
||||
logger.warning(f"创建边失败: 源节点不存在 ({source_id})")
|
||||
return
|
||||
if not self.memory_manager.graph_store or not self.memory_manager.graph_store.graph.has_node(target_id):
|
||||
logger.warning(f"创建边失败: 目标节点不存在 ({target_id})")
|
||||
return
|
||||
|
||||
edge_id = self.memory_manager.graph_store.add_edge(
|
||||
source_id=source_id,
|
||||
|
||||
@@ -148,8 +148,13 @@ async def initialize_unified_memory_manager():
|
||||
config = global_config.memory
|
||||
|
||||
# 创建管理器实例
|
||||
# 注意:我们将 data_dir 指向 three_tier 子目录,以隔离感知/短期记忆数据
|
||||
# 同时传入全局 _memory_manager 以共享长期记忆图存储
|
||||
base_data_dir = Path(getattr(config, "data_dir", "data/memory_graph"))
|
||||
|
||||
_unified_memory_manager = UnifiedMemoryManager(
|
||||
data_dir=Path(getattr(config, "data_dir", "data/memory_graph")),
|
||||
data_dir=base_data_dir,
|
||||
memory_manager=_memory_manager,
|
||||
# 感知记忆配置
|
||||
perceptual_max_blocks=getattr(config, "perceptual_max_blocks", 50),
|
||||
perceptual_block_size=getattr(config, "perceptual_block_size", 5),
|
||||
|
||||
@@ -52,7 +52,7 @@ class PerceptualMemoryManager:
|
||||
recall_top_k: 召回时返回的最大块数
|
||||
recall_similarity_threshold: 召回的相似度阈值
|
||||
"""
|
||||
self.data_dir = data_dir or Path("data/memory_graph/three_tier")
|
||||
self.data_dir = data_dir or Path("data/memory_graph")
|
||||
self.data_dir.mkdir(parents=True, exist_ok=True)
|
||||
|
||||
# 配置参数
|
||||
|
||||
@@ -53,7 +53,7 @@ class ShortTermMemoryManager:
|
||||
transfer_importance_threshold: 转移到长期记忆的重要性阈值
|
||||
llm_temperature: LLM 决策的温度参数
|
||||
"""
|
||||
self.data_dir = data_dir or Path("data/memory_graph/three_tier")
|
||||
self.data_dir = data_dir or Path("data/memory_graph")
|
||||
self.data_dir.mkdir(parents=True, exist_ok=True)
|
||||
|
||||
# 配置参数
|
||||
|
||||
@@ -35,6 +35,7 @@ class UnifiedMemoryManager:
|
||||
def __init__(
|
||||
self,
|
||||
data_dir: Path | None = None,
|
||||
memory_manager: MemoryManager | None = None,
|
||||
# 感知记忆配置
|
||||
perceptual_max_blocks: int = 50,
|
||||
perceptual_block_size: int = 5,
|
||||
@@ -70,7 +71,7 @@ class UnifiedMemoryManager:
|
||||
long_term_auto_transfer_interval: 自动转移间隔(秒)
|
||||
judge_confidence_threshold: 裁判模型的置信度阈值
|
||||
"""
|
||||
self.data_dir = data_dir or Path("data/memory_graph/three_tier")
|
||||
self.data_dir = data_dir or Path("data/memory_graph")
|
||||
self.data_dir.mkdir(parents=True, exist_ok=True)
|
||||
|
||||
# 配置参数
|
||||
@@ -82,7 +83,7 @@ class UnifiedMemoryManager:
|
||||
self.long_term_manager: LongTermMemoryManager
|
||||
|
||||
# 底层 MemoryManager(长期记忆)
|
||||
self.memory_manager: MemoryManager
|
||||
self.memory_manager: MemoryManager = memory_manager
|
||||
|
||||
# 配置参数存储(用于初始化)
|
||||
self._config = {
|
||||
@@ -124,8 +125,17 @@ class UnifiedMemoryManager:
|
||||
logger.info("开始初始化统一记忆管理器...")
|
||||
|
||||
# 初始化底层 MemoryManager(长期记忆)
|
||||
self.memory_manager = MemoryManager(data_dir=self.data_dir.parent)
|
||||
await self.memory_manager.initialize()
|
||||
if self.memory_manager is None:
|
||||
# 如果未提供外部 MemoryManager,则创建一个新的
|
||||
# 假设 data_dir 是 three_tier 子目录,则 MemoryManager 使用父目录
|
||||
# 如果 data_dir 是根目录,则 MemoryManager 使用该目录
|
||||
self.memory_manager = MemoryManager(data_dir=self.data_dir)
|
||||
await self.memory_manager.initialize()
|
||||
else:
|
||||
logger.info("使用外部提供的 MemoryManager")
|
||||
# 确保外部 MemoryManager 已初始化
|
||||
if not getattr(self.memory_manager, "_initialized", False):
|
||||
await self.memory_manager.initialize()
|
||||
|
||||
# 初始化感知记忆层
|
||||
self.perceptual_manager = PerceptualMemoryManager(
|
||||
|
||||
Reference in New Issue
Block a user