Получение LaTeX в R Plots

Я хотел бы добавить LaTeX верстка к элементам сюжетов в R (например: заголовок, метки оси, аннотации и т. д.) с использованием любой комбинации base/lattice или с ggplot2,

Вопросы:

  • Есть ли способ получить LaTeX на участки с использованием этих пакетов, и если да, то как это делается?
  • Если нет, есть ли дополнительные пакеты, необходимые для достижения этой цели.

Например, в Python matplotlib компилирует LaTeX через text.usetex пакеты, как обсуждено здесь: http://www.scipy.org/Cookbook/Matplotlib/UsingTex

Существует ли аналогичный процесс, с помощью которого такие графики могут быть созданы в R?

10 ответов

Этот скрипт содержит функцию latex2exp приблизительный перевод формул LaTeX в графические выражения Р. Вы можете использовать его везде, где можете вводить математические аннотации, такие как метки осей, метки условных обозначений и общий текст.

Например:

x <- seq(0, 4, length.out=100)
alpha <- 1:5
plot(x, xlim=c(0, 4), ylim=c(0, 10), xlab='x', ylab=latex2exp('\\alpha
     x^\\alpha\\text{, where }\\alpha \\in \\text{1:5}'), type='n')
for (a in alpha)
    lines(x, a*x^a, col=a)
legend('topleft', legend=latex2exp(sprintf("\\alpha = %d", alpha)), lwd=1, col=alpha)

производит этот сюжет.

Вот пример использования ggplot2:

q <- qplot(cty, hwy, data = mpg, colour = displ)
q + xlab(expression(beta +frac(miles, gallon)))

http://i31.tinypic.com/10z7n7d.png

Как украдено отсюда, следующая команда правильно использует LaTeX для рисования заголовка:

plot(1, main=expression(beta[1]))

Увидеть ?plotmath Больше подробностей.

Вы можете сгенерировать тикз-код из R: http://r-forge.r-project.org/projects/tikzdevice/

Вот кое-что из моих собственных лабораторных отчетов.

  • tickzDevice экспорт tikz изображения для LaTeX
  • Обратите внимание, что в некоторых случаях "\\" становится "\" а также "$" становится "$\" как в следующем коде R: "$z\\frac{a}{b}$" -> "$\z\frac{a}{b}$\"

  • Также xtable экспортирует таблицы в латексный код

Код:

library(reshape2)
library(plyr)
library(ggplot2)
library(systemfit)
library(xtable)
require(graphics)
require(tikzDevice)

setwd("~/DataFolder/")
Lab5p9 <- read.csv (file="~/DataFolder/Lab5part9.csv", comment.char="#")

AR <- subset(Lab5p9,Region == "Forward.Active")

# make sure the data names aren't already in latex format, it interferes with the ggplot ~  # tikzDecice combo
colnames(AR) <- c("$V_{BB}[V]$", "$V_{RB}[V]$" ,  "$V_{RC}[V]$" , "$I_B[\\mu A]$" , "IC" , "$V_{BE}[V]$" , "$V_{CE}[V]$" , "beta" , "$I_E[mA]$")

# make sure the working directory is where you want your tikz file to go
setwd("~/TexImageFolder/")

# export plot as a .tex file in the tikz format
tikz('betaplot.tex', width = 6,height = 3.5,pointsize = 12) #define plot name size and font size

#define plot margin widths
par(mar=c(3,5,3,5)) # The syntax is mar=c(bottom, left, top, right).

ggplot(AR, aes(x=IC, y=beta)) +                                # define data set 
    geom_point(colour="#000000",size=1.5) +                # use points
    geom_smooth(method=loess,span=2) +                     # use smooth
    theme_bw() +                    # no grey background
    xlab("$I_C[mA]$") +                 # x axis label in latex format
    ylab ("$\\beta$") +                 # y axis label in latex format
    theme(axis.title.y=element_text(angle=0)) + # rotate y axis label
    theme(axis.title.x=element_text(vjust=-0.5)) +  # adjust x axis label down
    theme(axis.title.y=element_text(hjust=-0.5)) +  # adjust y axis lable left
    theme(panel.grid.major=element_line(colour="grey80", size=0.5)) +# major grid color
    theme(panel.grid.minor=element_line(colour="grey95", size=0.4)) +# minor grid color 
    scale_x_continuous(minor_breaks=seq(0,9.5,by=0.5)) +# adjust x minor grid spacing
    scale_y_continuous(minor_breaks=seq(170,185,by=0.5)) + # adjust y minor grid spacing
    theme(panel.border=element_rect(colour="black",size=.75))# border color and size

dev.off() # export file and exit tikzDevice function

Вот классная функция, которая позволяет вам использовать функциональность plotmath, но с выражениями, сохраненными как объекты режима символа. Это позволяет вам манипулировать ими программно, используя функции вставки или регулярные выражения. Я не использую ggplot, но он также должен работать там:

    express <- function(char.expressions){
       return(parse(text=paste(char.expressions,collapse=";")))
    }
    par(mar=c(6,6,1,1))
    plot(0,0,xlim=sym(),ylim=sym(),xaxt="n",yaxt="n",mgp=c(4,0.2,0),
       xlab="axis(1,(-9:9)/10,tick.labels,las=2,cex.axis=0.8)",
       ylab="axis(2,(-9:9)/10,express(tick.labels),las=1,cex.axis=0.8)")
    tick.labels <- paste("x >=",(-9:9)/10)
    # this is what you get if you just use tick.labels the regular way:
    axis(1,(-9:9)/10,tick.labels,las=2,cex.axis=0.8)
    # but if you express() them... voila!
    axis(2,(-9:9)/10,express(tick.labels),las=1,cex.axis=0.8)

Я сделал это несколько лет назад, выводя в формате.fig вместо непосредственно в.pdf; Вы пишете заголовки, включая латексный код, и используете fig2ps или fig2pdf для создания окончательного графического файла. Установка, которую я должен был сделать, сломалась с R 2.5; если бы мне пришлось сделать это снова, я бы вместо этого изучил тикз, но я все равно включил это здесь в качестве еще одного потенциального варианта.

Мои заметки о том, как я это сделал с помощью Sweave, находятся здесь: http://www.stat.umn.edu/~arendahl/computing

У меня просто есть обходной путь. Сначала можно сгенерировать файл eps, а затем преобразовать его обратно в pgf, используя инструмент eps2pgf. Смотрите http://www.texample.net/tikz/examples/eps2pgf/

h <- rnorm(mean = 5, sd = 1, n = 1000) hist(h, main = expression(paste("Sampled values, ", mu, "=5, ", sigma, "=1")))

Взято из очень полезной статьи здесь https://stats.idre.ucla.edu/r/codefragments/greek_letters/

Например, вы можете использовать следующее:

      title(sub=TeX(sprintf(paste("Some latex symbols are ", r'(\lambda)', "and", r'(\alpha)'))))

Просто не забудьте заключить выражения LaTeX в использование r'()'. Вы также можете добавлять именованные объекты вpaste()функция. Например,

      lambda_variable <- 3
title(sub=TeX(sprintf(paste(r'(\lambda=)', lambda_variable))))

Не уверен, что есть лучшие способы сделать это, но вышеописанное сработало для меня :)

Другие вопросы по тегам