This package allows users to create high-quality heatmaps from
labelled hierarchical data. Specifically, it requires input data in the
form of a two-level hierarchical structure. It will produce a heatmap
where each row and column represent a category at the lower
level. Rows and columns are then grouped into a higher-level
groupings. Names for each higher-level category and
groupings are shown in the margins. While other packages
(e.g. dendextend) allow heatmap rows and columns to be
arranged by groups only, hhmR also allows the labelling of
the data at both the category and group level.
The package has two main functions: hhm and
tshhm. These are explained in more detail below.
hhm (Hierarchical
Heatmap)hhm creates a labelled heatmap from hierarchical data.
This function is useful to create a heatmap where the categories shown
on both the x and y axis are grouped in some way. This heatmap will
order the categories by their assigned groupings, and present both the
categories and grouping labels along the axes. An example using
geographic data might be a series of smaller geographies (lower
categories) which aggregate into larger geographical regions (upper
groups).
This function requires a data.frame containing columns which specify
the lower categories (ylower, xlower) and
upper groupings (yupper, xupper). These
categories and groupings are used to arrange and label rows and columns
on a heatmap. The data.frame must contain a values variable
containing values to populate the heatmap. Note that the groupings will,
by default, be arranged alphabetically (top to bottom / left to right).
The ordering of the groups can be manually specified by converting
yupper and/or xupper to factors. In this case,
the groupings will be ordered based on the ordering of the factor levels
provided.
Below is an example of the hhm function’s application.
For a more in-depth description of it’s usage, see the package
vignette.
# Import package
library(hhmR)
# Import toy demonstration dataset (see `?example_migration` for details)
data(example_migration)
# Intial heatmap
hierarchical_heatmap = hhm(df = example_migration,
ylower = "Origin County",
xlower = "Destination County",
yupper = "Origin Region",
xupper = "Destination Region",
values = "Migration",
yttl_width = 0.22,
xttl_height = 0.4)
# View result
hierarchical_heatmap

tshhm
(Time-Series Hierarchical Heatmap)tshhm creates a labelled time-series heatmap from
heirarchical data. This function is useful if you wish to create a
time-series heatmap where the categories shown on the y-axis can be
grouped in some way. This heatmap will order the categories by their
assigned group and present both the categories and group labels along
the y-axis. An example might be a series of smaller geographies (lower
categories) which aggregate into larger geographical regions (upper
groups).
This function requires a data.frame containing columns that specify
the lower categories (lower) and upper groups
(upper) that each value corresponds to. These categories
and groups will be used to arrange and label the rows of the heatmap.
The data.frame must also contain a values variable,
containing the values used to populate the heatmap, and a
times variable, containing the time period during which
each value was observed. Note that the groups in upper will
by default be arranged alphabetically (top to bottom). The ordering of
the groups can be manually specified by converting upper to
a factor. In this case, the groups will be ordered based on the ordering
of the factor levels. The ordering of rows within each group can also be
specified using the sort_lower variable.
Below is an of how the tshhm function can be used. For
more details, see the package
vignette.
# Import packages
library(dplyr)
# Import toy demonstration dataset (see `?example_time_series` for details)
data(example_time_series)
# Intial heatmap
time_series_heatmap = tshhm(df = example_time_series,
lower = "County",
upper = "Region",
times = "Year",
values = "Immigration",
yttl_width = 0.25)
# View result
time_series_heatmap
