Имитировать заполненный контур с ggplot - PullRequest
0 голосов
/ 27 ноября 2018

Я пытался имитировать вывод filled.contour с помощью ggplot geom_tile и geom_raster.Кажется, что есть некоторая интерполяция или что-то за кадром filled.contour, чтобы заполнить пробелы, особенно по оси Y.Любая идея, как сделать похожий, симпатичный сюжет с ggplot?

Данные, например, можно скачать здесь (ссылка ShareCSV).

Код например:

library("ggplot2")
library("reshape2")


file <- file.choose()
data <- read.csv(file, stringsAsFactors=FALSE, header=TRUE,
                 colClasses=c("POSIXct", rep("numeric", 12)),
                 check.names=FALSE)

palette <- colorRampPalette(c("darkblue", "blue", "lightblue1",
                              "green", "yellow", "red", "darkred"))

# GGplot version
df <- melt(data, id.vars="Time", measure.vars=names(data)[-1])
names(df)[2:3] <- c("Channel", "Value")
df$Channel <- log10(as.numeric(as.character(df$Channel)))
df$Value <- log10(df$Value)


p <- ggplot(data=df, aes(x=Time, y=Channel, fill=Value)) +
  # geom_tile() +
  geom_raster() +
  scale_y_continuous(expand=c(0, 0)) +
  scale_x_datetime(expand=c(0, 0)) +
  scale_fill_gradientn(colours=palette(100)) +
  theme_bw()

p

# Base version
Channel <- log10(as.numeric(names(data[-1])))
Value <- log10(data.matrix(data[, -1]))

filled.contour(x=data$Time, y=Channel, z=Value,
               color.palette=palette, nlevels=100)

Я попробовал следующее для df, и оно подошло довольно близко, но очень требовательно к вычислениям.

library("akima")

interpolation <- with(df, interp(x=Time, y=Channel, z=Value,
                      xo=seq(min(Time), max(Time), length.out=nrow(data)),
                      duplicate="mean"))

df<- interp2xyz(interpolation, data.frame=TRUE)
names(df) <- c("Time", "Channel", "Value")
df$Time <- as.POSIXct(df$Time, origin="1970-01-01")

Результат:

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...