Title: | Flexible Heatmaps for Functional Genomics and Sequence Features |
---|---|
Description: | This package provides functions for plotting heatmaps of genome-wide data across genomic intervals, such as ChIP-seq signals at peaks or across promoters. Many functions are also provided for investigating sequence features. |
Authors: | Malcolm Perry <[email protected]> |
Maintainer: | Malcolm Perry <[email protected]> |
License: | Artistic-2.0 |
Version: | 1.31.0 |
Built: | 2025-01-17 04:09:52 UTC |
Source: | https://github.com/bioc/heatmaps |
Return or set the coords in a Heatmap
coords(x) ## S4 method for signature 'Heatmap' coords(x) coords(x) <- value ## S4 replacement method for signature 'Heatmap' coords(x) <- value
coords(x) ## S4 method for signature 'Heatmap' coords(x) coords(x) <- value ## S4 replacement method for signature 'Heatmap' coords(x) <- value
x |
A heatmap |
value |
Replacement value |
integer, length 2, value of x@coords
data(HeatmapExamples) coords(hm) = c(-100, 100)
data(HeatmapExamples) coords(hm) = c(-100, 100)
Generate a Heatmap of coverage
CoverageHeatmap(windows, track, ...) ## S4 method for signature 'GenomicRanges,GenomicRanges' CoverageHeatmap(windows, track, coords = NULL, weight = 1, label = NULL, nbin = 0) ## S4 method for signature 'GenomicRanges,RleList' CoverageHeatmap(windows, track, coords = NULL, label = NULL, nbin = 0)
CoverageHeatmap(windows, track, ...) ## S4 method for signature 'GenomicRanges,GenomicRanges' CoverageHeatmap(windows, track, coords = NULL, weight = 1, label = NULL, nbin = 0) ## S4 method for signature 'GenomicRanges,RleList' CoverageHeatmap(windows, track, coords = NULL, label = NULL, nbin = 0)
windows |
A set of GRanges of equal length |
track |
A GRanges or RleList object specifying coverage |
... |
additional arguments used by methods This function generates a Heatmap object from a set of windows and an object containing genome-wide information about coverage. Either a GRanges or an RleList can be used. In the former case, the "weight" paramter is passed directly to the 'coverage' function. If nbin is set, binned coverage is calculated which will save memory and time when plotting and average out varible data. If the coverage track contains negative values, then the scale will be centered on zero, ie. c(-max(abs(image(hm))), max(abs(image(hm)))). This makes more sense for most color schemes which are centered on zero, and avoids misleading plots where either positive or negative values are over-emphasised. See ?getScale for details. The scale can be manually reset if desired using the "scale" method. |
coords |
Co-ordinates for the heatmap, defaults to c(0, width(windows)) |
weight |
Passed to coverage(track) constructor if class(track) == "GRanges" |
label |
Label for the heatmap |
nbin |
If set, number of bins to use across each window |
A Heatmap object
windows = GenomicRanges,track = GenomicRanges
: Heatmap of Coverage from 2 GRanges
windows = GenomicRanges,track = RleList
: Heatmap of Coverage from GRanges + RleList
data(HeatmapExamples) CoverageHeatmap(windows, rle_list, coords=c(-100, 100), label="Example")
data(HeatmapExamples) CoverageHeatmap(windows, rle_list, coords=c(-100, 100), label="Example")
Predifined color palettes from RColorBrewer + Rainbow
default_color(col)
default_color(col)
col |
Character, RColorBrewer colorscheme or "Rainbow" This function provides a convenient function to all color palettes from RColorBrewer, and a better version of R's rainbow function (specifically rev(rainbow(9, start=0, end=4/6)), so it starts blue and ends with red). |
character, a length-9 color palette
default_color("Blues") default_color("Rainbow")
default_color("Blues") default_color("Rainbow")
Make an appropriate scale for a heatmap
getScale(x, y)
getScale(x, y)
x |
Min/max values for the heatmap |
y |
Min/max values for the heatmap This function takes min/max values for a heatmap and generates a scale either starting, ending or centered on zero. |
numeric, length 2, a new scale
getScale(0.5, 5) # c(0, 5) getScale(-6, -2) # c(-6, 6) getScale(-6, 2) # c(-6, 6)
getScale(0.5, 5) # c(0, 5) getScale(-6, -2) # c(-6, 6) getScale(-6, 2) # c(-6, 6)
Function to create a heatmap object
Heatmap(image, coords = NULL, label = "", nseq = NULL, scale = NULL, metadata = list())
Heatmap(image, coords = NULL, label = "", nseq = NULL, scale = NULL, metadata = list())
image |
A numeric Matrix |
coords |
A length-2 integer vector |
label |
A character vector |
nseq |
An integer |
scale |
A length-2 vector |
metadata |
A list containing arbitrary metadata Using this function avoids calling 'new' directly or manually setting coords and nseq to integers. Other constructors exist for creating heatmaps from data, rather than a raw matrix. |
A Heatmap object
PatternHeatmap CoverageHeatmap PWMScanHeatmap
data(HeatmapExamples) hm = Heatmap(mat, coords=c(-100, 100), label="Test")
data(HeatmapExamples) hm = Heatmap(mat, coords=c(-100, 100), label="Test")
An S4 class to represent a heatmap
image
A numeric Matrix
scale
A length-2 vector
coords
A length-2 integer vector
nseq
An integer
label
A character vector
metadata
A list containing arbitrary metadata
A class used to represent a heatmap in a simple, self-contained way
Slots can be accessed and set using getters and setters with the same name.
CoverageHeatmap PatternHeatmap plotHeatmap plotHeatmapMeta
data(HeatmapExamples) hm = new("Heatmap", image=mat, scale=c(0,max(mat)), coords=c(-100L, 100L), nseq=1000L, label="Test", metadata=list()) # or use the constructor: hm = Heatmap(mat, coords=c(-100, 100), label="Test")
data(HeatmapExamples) hm = new("Heatmap", image=mat, scale=c(0,max(mat)), coords=c(-100L, 100L), nseq=1000L, label="Test", metadata=list()) # or use the constructor: hm = Heatmap(mat, coords=c(-100, 100), label="Test")
Generated Data for examples
An example heatmap
A second example heatmap
An example matrix
An example RleList
An example DNAStringSet
An example PWM
An example GRanges
hm hm2 mat rle_list string_set tata_pwm windows
hm hm2 mat rle_list string_set tata_pwm windows
An object of class Heatmap
of length 500.
invisible("HeatmapExamples")
Generate default options for a Heatmap
heatmapOptions(...)
heatmapOptions(...)
... |
options to set manually Guide to Heatmap options This is an reference to all the possible options for plotting heatmaps. Some options are handled by heatmaps functions (either plotHeatmap or plotHeatmapList), others are passed directly to plotting functions. Further explanation is available in the vignette. Arguments are numeric if not otherwise stated. color: A vector of colors or a default color, see ?default_color. plotHeatmap will interpolate between these colors to form a scale. box.width: width of box around the heatmap, passed to box() x.ticks: Logical, plot x axis ticks x.tick.labels: Character, labels to use for x ticks, (default blank) tcl: Length of x axis ticks padj: Vertical adjustment of x axis labels cex.axis: cex for axis labels scale: Logical, Plot scale or not scale.label: Character, label for scale scale.lwd: Width for line around scale cex.scale: Cex for Scale label: Logical, plot label or not label.xpos: x position for label, from left label.ypos: y position for label, from top cex.label: cex for axis labels label.col: Color for label, white is often useful for dark plots legend: Logical, plot legend (scale indicating values for colors) legend: Color for label, white is often useful for dark plots legend.pos: Character, position of legend relative to heatmap: 'l' for left, 'r' for right legend.ticks: Number of ticks to use on legend. cex.legend: cex to use for legend marks refline: Logical, Draw dashed line at coords = 0 label: Logical, plot label or not label.xpos: x position for label, from left label.ypos: y position for label, from top cex.label: cex for axis labels label.col: Color for label, white is often useful for dark plots legend: Logical, plot legend (scale indicating values for colors) legend: Color for label, white is often useful for dark plots legend.pos: Character, position of legend relative to heatmap: 'l' for left, 'r' for right legend.ticks: Number of ticks to use on legend. cex.legend: cex to use for legend marks refline: Logical, Draw dashed line at coords = 0 refline.width: Width of reference line transform: Function to transform values before plotting plot.mai: Length-4 numeric, margins around plot legend.mai: Length-4 numeric, margins around legend partition: Numeric, relative sizes of clusters partition.lines: Logical, plot lines delineating clusters partition.legend: Logical, plot cluster legend in HeatmapList partition.col: Character, colours to use for plotting clusters. Defaults to RColorBrewer's Set1 hook: Function called after plotting is complete. |
a list containing the specified options
plotHeatmap plotHeatmapList
myOptions = heatmapOptions() myOptions$color = "Reds" # plotHeatmap(hm, options=myOptions)
myOptions = heatmapOptions() myOptions$color = "Reds" # plotHeatmap(hm, options=myOptions)
Return or set the image in a Heatmap
## S4 method for signature 'Heatmap' image(x) image(x) <- value ## S4 replacement method for signature 'Heatmap' image(x) <- value
## S4 method for signature 'Heatmap' image(x) image(x) <- value ## S4 replacement method for signature 'Heatmap' image(x) <- value
x |
A heatmap |
value |
Replacement value |
matrix, from hm@image
data(HeatmapExamples) image(hm) = log(image(hm)) scale(hm) = c(0, max(image(hm)))
data(HeatmapExamples) image(hm) = log(image(hm)) scale(hm) = c(0, max(image(hm)))
Return or set the label in a Heatmap
label(x) ## S4 method for signature 'Heatmap' label(x) label(x) <- value ## S4 replacement method for signature 'Heatmap' label(x) <- value
label(x) ## S4 method for signature 'Heatmap' label(x) label(x) <- value ## S4 replacement method for signature 'Heatmap' label(x) <- value
x |
A heatmap |
value |
Replacement value |
character, value of hm@label
data(HeatmapExamples) label(hm) = "NewLabel" label(hm) # "NewLabel"
data(HeatmapExamples) label(hm) = "NewLabel" label(hm) # "NewLabel"
Return the number of sequences in a heatmap
## S4 method for signature 'Heatmap' length(x)
## S4 method for signature 'Heatmap' length(x)
x |
A heatmap |
integer, value of x@nseq
Store arbitrary metadata in a list, if desired.
metadata(x) ## S4 method for signature 'Heatmap' metadata(x) metadata(x) <- value ## S4 replacement method for signature 'Heatmap' metadata(x) <- value
metadata(x) ## S4 method for signature 'Heatmap' metadata(x) metadata(x) <- value ## S4 replacement method for signature 'Heatmap' metadata(x) <- value
x |
A heatmap |
value |
Replacement value |
list, value of hm@metadata
data(HeatmapExamples) metadata(hm) = list(replicate=1, cell_line="ESC") metadata(hm)$replicate == 1
data(HeatmapExamples) metadata(hm) = list(replicate=1, cell_line="ESC") metadata(hm)$replicate == 1
Return or set nseq in a Heatmap
nseq(x) ## S4 method for signature 'Heatmap' nseq(x) nseq(x) <- value ## S4 replacement method for signature 'Heatmap' nseq(x) <- value
nseq(x) ## S4 method for signature 'Heatmap' nseq(x) nseq(x) <- value ## S4 replacement method for signature 'Heatmap' nseq(x) <- value
x |
A heatmap |
value |
Replacement value |
integer, value of hm@nseq
data(HeatmapExamples) nseq(hm) = 1000
data(HeatmapExamples) nseq(hm) = 1000
Generate a Heatmap of patterns in DNA sequence
PatternHeatmap(seq, pattern, ...) ## S4 method for signature 'DNAStringSet,character' PatternHeatmap(seq, pattern, coords = NULL, min.score = NULL, label = NULL) ## S4 method for signature 'DNAStringSet,matrix' PatternHeatmap(seq, pattern, coords = NULL, min.score = "80%", label = NULL)
PatternHeatmap(seq, pattern, ...) ## S4 method for signature 'DNAStringSet,character' PatternHeatmap(seq, pattern, coords = NULL, min.score = NULL, label = NULL) ## S4 method for signature 'DNAStringSet,matrix' PatternHeatmap(seq, pattern, coords = NULL, min.score = "80%", label = NULL)
seq |
A DNAString of equal length |
pattern |
A nucleotide pattern or PWM |
... |
additional arguments used by methods This function creates a Heatmap from a set of DNA sequences. The resulting heatmap will be binary, with 1 representing a match and 0 otherwise. Patterns can be specified as a character vectore, eg. "CTCCC", or as a PWM. These arguments are passed to Biostrings functions, 'vmatchPattern' and 'matchPWM'. Character arguments can contain standard ambiguity codes. PWMs must be 4 by n matricies with columns names ACGT. "min.score" is specified either as an absolute value, or more commonly as a percentage e.g. "80 for details. PatternHeatmaps often look much better after smoothing. |
coords |
Co-ordinates for the heatmap, defaults to c(0, width(windows)) |
min.score |
Minimum score for PWM match |
label |
Label for the heatmap |
A heatmap
seq = DNAStringSet,pattern = character
: Heatmap of sequence patterns from sequence and character
seq = DNAStringSet,pattern = matrix
: Heatmap of sequence patterns from sequence and matrix
smoothHeatmap
data(HeatmapExamples) PatternHeatmap(string_set, "TA", coords=c(-100, 100), label="TA") PatternHeatmap(string_set, tata_pwm, coords=c(-100, 100), min.score="80%", label="TATA PWM")
data(HeatmapExamples) PatternHeatmap(string_set, "TA", coords=c(-100, 100), label="TA") PatternHeatmap(string_set, tata_pwm, coords=c(-100, 100), min.score="80%", label="TATA PWM")
Plot partition in a separate panel
plot_clusters(options)
plot_clusters(options)
options |
heatmapOptions passed as a list Two heatmapOptions values are relevant: * partition Numeric vector containing relative sizes of the clusters * colors Colors to use for clusters, additional colors are discarded This function plots a vertical color scale (or legend). With the default parameters, it looks good at about 1/5 the width of a heatmap, about 1cm x 10cm. This function only plots the legend, it does not set margin parameters. |
invisible(0)
plotHeatmapList
data(HeatmapExamples) opts = heatmapOptions() opts$partition = c(1,2,3,4) par(mai=opts$legend.mai) plot_clusters(opts)
data(HeatmapExamples) opts = heatmapOptions() opts$partition = c(1,2,3,4) par(mai=opts$legend.mai) plot_clusters(opts)
Plot a color legend for a heatmap
plot_legend(scale, options)
plot_legend(scale, options)
scale |
Numeric vector contain min and max for the scale |
options |
heatmapOptions passed as a list This function plots a vertical color scale (or legend). With the default parameters, it looks good at about 1/5 the width of a heatmap, about 1cm x 10cm. This function only plots the legend, it does not set margin parameters. |
invisible(0)
plotHeatmapList
data(HeatmapExamples) opts = heatmapOptions() opts$color = "Rainbow" par(mai=opts$legend.mai) plot_legend(c(0,1), opts)
data(HeatmapExamples) opts = heatmapOptions() opts$color = "Rainbow" par(mai=opts$legend.mai) plot_legend(c(0,1), opts)
Plot a Heatmap object to the device
plotHeatmap(heatmap, options = NULL, ...) ## S4 method for signature 'Heatmap' plotHeatmap(heatmap, options = NULL, ...)
plotHeatmap(heatmap, options = NULL, ...) ## S4 method for signature 'Heatmap' plotHeatmap(heatmap, options = NULL, ...)
heatmap |
A heatmap object |
options |
A list containing plotting options |
... |
Used for passing individual options This function will take a heatmap and plot it to the device with the specified options. Options can be passed together in a list or individually as additional arguments. If passing options as a list, it's best to first create a list containing the default settings using heatmapOptions() andmethod then setting options individually. plotHeatmap() does not control device settings at all, these can be set using plotHeatmapList() and the relevant options in heatmapOptions() See ?heatmapOptions for a full list of options. |
invisible(0)
Heatmap
: Plot a Heatmap object to the device
heatmapOptions plotHeatmapList
data(HeatmapExamples) plotHeatmap(hm, color="Blues")
data(HeatmapExamples) plotHeatmap(hm, color="Blues")
Plot a list of heatmaps
plotHeatmapList(heatmap_list, groups = 1:length(heatmap_list), options = heatmapOptions(), ...)
plotHeatmapList(heatmap_list, groups = 1:length(heatmap_list), options = heatmapOptions(), ...)
heatmap_list |
A list of Heatmaps |
groups |
Optionally group heatmaps together |
options |
Heatmap options |
... |
Additional options This function takes a list of one or more heatmaps and plots them to a single image tiled horizontally. The "groups" argument specifies heatmaps to be grouped together and plotted using the same display parameters and a unified scale. plotHeatmapList will try to guess the best scale, either starting or finishing at zero, or symetrical aronud zero - if this is not the desired behaviour, make sure the scales are identical before the heatmaps are passed to the function. Options are specified as for plotHeatmap, but can be specified per group by passing a list of options instead of a single vector. Note the difference between a length-2 character vector, c("Reds", "Blues"), and a list contatining two length-1 character vectors: list("Reds", "Blues"). These are generally large, complex plots, so it can better to plot straight to a file. PNG is preferred since pdf files generated can be if the images are not downsized. The default settings are designed for plots of about 10cm x 20cm per heatmap, but all of the relevant settigns can be tweaked using the options. For display-quality images, it helps to increase the resolution at to at least 150ppi, double the default of 72ppi on most systems. |
invisible(0)
plotHeatmap heatmapOptions plot_legend
data(HeatmapExamples) plotHeatmapList(list(hm, hm2), groups=c(1,2), color=list("Reds", "Blues"))
data(HeatmapExamples) plotHeatmapList(list(hm, hm2), groups=c(1,2), color=list("Reds", "Blues"))
Plot a Meta-region plot from heatmaps
plotHeatmapMeta(hm_list, binsize = 1, colors = gg_col(length(hm_list)), addReferenceLine = FALSE)
plotHeatmapMeta(hm_list, binsize = 1, colors = gg_col(length(hm_list)), addReferenceLine = FALSE)
hm_list |
A list of heatmaps |
binsize |
Integer, size of bins to use in plot |
colors |
Color to use for each heatmap |
addReferenceLine |
Logical, add reference line at zero or not This function creates a meta-region plot from 1 or more heatmaps with the same coordinates. A meta-region plot graphs the sum of the signal at each position in each heatmap rather than visualising the signal in two dimensions. Often binning is required to smooth noisy signal. |
invisible(0)
data(HeatmapExamples) plotHeatmapMeta(hm, color="steelblue")
data(HeatmapExamples) plotHeatmapMeta(hm, color="steelblue")
Plot heatmaps for several patterns in DNA sequence
plotPatternDensityMap(seq, patterns, ...) ## S4 method for signature 'DNAStringSet' plotPatternDensityMap(seq, patterns, coords = NULL, min.score = "80%", sigma = c(3, 3), output.size = NULL, options = NULL, ...)
plotPatternDensityMap(seq, patterns, ...) ## S4 method for signature 'DNAStringSet' plotPatternDensityMap(seq, patterns, coords = NULL, min.score = "80%", sigma = c(3, 3), output.size = NULL, options = NULL, ...)
seq |
DNAStringSet of equal width |
patterns |
A vector or list of patterns |
... |
Additional Heatmap plotting options This function is a convenient wrapper for plotting many different patterns for the same set of sequences. PatternHeatmap() is applied to the sequence for each pattern in the list, they are passed to smoothHeatmap() with the supplied parameters and finally PlotHeatmapList(). If fine-grained control is desired, or you want to mix other plot types, then more information is available in the vignette. |
coords |
Heatmap coords |
min.score |
Minimum score for PWM match |
sigma |
Bandwith for smoothing kernel |
output.size |
Output size of final image |
options |
Heatmap plotting options |
invisible(0)
DNAStringSet
: Plot heatmaps for several patterns in DNA sequence
PatternHeatmap plotHeatmapList smoothHeatmap
data(HeatmapExamples) plotPatternDensityMap(string_set, c("AT", "CG"), coords=c(-200, 200))
data(HeatmapExamples) plotPatternDensityMap(string_set, c("AT", "CG"), coords=c(-200, 200))
Generate a Heatmap of PWM Scores in DNA sequnce
PWMScanHeatmap(seq, pwm, ...) ## S4 method for signature 'DNAStringSet,matrix' PWMScanHeatmap(seq, pwm, coords = NULL, label = "")
PWMScanHeatmap(seq, pwm, ...) ## S4 method for signature 'DNAStringSet,matrix' PWMScanHeatmap(seq, pwm, coords = NULL, label = "")
seq |
A DNAString of equal length |
pwm |
A PWM |
... |
additional arguments used by methods This function creates a heatmap where each point is the score of a PWM match starting from that position, which can visualise regions of enrichment or exclusion of certain motifs |
coords |
Co-ordinates for the heatmap, defaults to c(0, width(windows)) |
label |
Label for the heatmap |
A heatmap
seq = DNAStringSet,pwm = matrix
: Heatmap of PWM Scores
PatternHeatmap
data(HeatmapExamples) PatternHeatmap(string_set, tata_pwm, coords=c(-100, 100), label="TATA Scan")
data(HeatmapExamples) PatternHeatmap(string_set, tata_pwm, coords=c(-100, 100), label="TATA Scan")
Reflect a heatmap in the x axis
## S4 method for signature 'Heatmap' rev(x)
## S4 method for signature 'Heatmap' rev(x)
x |
A heatmap |
A heatmap
Return or set the scale in a Heatmap
scale(x) ## S4 method for signature 'Heatmap' scale(x) scale(x) <- value ## S4 replacement method for signature 'Heatmap' scale(x) <- value
scale(x) ## S4 method for signature 'Heatmap' scale(x) scale(x) <- value ## S4 replacement method for signature 'Heatmap' scale(x) <- value
x |
A heatmap |
value |
Replacement value |
numeric, length 2, the value of hm@scale
data(HeatmapExamples) scale(hm) = c(-1000, 1000)
data(HeatmapExamples) scale(hm) = c(-1000, 1000)
Smooth a heatmap
smoothHeatmap(heatmap, ...) ## S4 method for signature 'Heatmap' smoothHeatmap(heatmap, sigma = c(3, 3), output.size = dim(image(heatmap)), algorithm = NULL)
smoothHeatmap(heatmap, ...) ## S4 method for signature 'Heatmap' smoothHeatmap(heatmap, sigma = c(3, 3), output.size = dim(image(heatmap)), algorithm = NULL)
heatmap |
A heatmap object |
... |
additional arguments to S4 methods This function smooths a heatmap using either binned kernel density (more efficient for binary heatmaps) or gaussian blur. Sigma controls the SD of the kernel in both cases, defined in terms of pixels. This means that if you have very diffirent x and y dimensions (eg. a 200bp heatmap around 10000 promoters) you will need to compensate by setting sigma[2] higher to get the same visual effect in both dimensions "output.size" specifies the dimensions of the output matrix. This can be useful to reduce plotting time significantly. Smoothing can use either a kernel density estimate or a blurring function. The methods implemented are KernSmooth:bkde2D and EBImage::filter2 with a gaussian filter. The kernel based method assumes we are smoothing individual points so the value of these points are ignored. This is most useful for smoothing PatternHeatmaps where each cell in the matrix is either 1 or 0. For non-binary heatmaps, blur is most appropriate. Not setting this parameter will choose the method automatically. Scaling the output heatmap is handled as in CoverageHeatmap. |
sigma |
Numeric, lengt2, (recycled if length 1) |
output.size |
Numeric, length 2 |
algorithm |
"kernel" or "blur" |
A heatmap
Heatmap
: Smooth a heatmap
data(HeatmapExamples) hm_smoothed = smoothHeatmap(hm, sigma=c(5,5), algorithm="blur")
data(HeatmapExamples) hm_smoothed = smoothHeatmap(hm, sigma=c(5,5), algorithm="blur")
Return the width of sequence represented in a heatmap
## S4 method for signature 'Heatmap' width(x)
## S4 method for signature 'Heatmap' width(x)
x |
A heatmap |
integer
Generate co-ordinates for each row of the image matrix of a Heatmap
xm(x) ## S4 method for signature 'Heatmap' xm(x)
xm(x) ## S4 method for signature 'Heatmap' xm(x)
x |
A Heatmap |
numeric, a list of co-ordinates for plotting values in hm@image
Heatmap
: Generate co-ordinates for each frow of the image matrix of a Heatmap
data(HeatmapExamples) xm(hm)
data(HeatmapExamples) xm(hm)
Generate co-ordinates for each column of the image matrix of a Heatmap
ym(x) ## S4 method for signature 'Heatmap' ym(x)
ym(x) ## S4 method for signature 'Heatmap' ym(x)
x |
A Heatmap |
numeric, a list of co-ordinates for plotting values in hm@image
Heatmap
: Generate co-ordinates for each column of the matrix
data(HeatmapExamples) ym(hm)
data(HeatmapExamples) ym(hm)