2016-06-16 51 views
5

Ho il seguente codice che ha funzionato perfettamente in qualche vecchio pre-versione 2.1 di ggplot2:bquote non funziona in etichette facet_grid nella versione ggplot2 2.1

dd <- 
structure(list(Dataset = structure(c(1L, 1L, 1L, 1L, 1L, 1L), .Label = c("train", 
"validation"), class = "factor"), Iterations = c(4L, 2L, 3L, 
4L, 1L, 3L), L1 = c(1e-07, 1e-07, 1e-07, 1e-06, 1e-07, 1e-06), 
    L2 = c(1e-05, 1e-05, 1e-05, 1e-05, 1e-05, 1e-05), Accuracy = c(0.2079478, 
    0.2079829, 0.2081201, 0.2086698, 0.2091378, 0.2093453), Loss = c(0.4468469, 
    0.446877, 0.4472973, 0.4485992, 0.4496757, 0.4499354)), .Names = c("Dataset", 
"Iterations", "L1", "L2", "Accuracy", "Loss"), row.names = c(NA, 
6L), class = "data.frame") 

labelAxis <- function(i) { 
    function(values) { 
    sapply(values, function(x) { bquote(lambda[.(i)]==10^.(round(log10(x)))) }) 
    } 
} 

ggplot(dd, aes(x=Iterations, y=Loss, color=Dataset)) + 
    facet_grid(. ~ L1 + L2, scales="fixed", 
      labeller=labeller(L1=labelAxis(1), L2=labelAxis(2), keep.as.numeric=T)) + 
    geom_line() 

Ora ggplot2 depreca il parametro labeller()keep.as.numeric=..., e, peggio ancora tuttavia, poiché il codice sopra riportato non produce più un bel rendering matematico delle etichette. Qualcuno sa come risolvere quel problema?

risposta

7

Ok, penso di aver capito. Il nuovo modo di modificare le etichette sfaccettatura è quello di utilizzare label_bquote(), in questo modo:

ggplot(dd, aes(x=Iterations, y=Loss, color=Dataset)) + 
    facet_grid(. ~ L1 + L2, scales="fixed", labeller=label_bquote(
    cols={lambda[1]==10^.(round(log10(L1)))}*", "*lambda[2]==10^.(round(log10(L2))))) + 
    geom_line() 

Nota quel paio apparentemente casuale di parentesi graffe. Questo è un R Gotcha. Senza queste parentesi, il parser R si strozza su un secondo operatore == nell'espressione.

+1

Il tuo Q & A è molto utile per me !! – cuttlefish44