-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathimport_kgd_stats.sh
executable file
·124 lines (101 loc) · 3.32 KB
/
import_kgd_stats.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
#!/bin/sh
function get_opts() {
help_text="\n
usage : import_kgd_stats.sh -r run_name\n
example : ./import_kgd_stats.sh -r 170224_D00390_0285_ACA62JANXX\n
"
RUN_NAME=""
BUILD_ROOT=/dataset/2024_illumina_sequencing_e/scratch/postprocessing/gbs
while getopts "hr:d:" opt; do
case $opt in
r)
RUN_NAME=$OPTARG
;;
d)
BUILD_ROOT=$OPTARG
;;
h)
echo -e $help_text
exit 0
;;
\?)
echo "Invalid option: -$OPTARG" >&2
exit 1
;;
:)
echo "Option -$OPTARG requires an argument." >&2
exit 1
;;
esac
done
RUN_PATH=$BUILD_ROOT/${RUN_NAME}
}
function check_opts() {
if [ -z "$GBS_PRISM_BIN" ]; then
echo "GBS_PRISM_BIN not set - quitting"
exit 1
fi
if [ -z "$RUN_NAME" ]; then
echo -e $help_text
exit 1
fi
if [ ! -d $RUN_PATH ]; then
echo $RUN_PATH not found
exit 1
fi
}
function echo_opts() {
echo "importing $RUN_NAME from $RUN_PATH"
}
get_opts $@
check_opts
echo_opts
## from here , process the import
function collate_data() {
rm -f $RUN_PATH/html/kgd_import_temp.dat
files=`ls $RUN_PATH/SQ*/KGD/SampleStats.csv.blinded | egrep -v "\/OLD|_OLD"`
for file in $files; do
# e.g.
#"seqID","callrate","sampdepth"
#"C26128-01_C9B0MANXX_7_2562_X4",0.6222982902613,6.32146313487939
#"C26128-02_C9B0MANXX_7_2562_X4",0.603175741065988,7.21642352772501
#"C26128-03_C9B0MANXX_7_2562_X4",0.601939137603498,9.28047600272411
#"C26128-22_C9B0MANXX_7_2562_X4",0.630183877558335,7.77328936521022
# ...
#"C26128-23_C9B0MANXX_7_2562_X4",0.596347539338328,7.91736262948493
# ( cf the tag count file :
#sample,flowcell,lane,sq,tags,reads
# total,C9B0MANXX,7,SQ2562,,236560795
# good,C9B0MANXX,7,SQ2562,,227493728
# C26128-23,C9B0MANXX,7,2562,321892,2866438
# C26128-94,C9B0MANXX,7,2562,323125,2770861
# C26128-07,C9B0MANXX,7,2562,307216,2209878
# C26128-84,C9B0MANXX,7,2562,295120,2300256
# C26128-17,C9B0MANXX,7,2562,297249,2072236
# C26128-33,C9B0MANXX,7,2562,299478,2660275
cohort=`dirname $file`
cohort=`dirname $cohort`
cohort=`basename $cohort`
run=$RUN_NAME
cat $file | sed 's/"//g' - | awk -F, '{printf("%s\t%s\t%s\t%s\t%s\n",run,cohort,$1,$2,$3);}' run=$run cohort=$cohort - >> $RUN_PATH/html/kgd_import_temp.dat
# e.g.
#180914_D00390_0399_ACCVK0ANXX SQ0788.all.DEER.PstI seqID callrate sampdepth
#180914_D00390_0399_ACCVK0ANXX SQ0788.all.DEER.PstI qc302484-1_CCVK0ANXX_1_788_X4 0.856633390168031 3.53962593224089
#180914_D00390_0399_ACCVK0ANXX SQ0788.all.DEER.PstI qc302485-1_CCVK0ANXX_1_788_X4 0.814684176959821 2.70259400502401
done
}
function import_data() {
cd $RUN_PATH/html
# import sample level stats as collated by collate_data
gupdate --explain -t lab_report -p "name=import_gbs_kgd_stats;file=kgd_import_temp.dat" $RUN_NAME
# import cohort level data
# currently just from the KGD stdout file - e.g. /dataset/2024_illumina_sequencing_e/scratch/postprocessing/gbs/221020_A01439_0127_AHMKVMDRX2/SQ1951.all.deer.PstI/SQ1951.all.deer.PstI.KGD_tassel3.KGD.stdout
files=`ls $RUN_PATH/*/*.KGD_tassel3.KGD.stdout | egrep -v "\/OLD|_OLD"`
for kgd_stdout in $files; do
gupdate --explain -t lab_report -p "name=import_gbs_kgd_cohort_stats;file=$kgd_stdout" $RUN_NAME
done
}
set -x
collate_data
import_data
set +x