Тестовая статистика (например, тест chisquare) внутри таблицы latex с использованием таблиц-пакета в R / Knitr/Rstudio

Я хотел бы использовать табличную()-функцию из пакета таблиц для выполнения кросс-табуляции двух переменных (например, v1 и v2) и представить p-значение chisq-теста в таблице. Легко получить перекрестную таблицу, но я не могу получить p-значение внутри таблицы. Вот что я пытался сделать, но безуспешно:--2-->

enter image description here

documentclass{article}

begin{document}

<<echo=TRUE,message=FALSE>>=
library(Hmisc)
library(tables)
v1 <- sample(letters[1:2],200,replace=TRUE)
v2 <- sample(month.name[1:3],200,replace=TRUE)
df <- data.frame(v1,v2)
@

It is straight forward to get the crosstabulation:
<<results='asis'>>=
latex(   tabular(    Factor(v1)   ~   Factor(v2)      , data=df)  )
@

But I cant get the p-value inside the table:

<<results='asis'>>=
latex(   tabular(    Factor(v1)*chisq.test(v1,v2)$p.value   ~   Factor(v2)      , data=df)  )
@

end{document}

2 ответов


Я не знаю, как это сделать с tables::tabular но это сделает это с Hmisc::summary.formula.reverse предполагая, что ваша система настроена для создания pdf-файлов через latex (). Мне пришлось искать архивы Rhelp, чтобы выяснить, что аргумент "exclude1" должен был идти в latex список аргументов. После того, как вы вернетесь через документацию exclude1 появляется в примере использования latex.summary.formula.reverse хотя я мысль Я читал страницу справки для summary.rms:

library(Hmisc)
latex(summary( v2 ~ v1, data=df,  method="reverse" ,test=TRUE), exclude1=FALSE)

enter image description here

вы можете перехватить вывод latex "по пути", если вы хотите встроить его в более длинный документ, назначив вывод именованному файлу.

latex(summary( v2 ~ v1, data=df,  method="reverse" ,test=TRUE), exclude1=FALSE, file="")
#--------
% latex.default(cstats, title = title, caption = caption, rowlabel = rowlabel,      col.just = col.just, numeric.dollar = FALSE, insert.bottom = legend,      rowname = lab, dcolumn = dcolumn, extracolheads = extracolheads,      extracolsize = Nsize, ...) 
%
\begin{table}[!tbp]
\caption{Descriptive Statistics by v2\label{summary}} 
\begin{center}
\begin{tabular}{lcccc}
\hline\hline
\multicolumn{1}{l}{}&\multicolumn{1}{c}{February}&\multicolumn{1}{c}{January}&\multicolumn{1}{c}{March}&\multicolumn{1}{c}{Test Statistic}\tabularnewline
&\multicolumn{1}{c}{{\scriptsize $N=56$}}&\multicolumn{1}{c}{{\scriptsize $N=73$}}&\multicolumn{1}{c}{{\scriptsize $N=71$}}&\tabularnewline
\hline
v1~:~a&43\%~{\scriptsize~(24)}&47\%~{\scriptsize~(34)}&44\%~{\scriptsize~(31)}&$ \chi^{2}_{2}=0.21 ,~ P=0.901  $\tabularnewline
~~~~b&57\%~{\scriptsize~(32)}&53\%~{\scriptsize~(39)}&56\%~{\scriptsize~(40)}&\tabularnewline
\hline
\end{tabular}
\end{center}
Numbers after percents are frequencies.\\noindent Test used:\Pearson test\end{table}

вы также можете вставить текст из статистики хи-квадрат в заголовок через xtable (). Например:

#sample data
var1<-sample(c('A', 'B'), 10, replace=T)
var2<-sample(c('Red', 'Blue'), 10, replace=T)
#join in frequency table
tab<-table(var1, var2)
#conduct chisq.test
test<-chisq.test(tab)
#show values of chisq.test()
name(test)
#Use xtable, use print.xtable for further manipulations
out<-xtable(tab, caption=paste('Important table, chi-squared =', test$statistic, ', p=', test$p.value,',' ,test$parameter, 'df', sep=' '))
#print
out