A hodge-podge of useful functions.
This is essentially my sandbox R Package. It has a hodge-podge of functions that I’ve used over the past several years. As I work with my sociophonetic data, I find myself running the same sorts of procedures over and over, so I often decide to write a generalized function to take care of that stuff in one line within a tidyverse pipeline.
The functions in joeyr
can be grouped into about five different
categories: the outlier detecters, sociophonetics functions, ggplot2
themes,
the “grapes”, and other helpful functions. This README briefly explains them all.
Some of these functions I’ve generalized into something that others may find useful. Others are very specific to my own code and workflow so I’m not sure if they’ll be useful to you. Some functions are documented well but lots are not.
For questions, feel free to contact me at [email protected] or on Twitter at @joey_stan.
This package can be downloaded to your computer by downloading it from Github.
#install.packages("devtools") # <- if not already installed
devtools::install_github("JoeyStanley/joeyr")
You can then load it like any other package.
library(joeyr)
## This is the "joeyr" package.
You’ll know you’ve got it installed properly when you see a little
message saying This is the "joeyr" package.
.
The main function, and the reason I created the package in the first
place, is find_outliers()
. It implements a version of the Mahalanobis
Distance, except it does so iteratively. After finding the distances for
each point, it marks the furthest token as an outlier, and then
recalculates the distance based on the remaining points. It continues
this one-at-a-time procedure until a proportion of your data (that
you’ve specified) has been removed.
For more details, see ?find_outliers
. In the future I’ll write a
vignette, blog post, or (perhaps some day) an article about it. For now,
look at the help page or email me.
Some functions in joeyr
are useful for sociophonetic analysis. This first set
includes what are essentially mathmatical functions in that they crunch some numbers.
-
eucl_dist()
calculates the Euclidean Distance, given a pair of x and y (or, more commonly, F1 and F2) coordinates. -
pillai()
calculates the Pillai score. It’s not a complicated process in general, but this function simplifies it down quite a bit so it doesn’t interrupt your workflow. -
tidy_mahalanobis()
is probably my favorite. It’s an implementation of themahalanobis()
function, which calculates the Mahalanobis distance, only it’s meant to work within atidyverse
pipeline of commands. Like thepillai()
function, it’s designed so that you can get the values you want without interrupting your flow. -
lbms_index()
allows you to quickly calculate the Low-Back-Merger Shift Index in your data (see Becker 2019; Boberg 2019).
There are three normalization procedures.
-
norm_anae()
makes it easy to do vowel formant normalization using the method described in the Atlas of North American English using just one line of code within a tidyverse pipeline. This is my current favorite normalization procedure and I was sick of writing large blocks of code in all my scripts, so I wrapped it up as a function. -
norm_deltaF()
is another way to normalize your data, based on Keith Johnson's (2020) paper. -
norm_logmeans()
is a straightforward log-means normalization procedure based on Barreda & Nearey (2018).
Finally, there are two functions are more about changing labels for phonemes and allophones.
-
switch_transcriptions()
(and its shortcuts including,arpa_to_wells()
), quickly converts between ARPABET labels and Wells (or Wells-inspired) keywords. -
code_allophones()
is a one-liner that adds contexual allophones ("BAN", "BAG", "SPOOL", "TOOT", etc.) to your vowel data.
These are currently not documented. The main one is theme_joey()
which will
produce plots using my own flavor of theme_bw()
. There are some variants
as well. The other helpful function is joey_arrow()
which is just a
shortcut for a type of arrow I like when I draw lines on a plot. I'll admit I
don't really use these anymore.
“Grapes” refer to the type of R functions that are flanked on either
side by %
, like %in%
. The ones here came about while writing my
dissertation (or rather, the code used to analze the data for my
dissertation) and were super helpful for that project.
-
%ni%
("not in"") is super handy and is the opposite if%in%
. I don’t use it so much anymore because I’ve figured out how to use!
properly, but I still love it. -
%wi%
("within") was one I wrote to see whether a number is within a range. I think tidyverse has%within%
somewhere in its suite of packages, but I wrote this before I knew about it. Plus, it’s a little shorter. -
%expanded_by%
takes a number and a range and expands the range by that much (applied to both sides). Soc(1, 3) %expanded_by% 3
producesc(-2, 6)
. It was helpul when I was automating the plots in my dissertation.
While writing my dissertation, I found myself doing the same sort of pipeline over and over so I just made a couple little shortcut functions to save myself some typing.
-
color_gradienter()
was needed in my Shiny app, The Gazetteer of Southern Vowels. I needed a way to take two arbitrary colors and produce an arbitrary number of colors at fixed intervals between them. This is helpful for plots: do you want to use your favorite color of green and your favorite color of blue, but also get three more colors in between them for a continuous scale?color_gradienter()
can do that. I don’t know everything about how color is encoded, but it seems to work well enough for me, though there may be some weird bugs. -
ucfirst()
was a function I copied over from Perl code. It just capitalizes the first character of a string. Unlike some other functions that are more sophisticaed and transform the text into title case, sometimes I just need the very first character only, rather than the first character of each word. -
get_centroids()
is a little shortcut that summarizes data quickly and is helpful when plotting medians within ellipses in ggplot2.
Previous versions of {joeyr}
had a couple other tools, but recent versions
of {tidyr}
and {dplyr}
have rendered them unnecessary. The following are
no longer part of {joeyr}
, though you can find the code on GitHub in the
R_depreciated
folder.
-
spread_n()
was perhaps my favorite function. I had a need for using the (old)tidyr::spread()
with multiplevalue
columns while reshaping formant data. I went to the RStudio forums and someone wrote a slick little function for me that I dubbedspread_n()
. (Kieran Healey saw that post and wrote a blog post on it!). The function has since been rendered obsolete with the newtidyr::pivot_wider()
(Kieran Healey wrote about that too), so I don’t usespread_n()
anymore. Perhaps it’ll eventually be removed from the package. But I can’t help but think that my asking that question had some role in thepivot_wider()
function. -
move_x_after_y()
andmove_x_before_y()
are helpful for when you want to take a column that you’ve just created and move it before or after some existing column. It’s a little buggy when you work with columns on the edges of your dataframe, but it worked well for me and my dissertation code. Note that oncedplyr
1.0.0 is released, these functions will be phased out since the newdplyr::relocate
function does what I intended these do to.
If you use this package, I would appreciate a citation. You can cite it as:
Stanley, Joseph A. joeyr: Functions for Vowel Data (R package version ###), 2023. https://joeystanley.github.io/joeyr/
Specifically, if you use the find_outliers()
function, you can refer to it as
something like "the Modified Mahalanobis Distance method implemented in Stanley
(2020)."
Stanley, Joseph A. “The Absence of a Religiolect among Latter-Day Saints in Southwest Washington.” In Speech in the Western States: Volume 3, Understudied Varieties, by Valerie Fridland, Alicia Beckford Wassink, Lauren Hall-Lew, and Tyler Kendall, 95–122. Publication of the American Dialect Society 105. Durham, NC: Duke University Press, 2020. https://doi.org/10.1215/00031283-8820642.
That’s joeyr
. I hope you find it useful!