В настоящее время я пытаюсь использовать ggplot2 для визуализации результатов простых экспериментов по току и напряжению. Мне удалось добиться хороших результатов для одного набора данных, конечно.
Однако у меня есть несколько наборов данных о напряжении тока, которые я рекурсивно ввожу в R, чтобы получить следующую организацию (см. Минимальный код):
data.frame(cbind(batch(string list), sample(string list), dataset(data.frame list)))
Редактировать: мои данные хранятся в текстовых файлах с именами batchname_samplenumber.txt, со столбцами напряжения и тока. Код, который я использую для их импорта:
require(plyr)
require(ggplot2)
#VARIABLES
regex <- "([[:alnum:]_]+).([[:alpha:]]+)"
regex2 <- "G5_([[:alnum:]]+)_([[:alnum:]]+).([[:alpha:]]+)"
#FUNCTIONS
getJ <- function(list, k) llply(list, function(i) llply(i, function(i, indix) getElement(i,indix), indix = k))
#FILES
files <- list.files("Data/",full.names= T)
#NAMES FOR FILES
paths <- llply(llply(files, basename),function(i) regmatches(i,regexec(regex,i)))
paths2 <- llply(llply(files, basename),function(i) regmatches(i,regexec(regex2,i)))
names <- llply(llply(getJ(paths, 2)),unlist)
batches <- llply(llply(getJ(paths2, 2)),unlist)
samples <- llply(llply(getJ(paths2, 3)),unlist)
#SETS OF DATA, NAMED
sets <- llply(files,function(i) read.table(i,skip = 0, header = F))
names(sets) <- names
for (i in as.list(names)) names(sets[[i]]) <- c("voltage","current")
df<-data.frame(cbind(batches,samples,sets))
И минимальные данные могут быть получены с помощью:
require(plyr)
batch <- list("A","A","B","B")
sample <- list(1,2,1,2)
set <- list(data.frame(voltage = runif(10), current = runif(10)),data.frame(voltage = runif(10), current = runif(10)),data.frame(voltage = runif(10), current = runif(10)),data.frame(voltage = runif(10), current = runif(10)))
df<-data.frame(cbind(batch,sample,set))
У меня вопрос: можно ли использовать данные как есть для построения графика, используя код, подобный следующему (что не работает)?
ggplot(data, aes(x = dataset$current, y = dataset$voltage, colour = sample)) + facet_wrap(~batch)
Более общей версией было бы: способен ли ggplot2 обрабатывать необработанные физические данные, в отличие от дискретных статистических данных (таких как алмазы, автомобили)?