Я пытаюсь выполнить функцию, которая отображает некоторые данные, а затем воспроизводит звук (соответствующий этим данным) в RStudio. Однако кажется, что воспроизведение звука блокирует построение. Почему это?
plot.prod.df <- function(df, row) {
# given a row number and a df, plot the prod df for that trial
# create data
print(paste0("plotting production data. trial: ", row))
if(is.null(df$prod[[row]])){
stop("Invalid trial")
}
else {
# get relevant production data
prod.df <- data.frame("onset" = df$prod[[row]]$onset * 1000,
"pitch" = df$prod[[row]]$pitch,
"error" = df$prod[[row]]$error_boolean)
prod.df$error <- as.factor(prod.df$error)
# get target notes
target.notes <- str.mel.to.vector(df$stimuli.pitch[[row]], "-")
# check if there were playbacktimes
print(df$playback.times[[row]])
if (any(is.na(df$playback.times[[row]]))) {
print("no playback times on this trial")
# plot
ggplot(prod.df, aes(x=onset, y=pitch, color = error)) +
theme(panel.grid.major = element_blank(), panel.grid.minor = element_blank(),
panel.background = element_blank(), axis.line = element_line(colour = "black")) +
geom_hline(yintercept = target.notes, color = magma.colors[4], size = 2, alpha = 0.7) +
geom_point() +
scale_color_manual(values=c(magma.colors[1], magma.colors[2]))
}
else {
playback.times <- fromJSON(df$playback.times[[row]])[2:length(fromJSON(df$playback.times[[row]]))] # remove the default original playback
print(playback.times)
# plot
ggplot(prod.df, aes(x=onset, y=pitch, color = error)) +
theme(panel.grid.major = element_blank(), panel.grid.minor = element_blank(),
panel.background = element_blank(), axis.line = element_line(colour = "black")) +
geom_hline(yintercept = target.notes, color = magma.colors[4], size = 2, alpha = 0.7) +
geom_vline(xintercept = playback.times, color = magma.colors[5], size = 2, alpha = 0.7) +
geom_point() +
scale_color_manual(values=c(magma.colors[1], magma.colors[2]))
}
}
}
# set up WavPlayer
sound::setWavPlayer("./sox/play")
play.seq <- function(midi_notes, length_of_each_note) {
#print("playing sequence user heard")
freqs <- midi_to_freq(midi_notes)
sines <- lapply(freqs, sound::Sine, length_of_each_note)
for (i in seq_along(1:length(sines))) {
Sys.sleep(length_of_each_note)
sound::play(cutSampleEnds(sines[[i]])) # cutSampleEnds removes cracks
}
}
play.and.plot.trial <- function(df, row = NULL) {
# if a row isn't specified, randomly select a row
if (is.null(row)) {
sampled_trial <- sample(1:nrow(df), 1)
}
else {
sampled_trial <- row
}
print(paste0("no. trial to plot: ", sampled_trial))
plot.prod.df(df, sampled_trial)
play.seq(str.mel.to.vector(df$stimuli.pitch[[sampled_trial]], "-"), 0.25)
}
play.and.plot.trial(dat)
Я могу подтвердить, что, если я закомментирую следующую строку и запущу play.and.plot.trial (dat), она построит график:
play.seq(str.mel.to.vector(df$stimuli.pitch[[sampled_trial]], "-"), 0.25)
I я не уверен, почему это останавливает построение графика; я думаю, он выводит только на консоль.
Я также пробовал добавить Sys.sleep (5) перед воспроизведением звука, и это не помогло.