source("../genomics/scripts/lab_helpers.R")
Attaching package: ‘dplyr’
The following objects are masked from ‘package:stats’:
filter, lag
The following objects are masked from ‘package:base’:
intersect, setdiff, setequal, union
library(readr)
wlab <- write_db("Laboratory")
Loading required package: DBI
# set to current sequencing run
ligs <- wlab %>%
tbl("ligation") %>%
collect() %>%
select(-digest_id:-water, -well:-corr_date)
current<- wlab %>%
tbl("pcr") %>%
filter(SEQ == params$seq) %>%
collect() %>%
select(pcr_id, SEQ)
barcode <- wlab %>%
tbl("barcodes") %>%
collect()
# pull out only the pools in current sequencing run
for(i in seq(current$pcr_id)){
# define the log file
filename <- paste0("~/Downloads/process", current$pcr_id[i], ".log.tsv")
# read in the log file
samples <- read_delim(filename, delim = "\t", col_names = c("barcode", "total_reads", "lack_rad_tag", "low_quality", "retained"),
col_types = cols("c", "c", "c", "c", "c")) #import all columns as character
# merge to barcodes to get barcode number and add pool to table
samples <- left_join(samples, barcode, by = "barcode") %>%
mutate(pool = current$pcr_id[i])
# merge to ligation_ids and remove barcode
samples <- left_join(samples, ligs, by = c("barcode_num", "pool")) %>%
select(-barcode)
dat <- wlab %>%
tbl("ligation") %>%
collect()
change <- dat %>%
filter(ligation_id %in% samples$ligation_id) %>%
select(-total_reads, -lack_rad_tag, -low_quality, -retained)
change <- left_join(change, samples, by = c("ligation_id", "barcode_num", "pool"))
dat <- change_rows(dat, change, "ligation_id")
dbWriteTable(wlab, "ligation", dat, row.names = F, overwrite = T)
}
LS0tCnRpdGxlOiAiQWRkIHNlcXVlbmNpbmcgcmVzdWx0cyB0byBkYXRhYmFzZSIKb3V0cHV0OiBodG1sX25vdGVib29rCnBhcmFtczoKICBzZXE6ICBTRVEzMQotLS0KCmBgYHtyfQpzb3VyY2UoIi4uL2dlbm9taWNzL3NjcmlwdHMvbGFiX2hlbHBlcnMuUiIpCmxpYnJhcnkocmVhZHIpCndsYWIgPC0gd3JpdGVfZGIoIkxhYm9yYXRvcnkiKQoKYGBgCgoKYGBge3J9CiMgc2V0IHRvIGN1cnJlbnQgc2VxdWVuY2luZyBydW4KbGlncyA8LSB3bGFiICU+JSAKICB0YmwoImxpZ2F0aW9uIikgJT4lIAogIGNvbGxlY3QoKSAlPiUgCiAgc2VsZWN0KC1kaWdlc3RfaWQ6LXdhdGVyLCAtd2VsbDotY29ycl9kYXRlKQoKY3VycmVudDwtIHdsYWIgJT4lIAogIHRibCgicGNyIikgJT4lIAogIGZpbHRlcihTRVEgPT0gcGFyYW1zJHNlcSkgJT4lIAogIGNvbGxlY3QoKSAlPiUgCiAgc2VsZWN0KHBjcl9pZCwgU0VRKQoKYmFyY29kZSA8LSB3bGFiICU+JSAKICB0YmwoImJhcmNvZGVzIikgJT4lIAogIGNvbGxlY3QoKQoKCiMgcHVsbCBvdXQgb25seSB0aGUgcG9vbHMgaW4gY3VycmVudCBzZXF1ZW5jaW5nIHJ1bgpmb3IoaSBpbiBzZXEoY3VycmVudCRwY3JfaWQpKXsKICAjIGRlZmluZSB0aGUgbG9nIGZpbGUKICBmaWxlbmFtZSA8LSBwYXN0ZTAoIn4vRG93bmxvYWRzL3Byb2Nlc3MiLCBjdXJyZW50JHBjcl9pZFtpXSwgIi5sb2cudHN2IikKICAjIHJlYWQgaW4gdGhlIGxvZyBmaWxlCiAgc2FtcGxlcyA8LSByZWFkX2RlbGltKGZpbGVuYW1lLCBkZWxpbSA9ICJcdCIsIGNvbF9uYW1lcyA9IGMoImJhcmNvZGUiLCAidG90YWxfcmVhZHMiLCAibGFja19yYWRfdGFnIiwgImxvd19xdWFsaXR5IiwgInJldGFpbmVkIiksIAogICAgY29sX3R5cGVzID0gY29scygiYyIsICJjIiwgImMiLCAiYyIsICJjIikpICNpbXBvcnQgYWxsIGNvbHVtbnMgYXMgY2hhcmFjdGVyCiAgIyBtZXJnZSB0byBiYXJjb2RlcyB0byBnZXQgYmFyY29kZSBudW1iZXIgYW5kIGFkZCBwb29sIHRvIHRhYmxlCiAgc2FtcGxlcyA8LSBsZWZ0X2pvaW4oc2FtcGxlcywgYmFyY29kZSwgYnkgPSAiYmFyY29kZSIpICU+JSAKICAgIG11dGF0ZShwb29sID0gY3VycmVudCRwY3JfaWRbaV0pCiAgIyBtZXJnZSB0byBsaWdhdGlvbl9pZHMgYW5kIHJlbW92ZSBiYXJjb2RlCiAgc2FtcGxlcyA8LSBsZWZ0X2pvaW4oc2FtcGxlcywgbGlncywgYnkgPSBjKCJiYXJjb2RlX251bSIsICJwb29sIikpICU+JSAKICAgIHNlbGVjdCgtYmFyY29kZSkKCmRhdCA8LSB3bGFiICU+JQogIHRibCgibGlnYXRpb24iKSAlPiUgCiAgY29sbGVjdCgpCgpjaGFuZ2UgPC0gZGF0ICU+JSAKICBmaWx0ZXIobGlnYXRpb25faWQgJWluJSBzYW1wbGVzJGxpZ2F0aW9uX2lkKSAlPiUgCiAgc2VsZWN0KC10b3RhbF9yZWFkcywgLWxhY2tfcmFkX3RhZywgLWxvd19xdWFsaXR5LCAtcmV0YWluZWQpCmNoYW5nZSA8LSBsZWZ0X2pvaW4oY2hhbmdlLCBzYW1wbGVzLCBieSA9IGMoImxpZ2F0aW9uX2lkIiwgImJhcmNvZGVfbnVtIiwgInBvb2wiKSkKCmRhdCA8LSBjaGFuZ2Vfcm93cyhkYXQsIGNoYW5nZSwgImxpZ2F0aW9uX2lkIikKIyBkYldyaXRlVGFibGUod2xhYiwgImxpZ2F0aW9uIiwgZGF0LCByb3cubmFtZXMgPSBGLCBvdmVyd3JpdGUgPSBUKQp9CgoKYGBgCgo=