That plot is from my German blog TikZ.de.
I planned to model this nice cake:
(Foto by Guido Draheim).
Like a cruller, just, ehm, more digital and mathematical.
How do we draw it?
Let’s think of a cross-section. In polar coordinates the sine function sin(x) gives a circle, sin(3x) are three leaves, we add some radius (1,25) as a middle piece. That gives us the function sin(3x) + 1.25 in polar coordinates:
data:image/s3,"s3://crabby-images/11c50/11c501cf76dbb030a683e992603c89cbd2fa52ca" alt="Plot in 2d"
We embed it in the three-dimensional space, like in the xy plane with z=0 as (x,y,z)(t) = ( cos(t)(sin(3t)+1.25), sin(t)(sin(3t) + 1.25), 0 ):
data:image/s3,"s3://crabby-images/38961/38961419c0569b60689f9769e0e032cd62e22517" alt="Plot in 3d"
Or rotated a bit:
data:image/s3,"s3://crabby-images/23cc0/23cc0c4258f2f981107ae2f4ab75477b388e9907" alt="Plot mit festem Wert in 3d"
We can move it in the space by drawing in the xz plane and move with linear y: (x,y,z)(t) = ( cos(t)(sin(3t)+1.25), t, sin(t)(sin(3t)+1.25) ). That becomes:
data:image/s3,"s3://crabby-images/b1259/b12593caccb1fd16e295be88fdeabe9ea0a9b5b3" alt="Linearer Plot in 3d"
But we want to rotate it. For doing this, we use a torus function , like this one:
x(t,s) = (2+cos(t))cos(s+pi/2)
y(t,s) = (2+cos(t))sin(s+pi/2)
z(t,s) = sin(t)
We combine it with our function:
x(t,s) = (6+(sin(3t)+1.25)cos(t))cos(s)
y(t,s) = (6+(sin(3t)+1.25)cos(t))sin(s)
z(t,s) = (sin(3t)+1.25)sin(t)
Here is a cut, half circle rotation:
data:image/s3,"s3://crabby-images/0c58b/0c58bc48774eefc69237b7b36ffc50cc84edb56c" alt="Rotiert in 3d"
Here is the whole torus based rotated 3d image of the original function:
data:image/s3,"s3://crabby-images/5604c/5604c1e4fc2e4df8c30836a025f7a8967a303628" alt="Voll rotiert"
And now to the twist. We can twist it by adding a multiple of t or y in the function argument and achieve the rotation with growing y:
data:image/s3,"s3://crabby-images/f6296/f6296d135f1a42aeee7c953d881689b73f149afb" alt="Verdrehter torus"
Math done, let’s add color. Ok, and now the code:
% !TEX lualatex % Mit LuaLaTeX übersetzen, weil die Berechnungen zu aufwendig für pdfLaTeX sind \documentclass{standalone} \usepackage{pgfplots} \usetikzlibrary{backgrounds} \begin{document} \begin{tikzpicture} \begin{axis}[axis equal, hide axis, /tikz/background rectangle/.style = { left color = black, right color = black!20, shading angle = 135, }, show background rectangle ] \addplot3[ surf, shader = flat, miter limit = 1, domain = 0:360, y domain = 0:360, samples = 60,% low res for online compiler, take 100 for the image below, samples y = 40,% % low res for online compiler, take 70 for the image below, z buffer = sort, colormap/hot2, ] ( {(6+(sin(3*(x+3*y))+1.25)*cos(x))*cos(y)}, {(6+(sin(3*(x+3*y))+1.25)*cos(x))*sin(y)}, {((sin(3*(x+3*y))+1.25)*sin(x))} ); \end{axis} \end{tikzpicture} \end{document}
With more resolution, samples=100 and samples y=70:
data:image/s3,"s3://crabby-images/c8e29/c8e29071813f434368f492315aa3855ee56bee93" alt="Cruller in space"
All codes and explanation are also here:
- Deutsch: Drehtransformation mit pgfplots, in German on TeXwelt.de
- Englisch: Rotation transformation of a parametrized plot, with answer by cmhughes on TeX.SE
- Französisch: Représenter un vissage à l’aide de pgfplots, French post on TeXnique.fr