llmemory 0.1.7 → 0.1.8
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.
- checksums.yaml +4 -4
- data/lib/llmemory/cli/commands/long_term/edges.rb +1 -1
- data/lib/llmemory/cli/commands/long_term/graph.rb +1 -1
- data/lib/llmemory/dashboard/app/views/llmemory/dashboard/graph/index.html.erb +1 -1
- data/lib/llmemory/long_term/graph_based/conflict_resolver.rb +2 -2
- data/lib/llmemory/long_term/graph_based/edge.rb +3 -3
- data/lib/llmemory/long_term/graph_based/knowledge_graph.rb +2 -2
- data/lib/llmemory/long_term/graph_based/memory.rb +2 -2
- data/lib/llmemory/long_term/graph_based/storages/active_record_storage.rb +3 -3
- data/lib/llmemory/long_term/graph_based/storages/memory_storage.rb +3 -3
- data/lib/llmemory/version.rb +1 -1
- metadata +1 -1
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 63dd1fafe3af80e9a86be5da51e3ef4dbb6254cc0ebad341bed240875f539ebf
|
|
4
|
+
data.tar.gz: 6da8ed10591ed7c88a1be6b33ba30eff780d388cf146750f070518a1748f9f92
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 527c5e19c2f53299e966c7c8d8e2b004375a99ab58f726d50b23bac88d015a3c8eb48ddbb00da1f536522122c782c754110dedb77f698a721a058227cb5e8bee
|
|
7
|
+
data.tar.gz: e7cd4cfbb1dcb805687de7217b84299f130ac941edd97a39de4d7deba784a3e45e4944e2ae6fd07ff0da433bdc6f2c7227b7fc84130be1848adc7ccbc888fda9
|
|
@@ -32,7 +32,7 @@ module Llmemory
|
|
|
32
32
|
id = e.respond_to?(:id) ? e.id : e[:id]
|
|
33
33
|
subj = e.respond_to?(:subject_id) ? e.subject_id : e[:subject_id]
|
|
34
34
|
pred = e.respond_to?(:predicate) ? e.predicate : e[:predicate]
|
|
35
|
-
obj = e.respond_to?(:
|
|
35
|
+
obj = e.respond_to?(:target_id) ? e.target_id : e[:object_id]
|
|
36
36
|
puts "#{id}: #{subj} --#{pred}--> #{obj}"
|
|
37
37
|
end
|
|
38
38
|
end
|
|
@@ -62,7 +62,7 @@ module Llmemory
|
|
|
62
62
|
end
|
|
63
63
|
edges.each do |e|
|
|
64
64
|
subj = e.respond_to?(:subject_id) ? e.subject_id : e[:subject_id]
|
|
65
|
-
obj = e.respond_to?(:
|
|
65
|
+
obj = e.respond_to?(:target_id) ? e.target_id : e[:object_id]
|
|
66
66
|
pred = e.respond_to?(:predicate) ? e.predicate : e[:predicate]
|
|
67
67
|
lines << " \"#{subj}\" -> \"#{obj}\" [label=\"#{pred}\"];"
|
|
68
68
|
end
|
|
@@ -32,7 +32,7 @@
|
|
|
32
32
|
<tr>
|
|
33
33
|
<td><%= e.respond_to?(:subject_id) ? e.subject_id : e[:subject_id] %></td>
|
|
34
34
|
<td><%= e.respond_to?(:predicate) ? e.predicate : e[:predicate] %></td>
|
|
35
|
-
<td><%= e.respond_to?(:
|
|
35
|
+
<td><%= e.respond_to?(:target_id) ? e.target_id : e[:object_id] %></td>
|
|
36
36
|
</tr>
|
|
37
37
|
<% end %>
|
|
38
38
|
</tbody>
|
|
@@ -17,9 +17,9 @@ module Llmemory
|
|
|
17
17
|
|
|
18
18
|
subject_id = new_edge.subject_id
|
|
19
19
|
existing = @graph.find_edges(subject: subject_id, predicate: new_edge.predicate, include_archived: false)
|
|
20
|
-
to_archive = existing.reject { |e| e.
|
|
20
|
+
to_archive = existing.reject { |e| e.target_id == new_edge.target_id }
|
|
21
21
|
to_archive.each do |e|
|
|
22
|
-
@graph.archive_edge(e.id, reason: "replaced by #{new_edge.
|
|
22
|
+
@graph.archive_edge(e.id, reason: "replaced by #{new_edge.target_id}")
|
|
23
23
|
end
|
|
24
24
|
to_archive.map(&:id)
|
|
25
25
|
end
|
|
@@ -8,7 +8,7 @@ module Llmemory
|
|
|
8
8
|
:user_id,
|
|
9
9
|
:subject_id,
|
|
10
10
|
:predicate,
|
|
11
|
-
:
|
|
11
|
+
:target_id,
|
|
12
12
|
:properties,
|
|
13
13
|
:created_at,
|
|
14
14
|
:archived_at,
|
|
@@ -20,7 +20,7 @@ module Llmemory
|
|
|
20
20
|
user_id: hash[:user_id] || hash["user_id"],
|
|
21
21
|
subject_id: hash[:subject_id] || hash["subject_id"],
|
|
22
22
|
predicate: (hash[:predicate] || hash["predicate"]).to_s,
|
|
23
|
-
|
|
23
|
+
target_id: hash[:object_id] || hash["object_id"],
|
|
24
24
|
properties: hash[:properties] || hash["properties"] || {},
|
|
25
25
|
created_at: hash[:created_at] || hash["created_at"],
|
|
26
26
|
archived_at: hash[:archived_at] || hash["archived_at"]
|
|
@@ -37,7 +37,7 @@ module Llmemory
|
|
|
37
37
|
user_id: user_id,
|
|
38
38
|
subject_id: subject_id,
|
|
39
39
|
predicate: predicate,
|
|
40
|
-
object_id:
|
|
40
|
+
object_id: target_id,
|
|
41
41
|
properties: properties || {},
|
|
42
42
|
created_at: created_at,
|
|
43
43
|
archived_at: archived_at
|
|
@@ -49,7 +49,7 @@ module Llmemory
|
|
|
49
49
|
user_id: @user_id,
|
|
50
50
|
subject_id: subject_id,
|
|
51
51
|
predicate: predicate.to_s,
|
|
52
|
-
|
|
52
|
+
target_id: object_id,
|
|
53
53
|
properties: properties,
|
|
54
54
|
created_at: Time.now,
|
|
55
55
|
archived_at: nil
|
|
@@ -87,7 +87,7 @@ module Llmemory
|
|
|
87
87
|
edges = @storage.find_edges(@user_id, subject_id: node_id, include_archived: false)
|
|
88
88
|
edges.each do |e|
|
|
89
89
|
result_edges << e
|
|
90
|
-
queue << [e.
|
|
90
|
+
queue << [e.target_id, d + 1] unless visited[e.target_id]
|
|
91
91
|
end
|
|
92
92
|
edges_out = @storage.find_edges(@user_id, object_id: node_id, include_archived: false)
|
|
93
93
|
edges_out.each do |e|
|
|
@@ -38,7 +38,7 @@ module Llmemory
|
|
|
38
38
|
user_id: @user_id,
|
|
39
39
|
subject_id: subject_id,
|
|
40
40
|
predicate: r[:predicate],
|
|
41
|
-
|
|
41
|
+
target_id: object_id,
|
|
42
42
|
properties: {},
|
|
43
43
|
created_at: Time.now,
|
|
44
44
|
archived_at: nil
|
|
@@ -109,7 +109,7 @@ module Llmemory
|
|
|
109
109
|
traversed = @kg.traverse(start_node: node, depth: 1)
|
|
110
110
|
traversed[:edges].each do |e|
|
|
111
111
|
subj = @kg.find_node_by_id(e.subject_id)
|
|
112
|
-
obj = @kg.find_node_by_id(e.
|
|
112
|
+
obj = @kg.find_node_by_id(e.target_id)
|
|
113
113
|
edge_text = "#{subj&.name} #{e.predicate} #{obj&.name}"
|
|
114
114
|
out << { text: edge_text, score: 0.85, created_at: e.created_at } unless out.any? { |o| o[:text] == edge_text }
|
|
115
115
|
end
|
|
@@ -70,7 +70,7 @@ module Llmemory
|
|
|
70
70
|
rec.update!(
|
|
71
71
|
subject_id: e.subject_id,
|
|
72
72
|
predicate: e.predicate,
|
|
73
|
-
object_id: e.
|
|
73
|
+
object_id: e.target_id,
|
|
74
74
|
properties: e.properties || {}
|
|
75
75
|
)
|
|
76
76
|
else
|
|
@@ -79,7 +79,7 @@ module Llmemory
|
|
|
79
79
|
user_id: user_id,
|
|
80
80
|
subject_id: e.subject_id,
|
|
81
81
|
predicate: e.predicate,
|
|
82
|
-
object_id: e.
|
|
82
|
+
object_id: e.target_id,
|
|
83
83
|
properties: e.properties || {}
|
|
84
84
|
)
|
|
85
85
|
end
|
|
@@ -142,7 +142,7 @@ module Llmemory
|
|
|
142
142
|
user_id: r.user_id,
|
|
143
143
|
subject_id: r.subject_id,
|
|
144
144
|
predicate: r.predicate,
|
|
145
|
-
|
|
145
|
+
target_id: r.object_id,
|
|
146
146
|
properties: r.properties || {},
|
|
147
147
|
created_at: r.created_at,
|
|
148
148
|
archived_at: r.archived_at
|
|
@@ -58,7 +58,7 @@ module Llmemory
|
|
|
58
58
|
user_id: user_id,
|
|
59
59
|
subject_id: e.subject_id,
|
|
60
60
|
predicate: e.predicate,
|
|
61
|
-
|
|
61
|
+
target_id: e.target_id,
|
|
62
62
|
properties: e.properties || {},
|
|
63
63
|
created_at: e.created_at || Time.now,
|
|
64
64
|
archived_at: nil
|
|
@@ -78,7 +78,7 @@ module Llmemory
|
|
|
78
78
|
next false unless include_archived || !e.archived?
|
|
79
79
|
next false if subject_id && e.subject_id != subject_id
|
|
80
80
|
next false if predicate && e.predicate != predicate.to_s
|
|
81
|
-
next false if object_id && e.
|
|
81
|
+
next false if object_id && e.target_id != object_id
|
|
82
82
|
true
|
|
83
83
|
end
|
|
84
84
|
list
|
|
@@ -94,7 +94,7 @@ module Llmemory
|
|
|
94
94
|
user_id: e.user_id,
|
|
95
95
|
subject_id: e.subject_id,
|
|
96
96
|
predicate: e.predicate,
|
|
97
|
-
|
|
97
|
+
target_id: e.target_id,
|
|
98
98
|
properties: e.properties,
|
|
99
99
|
created_at: e.created_at,
|
|
100
100
|
archived_at: t
|
data/lib/llmemory/version.rb
CHANGED