
내 코드는 다음과 같습니다.
\begin{tikzpicture}
[
scale=1.05,
declare function=
{
funcc(\x)=
%(\x<-0.6) * (\x)+
(\x<-0.6) * (0.7285067873303168+2.058823529411765*\x+2.1606334841628962*\x^2 + 0.7918552036199096*\x^3)+
and(\x>=-0.6,\x<-0.4) * (1.1411764705882352+ 4.294117647058823*\x + 6.029411764705881*\x^2 +
2.941176470588235*\x^3)+
and(\x>=-0.4,\x < -0.2) * (0.5*(2 + 6*\x + 5*\x^2))+
and(\x>=-0.2,\x <0) * (1 +1*\x - 12.5*\x^2 - 25*\x^3)+
and(\x>=0,\x <0.2) * (1 - 1*\x - 12.5*\x^2 +25*\x^3)+
add(\x>=0.2,\x < 0.4) * (0.5*(2 - 6*\x + 5*\x^2))+
and(\x>=0.4 ,\x<0.6) * (1.14118 - 4.29412*\x + 6.02941*\x^2 - 2.94118*\x^3) +
%(\x>=0.6) * (\x^3);
(\x>=0.6) * (0.728507 - 2.05882*\x + 2.16063*\x^2 - 0.791855*\x^3);
},
]
\begin{axis}
[
title = {},%\quad The distribution of the points and the line of regression},
axis lines = middle,
legend pos=outer north east,
xlabel={$x$},
ylabel={$y$},
xmin=-2, xmax=2,
ymin=-2, ymax=2,
]
\addplot%S 10
[
domain = -1:1,
legend pos=outer north east,
color=yellow,
samples = 1000
]
{
(\x<-0.6) * (0.7285067873303168+2.058823529411765*\x+2.1606334841628962*\x^2 + 0.7918552036199096*\x^3)+
and(\x>=-0.6,\x<-0.4) * (1.1411764705882352+ 4.294117647058823*\x + 6.029411764705881*\x^2 +
2.941176470588235*\x^3)+
and(\x>=-0.4,\x < -0.2) * (0.5*(2 + 6*\x + 5*\x^2))+
and(\x>=-0.2,\x <0) * (1 +1*\x - 12.5*\x^2 - 25*\x^3)+
and(\x>=0,\x <0.2) * (1 - 1*\x - 12.5*\x^2 +25*\x^3)+
add(\x>=0.2,\x < 0.4) * (0.5*(2 - 6*\x + 5*\x^2))+
and(\x>=0.4 ,\x<0.6) * (1.14118 - 4.29412*\x + 6.02941*\x^2 - 2.94118*\x^3) +
%(\x>=0.6) * (\x^3);
(\x>=0.6) * (0.728507 - 2.05882*\x + 2.16063*\x^2 - 0.791855*\x^3)
};
\addplot %N 10
[
domain = -1:1,
legend pos=outer north east,
color=green,
samples = 1000
]
{
-220.942*x^10+494.91*x^8-381.434*x^6+123.36*x^4-16.8552*x^2+1.
};
\addplot %N_{5}
[
domain = -1:1,
legend pos=outer north east,
color=blue,
samples = 1000
]
{
1.20192*x^4-1.73077*x^2+0.567308
};
%\addlegendentry{$N_{5}(x)$}
\addplot %f(x)
[
domain = -1:1,
legend pos=outer north east,
color=red,
samples = 1000
]
{
1 /(1+25*x^2)
};
%\addlegendentry{$f(x) = \frac{1}{1+25x^{2}}$}
\legend{$S_{10}(x)$,$N_{10}(x)$,$N_{5}(x)$,$f(x) = \frac{1}{1+25x^{2}}$};
\end{axis}
\end{tikzpicture}
결과는 아래와 같습니다.
노란색 선은 빨간색 선과 거의 같아야 하지만 차이가 너무 큽니다.
Mathematica에서 얻은 노란색 선의 올바른 결과는 다음과 같습니다.
어차피 내 실수를 찾을 수 없어서 문제는 pdgplots 자체에 있는 것 같아요. 그런데, 코드를 고치는데 하룻밤 정도 걸렸는데 괜찮은 것 같습니다.
답변1
모두를 제공 add
으로 변경하면 다음과 같습니다 and
.
\documentclass[border=1cm]{standalone}
\usepackage{pgfplots}
\pgfplotsset{compat=1.18}
\begin{document}
\begin{tikzpicture}
[
scale=1.05,
declare function=
{
funcc(\x)=
%(\x<-0.6) * (\x)+
(\x<-0.6) * (0.7285067873303168+2.058823529411765*\x+2.1606334841628962*\x^2 + 0.7918552036199096*\x^3)+
and(\x>=-0.6,\x<-0.4) * (1.1411764705882352+ 4.294117647058823*\x + 6.029411764705881*\x^2 +
2.941176470588235*\x^3)+
and(\x>=-0.4,\x < -0.2) * (0.5*(2 + 6*\x + 5*\x^2))+
and(\x>=-0.2,\x <0) * (1 +1*\x - 12.5*\x^2 - 25*\x^3)+
and(\x>=0,\x <0.2) * (1 - 1*\x - 12.5*\x^2 +25*\x^3)+
and(\x>=0.2,\x < 0.4) * (0.5*(2 - 6*\x + 5*\x^2))+
and(\x>=0.4 ,\x<0.6) * (1.14118 - 4.29412*\x + 6.02941*\x^2 - 2.94118*\x^3) +
%(\x>=0.6) * (\x^3);
(\x>=0.6) * (0.728507 - 2.05882*\x + 2.16063*\x^2 - 0.791855*\x^3);
},
]
\begin{axis}
[
title = {},%\quad The distribution of the points and the line of regression},
axis lines = middle,
legend pos=outer north east,
xlabel={$x$},
ylabel={$y$},
xmin=-2, xmax=2,
ymin=-2, ymax=2,
]
\addplot%S 10
[
domain = -1:1,
legend pos=outer north east,
color=yellow,
samples = 100
]
{
(\x<-0.6) * (0.7285067873303168+2.058823529411765*\x+2.1606334841628962*\x^2 + 0.7918552036199096*\x^3)+
and(\x>=-0.6,\x<-0.4) * (1.1411764705882352+ 4.294117647058823*\x + 6.029411764705881*\x^2 +
2.941176470588235*\x^3)+
and(\x>=-0.4,\x < -0.2) * (0.5*(2 + 6*\x + 5*\x^2))+
and(\x>=-0.2,\x <0) * (1 +1*\x - 12.5*\x^2 - 25*\x^3)+
and(\x>=0,\x <0.2) * (1 - 1*\x - 12.5*\x^2 +25*\x^3)+
and(\x>=0.2,\x < 0.4) * (0.5*(2 - 6*\x + 5*\x^2))+
and(\x>=0.4 ,\x<0.6) * (1.14118 - 4.29412*\x + 6.02941*\x^2 - 2.94118*\x^3) +
%(\x>=0.6) * (\x^3);
(\x>=0.6) * (0.728507 - 2.05882*\x + 2.16063*\x^2 - 0.791855*\x^3)
};
\addplot %N 10
[
domain = -1:1,
legend pos=outer north east,
color=green,
samples = 100
]
{
-220.942*x^10+494.91*x^8-381.434*x^6+123.36*x^4-16.8552*x^2+1.
};
\addplot %N_{5}
[
domain = -1:1,
legend pos=outer north east,
color=blue,
samples = 100
]
{
1.20192*x^4-1.73077*x^2+0.567308
};
%\addlegendentry{$N_{5}(x)$}
\addplot %f(x)
[
domain = -1:1,
legend pos=outer north east,
color=red,
samples = 100
]
{
1 /(1+25*x^2)
};
%\addlegendentry{$f(x) = \frac{1}{1+25x^{2}}$}
\legend{$S_{10}(x)$,$N_{10}(x)$,$N_{5}(x)$,$f(x) = \frac{1}{1+25x^{2}}$};
\end{axis}
\end{tikzpicture}
\end{document}
노란색 플롯이 빨간색 플롯 근처에 있습니다. 분명히, 나는 당신이 무엇을 하려고 하는지 모르지만, 버그로 인한 것보다는 당신이 이런 실수를 했을 가능성이 더 높은 것 같습니다.