Я использую TexLive XuaLatex с PGFplots 1.13 для построения графика данных. У меня есть такая таблица:
x , y , z
0 , 0 , 0
0 , 0 , 1
1 , 1 , 0
1 , 1 , 1
2 , 2 , 0
2 , 4 , 1
3 , 3 , 0
3 , 9 , 1
4 , 4 , 0
4 , 16 , 1
5 , 5 , 0
5 , 25 , 1
6 , 6 , 0
6 , 36 , 1
Как я могу использовать среду осей PGFplot для построения графика y по x, где z=bar, когда bar — это число. Я думаю о том, как можно получить доступ к данным с помощьюMySQL
\begin{tikzpicture}
\begin{axis}[/pgf/number format/.cd, use comma]
\addplot
table[x=x,y=y,WHERE z=0, col sep=comma]
{DATA.csv};
\addplot
table[x=x,y=y,WHERE z=1,col sep=comma]
{DATA.csv};
\end{axis}
\end{tikzpicture}
Я не нашел ничего об этом в руководстве. Я не хочу решения, которое исключает вопрос, имея такую таблицу:
x, y1, y2
а затем постройте график при x=x, y=y1 и второй график при x=x, y=y2.
Это может быть удобным решением для простого примера, который я привожу, но оно не работает для моей задачи, поскольку в реальной задаче необходимо отобразить 10 различных y по x для 4 различных z, и мне по нескольким причинам не нужна реализация, подобная предложенному решению.
Большое спасибо за ваше время
решение1
Я думаю, есть несколько способов сделать это. Один из способов — использовать y expr={ifthenelse(\thisrow{z}==0,\thisrow{y},nan}
вместо y=y
.
\documentclass[border=5mm]{standalone}
\usepackage{pgfplots}
\pgfplotsset{compat=1.14}
\usepackage{filecontents}
\begin{filecontents*}{DATA.csv}
x,y,z
0,0,0
0,0,1
1,1,0
1,1,1
2,2,0
2,4,1
3,3,0
3,9,1
4,4,0
4,16,1
5,5,0
5,25,1
6,6,0
6,36,1
\end{filecontents*}
\begin{document}
\begin{tikzpicture}
\begin{axis}[/pgf/number format/.cd, use comma]
\addplot
table[x=x,y expr={ifthenelse(\thisrow{z}==0,\thisrow{y},nan)}, col sep=comma]
{DATA.csv};
\addplot
table[x=x,y expr={ifthenelse(\thisrow{z}==1,\thisrow{y},nan)},col sep=comma]
{DATA.csv};
\end{axis}
\end{tikzpicture}
\end{document}