bio-data-visualization-genome-tracks
SKILL.md
Genome Track Visualization
pyGenomeTracks (Python/CLI)
# Create tracks configuration file
cat > tracks.ini << 'EOF'
[bigwig]
file = coverage.bw
title = Coverage
height = 4
color = #4DBBD5
min_value = 0
[spacer]
height = 0.5
[peaks]
file = peaks.bed
title = Peaks
color = #E64B35
height = 2
labels = false
[spacer]
height = 0.5
[genes]
file = genes.gtf
title = Genes
height = 5
fontsize = 10
style = flybase
color = #3C5488
[x-axis]
EOF
# Generate plot
pyGenomeTracks --tracks tracks.ini --region chr1:1000000-2000000 \
--outFileName tracks.png --dpi 150
pyGenomeTracks with Multiple Samples
[sample1 coverage]
file = sample1.bw
title = Sample 1
height = 3
color = #4DBBD5
min_value = 0
max_value = auto
[sample2 coverage]
file = sample2.bw
title = Sample 2
height = 3
color = #E64B35
min_value = 0
max_value = auto
[sample1 peaks]
file = sample1_peaks.narrowPeak
title = Sample 1 Peaks
color = #4DBBD5
height = 1
file_type = narrowPeak
[sample2 peaks]
file = sample2_peaks.narrowPeak
title = Sample 2 Peaks
color = #E64B35
height = 1
file_type = narrowPeak
pyGenomeTracks Programmatic
import pygenometracks.tracks as pygtk
tracks = pygtk.PlotTracks('tracks.ini', fig_width=40, dpi=150)
tracks.plot('output.png', 'chr1', 1000000, 2000000)
Gviz (R)
library(Gviz)
library(GenomicRanges)
# Genome axis
gtrack <- GenomeAxisTrack()
# Ideogram
itrack <- IdeogramTrack(genome = 'hg38', chromosome = 'chr1')
# Gene model
library(TxDb.Hsapiens.UCSC.hg38.knownGene)
txdb <- TxDb.Hsapiens.UCSC.hg38.knownGene
grtrack <- GeneRegionTrack(txdb, genome = 'hg38', chromosome = 'chr1',
name = 'Genes', transcriptAnnotation = 'symbol')
# Data track from BigWig
dtrack <- DataTrack(range = 'coverage.bw', genome = 'hg38', chromosome = 'chr1',
name = 'Coverage', type = 'histogram', col.histogram = '#4DBBD5')
# Annotation track from BED
atrack <- AnnotationTrack(range = 'peaks.bed', genome = 'hg38', chromosome = 'chr1',
name = 'Peaks', fill = '#E64B35')
# Plot tracks
plotTracks(list(itrack, gtrack, dtrack, atrack, grtrack),
from = 1000000, to = 2000000, sizes = c(1, 1, 3, 1, 3))
Gviz with Multiple Samples
# Create overlay data track
dtrack1 <- DataTrack(range = 'sample1.bw', name = 'Sample1', col = '#4DBBD5')
dtrack2 <- DataTrack(range = 'sample2.bw', name = 'Sample2', col = '#E64B35')
overlay <- OverlayTrack(trackList = list(dtrack1, dtrack2))
plotTracks(list(gtrack, overlay, grtrack), from = 1000000, to = 2000000,
type = 'histogram', legend = TRUE)
Gviz Customization
# Highlight regions
ht <- HighlightTrack(trackList = list(dtrack, atrack),
start = c(1200000, 1500000),
end = c(1300000, 1600000),
chromosome = 'chr1')
# Custom display parameters
displayPars(dtrack) <- list(
background.title = '#3C5488',
fontcolor.title = 'white',
col.axis = 'black',
ylim = c(0, 100)
)
plotTracks(list(gtrack, ht, grtrack), from = 1000000, to = 2000000)
IGV.js (Web)
<!DOCTYPE html>
<html>
<head>
<script src="https://cdn.jsdelivr.net/npm/igv@3.0.0/dist/igv.min.js"></script>
</head>
<body>
<div id="igv-div"></div>
<script>
var options = {
genome: "hg38",
locus: "chr1:1,000,000-2,000,000",
tracks: [
{
name: "Coverage",
url: "coverage.bw",
type: "wig",
color: "#4DBBD5"
},
{
name: "Peaks",
url: "peaks.bed",
type: "annotation",
color: "#E64B35"
}
]
};
igv.createBrowser(document.getElementById('igv-div'), options);
</script>
</body>
</html>
Create BigWig from BAM
# Using deepTools
bamCoverage -b sample.bam -o coverage.bw \
--binSize 10 --normalizeUsing RPKM --effectiveGenomeSize 2913022398
# Using bedtools + wigToBigWig
bedtools genomecov -bg -ibam sample.bam > coverage.bedGraph
sort -k1,1 -k2,2n coverage.bedGraph > coverage.sorted.bedGraph
bedGraphToBigWig coverage.sorted.bedGraph chrom.sizes coverage.bw
Multi-Region Plot
# pyGenomeTracks with BED regions
pyGenomeTracks --tracks tracks.ini --BED regions.bed \
--outFileName multi_region.pdf --dpi 150
# Gviz with multiple regions
regions <- GRanges(seqnames = 'chr1', ranges = IRanges(start = c(1e6, 2e6), end = c(1.5e6, 2.5e6)))
pdf('multi_region.pdf', width = 10, height = 8)
for (i in seq_along(regions)) {
plotTracks(track_list, from = start(regions[i]), to = end(regions[i]))
}
dev.off()
Related Skills
- genome-intervals/bigwig-tracks - BigWig file handling
- chip-seq/chipseq-visualization - ChIP-specific tracks
- hi-c-analysis/hic-visualization - Hi-C contact maps
Weekly Installs
3
Repository
gptomics/bioskillsInstalled on
windsurf2
trae2
opencode2
codex2
claude-code2
antigravity2