我有一张包含标志以及 x 和 y 值的表。我想对第一列为 1 的所有行进行回归。我该怎么做?
\documentclass{article}
\usepackage{array}
\usepackage{pgfplots}
\pgfplotsset{compat=1.5.1}
\usepackage{pgfplotstable}
\begin{document}
\pgfplotstableread{
Exmpl a v
1 0 0
1 1 1
1 2 1
1 3 4
2 0 -0
2 1 -1
2 2 -1
2 3 -4
} \data
\begin{tikzpicture}
\begin{axis} % [legend pos=outer north east]
\addplot table [x=a, y=v] {\data};
\addplot table [x=a, y={create col/linear regression={y=v}}] {\data};
\end{axis}
\end{tikzpicture}
\end{document}
我认为 pgfplots 过滤器不适用于此,因为我猜想 pgfplots 仅获取 x 和 y 值。如果有可能创建一个过滤表并从那里进行回归和绘图,那就太好了。
答案1
我认为在两个问题的帮助下我几乎找到了解决方案: 使用 pgfplotstable 创建列联表和 使用 pgfplots 访问单个表元素? 其想法是,如果 Exmpl 值为 1,则转置矩阵,创建一个新矩阵,循环遍历所有列并复制列。
\documentclass{article}
\usepackage{array}
\usepackage{pgfplots}
\pgfplotsset{compat=1.5.1}
\usepackage{pgfplotstable}
\usepackage{ifthen}
\newcommand{\pgfplotstablefilterrows}[3]
{
\pgfplotstablegetrowsof{#1}
\pgfmathsetmacro{\NumOfRows}{\pgfplotsretval}
\pgfmathsetmacro{\MaxRow}{\NumOfRows-1}
\pgfplotstablegetcolsof{#1}
\pgfmathsetmacro{\NumOfCols}{\pgfplotsretval}
\pgfplotstabletranspose{\TransposedData}{#1}
\pgfplotstableset{create on use/TransposedHead/.style={copy column from table={\TransposedData}{[index]0}}}
\pgfplotstablenew[columns={TransposedHead}]{\NumOfCols}{\TransposedFilteredData}
\pgfplotsforeachungrouped \pgfplotstablerowindex in {0,1,...,\MaxRow}{ % Row loop
#3
}
\pgfplotstabletranspose[colnames from=TransposedHead,input colnames to=]{#2}{\TransposedFilteredData}
\pgfplotstableclear{\TransposedData}
\pgfplotstableclear{\TransposedFilteredData}
}
\begin{document}
\pgfplotstableread{
Exmpl a v
1 0 0
1 1 1
1 2 1
1 3 4
2 0 -0
2 1 -1
2 2 -1
2 3 -4
} \data
\pgfplotstablefilterrows{\data}{\FilteredData}
{
\pgfplotstablegetelem{\pgfplotstablerowindex}{[index]0}\of\data
\ifthenelse{\equal{\pgfplotsretval}{1}}
{
\pgfplotstablecreatecol[copy column from table={\TransposedData}{\pgfplotstablerowindex}]{\pgfplotstablerowindex}{\TransposedFilteredData}
}
{}
}
\begin{tikzpicture}
\begin{axis} % [legend pos=outer north east]
\addplot table [x=a, y=v] {\data};
\addplot table [x=a, y={create col/linear regression={y=v}}] {\FilteredData}; % compute a linear regression from the input table
\end{axis}
\end{tikzpicture}
\end{document}
从代码中你也许可以看出,我并没有太多乳胶编程经验。无论如何,它还是有用的。祝好,Juhui