-
Notifications
You must be signed in to change notification settings - Fork 1
/
get_SNV_table.pl
executable file
·91 lines (78 loc) · 1.86 KB
/
get_SNV_table.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
# Get variant allele from every single cell
# merge counts from single cell into a matrix
use strict;
use warnings;
if(@ARGV<1)
{
print "perl $0 <output path from ATAC_mito_sc> <ProjectInfor> \n";
exit;
}
my $SNV=$ARGV[0]."/pool_output/".$ARGV[1].".merge.mt.mpileup.q20Q30.snv.filter.addfreq.sort";
my $summary=$ARGV[0]."/summary.tsv";
my $sc_output=$ARGV[0]."sc_output/";
my %SNV_hash;
open IN, "$SNV" or die "can not open $SNV\n";
while(<IN>)
{
my @a=split;
$SNV_hash{$a[1]}{"base"}=$a[2]."/".$a[3];
my $flag=0;
if($a[4]<$a[5]){$flag=1}
$SNV_hash{$a[1]}{"flag"}=$flag;
}
close IN;
open SUM,"$summary" or die " can not open $summary\n";
my %matrix;
<SUM>;
while(<SUM>)
{
chomp;
my @a=split;
my $file=$sc_output.$a[0]."/Mapping_hg19/".$a[0].".counts";
open SC,"$file" or die "can not open $file\n";
while(<SC>)
{
my @b=split;
if ( exists($SNV_hash{$b[1]}))
{
# print "position\t",$b[1],"\t";
my $base=$SNV_hash{$b[1]}{"base"};
my $flag=$SNV_hash{$b[1]}{"flag"};
# print $base,"\t";
# print $b[2]."/".$b[5],"\n";
if ($base eq $b[2]."/".$b[5])
{
if($flag == 1)
{
$matrix{$a[0]}{$b[1]}=$b[7];
}
else{
$matrix{$a[0]}{$b[1]}=$b[8];
}
}
else
{
$matrix{$a[0]}{$b[1]}=0;
}
}
}
close SC;
$matrix{$a[0]}{"depth"}=$a[17];
}
foreach my $sc (keys %matrix)
{
print $sc;
foreach my $site (keys %SNV_hash)
{
my $count;
if(exists($matrix{$sc}{$site}))
{$count=$matrix{$sc}{$site}}
else
{$count="na"}
print "\t", $count;
}
print "\t",$matrix{$sc}{"depth"},"\n";
}
my @sites=keys %SNV_hash;
print STDERR join("\n",@sites),"\n";