From e17565af4d491c3993b80e8a5b47b84a0f69ac67 Mon Sep 17 00:00:00 2001 From: Romain Franconville Date: Thu, 19 Mar 2020 12:34:43 -0400 Subject: [PATCH 1/3] Make bodyid in neuprint_get_roiInfo a character (like get_names and get_meta) --- R/name.R | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/R/name.R b/R/name.R index b12276d2..32274f02 100644 --- a/R/name.R +++ b/R/name.R @@ -117,7 +117,6 @@ neuprint_get_meta <- function(bodyids, dataset = NULL, all_segments = TRUE, conn "size","cellBodyFiber"), dataset=dataset,conn=conn,...) returnCypher <- paste0("n.",fieldNames," AS ",dfFields(fieldNames),collapse=" , ") -#n.bodyId AS bodyid, n.%s AS name, n.type AS type, n.status AS status, n.statusLabel AS statusLabel, n.size AS voxels, n.pre AS pre, n.post AS post,n.cropped AS cropped, exists(n.somaLocation) as soma, n.cellBodyFiber as cellBodyFiber, n.downstream as downstream" cypher = sprintf( paste( "WITH %s AS bodyIds UNWIND bodyIds AS bodyId ", @@ -189,7 +188,7 @@ neuprint_get_roiInfo <- function(bodyids, dataset = NULL, all_segments = FALSE, all_segments ) nc = neuprint_fetch_custom(cypher=cypher, dataset = dataset, conn = conn, ...) - lc <- lapply(nc$data,function(x){cbind(bodyid=x[[1]],as.data.frame(t(unlist(jsonlite::fromJSON(x[[2]])))))}) + lc <- lapply(nc$data,function(x){cbind(bodyid=as.character(x[[1]]),as.data.frame(t(unlist(jsonlite::fromJSON(x[[2]])))),stringsAsFactors=FALSE)}) d <- dplyr::bind_rows(lc) d } From d41cab96274b6b643dd731587f46d8c8b5f5d686 Mon Sep 17 00:00:00 2001 From: Romain Franconville Date: Thu, 19 Mar 2020 13:26:13 -0400 Subject: [PATCH 2/3] When chunking, roi parameter was getting propagated wrongly. Rename the string for queries to fix --- R/synapses.R | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/R/synapses.R b/R/synapses.R index eac7f951..f505276a 100644 --- a/R/synapses.R +++ b/R/synapses.R @@ -52,7 +52,7 @@ neuprint_get_synapses <- function(bodyids, roi = NULL, remove.autapses=TRUE, ". Please call neuprint_ROIs() to see the available ROIs." ) } - roi = sprintf("AND (exists(s.`%s`))", roi) + roiQ = sprintf("AND (exists(s.`%s`))", roi) } n <- length(bodyids) if(is.numeric(chunk)) { @@ -91,7 +91,7 @@ neuprint_get_synapses <- function(bodyids, roi = NULL, remove.autapses=TRUE, } return(d) } - if(is.null(roi)) roi <- "" + if(is.null(roi)) roiQ <- "" cypher.post = sprintf(paste("WITH %s AS bodyIds UNWIND bodyIds AS bodyId", "MATCH (a:`%s`)-[:Contains]->(:SynapseSet)-[:Contains]->(p:Synapse)<-[:SynapsesTo]-(s:Synapse)<-[:Contains]-(c:SynapseSet)<-[:Contains]-(b:`%s`)", "WHERE a.bodyId=bodyId AND (s.type='pre') %s", @@ -101,7 +101,7 @@ neuprint_get_synapses <- function(bodyids, roi = NULL, remove.autapses=TRUE, id2json(bodyids), "Segment", "Segment", - roi) + roiQ) cypher.pre = sprintf(paste("WITH %s AS bodyIds UNWIND bodyIds AS bodyId", "MATCH (a:`%s`)-[:Contains]->(c:SynapseSet)-[:Contains]->(s:Synapse)-[:SynapsesTo]->(:Synapse)<-[:Contains]-(:SynapseSet)<-[:Contains]-(b:`%s`)", "WHERE a.bodyId=bodyId AND (s.type='pre') %s", @@ -111,7 +111,7 @@ neuprint_get_synapses <- function(bodyids, roi = NULL, remove.autapses=TRUE, id2json(bodyids), "Segment", "Segment", - roi) + roiQ) nc.post = neuprint_fetch_custom(cypher=cypher.post, conn = conn, dataset = dataset, ...) nc.pre = neuprint_fetch_custom(cypher=cypher.pre, conn = conn, dataset = dataset, ...) m = rbind(neuprint_list2df(nc.post),neuprint_list2df(nc.pre)) From ad7abfcf5e29fee78492dbfe439dd8443a6f62ea Mon Sep 17 00:00:00 2001 From: Romain Franconville Date: Thu, 19 Mar 2020 13:30:24 -0400 Subject: [PATCH 3/3] Reverting irrelevant change --- R/name.R | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/R/name.R b/R/name.R index 32274f02..a76d891d 100644 --- a/R/name.R +++ b/R/name.R @@ -188,7 +188,7 @@ neuprint_get_roiInfo <- function(bodyids, dataset = NULL, all_segments = FALSE, all_segments ) nc = neuprint_fetch_custom(cypher=cypher, dataset = dataset, conn = conn, ...) - lc <- lapply(nc$data,function(x){cbind(bodyid=as.character(x[[1]]),as.data.frame(t(unlist(jsonlite::fromJSON(x[[2]])))),stringsAsFactors=FALSE)}) + lc <- lapply(nc$data,function(x){cbind(bodyid=x[[1]],as.data.frame(t(unlist(jsonlite::fromJSON(x[[2]])))))}) d <- dplyr::bind_rows(lc) d }