@cogitator-ai/memory 0.2.0 → 0.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +572 -21
- package/dist/context-builder.d.ts.map +1 -1
- package/dist/context-builder.js +4 -0
- package/dist/context-builder.js.map +1 -1
- package/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/knowledge-graph/entity-extractor.d.ts +30 -0
- package/dist/knowledge-graph/entity-extractor.d.ts.map +1 -0
- package/dist/knowledge-graph/entity-extractor.js +158 -0
- package/dist/knowledge-graph/entity-extractor.js.map +1 -0
- package/dist/knowledge-graph/graph-adapter.d.ts +56 -0
- package/dist/knowledge-graph/graph-adapter.d.ts.map +1 -0
- package/dist/knowledge-graph/graph-adapter.js +656 -0
- package/dist/knowledge-graph/graph-adapter.js.map +1 -0
- package/dist/knowledge-graph/graph-context-builder.d.ts +23 -0
- package/dist/knowledge-graph/graph-context-builder.d.ts.map +1 -0
- package/dist/knowledge-graph/graph-context-builder.js +318 -0
- package/dist/knowledge-graph/graph-context-builder.js.map +1 -0
- package/dist/knowledge-graph/index.d.ts +9 -0
- package/dist/knowledge-graph/index.d.ts.map +1 -0
- package/dist/knowledge-graph/index.js +6 -0
- package/dist/knowledge-graph/index.js.map +1 -0
- package/dist/knowledge-graph/inference-engine.d.ts +17 -0
- package/dist/knowledge-graph/inference-engine.d.ts.map +1 -0
- package/dist/knowledge-graph/inference-engine.js +270 -0
- package/dist/knowledge-graph/inference-engine.js.map +1 -0
- package/dist/knowledge-graph/schema.d.ts +854 -0
- package/dist/knowledge-graph/schema.d.ts.map +1 -0
- package/dist/knowledge-graph/schema.js +166 -0
- package/dist/knowledge-graph/schema.js.map +1 -0
- package/package.json +3 -3
|
@@ -0,0 +1,270 @@
|
|
|
1
|
+
import { nanoid } from 'nanoid';
|
|
2
|
+
const DEFAULT_RULES = [
|
|
3
|
+
{
|
|
4
|
+
name: 'transitive_knows',
|
|
5
|
+
description: 'If A knows B and B knows C, then A is related to C',
|
|
6
|
+
pattern: {
|
|
7
|
+
edgeTypes: ['knows', 'knows'],
|
|
8
|
+
minPathLength: 2,
|
|
9
|
+
maxPathLength: 2,
|
|
10
|
+
},
|
|
11
|
+
conclusion: {
|
|
12
|
+
edgeType: 'related_to',
|
|
13
|
+
label: 'indirect_connection',
|
|
14
|
+
weightFormula: 'min',
|
|
15
|
+
bidirectional: true,
|
|
16
|
+
},
|
|
17
|
+
confidence: 0.6,
|
|
18
|
+
enabled: true,
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
name: 'colleagues',
|
|
22
|
+
description: 'People who work at the same organization are colleagues',
|
|
23
|
+
pattern: {
|
|
24
|
+
edgeTypes: ['works_at', 'works_at'],
|
|
25
|
+
minPathLength: 2,
|
|
26
|
+
maxPathLength: 2,
|
|
27
|
+
nodeTypeConstraints: {
|
|
28
|
+
0: ['person'],
|
|
29
|
+
1: ['organization'],
|
|
30
|
+
2: ['person'],
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
conclusion: {
|
|
34
|
+
edgeType: 'associated_with',
|
|
35
|
+
label: 'colleague',
|
|
36
|
+
weightFormula: 'min',
|
|
37
|
+
bidirectional: true,
|
|
38
|
+
},
|
|
39
|
+
confidence: 0.8,
|
|
40
|
+
enabled: true,
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
name: 'location_hierarchy',
|
|
44
|
+
description: 'Transitive location containment',
|
|
45
|
+
pattern: {
|
|
46
|
+
edgeTypes: ['located_in', 'located_in'],
|
|
47
|
+
minPathLength: 2,
|
|
48
|
+
maxPathLength: 3,
|
|
49
|
+
nodeTypeConstraints: {
|
|
50
|
+
0: ['location', 'organization', 'person'],
|
|
51
|
+
1: ['location'],
|
|
52
|
+
2: ['location'],
|
|
53
|
+
},
|
|
54
|
+
},
|
|
55
|
+
conclusion: {
|
|
56
|
+
edgeType: 'located_in',
|
|
57
|
+
weightFormula: 'product',
|
|
58
|
+
bidirectional: false,
|
|
59
|
+
},
|
|
60
|
+
confidence: 0.9,
|
|
61
|
+
enabled: true,
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
name: 'part_of_hierarchy',
|
|
65
|
+
description: 'Transitive part-of relationship',
|
|
66
|
+
pattern: {
|
|
67
|
+
edgeTypes: ['part_of', 'part_of'],
|
|
68
|
+
minPathLength: 2,
|
|
69
|
+
maxPathLength: 3,
|
|
70
|
+
},
|
|
71
|
+
conclusion: {
|
|
72
|
+
edgeType: 'part_of',
|
|
73
|
+
weightFormula: 'product',
|
|
74
|
+
bidirectional: false,
|
|
75
|
+
},
|
|
76
|
+
confidence: 0.85,
|
|
77
|
+
enabled: true,
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
name: 'causality_chain',
|
|
81
|
+
description: 'If A causes B and B causes C, then A indirectly causes C',
|
|
82
|
+
pattern: {
|
|
83
|
+
edgeTypes: ['causes', 'causes'],
|
|
84
|
+
minPathLength: 2,
|
|
85
|
+
maxPathLength: 2,
|
|
86
|
+
},
|
|
87
|
+
conclusion: {
|
|
88
|
+
edgeType: 'causes',
|
|
89
|
+
label: 'indirect_cause',
|
|
90
|
+
weightFormula: 'product',
|
|
91
|
+
bidirectional: false,
|
|
92
|
+
},
|
|
93
|
+
confidence: 0.7,
|
|
94
|
+
enabled: true,
|
|
95
|
+
},
|
|
96
|
+
];
|
|
97
|
+
export class GraphInferenceEngine {
|
|
98
|
+
rules = new Map();
|
|
99
|
+
graphAdapter;
|
|
100
|
+
constructor(graphAdapter, useDefaultRules = true) {
|
|
101
|
+
this.graphAdapter = graphAdapter;
|
|
102
|
+
if (useDefaultRules) {
|
|
103
|
+
for (const rule of DEFAULT_RULES) {
|
|
104
|
+
this.registerRule(rule);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
registerRule(rule) {
|
|
109
|
+
const id = `rule_${nanoid(8)}`;
|
|
110
|
+
this.rules.set(id, { ...rule, id });
|
|
111
|
+
return id;
|
|
112
|
+
}
|
|
113
|
+
removeRule(ruleId) {
|
|
114
|
+
this.rules.delete(ruleId);
|
|
115
|
+
}
|
|
116
|
+
getRules() {
|
|
117
|
+
return Array.from(this.rules.values());
|
|
118
|
+
}
|
|
119
|
+
enableRule(ruleId) {
|
|
120
|
+
const rule = this.rules.get(ruleId);
|
|
121
|
+
if (rule) {
|
|
122
|
+
rule.enabled = true;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
disableRule(ruleId) {
|
|
126
|
+
const rule = this.rules.get(ruleId);
|
|
127
|
+
if (rule) {
|
|
128
|
+
rule.enabled = false;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
async infer(agentId, options) {
|
|
132
|
+
const inferred = [];
|
|
133
|
+
const seenPairs = new Set();
|
|
134
|
+
const rulesToApply = options?.ruleIds
|
|
135
|
+
? Array.from(this.rules.values()).filter((r) => options.ruleIds.includes(r.id))
|
|
136
|
+
: Array.from(this.rules.values()).filter((r) => r.enabled);
|
|
137
|
+
for (const rule of rulesToApply) {
|
|
138
|
+
const ruleInferences = await this.applyRule(agentId, rule, options);
|
|
139
|
+
for (const edge of ruleInferences) {
|
|
140
|
+
const pairKey = `${edge.sourceNodeId}:${edge.targetNodeId}:${edge.type}`;
|
|
141
|
+
const reversePairKey = `${edge.targetNodeId}:${edge.sourceNodeId}:${edge.type}`;
|
|
142
|
+
if (!seenPairs.has(pairKey) && !seenPairs.has(reversePairKey)) {
|
|
143
|
+
inferred.push(edge);
|
|
144
|
+
seenPairs.add(pairKey);
|
|
145
|
+
if (edge.bidirectional) {
|
|
146
|
+
seenPairs.add(reversePairKey);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
if (options?.maxInferences && inferred.length >= options.maxInferences) {
|
|
150
|
+
return inferred;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
return inferred;
|
|
155
|
+
}
|
|
156
|
+
async applyRule(agentId, rule, options) {
|
|
157
|
+
const inferred = [];
|
|
158
|
+
const firstEdgeType = rule.pattern.edgeTypes[0];
|
|
159
|
+
const edgesResult = await this.graphAdapter.queryEdges({
|
|
160
|
+
agentId,
|
|
161
|
+
types: [firstEdgeType],
|
|
162
|
+
minConfidence: options?.minConfidence,
|
|
163
|
+
});
|
|
164
|
+
if (!edgesResult.success)
|
|
165
|
+
return inferred;
|
|
166
|
+
for (const startEdge of edgesResult.data) {
|
|
167
|
+
if (options?.nodeFilter && !options.nodeFilter.includes(startEdge.sourceNodeId)) {
|
|
168
|
+
continue;
|
|
169
|
+
}
|
|
170
|
+
const paths = await this.findMatchingPaths(agentId, startEdge, rule.pattern.edgeTypes.slice(1), rule.pattern.maxPathLength, rule.pattern.nodeTypeConstraints, options?.minConfidence);
|
|
171
|
+
for (const path of paths) {
|
|
172
|
+
if (path.length < rule.pattern.minPathLength)
|
|
173
|
+
continue;
|
|
174
|
+
const allEdges = [startEdge, ...path];
|
|
175
|
+
const sourceNodeId = startEdge.sourceNodeId;
|
|
176
|
+
const targetNodeId = path[path.length - 1].targetNodeId;
|
|
177
|
+
if (sourceNodeId === targetNodeId)
|
|
178
|
+
continue;
|
|
179
|
+
const existingEdges = await this.graphAdapter.getEdgesBetween(sourceNodeId, targetNodeId);
|
|
180
|
+
if (existingEdges.success &&
|
|
181
|
+
existingEdges.data.some((e) => e.type === rule.conclusion.edgeType)) {
|
|
182
|
+
continue;
|
|
183
|
+
}
|
|
184
|
+
const weight = this.calculateWeight(allEdges, rule.conclusion.weightFormula);
|
|
185
|
+
const confidence = Math.min(rule.confidence, ...allEdges.map((e) => e.confidence));
|
|
186
|
+
if (options?.minConfidence && confidence < options.minConfidence)
|
|
187
|
+
continue;
|
|
188
|
+
inferred.push({
|
|
189
|
+
agentId,
|
|
190
|
+
sourceNodeId,
|
|
191
|
+
targetNodeId,
|
|
192
|
+
type: rule.conclusion.edgeType,
|
|
193
|
+
label: rule.conclusion.label,
|
|
194
|
+
weight,
|
|
195
|
+
bidirectional: rule.conclusion.bidirectional,
|
|
196
|
+
properties: {},
|
|
197
|
+
confidence,
|
|
198
|
+
source: 'inferred',
|
|
199
|
+
ruleId: rule.id,
|
|
200
|
+
supportingPath: allEdges.map((e) => e.id),
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
return inferred;
|
|
205
|
+
}
|
|
206
|
+
async findMatchingPaths(agentId, currentEdge, remainingTypes, maxDepth, nodeTypeConstraints, minConfidence, currentDepth = 1) {
|
|
207
|
+
if (remainingTypes.length === 0 || currentDepth >= maxDepth) {
|
|
208
|
+
return [[]];
|
|
209
|
+
}
|
|
210
|
+
const nextType = remainingTypes[0];
|
|
211
|
+
const currentNodeId = currentEdge.targetNodeId;
|
|
212
|
+
if (nodeTypeConstraints?.[currentDepth]) {
|
|
213
|
+
const nodeResult = await this.graphAdapter.getNode(currentNodeId);
|
|
214
|
+
if (nodeResult.success && nodeResult.data) {
|
|
215
|
+
const allowedTypes = nodeTypeConstraints[currentDepth];
|
|
216
|
+
if (!allowedTypes.includes(nodeResult.data.type)) {
|
|
217
|
+
return [];
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
const nextEdgesResult = await this.graphAdapter.queryEdges({
|
|
222
|
+
agentId,
|
|
223
|
+
sourceNodeId: currentNodeId,
|
|
224
|
+
types: [nextType],
|
|
225
|
+
minConfidence,
|
|
226
|
+
});
|
|
227
|
+
if (!nextEdgesResult.success)
|
|
228
|
+
return [];
|
|
229
|
+
const paths = [];
|
|
230
|
+
for (const nextEdge of nextEdgesResult.data) {
|
|
231
|
+
const subPaths = await this.findMatchingPaths(agentId, nextEdge, remainingTypes.slice(1), maxDepth, nodeTypeConstraints, minConfidence, currentDepth + 1);
|
|
232
|
+
for (const subPath of subPaths) {
|
|
233
|
+
paths.push([nextEdge, ...subPath]);
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
return paths;
|
|
237
|
+
}
|
|
238
|
+
calculateWeight(edges, formula) {
|
|
239
|
+
const weights = edges.map((e) => e.weight);
|
|
240
|
+
switch (formula) {
|
|
241
|
+
case 'min':
|
|
242
|
+
return Math.min(...weights);
|
|
243
|
+
case 'max':
|
|
244
|
+
return Math.max(...weights);
|
|
245
|
+
case 'average':
|
|
246
|
+
return weights.reduce((a, b) => a + b, 0) / weights.length;
|
|
247
|
+
case 'product':
|
|
248
|
+
return weights.reduce((a, b) => a * b, 1);
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
async materialize(edges) {
|
|
252
|
+
const materialized = [];
|
|
253
|
+
for (const edge of edges) {
|
|
254
|
+
const { ruleId, supportingPath, ...edgeData } = edge;
|
|
255
|
+
const result = await this.graphAdapter.addEdge({
|
|
256
|
+
...edgeData,
|
|
257
|
+
metadata: {
|
|
258
|
+
...edgeData.metadata,
|
|
259
|
+
inferredBy: ruleId,
|
|
260
|
+
supportingPath,
|
|
261
|
+
},
|
|
262
|
+
});
|
|
263
|
+
if (result.success) {
|
|
264
|
+
materialized.push(result.data);
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
return { success: true, data: materialized };
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
//# sourceMappingURL=inference-engine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inference-engine.js","sourceRoot":"","sources":["../../src/knowledge-graph/inference-engine.ts"],"names":[],"mappings":"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"}
|