兩條曲線未在同一點連接

兩條曲線未在同一點連接

我一直在嘗試繪製兩個函數,它們代表笛卡爾座標中的旋轉橢圓。然而,這兩條曲線相交的點看起來並不像它們「連接」或閉合。有沒有辦法解決這問題?我不知道這是為什麼。在此輸入影像描述

這是代碼:

\documentclass{article}

\usepackage{tikz}
\usepackage{pgfplots}

\begin{document}

\begin{tikzpicture}[scale=1]
\begin{axis}[ticks=none,
axis x line=middle,
axis y line=middle,
y axis line style={<->},
xlabel=$x$,
ylabel={$y$}
]
\addplot[-] expression[line width=0.4,smooth,samples=200,domain=0:49.999] {sqrt((1.38^(2.0)-0.5^(2.0))*(50.0*(x)-(x)^(2.0)))+0.5*(x)};
\addplot[-] expression[line width=0.4,smooth,samples=200,domain=0:49.999] {-sqrt((1.38^(2.0)-0.5^(2.0))*(50.0*(x)-(x)^(2.0)))+0.5*(x)};

\end{axis}
\end{tikzpicture}

\end{document}

謝謝您的協助,

答案1

我不知道具體原因,但我想您可能必須正確調整網域。這是一個(非優雅的)解決方法,使用shorten.

\documentclass[border=4]{standalone}
\usepackage{pgfplots}
\pgfplotsset{compat=1.12}
\usepgfplotslibrary{groupplots}

\begin{document}
  \begin{tikzpicture}[scale=1]
\begin{axis}[ticks=none,
axis x line=middle,
axis y line=middle,
y axis line style={<->},
xlabel=$x$,
ylabel={$y$}
]
\addplot[shorten >= -0.5ex,smooth,line width=0.4pt,samples=300,domain=0:49.99999999999999999999] {sqrt((1.38^(2.0)-0.5^(2.0))*(50.0*(x)-(x)^(2.0)))+0.5*(x)};
\addplot[shorten >= -0.5ex,smooth,line width=0.4pt,samples=300,domain=0:49.99999999999999999999] {-sqrt((1.38^(2.0)-0.5^(2.0))*(50.0*(x)-(x)^(2.0)))+0.5*(x)};
\end{axis}
\end{tikzpicture}
\end{document}

在此輸入影像描述

答案2

繪圖也可以透過使用參數變數(範例中的 t)來完成smooth cycle

\documentclass{article}
\usepackage{tikz}
\usepackage{pgfplots}

\begin{document}
\begin{tikzpicture}[scale=1]
  \begin{axis}[ticks=none,
    axis x line=middle,
    axis y line=middle,
    y axis line style={<->},
    xlabel=$x$,
    ylabel={$y$}
  ]
    \def\xzero{25}
    \def\yzero{12.5}
    \def\RotPhi{66}
    \def\RadiusA{36.5}
    \def\RadiusB{22}
    \addplot[
      line width=.4,
      smooth cycle,
      variable=t,
      samples=100,
      domain=0:360,
    ] ({
      \xzero + \RadiusA*cos(\RotPhi)*cos(t) - \RadiusB*sin(\RotPhi)*sin(t)
    }, {
      \yzero + \RadiusA*sin(\RotPhi)*cos(t) + \RadiusB*cos(\RotPhi)*sin(t)
    })
    ; 
  \end{axis}
\end{tikzpicture}
\end{document}

結果

相關內容