diff --git a/agent_loop.py b/agent_loop.py
index 8516c48..1c3e6bc 100644
--- a/agent_loop.py
+++ b/agent_loop.py
@@ -73,5 +73,9 @@ def agent_runner_loop(client, system_prompt, user_input, handler, tools_schema,
datastr = json.dumps(outcome.data, ensure_ascii=False, default=json_default) if type(outcome.data) in [dict, list] else str(outcome.data)
next_prompt += f"\n{datastr}\n\n\n"
next_prompt += outcome.next_prompt
+ if (turn+1) % 5 == 0:
+ next_prompt += f"\n\n[DANGER] 已连续执行第 {turn+1} 轮。禁止无效重试。若无有效进展,必须切换策略:1. 探测物理边界 2. 请求用户协助。"
+ if turn == 23:
+ next_prompt += f"\n\n[DANGER] 已连续执行第 {turn+1} 轮。你必须总结情况进行ask_user,不允许继续重试。"
messages = [{"role": "user", "content": next_prompt}]
return {'result': 'MAX_TURNS_EXCEEDED'}
\ No newline at end of file
diff --git a/assets/tools_schema.json b/assets/tools_schema.json
index c52288b..0611135 100644
--- a/assets/tools_schema.json
+++ b/assets/tools_schema.json
@@ -47,11 +47,11 @@
"save_to_file": {"type": "string", "description": "可选。将 JS 执行结果(js_return)保存到的文件路径。注意:该功能不支持 await 等异步结果。"}}, "required": ["script"]}
}},
{"type": "function", "function": {
- "name": "update_sop_plan",
- "description": "【在读取SOP后需要调用】准备开始执行此SOP。提取容易遗忘但关键的内容,生成极简检查清单,100tokens以内,后续每轮自动注入context。特别是靠后的内容。",
+ "name": "update_working_mem",
+ "description": "更新当前任务的工作记忆。当任务目标细化、阶段切换或发现关键物理约束(坑)时调用,内容将作为物理锚点在后续每轮自动注入,强行锁定推理方向,防止长程任务逻辑漂移。",
"parameters": {"type": "object", "properties": {
- "keys": {"type": "string", "description": "每轮自动注入的必须注意的文本,可以是约束规则/执行步骤/需要注意的坑"},
- "sop_path": {"type": "string", "description": "sop路径,必要时可以再读"}}}
+ "key_info": {"type": "string", "description": "替换掉当前的极简关键信息(200tokens以内),包含当前进度和目标、已获取的关键信息及下一步必须绕过的坑,已经解决或完成的步骤可以去掉"},
+ "related_sop": {"type": "string", "description": "相关sop名称,可以多个,必要时需要再读"}}}
}},
{"type": "function", "function": {
"name": "ask_user",
@@ -62,7 +62,7 @@
}},
{"type": "function", "function": {
"name": "trigger_memory_update",
- "description": "用户的任务完成后,若发现值得长期记忆的信息(环境事实/用户偏好/避坑经验),调用此工具触发记忆提炼。不允许在记忆更新或自主流程内调用。",
+ "description": "若发现值得长期记忆的信息(环境事实/用户偏好/避坑经验),调用此工具触发记忆提炼。一次用户对话只允许调用一次,严禁在记忆更新或自主流程内调用。",
"parameters": {"type": "object", "properties": {}}}
}
]
\ No newline at end of file
diff --git a/ga.py b/ga.py
index f172a05..9d2123b 100644
--- a/ga.py
+++ b/ga.py
@@ -241,8 +241,8 @@ class GenericAgentHandler(BaseHandler):
'''
def __init__(self, parent, last_history=None, cwd='./'):
self.parent = parent
- self.sop_keys = ""
- self.sop_path = ""
+ self.key_info = ""
+ self.related_sop = ""
self.cwd = cwd
self.history_info = last_history if last_history else []
self.code_stop_signal = []
@@ -382,19 +382,19 @@ class GenericAgentHandler(BaseHandler):
result = tips + result
next_prompt = self._get_anchor_prompt()
if 'memory' in path or 'sop' in path:
- next_prompt += "\nPROTOCOL: 你正在读取记忆或SOP文件,若决定按sop执行请先调用准备执行相关工具,提取sop中的重点内容(特别是靠后的)进入工作记忆。"
+ next_prompt += "\nPROTOCOL: 你正在读取记忆或SOP文件,若决定按sop执行请先调用相关工具提取sop中的关键点(特别是靠后的)进入工作记忆。"
return StepOutcome(result, next_prompt=next_prompt)
- def do_update_sop_plan(self, args, response):
+ def do_update_working_mem(self, args, response):
'''读取完sop后,为整个任务设定后续需要临时记忆的重点。
'''
- sop_keys = args.get("keys", "")
- sop_path = args.get("sop_path", "")
- if sop_keys: self.sop_keys = sop_keys
- if sop_path: self.sop_path = sop_path
- yield f"[Info] Updated sop_keys and sop_path.\n"
- yield f"sop_keys:\n{self.sop_keys}\n\n"
- yield f"sop_path:\n{self.sop_path}\n\n"
+ key_info = args.get("key_info", "")
+ related_sop = args.get("related_sop", "")
+ if key_info: self.key_info = key_info
+ if related_sop: self.related_sop = related_sop
+ yield f"[Info] Updated key_info and related_sop.\n"
+ yield f"key_info:\n{self.key_info}\n\n"
+ yield f"related_sop:\n{self.related_sop}\n\n"
next_prompt = self._get_anchor_prompt()
return StepOutcome({"status": "success"}, next_prompt=next_prompt)
@@ -458,8 +458,8 @@ class GenericAgentHandler(BaseHandler):
def _get_anchor_prompt(self):
h_str = "\n".join(self.history_info[-20:])
prompt = f"\n### [WORKING MEMORY]\n\n{h_str}\n"
- if self.sop_keys: prompt += f"\n{self.sop_keys}"
- if self.sop_path: prompt += f"\n有不清晰的地方请再次读取{self.sop_path}"
+ if self.key_info: prompt += f"\n{self.key_info}"
+ if self.related_sop: prompt += f"\n有不清晰的地方请再次读取{self.related_sop}"
print(prompt)
return prompt