From 288f801bd64fe8a17f34c7c0604440446f43f48f Mon Sep 17 00:00:00 2001 From: Kaiwen He Date: Thu, 15 Aug 2024 16:33:18 -0500 Subject: [PATCH] updated KGs: robokop, rtx-kg2, and text-mining; added AT/KL to edges; solve dict-get failed error; added mvp1 templates; filter edges with same subject and object --- .../neo-low-level/make-query-low-level.rkt | 38 ++--- .../query-low-level-multi-db.rkt | 3 +- .../neo-low-level/query-low-level-robokop.rkt | 5 +- .../neo-low-level/query-low-level-rtx-kg2.rkt | 5 +- .../query-low-level-text-mining.rkt | 5 +- .../neo/neo-server/neo-server-utils.rkt | 121 ++++++++------ medikanren2/neo/neo-server/neo-server.rkt | 147 +++++++++--------- 7 files changed, 170 insertions(+), 154 deletions(-) diff --git a/medikanren2/neo/neo-low-level/make-query-low-level.rkt b/medikanren2/neo/neo-low-level/make-query-low-level.rkt index 66c2cb67..36eda17b 100644 --- a/medikanren2/neo/neo-low-level/make-query-low-level.rkt +++ b/medikanren2/neo/neo-low-level/make-query-low-level.rkt @@ -21,6 +21,7 @@ (define (make-query-low-level db-path-under-parent ;; for example, "rtx-kg2/pre_2.8.0/rtx-kg2pre_2.8.0.db" + kg-infores ) (pretty-log `(In make-query-low-level for) @@ -94,17 +95,18 @@ (define (curie->properties curie) (enumerator->list (lambda (yield) - ((dict-enumerator (dict-get curie=>ckey=>cvalue=>1 (string->id curie))) + ((dict-enumerator (dict-get-safe curie=>ckey=>cvalue=>1 (string->id curie) dict.empty)) (lambda (ckey cvalue=>1) (yield (map id->string (cons ckey (enumerator->list (dict-key-enumerator cvalue=>1)))))))))) (define (edge-id->properties eid) - (enumerator->list - (lambda (yield) - ((dict-enumerator (dict-get eid=>ekey=>evalue=>1 eid)) - (lambda (ekey evalue=>1) - (yield (map id->string (cons ekey (enumerator->list - (dict-key-enumerator evalue=>1)))))))))) + (cons (list "upstream_resource_ids" (list kg-infores)) + (enumerator->list + (lambda (yield) + ((dict-enumerator (dict-get eid=>ekey=>evalue=>1 eid)) + (lambda (ekey evalue=>1) + (yield (map id->string (cons ekey (enumerator->list + (dict-key-enumerator evalue=>1))))))))))) (define (query:Known->X curie*.K predicate*.K->X category*.X) (define (query. yield) @@ -381,13 +383,11 @@ (define (query:dict.Known->dict.Known curie=>1.S predicate*.S->O curie=>1.O direction-tag) (define (query.sub->obj yield) (let* ((ekey.predicate (string->id str.predicate)) - (ckey.name (string->id "name")) (predicate=>1 (string*->id=>1 predicate*.S->O)) (predicate=>eid=>1 (dict-get ekey=>evalue=>eid=>1 ekey.predicate))) ((merge-join fx< curie=>1.S subject=>eid=>object=>1) (lambda (id.S __ eid=>O=>1) - (let* ((name.S (get-name-from-dict-safe (dict-get curie=>ckey=>cvalue=>1 id.S) ckey.name)) - (S (id->string id.S))) + (let* ((S (id->string id.S))) ((merge-join fx< predicate=>1 predicate=>eid=>1) (lambda (id.predicate.S->O __ eid=>1) (let ((predicate.S->O (id->string id.predicate.S->O))) @@ -395,20 +395,15 @@ (lambda (eid __ O=>1) ((merge-join fx< curie=>1.O O=>1) (lambda (id.O __ ___) - (let* ((name.O (get-name-from-dict-safe (dict-get curie=>ckey=>cvalue=>1 id.O) - ckey.name)) - (O (id->string id.O))) - (yield (list* S name.S predicate.S->O O name.O - (edge-id->properties eid)))))))))))))))) + (let* ((O (id->string id.O))) + (yield (list* S predicate.S->O O (edge-id->properties eid)))))))))))))))) (define (query.obj->sub yield) (let* ((ekey.predicate (string->id str.predicate)) - (ckey.name (string->id "name")) (predicate=>1 (string*->id=>1 predicate*.S->O)) (predicate=>eid=>1 (dict-get ekey=>evalue=>eid=>1 ekey.predicate))) ((merge-join fx< curie=>1.O object=>eid=>subject=>1) (lambda (id.O __ eid=>S=>1) - (let* ((name.O (get-name-from-dict-safe (dict-get curie=>ckey=>cvalue=>1 id.O) ckey.name)) - (O (id->string id.O))) + (let* ((O (id->string id.O))) ((merge-join fx< predicate=>1 predicate=>eid=>1) (lambda (id.predicate.O->S __ eid=>1) (let ((predicate.O->S (id->string id.predicate.O->S))) @@ -416,11 +411,8 @@ (lambda (eid __ S=>1) ((merge-join fx< curie=>1.S S=>1) (lambda (id.S __ ___) - (let* ((name.S (get-name-from-dict-safe (dict-get curie=>ckey=>cvalue=>1 id.S) - ckey.name)) - (S (id->string id.S))) - (yield (list* S name.S predicate.O->S O name.O - (edge-id->properties eid)))))))))))))))) + (let* ((S (id->string id.S))) + (yield (list* S predicate.O->S O (edge-id->properties eid)))))))))))))))) (cond [(eq? direction-tag 'obj->sub) (maybe-time (enumerator->rlist query.obj->sub))] [(eq? direction-tag 'sub->obj) maybe-time (enumerator->rlist query.sub->obj)] diff --git a/medikanren2/neo/neo-low-level/query-low-level-multi-db.rkt b/medikanren2/neo/neo-low-level/query-low-level-multi-db.rkt index fb8b5275..fc4217a1 100644 --- a/medikanren2/neo/neo-low-level/query-low-level-multi-db.rkt +++ b/medikanren2/neo/neo-low-level/query-low-level-multi-db.rkt @@ -513,10 +513,11 @@ (curie-in-db?-rtx-kg2 curie))) (define (curies-in-db curie*) + (remove-duplicates (append (curies-in-db-robokop curie*) (curies-in-db-text-mining curie*) - (curies-in-db-rtx-kg2 curie*))) + (curies-in-db-rtx-kg2 curie*)))) (define (curie->properties curie) (append diff --git a/medikanren2/neo/neo-low-level/query-low-level-robokop.rkt b/medikanren2/neo/neo-low-level/query-low-level-robokop.rkt index 562fe95d..f502fb60 100644 --- a/medikanren2/neo/neo-low-level/query-low-level-robokop.rkt +++ b/medikanren2/neo/neo-low-level/query-low-level-robokop.rkt @@ -23,7 +23,8 @@ "make-query-low-level.rkt" racket/match) -(define db-path-under-parent "robokop-may-9-2024/march-7-2024/robokop.db") +#;(define db-path-under-parent "robokop-may-9-2024/march-7-2024/robokop.db") +(define db-path-under-parent "robokop-aug-6-2024/july-31-2024/robokop.db") (match-define (list @@ -46,4 +47,4 @@ edge-id->properties get-highest-bucket-number ) - (make-query-low-level db-path-under-parent)) + (make-query-low-level db-path-under-parent "infores:robokop-kg")) diff --git a/medikanren2/neo/neo-low-level/query-low-level-rtx-kg2.rkt b/medikanren2/neo/neo-low-level/query-low-level-rtx-kg2.rkt index baf2ed80..05b1f462 100644 --- a/medikanren2/neo/neo-low-level/query-low-level-rtx-kg2.rkt +++ b/medikanren2/neo/neo-low-level/query-low-level-rtx-kg2.rkt @@ -23,7 +23,8 @@ "make-query-low-level.rkt" racket/match) -(define db-path-under-parent "rtx-kg2-may-9-2024/rtx-kg2-2.9.0pre/rtx-kg2.db") +#;(define db-path-under-parent "rtx-kg2-may-9-2024/rtx-kg2-2.9.0pre/rtx-kg2.db") +(define db-path-under-parent "rtx-kg2-Aug-6-2024/rtx-kg2-2.10.0pre/rtx-kg2.db") (match-define (list @@ -46,4 +47,4 @@ edge-id->properties get-highest-bucket-number ) - (make-query-low-level db-path-under-parent)) + (make-query-low-level db-path-under-parent "infores:rtx-kg2")) diff --git a/medikanren2/neo/neo-low-level/query-low-level-text-mining.rkt b/medikanren2/neo/neo-low-level/query-low-level-text-mining.rkt index a9fe3a04..1ad1270d 100644 --- a/medikanren2/neo/neo-low-level/query-low-level-text-mining.rkt +++ b/medikanren2/neo/neo-low-level/query-low-level-text-mining.rkt @@ -23,7 +23,8 @@ "make-query-low-level.rkt" racket/match) -(define db-path-under-parent "text-mining-apr-5-2024/apr_2_2024/text_mining.db") +(define db-path-under-parent "text-mining-aug-5-2024/aug_5_2024/text_mining.db") +#;(define db-path-under-parent "text-mining-apr-5-2024/apr_2_2024/text_mining.db") (match-define (list @@ -46,4 +47,4 @@ edge-id->properties get-highest-bucket-number ) - (make-query-low-level db-path-under-parent)) + (make-query-low-level db-path-under-parent "infores:text-mining-provider-targeted")) diff --git a/medikanren2/neo/neo-server/neo-server-utils.rkt b/medikanren2/neo/neo-server/neo-server-utils.rkt index 2e963a25..141cf64d 100644 --- a/medikanren2/neo/neo-server/neo-server-utils.rkt +++ b/medikanren2/neo/neo-server/neo-server-utils.rkt @@ -10,19 +10,23 @@ minus-one-before-zero find-max-number get-source + UNSECRET-SOURCE num-pubs get-score-from-result set-score-in-result normalize-scores edge-has-source? - data-attributes + publication-attributes auxiliary-graph-attribute + qualifier-attribute* merge-trapi-responses semantic-exclude* domain-exclude* range-exclude* get-object get-and-print-qualifiers + Unsecret-agent-type-attribute + Unsecret-knowledge-level-attribute agent-type-attribute knowledge-level-attribute ) @@ -59,19 +63,18 @@ '()))) (define mvp2-filter - (lambda (target-eprop direction) + (lambda (target-eprop direction care-aspect?) (let* ((aspect (get-assoc "object_aspect_qualifier" target-eprop)) (direction^ (get-assoc "object_direction_qualifier" target-eprop))) - (and - aspect - direction^ - (or - (equal? "activity" aspect) - (equal? "abundance" aspect) - (equal? "activity_or_abundance" aspect) - (equal? "expression" aspect) - (equal? "synthesis" aspect)) - (equal? direction direction^))))) + (if care-aspect? + (and + aspect + direction^ + (member aspect '("activity" "abundance" "activity_or_abundance" "expression" "synthesis")) + (equal? direction direction^)) + (and + direction^ + (equal? direction direction^)))))) #| A increases B increases C = A increases C @@ -92,17 +95,21 @@ A decreases B increases C = A decreases C ,(? string? curie_z) ,props_xy ,props_yz) - (if (equal? direction "increased") - (or - (and (mvp2-filter props_xy "increased") - (mvp2-filter props_yz "increased")) - (and (mvp2-filter props_xy "decreased") - (mvp2-filter props_yz "decreased"))) - (or - (and (mvp2-filter props_xy "increased") - (mvp2-filter props_yz "decreased")) - (and (mvp2-filter props_xy "decreased") - (mvp2-filter props_yz "increased"))))] + (if (equal? pred_xy "biolink:affects") + (if (equal? direction "increased") + (or + (and (mvp2-filter props_xy "increased" #f) + (mvp2-filter props_yz "increased" #t)) + (and (mvp2-filter props_xy "decreased" #f) + (mvp2-filter props_yz "decreased" #t))) + (or + (and (mvp2-filter props_xy "increased" #f) + (mvp2-filter props_yz "decreased" #t)) + (and (mvp2-filter props_xy "decreased" #f) + (mvp2-filter props_yz "increased" #t)))) + (if (equal? direction "increased") + (mvp2-filter props_yz "increased" #t) + (mvp2-filter props_yz "decreased" #t)))] [else #f])) e*))) @@ -111,7 +118,7 @@ A decreases B increases C = A decreases C (filter (lambda (e) (let-values ([(_ eprop) (split-at e 3)]) - (mvp2-filter eprop direction))) + (mvp2-filter eprop direction #t))) q))) (define find-max-number @@ -125,14 +132,13 @@ A decreases B increases C = A decreases C (loop (cdr n*) greatest))))))) (define (get-source-helper props) - (or (get-assoc "primary_knowledge_source" props) - (and (get-assoc "json_attributes" props) - "infores:text-mining-provider-targeted"))) + (get-assoc "primary_knowledge_source" props)) (define (get-source props) - (hash - 'resource_id (get-source-helper props) - 'resource_role "primary_knowledge_source")) + (hash + 'type "biolink:RetrievalSource" + 'resource_id (get-source-helper props) + 'resource_role "primary_knowledge_source")) (define (num-pubs props) (let ((score (string->number (get-assoc "mediKanren-score" props))) @@ -142,6 +148,13 @@ A decreases B increases C = A decreases C ((equal? source "infores:text-mining-provider-targeted") (* 10 score)) (else score)))) +(define (UNSECRET-SOURCE prop) + (hash + 'type "biolink:RetrievalSource" + 'resource_id "infores:unsecret-agent" + 'resource_role "aggregator_knowledge_source" + 'upstream_resource_ids (get-assoc "upstream_resource_ids" prop))) + (define (get-score-from-result result) (let ((analyses (hash-ref result 'analyses #f))) (if analyses @@ -165,21 +178,10 @@ A decreases B increases C = A decreases C results (map (lambda (x) (set-score-in-result x (/ (get-score-from-result x) (* 1.0 max-score)))) results))))) -(define edge-has-source? - (lambda (props) - (or (get-assoc "primary_knowledge_source" props) - (and (get-assoc "json_attributes" props) - (let ((attr-hl (string->jsexpr (get-assoc "json_attributes" props)))) - (let loop ((hl attr-hl)) - (cond - ((null? hl) #f) - ((equal? - (hash-ref (car hl) 'attribute_type_id #f) - "biolink:primary_knowledge_source") - #t) - (else (loop (cdr hl)))))))))) - -(define (data-attributes props has-pub?) +(define (edge-has-source? props) + (get-source-helper props)) + +(define (publication-attributes props has-pub?) (if has-pub? (list (get-publications props)) (list))) @@ -190,8 +192,7 @@ A decreases B increases C = A decreases C (cond [(null? props) pubs] [else - (let ((publication (or (get-assoc "publications" (car props)) - (get-assoc "supporting_publications" (car props))))) + (let ((publication (get-assoc "publications" (car props)))) (helper (cdr props) (append (cond @@ -215,18 +216,40 @@ A decreases B increases C = A decreases C 'attribute_type_id "biolink:support_graphs" 'value (list id)))) -(define agent-type-attribute +(define (qualifier-attribute* qualifier-name props) + (let ((qualifer (get-assoc qualifier-name props))) + (if qualifer + (list (hash 'qualifier_type_id (string-append "biolink:" qualifier-name) + 'qualifier_value qualifer)) + '()))) + + +(define Unsecret-agent-type-attribute (hash 'attribute_type_id "biolink:agent_type" 'value "computational_model" 'attribute_source "infores:unsecret-agent")) -(define knowledge-level-attribute +(define Unsecret-knowledge-level-attribute (hash 'attribute_type_id "biolink:knowledge_level" 'value "prediction" 'attribute_source "infores:unsecret-agent")) +(define (agent-type-attribute prop) + (let* ((edge-from-tmkg? (get-assoc "json_attributes" prop)) + (agent-type (if edge-from-tmkg? "text_mining_agent" (get-assoc "agent_type" prop)))) + (hash + 'attribute_type_id "biolink:agent_type" + 'value agent-type))) + +(define (knowledge-level-attribute prop) + (let* ((edge-from-tmkg? (get-assoc "json_attributes" prop)) + (knowledge-level (if edge-from-tmkg? "not_provided" (get-assoc "knowledge_level" prop)))) + (hash + 'attribute_type_id "biolink:knowledge_level" + 'value knowledge-level))) + ;; TODO: test it with calling out Genetics KP (define (merge-trapi-responses r1 r2 original-query_graph) (let* ((message1 (hash-ref r1 'message)) diff --git a/medikanren2/neo/neo-server/neo-server.rkt b/medikanren2/neo/neo-server/neo-server.rkt index 9da0b286..fb98d6a1 100644 --- a/medikanren2/neo/neo-server/neo-server.rkt +++ b/medikanren2/neo/neo-server/neo-server.rkt @@ -29,7 +29,7 @@ (define DEFAULT_PORT 8384) -(define NEO_SERVER_VERSION "1.52") +(define NEO_SERVER_VERSION "1.53") ;; Maximum number of results to be returned from *each individual* KP, ;; or from mediKanren itself. @@ -980,11 +980,6 @@ (let ((score-one-result (make-score-result n))) (map (lambda (h i) (set-score-in-result h (score-one-result h i))) results (iota n))))) -(define UNSECRET-SOURCE - (hash - 'resource_id "infores:unsecret-agent" - 'resource_role "aggregator_knowledge_source")) - (define (excluded-semmed-edge? prop) (let ((source (get-assoc "primary_knowledge_source" prop))) ;only rkx-kg2 has semmed edge (and (equal? source "infores:semmeddb") @@ -1054,7 +1049,7 @@ [else "UMLS:C0017337"]))) (not (member object GENERAL-NODES)))) -(define (node-has-name-and-cat? curie) +(define (node-has-cat? curie) (let* ((props (curie->properties curie)) (categories (list-assoc "category" props)) (categories (filter @@ -1062,9 +1057,11 @@ (not (or (class-mixin? c) (class-abstract? c)))) - categories)) - (name (get-assoc "name" props))) - (and (not (null? categories)) name))) + categories))) + (not (null? categories)))) + +(define (same-concept? c1 c2) + (equal? (curie->representative c1) (curie->representative c2))) (define (handle-mvp-creative-query body-json message query_graph edges nodes which-mvp) @@ -1120,7 +1117,8 @@ (query:X->Known-scored chemical-catogory+ '("biolink:treats" - "biolink:treats_or_applied_or_studied_to_treat") + "biolink:treats_or_applied_or_studied_to_treat" + "biolink:ameliorates_condition") curies score*))))) (define 2-hop-proc @@ -1132,10 +1130,10 @@ (set->list (get-non-deprecated/mixin/abstract-ins-and-descendent-classes*-in-db '("biolink:Gene" "biolink:GeneOrGeneProduct" "biolink:Protein"))) - (set->list - (get-non-deprecated/mixin/abstract-ins-and-descendent-predicates*-in-db - '("biolink:gene_associated_with_condition" - "biolink:contributes_to"))) + '("biolink:contributes_to" + "biolink:gene_associated_with_condition" + "biolink:causes" + "biolink:target_for") curies score* result-amount @@ -1184,9 +1182,10 @@ (lambda (score* result-amount) (query:Known->Y->X-auto-grow curies - (set->list - (get-non-deprecated/mixin/abstract-ins-and-descendent-predicates*-in-db - '("biolink:affects" "biolink:interacts_with"))) + '("biolink:affects" + "biolink:physically_interacts_with" + "biolink:indirectly_physically_interacts_with" + "biolink:directly_physically_interacts_with") (set->list (get-non-deprecated/mixin/abstract-ins-and-descendent-classes*-in-db '("biolink:Gene" "biolink:GeneOrGeneProduct" "biolink:Protein"))) @@ -1249,9 +1248,10 @@ (lambda (score* result-amount) (query:X->Y->Known-auto-grow chemical-catogory+ - (set->list - (get-non-deprecated/mixin/abstract-ins-and-descendent-predicates*-in-db - '("biolink:affects" "biolink:interacts_with"))) + '("biolink:affects" + "biolink:physically_interacts_with" + "biolink:indirectly_physically_interacts_with" + "biolink:directly_physically_interacts_with") (set->list (get-non-deprecated/mixin/abstract-ins-and-descendent-classes*-in-db '("biolink:Gene" "biolink:GeneOrGeneProduct" "biolink:Protein"))) @@ -1287,7 +1287,7 @@ mvp2: {'look-up': 50, '1 hops': 40, ' 2 hops': 1} predicate-type-values = {'causation': 3, 'association': 2, 'other': 1} |# - (define causation-prediates (get-non-deprecated/mixin/abstract-ins-and-descendent-predicates*-in-db '("biolink:contributes_to" "biolink:affects"))) + (define causation-prediates (get-non-deprecated/mixin/abstract-ins-and-descendent-predicates*-in-db '("biolink:contributes_to" "biolink:affects" "biolink:target_for"))) (define association-predicates (get-non-deprecated/mixin/abstract-ins-and-descendent-predicates*-in-db '("biolink:gene_associated_with_condition" "biolink:interacts_with"))) (define (score-mvp-edge e) (match e @@ -1501,60 +1501,56 @@ (class-abstract? c)))) categories)) (name (get-assoc "name" props))) - (hash-set! nodes (string->symbol curie) - (hash 'categories categories - 'name name - 'attributes (list) - ))))) + (if name + (hash-set! nodes (string->symbol curie) + (hash 'categories categories + 'name name + 'attributes (list))) + (hash-set! nodes (string->symbol curie) + (hash 'categories categories + 'attributes (list) + )))))) (define (add-edge! subj obj props n) - (let* ((id - (or - #;(get-assoc "id" props) ; rtx-kg2 - #;(get-assoc "assertion_id" props) ;text-mining - (number->string n))) + (let* ((id (number->string n)) (id (string-append "medik:edge#" id)) (id-sym (string->symbol id)) (object obj) (subject subj) (predicate (get-assoc "predicate" props)) - (aspect-qualifier (get-assoc "object_aspect_qualifier" props)) - (direction-qualifier (get-assoc "object_direction_qualifier" props)) - (qualifed-predicate (get-assoc "qualified_predicate" props)) + (aspect-qualifier (qualifier-attribute* "object_aspect_qualifier" props)) + (direction-qualifier (qualifier-attribute* "object_direction_qualifier" props)) + (qualifed-predicate (qualifier-attribute* "qualified_predicate" props)) + (qualifiers-attr* (append aspect-qualifier direction-qualifier qualifed-predicate)) (has-pub? (> (num-pubs props) 0))) (add-node! object) (add-node! subject) - (unless (hash-has-key? edges id-sym) - (if (and - #;(or (eq? which-mvp 'mvp2-chem) (eq? which-mvp 'mvp2-gene)) - aspect-qualifier direction-qualifier qualifed-predicate) - (hash-set! edges id-sym - (hash 'attributes - (or - (and (get-assoc "json_attributes" props) - (string->jsexpr (get-assoc "json_attributes" props))) - (data-attributes props has-pub?)) - 'object object - 'predicate predicate - 'subject subject - 'sources (list (get-source props) UNSECRET-SOURCE) - 'qualifiers (list - (hash 'qualifier_type_id "biolink:object_aspect_qualifier" - 'qualifier_value aspect-qualifier) - (hash 'qualifier_type_id "biolink:object_direction_qualifier" - 'qualifier_value direction-qualifier) - (hash 'qualifier_type_id "biolink:qualified_predicate" - 'qualifier_value qualifed-predicate)))) - (hash-set! edges id-sym - (hash 'attributes - (or - (and (get-assoc "json_attributes" props) - (string->jsexpr (get-assoc "json_attributes" props))) - (data-attributes props has-pub?)) - 'object object - 'predicate predicate - 'subject subject - 'sources (list (get-source props) UNSECRET-SOURCE))))) + (if (not (null? qualifiers-attr*)) + (hash-set! edges id-sym + (hash 'attributes + (or + #;(and (get-assoc "json_attributes" props) + (string->jsexpr (get-assoc "json_attributes" props))) + (list* (agent-type-attribute props) + (knowledge-level-attribute props) + (publication-attributes props has-pub?))) + 'object object + 'predicate predicate + 'subject subject + 'sources (list (get-source props) (UNSECRET-SOURCE props)) + 'qualifiers qualifiers-attr*)) + (hash-set! edges id-sym + (hash 'attributes + (or + #;(and (get-assoc "json_attributes" props) + (string->jsexpr (get-assoc "json_attributes" props))) + (list* (agent-type-attribute props) + (knowledge-level-attribute props) + (publication-attributes props has-pub?))) + 'object object + 'predicate predicate + 'subject subject + 'sources (list (get-source props) (UNSECRET-SOURCE props))))) id)) (define (add-creative-edge! sub obj pred n aux-id) @@ -1564,8 +1560,8 @@ (hash 'attributes (list (auxiliary-graph-attribute aux-id) - agent-type-attribute - knowledge-level-attribute) + Unsecret-agent-type-attribute + Unsecret-knowledge-level-attribute) 'object obj 'predicate pred 'subject sub @@ -1584,8 +1580,8 @@ (hash 'attributes (list (auxiliary-graph-attribute aux-id) - agent-type-attribute - knowledge-level-attribute) + Unsecret-agent-type-attribute + Unsecret-knowledge-level-attribute) 'object obj 'predicate pred 'subject sub @@ -1634,9 +1630,10 @@ ,(? string? curie_z) ,props_xy ,props_yz) - (if (and (node-has-name-and-cat? curie_x) - (node-has-name-and-cat? curie_y) - (node-has-name-and-cat? curie_z)) + (if (and (node-has-cat? curie_x) + (node-has-cat? curie_y) + (node-has-cat? curie_z) + (not (same-concept? curie_y curie_z))) (let* ((edge_xy (add-edge! curie_x curie_y props_xy en)) (edge_yz (add-edge! curie_y curie_z props_yz (+ en 1))) (auxiliary_id (add-auxiliary! (list edge_xy edge_yz) an)) @@ -1693,8 +1690,8 @@ ,curie_y . ,props_xy) - (if (and (node-has-name-and-cat? curie_x) - (node-has-name-and-cat? curie_y)) + (if (and (node-has-cat? curie_x) + (node-has-cat? curie_y)) (let ((edge_xy (add-edge! curie_x curie_y props_xy en))) (add-unmerged-result! (cond