forked from nicgirault/circosJS
-
Notifications
You must be signed in to change notification settings - Fork 0
/
histogram.js
108 lines (103 loc) · 2.91 KB
/
histogram.js
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
var gieStainColor = {
gpos100: 'rgb(0,0,0)',
gpos: 'rgb(0,0,0)',
gpos75: 'rgb(130,130,130)',
gpos66: 'rgb(160,160,160)',
gpos50: 'rgb(200,200,200)',
gpos33: 'rgb(210,210,210)',
gpos25: 'rgb(200,200,200)',
gvar: 'rgb(220,220,220)',
gneg: 'rgb(255,255,255)',
acen: 'rgb(217,47,39)',
stalk: 'rgb(100,127,164)',
select: 'rgb(135,177,255)'
}
var buildData = function (rawData1, rawData2, karyotype) {
var binLength = 10000000
var data = []
var rawDataByChr1 = d3.nest().key(function (d) { return d.chr }).entries(rawData1)
var rawDataByChr2 = d3.nest().key(function (d) { return d.chr }).entries(rawData2)
karyotype.forEach(function (chr) {
var raw1 = rawDataByChr1.filter(function (d) { return d.key === chr.id })[0].values
var raw2 = rawDataByChr2.filter(function (d) { return d.key === chr.id })[0].values
d3.range(0, chr.len, binLength).forEach(function (position) {
var counter = 0
raw1.forEach(function (datum) {
var start = parseInt(datum.start)
var end = parseInt(datum.end)
if ((start < position && end > position) || (start > position && start < position + binLength)) {
counter++
}
})
raw2.forEach(function (datum) {
var start = parseInt(datum.start)
var end = parseInt(datum.end)
if ((start < position && end > position) || (start > position && start < position + binLength)) {
counter++
}
})
data.push({
block_id: chr.id,
start: position,
end: Math.min(position + binLength - 1, chr.len),
value: counter
})
})
})
return data
}
var drawCircos = function (error, GRCh37, cytobands, es, ips) {
var width = document.getElementsByClassName('mdl-card__supporting-text')[0].offsetWidth
var circos = new Circos({
container: '#histogramChart',
width: width,
height: width
})
cytobands = cytobands.map(function (d) {
return {
block_id: d.chrom,
start: parseInt(d.chromStart),
end: parseInt(d.chromEnd),
gieStain: d.gieStain,
name: d.name
}
})
circos
.layout(
GRCh37,
{
innerRadius: width / 2 - 150,
outerRadius: width / 2 - 120,
labels: {
display: false
},
ticks: {
display: false,
labelDenominator: 1000000
}
}
)
.highlight('cytobands', cytobands, {
innerRadius: width / 2 - 150,
outerRadius: width / 2 - 120,
opacity: 0.6,
color: function (d) {
return gieStainColor[d.gieStain]
},
tooltipContent: function (d) {
return d.name
}
})
.histogram('es', buildData(es, ips, GRCh37), {
innerRadius: 1.01,
outerRadius: 1.4,
color: 'OrRd'
})
.render()
}
d3.queue()
.defer(d3.json, './data/GRCh37.json')
.defer(d3.csv, './data/cytobands.csv')
.defer(d3.csv, './data/es.csv')
.defer(d3.csv, './data/ips.csv')
.await(drawCircos)