Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Pathfinder #191

Merged
merged 39 commits into from
Aug 30, 2024
Merged
Changes from 1 commit
Commits
Show all changes
39 commits
Select commit Hold shift + click to select a range
7ec573a
feat: add pathfinder templateGroups, templates for drug-disease
colleenXu Mar 21, 2024
8deeada
feat: allow inferred explain-type queries
tokebe Dec 20, 2023
f52c0f8
Merge branch 'main' into pathfinder-templates
colleenXu Mar 22, 2024
52bc25d
identify pathfinder queries. identify templates
rjawesome Mar 23, 2024
60dc949
create pathfinder intermediate aux graphs & results
rjawesome Mar 26, 2024
f8fe4e2
add kg edges to pathfinder
rjawesome Mar 26, 2024
9e1e0f7
score pathfinder results
rjawesome Mar 27, 2024
bd77b6d
implementation of creative limit for pathfinder
rjawesome Mar 28, 2024
d12742e
Merge branch 'pathfinder-templates' into pathfinder
rjawesome Mar 28, 2024
24eb56f
add debug statements
rjawesome Mar 28, 2024
f2832f0
code reorganization for pathfinder
rjawesome Mar 29, 2024
286dd47
logs & telemetry
rjawesome Mar 30, 2024
aa26be6
bugfix for couting ids
rjawesome Apr 2, 2024
c94cdb5
testing / function reorganization
rjawesome Apr 2, 2024
a1619c3
remove unnecessary types; creative mode bugfix
rjawesome Apr 2, 2024
7ff4daa
use guard clauses for easier code readibility
rjawesome Apr 2, 2024
e4e1a3a
variable names, cleaning up more loops
rjawesome Apr 2, 2024
97092c3
Merge branch 'main' into pathfinder-templates
colleenXu Apr 3, 2024
dd27a9d
feat: add pathfinder templates for chem-gene
colleenXu Apr 3, 2024
c9c9e8c
chore: remove extra predicate from pathfinder template
colleenXu Apr 3, 2024
6f84108
feat: add pathfinder templates for disease-disease
colleenXu Apr 3, 2024
b6aed6f
Merge branch 'main' of https://github.com/biothings/bte_trapi_query_g…
rjawesome Apr 4, 2024
3cd3b90
Merge branch 'pathfinder-templates' of https://github.com/biothings/b…
rjawesome Apr 4, 2024
fd7bd75
fix pathfinder improt
rjawesome Apr 4, 2024
080de45
fix push call
rjawesome Apr 4, 2024
4a119a2
implement pruning for pathfinder
rjawesome Apr 5, 2024
fbd4558
fix aux graph for main edge
rjawesome Apr 5, 2024
2fc3fda
feat: add pathfinder gene-disease templates
colleenXu Apr 5, 2024
1faf114
Merge branch 'pathfinder-templates' into pathfinder
colleenXu Apr 5, 2024
be78fec
fix node in PF edge
rjawesome Apr 6, 2024
576721e
more pathfinder testing
rjawesome Apr 6, 2024
79a66d6
Merge branch 'pathfinder' of https://github.com/biothings/bte_trapi_q…
rjawesome Apr 6, 2024
f861412
chore: fix error with missing pathfinder flag for one group
colleenXu Apr 11, 2024
82bd2d6
fix aux graph while loop
rjawesome Apr 17, 2024
78c0c84
Merge branch 'main' of https://github.com/biothings/bte_trapi_query_g…
tokebe Apr 17, 2024
e1ab149
make aux graphs more efficient
rjawesome Apr 18, 2024
715c1c9
Analyze aux graphs individually
rjawesome Apr 19, 2024
88bad1e
fix: support graph suffixes
rjawesome May 3, 2024
894bbb0
add pruning test
rjawesome May 11, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
add kg edges to pathfinder
rjawesome committed Mar 26, 2024
commit f8fe4e2b5918c397c2059d2e26a7b23d6c80b01d
80 changes: 65 additions & 15 deletions src/index.ts
Original file line number Diff line number Diff line change
@@ -573,15 +573,18 @@ export default class TRAPIQueryHandler {
const kgEdge = creativeResponse.message.results[0].analyses[0].edge_bindings[mainEdgeID][0].id;
const kgSrc = creativeResponse.message.results[0].node_bindings[mainEdge.subject][0].id;
const kgDst = creativeResponse.message.results[0].node_bindings[mainEdge.object][0].id;
const dfsNodes: {[node: string]: {dst: string, edge: string}[]} = {};
const dfsNodes: {[node: string]: {[dst: string]: string[]}} = {};
for (const supportGraph of creativeResponse.message.knowledge_graph.edges[kgEdge].attributes.find(attr => attr.attribute_type_id === 'biolink:support_graphs').value as string[]) {
const auxGraph = creativeResponse.message.auxiliary_graphs[supportGraph];
for (const subEdge of auxGraph.edges) {
const kgSubEdge = creativeResponse.message.knowledge_graph.edges[subEdge];
if (!dfsNodes[kgSubEdge.subject]) {
dfsNodes[kgSubEdge.subject] = [];
dfsNodes[kgSubEdge.subject] = {};
}
dfsNodes[kgSubEdge.subject].push({ dst: kgSubEdge.object, edge: subEdge });
if (!dfsNodes[kgSubEdge.subject][kgSubEdge.object]) {
dfsNodes[kgSubEdge.subject][kgSubEdge.object] = [];
}
dfsNodes[kgSubEdge.subject][kgSubEdge.object].push(subEdge);
}
}

@@ -592,10 +595,23 @@ export default class TRAPIQueryHandler {
while (stack.length !== 0) {
const { node, path } = stack.pop();
if (node === kgDst) {
if (path.length > 3) {
// loop through all intermediate nodes (nodes are even indices)
for (let i = 2; i < path.length - 2; i += 2) {
if (path.length > 2) {
// loop through all intermediate nodes
for (let i = 1; i < path.length - 1; i++) {
const intermediateNode = path[i];
const firstEdges = [];
const secondEdges = [];
for (let j = 0; j < i; j++) {
for (let edge of dfsNodes[path[j]][path[j+1]]) {
firstEdges.push(edge);
}
}
for (let j = i; j < path.length - 1; j++) {
for (let edge of dfsNodes[path[j]][path[j+1]]) {
secondEdges.push(edge);
}
}

if (!(`pathfinder-${kgSrc}-${intermediateNode}-${kgDst}` in newResultObject)) {
newResultObject[`pathfinder-${kgSrc}-${intermediateNode}-${kgDst}`] = {
node_bindings: {
@@ -606,23 +622,54 @@ export default class TRAPIQueryHandler {
analyses: [{
resource_id: "infores:biothings-explorer",
edge_bindings: {
[mainEdgeID]: [{ id: kgEdge }]
[mainEdgeID]: [{ id: kgEdge }],
[intermediateEdges[0][0]]: [{ id: `pathfinder-${kgSrc}-${intermediateNode}` }],
[intermediateEdges[1][0]]: [{ id: `pathfinder-${intermediateNode}-${kgDst}` }],
},
score: 1
}],
};
newAuxGraphs[`pathfinder-${kgSrc}-${intermediateNode}`] = { edges: new Set(path.slice(1, i).filter((_, ind) => ind % 2 == 0)) };
newAuxGraphs[`pathfinder-${intermediateNode}-${kgDst}`] = { edges: new Set(path.slice(i + 1).filter((_, ind) => ind % 2 == 0)) };
creativeResponse.message.knowledge_graph.edges[`pathfinder-${kgSrc}-${intermediateNode}`] = {
predicate: 'biolink:related_to',
subject: kgSrc,
object: intermediateNode,
sources: [
{
resource_id: this.options.provenanceUsesServiceProvider
? 'infores:service-provider-trapi'
: 'infores:biothings-explorer',
resource_role: 'primary_knowledge_source',
},
],
attributes: [{ attribute_type_id: 'biolink:support_graphs', value: [`pathfinder-${kgSrc}-${intermediateNode}-support`] }],
};
creativeResponse.message.knowledge_graph.edges[`pathfinder-${intermediateNode}-${kgDst}`] = {
predicate: 'biolink:related_to',
subject: intermediateNode,
object: kgDst,
sources: [
{
resource_id: this.options.provenanceUsesServiceProvider
? 'infores:service-provider-trapi'
: 'infores:biothings-explorer',
resource_role: 'primary_knowledge_source',
},
],
attributes: [{ attribute_type_id: 'biolink:support_graphs', value: [`pathfinder-${intermediateNode}-${kgDst}-support`] }],
};
newAuxGraphs[`pathfinder-${kgSrc}-${intermediateNode}-support`] = { edges: new Set(firstEdges) };
newAuxGraphs[`pathfinder-${intermediateNode}-${kgDst}-support`] = { edges: new Set(secondEdges) };

} else {
path.slice(1, i).filter((_, ind) => ind % 2 == 0).forEach(edge => newAuxGraphs[`pathfinder-${kgSrc}-${intermediateNode}`].edges.add(edge));
path.slice(i + 1).filter((_, ind) => ind % 2 == 0).forEach(edge => newAuxGraphs[`pathfinder-${intermediateNode}-${kgDst}`].edges.add(edge));
firstEdges.forEach(edge => newAuxGraphs[`pathfinder-${kgSrc}-${intermediateNode}-support`].edges.add(edge));
secondEdges.forEach(edge => newAuxGraphs[`pathfinder-${intermediateNode}-${kgDst}-support`].edges.add(edge));
}
}
}
} else {
for (const neighbor of dfsNodes[node]) {
if (!path.includes(neighbor.dst)) {
stack.push({ node: neighbor.dst, path: [...path, neighbor.edge, neighbor.dst ] });
for (const neighbor in dfsNodes[node]) {
if (!path.includes(neighbor)) {
stack.push({ node: neighbor, path: [...path, neighbor ] });
}
}
}
@@ -636,7 +683,10 @@ export default class TRAPIQueryHandler {
}
Object.assign(creativeResponse.message.auxiliary_graphs, finalNewAuxGraphs);

// TODO: Add knowledge graph edges & combine scoring information
// TODO: combine scoring information
// TODO: Fix 500 cap impl
// TODO: formatting
// TODO: move to a seperate file if this gets too big?

this.getResponse = () => creativeResponse;
}