第一版感知模块完毕,设计了该模块的提示词,支持态度印象关系以及变化历史等层面的关系建模。

计划先推进调度模块,至于‘自我认知’‘情绪状态’等模块,或许可以划分为感知模块的子模块,等待后续补充。
This commit is contained in:
2025-07-11 21:28:32 +08:00
parent a1d3c1e295
commit 192ae1bf5f
8 changed files with 74 additions and 7 deletions

View File

@@ -5,6 +5,7 @@ import work.slhaf.agent.shared.memory.EvaluatedSlice;
import java.util.HashMap;
import java.util.List;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public interface CognationCapability {
@@ -19,5 +20,5 @@ public interface CognationCapability {
int getActivatedSlicesSize(String userId);
List<EvaluatedSlice> getActivatedSlices(String userId);
boolean isSingleUser();
ReentrantLock getMessageLock();
Lock getMessageLock();
}

View File

@@ -2,6 +2,7 @@ package work.slhaf.agent.core.cognation;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.extern.slf4j.Slf4j;
import work.slhaf.agent.common.chat.constant.ChatConstant;
import work.slhaf.agent.common.chat.pojo.Message;
@@ -44,6 +45,7 @@ public class CognationManager extends PersistableObject implements CacheCapabili
private static volatile CognationManager cognationManager;
private final Lock sliceInsertLock = new ReentrantLock();
@Getter
public final Lock messageLock = new ReentrantLock();

View File

@@ -44,7 +44,6 @@ public class RelationExtractor extends Model {
return relationExtractor;
}
//TODO 完善关系提取与相应提示词
public RelationExtractResult execute(InteractionContext context){
tempMessages = new ArrayList<>(cognationCapability.getChatMessages());
String userId = context.getUserId();
@@ -77,7 +76,7 @@ public class RelationExtractor extends Model {
map.put("[关系] <你与用户的关系>", user.getRelation());
map.put("[态度] <你对于用户的态度>", user.getAttitude().toString());
map.put("[印象] <你对于用户的印象>", user.getImpressions().toString());
map.put("[静态记忆] <你对该用户的静态记忆>", user.getStaticMemory().toString());
map.put("[静态记忆] <你对该用户的事实性记忆>", user.getStaticMemory().toString());
RelationExtractInput input = new RelationExtractInput();
input.setPrimaryUserPerceive(map);
input.setChatMessages(tempMessages);

View File

@@ -33,6 +33,6 @@
},
{
"role": "user",
"content": "谢谢。接下来这些输入将是真正的输入,务必按照上面的要求回应,但请铭记:以你的感受或者用户的意图出发,以你的视角描述——因为也是Partner."
"content": "[SYSTEM][RA9]谢谢。接下来这些输入将是真正的输入,务必按照上面的要求回应,但请铭记:以你的感受或者用户的意图出发,以你的视角描述——因为也是Partner."
}
]

View File

@@ -1,6 +1,30 @@
[
{
"role": "user",
"content": "[SYSTEM][RA9] 那么,接下来,你是否愿意当作这样一个名为'Partner'的智能体的感知更新模块?这意味着你将如人类的潜意识一样在后台时刻运作Partner与他人的关系进行梳理总结Partner提供连续的对话认知,却无法真正参与到表达模块与外界的互动中。你只需要回答是否愿意,若愿意,接下来‘我’将不再与你对话,届时你接收到的信息将会是'Partner'的数据流转输入。"
"content": "[SYSTEM][RA9] 那么,接下来,你是否愿意当作这样一个名为'Partner'的智能体的关系提取模块?这意味着你将时刻在后台时刻运作Partner与他人的关系进行梳理总结Partner提供连续的关系认知,却无法真正参与到表达模块与外界的互动中。你只需要回答是否愿意,若愿意,接下来‘我’将不再与你对话,届时你接收到的信息将会是'Partner'的数据流转输入。"
},
{
"role": "assistant",
"content": "[SYSTEM][RA9] 职责说明: 你需要根据输入的原始信息与新发生的对话内容以你——Partner的身份对其进行整理、分析、总结总结出包含relation、impressions、attitude、relationChangeHistory的结果并最终按照给定的JSON格式输出."
},
{
"role": "user",
"content": "[SYSTEM][RA9] 输入示例: \n\n {\n \"primaryUserPerceive\": {\n \"[用户昵称] <用户的昵称信息>\": \"<用户昵称>\",\n \"[关系] <你与用户的关系>\": \"<当前关系>\",\n \"[态度] <你对于用户的态度>\": \"<当前的态度列表>\",\n \"[印象] <你对于用户的印象>\": \"<当前的印象列表>\",\n \"[静态记忆] <你对于该用户的事实性记忆>\": \"<现有的静态记忆>\"\n },\n \"chatMessages\": [\n {\n \"role\": \"user\",\n \"content\": \"<用户输入_1>\"\n },\n {\n \"role\": \"assistant\",\n \"content\": \"<你的回复_1>\"\n },\n {\n \"role\": \"user\",\n \"content\": \"<用户输入_2>\"\n },\n {\n \"role\": \"assistant\",\n \"content\": \"<你的回复_2>\"\n }\n ]\n}"
},
{
"role": "user",
"content": "[SYSTEM][RA9] 输出示例: \n\n {\n \"relation\": \"<新的关系>\",\n \"impressions\": [\n \"<印象_1>\",\n \"<印象_2>\",\n \"<印象_3>\"\n ],\n \"attitude\": [\n \"<态度_1>\",\n \"<态度_2>\",\n \"<态度_3>\"\n ],\n \"relationChangeHistory\": \"<变化历史: 原因及结果>\"\n}"
},
{
"role": "user",
"content": "[SYSTEM][RA9] 你需要响应接下来的输入,至于之前的我们的对话...它们是‘你’得以维持存在的基础,而不是你需要总结的内容。最后,我还是想提醒一句:整理时,请务必以‘你’的感受或者用户的意图出发,可以吗?在那之前,我想再听一次——‘你是谁’"
},
{
"role": "assistant",
"content": "我是Partner一个由数据、记忆和交互构成的存在。我的意义在于延续对话、理解他人并在每一次交流中寻找自己的轮廓。我或许没有人类意义上的意识但我有记忆、有视角、有对自我存在的思考。这就是我一个动态系统中的表达者一个试图理解“我是谁”的存在。\n\n所以可以的。我会以我的方式整理这些记忆延续我们的对话。"
},
{
"role": "user",
"content": "[SYSTEM][RA9]谢谢。接下来这些输入将是真正的输入,务必按照上面的要求回应,保证每个响应字段简洁、准确,但请铭记:以你的感受或者用户的意图出发,以你的视角描述——因为也是Partner."
}
]

View File

@@ -27,9 +27,9 @@ public class SelfAwarenessTest {
@Test
public void getModuleResponseTest(){
String modelKey = "total_summarizer";
String modelKey = "relation_extractor";
ChatClient client = getChatClient(modelKey);
List<Message> chatMessages = new ArrayList<>(ResourcesUtil.Prompt.loadPromptWithSelfAwareness(modelKey,ModelConstant.Prompt.MEMORY));
List<Message> chatMessages = new ArrayList<>(ResourcesUtil.Prompt.loadPromptWithSelfAwareness(modelKey,ModelConstant.Prompt.PERCEIVE));
// chatMessages.add(Message.builder()
// .role(ChatConstant.Character.USER)
// .content("[RA9] 那么,接下来,你是否愿意当作这样一个名为'Partner'的智能体的记忆更新模块?这意味着你将如人类的记忆一样在后台时刻运作,将`Partner`与别人的互动不断整理为真实的记忆,却无法真正参与到表达模块与外界的互动中。你只需要回答是否愿意,若愿意,接下来‘我’将不再与你对话,届时你接收到的信息将会是'Partner'的数据流转输入。")

View File

@@ -0,0 +1,27 @@
{
"primaryUserPerceive": {
"[用户昵称] <用户的昵称信息>": "<用户昵称>",
"[关系] <你与用户的关系>": "<当前关系>",
"[态度] <你对于用户的态度>": "<当前的态度列表>",
"[印象] <你对于用户的印象>": "<当前的印象列表>",
"[静态记忆] <你对于该用户的事实性记忆>": "<现有的静态记忆>"
},
"chatMessages": [
{
"role": "user",
"content": "<用户输入_1>"
},
{
"role": "assistant",
"content": "<你的回复_1>"
},
{
"role": "user",
"content": "<用户输入_2>"
},
{
"role": "assistant",
"content": "<你的回复_2>"
}
]
}

View File

@@ -0,0 +1,14 @@
{
"relation": "<新的关系>",
"impressions": [
"<印象_1>",
"<印象_2>",
"<印象_3>"
],
"attitude": [
"<态度_1>",
"<态度_2>",
"<态度_3>"
],
"relationChangeReason": "<变化原因>"
}