Nothing
#' Plot pitch object
#'
#' Function for plotting pitch objects called by [praatpicture]. Instead of
#' using this function directly, just use
#' `praatpicture('my_sound_file', frames='pitch')`.
#'
#' @param pt PitchTier object loaded using [rPraat::pt.read]
#' @param start Start time (in seconds) of desired plotted area.
#' @param end End time (in seconds) of desired plotted area.
#' @param tfrom0 Logical; should time on the x-axis run from 0 or from the
#' original time? Default is `TRUE`.
#' @param tgbool Logical; should dotted lines be plotted corresponding to
#' locations in a TextGrid? Default is `FALSE`.
#' @param lines Numeric vector giving locations in seconds of locations from
#' a TextGrid to be plotted with dotted lines. Default is `NULL`.
#' @param focusTierColor String or vector of strings giving the color(s) to
#' use for plotting focus tier lines. If multiple tiers are focused, a vector
#' of the same length can be passed, and the nth tier will be plotted in the
#' nth color. Default is `'black'`.
#' @param focusTierLineType String or vector of strings giving the line
#' type(s) for plotting focus tier lines. If multiple tiers are focused, a
#' vector of the same length can be passed, and the nth tier will be plotted in
#' the nth line type. Default is `'dotted'`.
#' @param plotType String giving the type of pitch plot to produce; default
#' is `draw` (a line plot), the only other option is `speckle` (a point plot).
#' Alternatively a vector `c('draw','speckle')` can be passed, in which case
#' both are used.
#' @param scale String giving the frequency scale to use when producing
#' pitch plots. Default is `hz`; other options are `logarithmic` (also in Hz),
#' `semitones`, `erb`, and `mel`.
#' @param freqRange Vector of two integers giving the frequency range to be
#' used for producing pitch plots. Default is `NULL`, in which case the pitch
#' range is automatically reset to `c(-12,30)` for the `semitones` scale,
#' `c(0,10)` for the `erb` scale, and `c(50,500)` for the Hz-based scales,
#' following Praat defaults.
#' @param semitonesRe Frequency in Hz giving the reference level for converting
#' pitch frequency to semitones. Default is `100`.
#' @param color String giving the name of the color to be used for
#' plotting pitch. Default is `'black'`.
#' @param ind Integer indexing waveform relative to other plot components.
#' Default is `NULL`.
#' @param min_max_only Logical; should only minimum and maximum values be given
#' on the y-axis? Default is `TRUE`. Can also be a logical vector if some but
#' not all plot components should have minimum and maximum values on the y-axis.
#' Ignored for TextGrid component.
#' @param highlight Named list giving parameters for differential
#' highlighting of pitch based on the time domain. This list
#' should contain information about which parts of the plot to highlight, either
#' done with the `start` and `end` arguments which must be numbers or numeric
#' vectors, or using the `tier` and `label` arguments to highlight based on
#' information in a plotted TextGrid. Further contains the optional arguments
#' `color` (string or vector of strings, see `color`),
#' `drawSize` or `speckleSize` (both numeric), and `background`
#' (a string specifying a background color).
#' @param axisLabel String giving the name of the label to print along the
#' y-axis when printing a pitch track. Default is `NULL`, in which case the
#' axis label will depend on the scale.
#' @param drawSize Number indicating the line width if
#' `plotType` is `'draw'`. Default is `1`. Controls the `lwd` argument of
#' [graphics::lines].
#' @param speckleSize Number indicating the point size of if `_plotType` is
#' `'speckle'`. Default is `1`. Controls the `cex` arguments of
#' [graphics::points].
#'
#' @return No return values, called internally by [praatpicture] and sibling
#' functions.
#' @export
#'
#' @examples
#' # Don't use directly
#' datapath <- system.file('extdata', package='praatpicture')
#' soundFile <- paste0(datapath, '/1.wav')
#' praatpicture(soundFile, frames='pitch')
pitchplot <- function(pt, start, end, tfrom0=TRUE, tgbool=FALSE, lines=NULL,
focusTierColor='black', focusTierLineType='dotted',
plotType='draw', scale='hz', freqRange=NULL,
semitonesRe=100, color='black', ind=NULL,
min_max_only=TRUE, highlight=NULL,
axisLabel=NULL, drawSize=1, speckleSize=1) {
if (scale == 'logarithmic') {
logsc <- 'y'
} else {
logsc <- ''
}
if (!min_max_only[ind]) {
if (ind == 1 | scale == 'logarithmic') {
yax <- 's'
} else {
ytix <- grDevices::axisTicks(freqRange, log=F)
ytix <- ytix[-length(ytix)]
yax <- 'n'
}
} else {
yax <- 'n'
ytix <- freqRange
}
if (tfrom0) {
pt$t <- pt$t - start
start <- 0
}
if (!is.null(highlight)) {
highlight_tSpeckle <- c()
highlight_fSpeckle <- c()
highlight_tDraw <- c()
highlight_fDraw <- c()
for (int in 1:length(highlight$start)) {
times <- which(pt$t > highlight$start[int] & pt$t < highlight$end[int])
highlight_tSpeckle <- c(highlight_tSpeckle, pt$t[times],
max(pt$t[times] + 0.0001))
highlight_fSpeckle <- c(highlight_fSpeckle, pt$f[times], NA)
if (highlight$start[int] < start) {
extrema <- zoo::na.approx(c(NA, pt$f),
c(highlight$end[int], pt$t))
highlight_tDraw <- c(highlight_tDraw,
pt$t[times], highlight$end[int],
max(pt$t[times] + 0.0001))
highlight_fDraw <- c(highlight_fDraw, pt$f[times], extrema[1], NA)
} else {
extrema <- zoo::na.approx(c(NA, NA, pt$f),
c(highlight$start[int], highlight$end[int],
pt$t))[1:2]
highlight_tDraw <- c(highlight_tDraw, highlight$start[int],
pt$t[times], highlight$end[int],
max(pt$t[times] + 0.0001))
highlight_fDraw <- c(highlight_fDraw, extrema[1], pt$f[times],
extrema[2], NA)
}
if (any(highlight$start < start)) {
highlight$start[which(highlight$start < start)] <- start
}
if (any(highlight$end > end)) {
highlight$end[which(highlight$end > end)] <- end
}
}
if (!'color' %in% names(highlight)) highlight$color <- color
if (!'drawSize' %in% names(highlight)) highlight$drawSize <- drawSize
if (!'speckleSize' %in% names(highlight)) highlight$speckleSize <-
speckleSize
}
if ('draw' %in% plotType) {
plot(pt$t, pt$f, xlim=c(start, end+start), xaxt='n', ylim=freqRange,
yaxt=yax, type='l', log=logsc, col=color, lwd=drawSize)
if (ind != 1 & scale != 'logarithmic' & !min_max_only[ind]) {
graphics::axis(2, at=ytix)
}
if (min_max_only[ind]) graphics::axis(2, at=ytix, las=2, padj=c(0,1),
tick=F)
if ('speckle' %in% plotType) {
graphics::points(pt$t, pt$f, pch=20, col=color, cex=speckleSize)
}
if (!is.null(highlight)) {
if ('background' %in% names(highlight)) {
graphics::rect(highlight$start,
freqRange[1] - freqRange[2] * 2,
highlight$end,
freqRange[2] + freqRange[2] * 2,
col = highlight$background, border = NA)
}
graphics::lines(highlight_tDraw, highlight_fDraw, col=highlight$color,
lwd=highlight$drawSize)
if ('speckle' %in% plotType) {
graphics::points(highlight_tSpeckle, highlight_fSpeckle, pch=20,
col=highlight$color, cex=highlight$speckleSize)
}
}
if (tgbool) {
for (i in 1:length(lines)) {
graphics::abline(v=lines[[i]], col=focusTierColor[i],
lty=focusTierLineType[i])
}
}
graphics::mtext(axisLabel, side=2, line=3.5, cex=0.8)
}
if (length(plotType) == 1) {
if (plotType == 'speckle') {
plot(pt$t, pt$f, xlim=c(start, end+start), xaxt='n', ylim=freqRange,
yaxt=yax, type='p', pch=20, log=logsc, col=color, cex=speckleSize)
if (ind != 1 & scale != 'logarithmic' & !min_max_only[ind]) {
graphics::axis(2, at=ytix)
}
if (min_max_only[ind]) graphics::axis(2, at=ytix, las=2, padj=c(0,1),
tick=F)
if (!is.null(highlight)) {
if ('background' %in% names(highlight)) {
graphics::rect(highlight$start,
freqRange[1] - freqRange[2] * 2,
highlight$end,
freqRange[2] + freqRange[2] * 2,
col = highlight$background, border = NA)
}
graphics::points(highlight_tSpeckle, highlight_fSpeckle,
col=highlight$color, pch=20,
cex=highlight$speckleSize)
if ('draw' %in% plotType) {
graphics::lines(highlight_tDraw, highlight_fDraw, col=highlight$color,
lwd=highlight$drawSize)
}
}
if (tgbool) {
for (i in 1:length(lines)) {
graphics::abline(v=lines[[i]], col=focusTierColor[i],
lty=focusTierLineType[i])
}
}
graphics::mtext(axisLabel, side=2, line=3.5, cex=0.8)
}
}
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.