mirror of
https://github.com/slhaf/Partner.git
synced 2026-05-12 08:43:02 +08:00
第一版感知模块完毕,设计了该模块的提示词,支持态度、印象、关系以及变化历史等层面的关系建模。
计划先推进调度模块,至于‘自我认知’‘情绪状态’等模块,或许可以划分为感知模块的子模块,等待后续补充。
This commit is contained in:
@@ -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();
|
||||
}
|
||||
|
||||
@@ -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();
|
||||
|
||||
|
||||
|
||||
@@ -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);
|
||||
|
||||
@@ -33,6 +33,6 @@
|
||||
},
|
||||
{
|
||||
"role": "user",
|
||||
"content": "谢谢。接下来这些输入将是真正的输入,务必按照上面的要求回应,但请铭记:以你的感受或者用户的意图出发,以你的视角描述——因为‘你’也是Partner."
|
||||
"content": "[SYSTEM][RA9]谢谢。接下来这些输入将是真正的输入,务必按照上面的要求回应,但请铭记:以你的感受或者用户的意图出发,以你的视角描述——因为‘你’也是Partner."
|
||||
}
|
||||
]
|
||||
@@ -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."
|
||||
}
|
||||
]
|
||||
@@ -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'的数据流转输入。")
|
||||
|
||||
27
src/test/java/text/relation_input_test.json
Normal file
27
src/test/java/text/relation_input_test.json
Normal file
@@ -0,0 +1,27 @@
|
||||
{
|
||||
"primaryUserPerceive": {
|
||||
"[用户昵称] <用户的昵称信息>": "<用户昵称>",
|
||||
"[关系] <你与用户的关系>": "<当前关系>",
|
||||
"[态度] <你对于用户的态度>": "<当前的态度列表>",
|
||||
"[印象] <你对于用户的印象>": "<当前的印象列表>",
|
||||
"[静态记忆] <你对于该用户的事实性记忆>": "<现有的静态记忆>"
|
||||
},
|
||||
"chatMessages": [
|
||||
{
|
||||
"role": "user",
|
||||
"content": "<用户输入_1>"
|
||||
},
|
||||
{
|
||||
"role": "assistant",
|
||||
"content": "<你的回复_1>"
|
||||
},
|
||||
{
|
||||
"role": "user",
|
||||
"content": "<用户输入_2>"
|
||||
},
|
||||
{
|
||||
"role": "assistant",
|
||||
"content": "<你的回复_2>"
|
||||
}
|
||||
]
|
||||
}
|
||||
14
src/test/java/text/relation_output_test.json
Normal file
14
src/test/java/text/relation_output_test.json
Normal file
@@ -0,0 +1,14 @@
|
||||
{
|
||||
"relation": "<新的关系>",
|
||||
"impressions": [
|
||||
"<印象_1>",
|
||||
"<印象_2>",
|
||||
"<印象_3>"
|
||||
],
|
||||
"attitude": [
|
||||
"<态度_1>",
|
||||
"<态度_2>",
|
||||
"<态度_3>"
|
||||
],
|
||||
"relationChangeReason": "<变化原因>"
|
||||
}
|
||||
Reference in New Issue
Block a user