-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcoverage_stat.pl
executable file
·92 lines (75 loc) · 2.66 KB
/
coverage_stat.pl
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
#! /usr/bin/perl
use strict;
use warnings;
use feature qw(say);
die("Wrong number of arguments. Provide normal IDT, normal RMG, normal CMR, tumor IDT, tumor RMG, tumor CMR, followup IDT, followup RMG, followup CMR, output file") unless @ARGV == 10;
my ($normal_IDT_stat, $normal_RMG_stat, $normal_CMR_stat, $tumor_IDT_stat, $tumor_RMG_stat, $tumor_CMR_stat, $followup_IDT_stat, $followup_RMG_stat, $followup_CMR_stat, $out_file) = @ARGV;
if ($normal_RMG_stat =~ /AML_CMR/ and $normal_CMR_stat =~ /AML_RMG/) {
($normal_RMG_stat, $normal_CMR_stat) = ($normal_CMR_stat, $normal_RMG_stat);
}
if ($tumor_RMG_stat =~ /AML_CMR/ and $tumor_CMR_stat =~ /AML_RMG/) {
($tumor_RMG_stat, $tumor_CMR_stat) = ($tumor_CMR_stat, $tumor_RMG_stat);
}
if ($followup_RMG_stat =~ /AML_CMR/ and $followup_CMR_stat =~ /AML_RMG/) {
($followup_RMG_stat, $followup_CMR_stat) = ($followup_CMR_stat, $followup_RMG_stat);
}
my @metrics_names = qw(
MEAN_TARGET_COVERAGE
MEDIAN_TARGET_COVERAGE
ON_TARGET_BASES
ZERO_CVG_TARGETS_PCT
PCT_USABLE_BASES_ON_TARGET
PCT_TARGET_BASES_100X
PCT_TARGET_BASES_30X
PCT_TARGET_BASES_10X
PCT_TARGET_BASES_1X
PCT_EXC_BASEQ
PCT_EXC_DUPE
PCT_EXC_MAPQ
PCT_EXC_OFF_TARGET
PCT_EXC_OVERLAP
);
my %stats = (
normal => {
IDT => $normal_IDT_stat,
RMG => $normal_RMG_stat,
CMR => $normal_CMR_stat,
},
tumor => {
IDT => $tumor_IDT_stat,
RMG => $tumor_RMG_stat,
CMR => $tumor_CMR_stat,
},
followup => {
IDT => $followup_IDT_stat,
RMG => $followup_RMG_stat,
CMR => $followup_CMR_stat,
},
);
open (my $out_fh, ">", "$out_file")
or die "couldn't open $out_file to write";
my $header = join "\t", 'Sample', 'ROI_set', @metrics_names;
say $out_fh $header;
for my $type (sort keys %stats) {
for my $roi (sort keys %{$stats{$type}}) {
open (my $stat_fh, $stats{$type}->{$roi}) or die "failed to open $type $roi coverage_stat";
my (@metrics_keys, @metrics_values);
while (<$stat_fh>) {
chomp;
next if /^(#|\s+)/;
@metrics_keys = split /\t/, $_ if /^BAIT_SET/;
@metrics_values = split /\t/, $_ if /^(AML|xgen)/;
last if @metrics_keys and @metrics_values;
}
close $stat_fh;
my %metrics;
@metrics{@metrics_keys} = @metrics_values;
my @values;
for my $metrics_name (@metrics_names) {
push @values, $metrics{$metrics_name};
}
my $values = join "\t", $type, $roi, @values;
say $out_fh $values;
}
}
close $out_fh;