@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.
Files changed (33) hide show
  1. package/README.md +572 -21
  2. package/dist/context-builder.d.ts.map +1 -1
  3. package/dist/context-builder.js +4 -0
  4. package/dist/context-builder.js.map +1 -1
  5. package/dist/index.d.ts +3 -1
  6. package/dist/index.d.ts.map +1 -1
  7. package/dist/index.js +1 -0
  8. package/dist/index.js.map +1 -1
  9. package/dist/knowledge-graph/entity-extractor.d.ts +30 -0
  10. package/dist/knowledge-graph/entity-extractor.d.ts.map +1 -0
  11. package/dist/knowledge-graph/entity-extractor.js +158 -0
  12. package/dist/knowledge-graph/entity-extractor.js.map +1 -0
  13. package/dist/knowledge-graph/graph-adapter.d.ts +56 -0
  14. package/dist/knowledge-graph/graph-adapter.d.ts.map +1 -0
  15. package/dist/knowledge-graph/graph-adapter.js +656 -0
  16. package/dist/knowledge-graph/graph-adapter.js.map +1 -0
  17. package/dist/knowledge-graph/graph-context-builder.d.ts +23 -0
  18. package/dist/knowledge-graph/graph-context-builder.d.ts.map +1 -0
  19. package/dist/knowledge-graph/graph-context-builder.js +318 -0
  20. package/dist/knowledge-graph/graph-context-builder.js.map +1 -0
  21. package/dist/knowledge-graph/index.d.ts +9 -0
  22. package/dist/knowledge-graph/index.d.ts.map +1 -0
  23. package/dist/knowledge-graph/index.js +6 -0
  24. package/dist/knowledge-graph/index.js.map +1 -0
  25. package/dist/knowledge-graph/inference-engine.d.ts +17 -0
  26. package/dist/knowledge-graph/inference-engine.d.ts.map +1 -0
  27. package/dist/knowledge-graph/inference-engine.js +270 -0
  28. package/dist/knowledge-graph/inference-engine.js.map +1 -0
  29. package/dist/knowledge-graph/schema.d.ts +854 -0
  30. package/dist/knowledge-graph/schema.d.ts.map +1 -0
  31. package/dist/knowledge-graph/schema.js +166 -0
  32. package/dist/knowledge-graph/schema.js.map +1 -0
  33. 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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"}