Chargement des fichiers du répertoire lorenz
[pst-eqdf.git] / lorenz / Lorenz-PSTricks.tex
diff --git a/lorenz/Lorenz-PSTricks.tex b/lorenz/Lorenz-PSTricks.tex
new file mode 100644 (file)
index 0000000..ae850d6
--- /dev/null
@@ -0,0 +1,541 @@
+\documentclass{article}\r
+\usepackage[a4paper,margin=2cm]{geometry}\r
+\usepackage[T1]{fontenc}\r
+\usepackage[latin1]{inputenc}%\r
+\usepackage[garamond]{mathdesign}\r
+\renewcommand{\ttdefault}{lmtt}\r
+\usepackage{pst-node,pst-eqdf}\r
+\usepackage{amsmath}\r
+\usepackage{url}\r
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
+% Essai de Manuel Luque 19 février 2003\r
+% transformé par Denis Girou le 25 février 2003\r
+% révision le 14 septembre 2011\r
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
+\makeatletter\r
+\pst@addfams{pst-plothsb}\r
+\r
+\define@key[psset]{pst-plothsb}{HueBegin}{% Between 0 and 1\r
+\edef\PstParametricplotHSB@HueBegin{#1}}\r
+\r
+\define@key[psset]{pst-plothsb}{HueEnd}{% Between 0 and 1\r
+\edef\PstParametricplotHSB@HueEnd{#1}}\r
+\r
+\newif\ifPst@HSB\r
+\define@key[psset]{pst-plothsb}{HSB}[true]{\@nameuse{Pst@HSB#1}}\r
+\r
+% Default values\r
+\psset{HueBegin=0,HueEnd=1,HSB=true}\r
+\r
+\def\parametricplotHSB{\pst@object{parametricplotHSB}}\r
+\def\parametricplotHSB@i{\@ifnextchar[{\parametricplotHSB@do}{\parametricplotHSB@do[]}}\r
+\def\parametricplotHSB@do[#1]#2#3#4{{%\r
+\psset{#1}%\r
+\begin@ClosedObj\r
+\addto@pscode{%\r
+/t  #2 def\r
+/dt #3 t sub \psk@plotpoints\space div def\r
+/t t dt sub def\r
+/Counter 0 def\r
+\psk@plotpoints {\r
+  /t t dt add def\r
+  /Counter Counter 1 add def\r
+/F@pstplot \ifPst@algebraic (#4)\r
+                    tx@AlgToPs begin AlgToPs end cvx\r
+                 \else { #4 }\r
+          \fi\r
+   def\r
+\ifPst@algebraic\r
+   F@pstplot\r
+    \else  #4\r
+\fi\r
+  \pst@number\psyunit mul exch\r
+  \pst@number\psxunit mul exch\r
+  1 Counter eq\r
+    {moveto}                    % First point\r
+    {\ifPst@HSB                 % Other points than the first one\r
+       /PointY exch def\r
+       /PointX exch def\r
+       Counter \psk@plotpoints\space div\r
+           \PstParametricplotHSB@HueEnd\space\r
+             \PstParametricplotHSB@HueBegin\space sub mul\r
+           \PstParametricplotHSB@HueBegin\space add\r
+         1 1 sethsbcolor\r
+       PointX PointY lineto\r
+       stroke\r
+       PointX PointY moveto\r
+     \else\r
+       lineto\r
+     \fi} ifelse\r
+    } repeat}% fin du code ps\r
+\end@ClosedObj}} % fin de la commande PSTricks\r
+\r
+\makeatother\r
+\r
+\makeatletter\r
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
+% adaptation de \parametricplotHSB\r
+% à \lisplotHSB\r
+% le 10 juin 2012\r
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
+\def\listplotHSB{\pst@object{listplotHSB}}\r
+\def\listplotHSB@i#1{%\r
+\begin@ClosedObj\r
+  \addto@pscode{%\r
+  /Counter 0 def\r
+     /XY [ #1 ] def\r
+     XY 0 get\r
+     XY 1 get\r
+  \pst@number\psyunit mul exch\r
+  \pst@number\psxunit mul exch\r
+       moveto\r
+     /L XY length def\r
+     2 2 L 2 sub {/i exch def\r
+   /x1  XY i get \pst@number\psxunit mul def\r
+   /y1  XY i 1 add get \pst@number\psyunit mul def\r
+    x1 y1\r
+    \ifPst@HSB\r
+    Counter L 2 div div\r
+    \PstParametricplotHSB@HueEnd\space\r
+    \PstParametricplotHSB@HueBegin\space sub mul\r
+    \PstParametricplotHSB@HueBegin\space add\r
+    1 1 sethsbcolor\r
+    /Counter Counter 1 add def\r
+    \fi\r
+     lineto\r
+     stroke\r
+  x1 y1 moveto\r
+  } for\r
+  }%\r
+\end@ClosedObj}\r
+\makeatother\r
+\def\formules{%\r
+    /xObservateur abscisse Sin1 mul neg ordonnee Cos1 mul add def\r
+    /yObservateur abscisse Cos1Sin2 mul neg ordonnee Sin1Sin2 mul sub cote Cos2 mul add def\r
+    /zObservateur abscisse neg Cos1Cos2 mul ordonnee Sin1Cos2 mul sub cote Sin2 mul sub Dobs add def\r
+    /xScreen DScreen xObservateur mul zObservateur div def\r
+    /yScreen DScreen yObservateur mul zObservateur div def\r
+  xScreen yScreen}\r
+\r
+\makeatletter\r
+\pst@addfams{pst-pnodeTroisD}\r
+\r
+\define@key[psset]{pst-pnodeTroisD}{THETA}{\edef\psk@TroisD@Theta{#1 }}\r
+\define@key[psset]{pst-pnodeTroisD}{PHI}{\edef\psk@TroisD@Phi{#1 }}\r
+\define@key[psset]{pst-pnodeTroisD}{Dobs}{\edef\psk@TroisD@Dobs{#1 }}\r
+\define@key[psset]{pst-pnodeTroisD}{Decran}{\edef\psk@TroisD@Ecran{#1 }}\r
+\psset{THETA=300,PHI=20,Dobs=200,Decran=25}\r
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\r
+\def\pnodeTroisD{\@ifnextchar[{\pst@pnodeTroisD}{\pst@pnodeTroisD[]}}\r
+\r
+\def\pst@pnodeTroisD[#1](#2,#3,#4)#5{{%\r
+\pst@killglue\r
+\psset{#1}%\r
+\pnode(!\r
+ /THETA \psk@TroisD@Theta\space def\r
+ /PHI \psk@TroisD@Phi\space def\r
+ /Dobs \psk@TroisD@Dobs\space def\r
+ /DScreen \psk@TroisD@Ecran\space def\r
+ /Sin1 THETA sin def\r
+ /Sin2 PHI sin def\r
+ /Cos1 THETA cos def\r
+ /Cos2 PHI cos def\r
+ /Cos1Sin2 Cos1 Sin2 mul def\r
+ /Sin1Sin2 Sin1 Sin2 mul def\r
+ /Cos1Cos2 Cos1 Cos2 mul def\r
+ /Sin1Cos2 Sin1 Cos2 mul def\r
+ /xObservateur #2 Sin1 mul neg #3 Cos1 mul add def\r
+ /yObservateur #2 Cos1Sin2 mul neg #3 Sin1Sin2 mul sub #4 Cos2 mul add def\r
+ /zObservateur #2 neg Cos1Cos2 mul #3 Sin1Cos2 mul sub #4 Sin2 mul sub Dobs add def\r
+ /xScreen DScreen xObservateur mul zObservateur div def\r
+ /yScreen DScreen yObservateur mul zObservateur div def\r
+  xScreen yScreen){#5}}}\r
+\makeatother\r
+\title{L'attracteur de Lorenz avec PSTricks}\r
+\date{12 juin 2012}\r
+\begin{document}\r
+\maketitle\r
+\section{Présentation}\r
+Ceci n'est pas un cours sur l'attracteur de Lorenz, il existe sur internet un grand nombre de sites qui lui sont consacrés très complets et d'une grande qualité pédagogique. Il s'agit, plus simplement, de montrer que l'utilisation de PSTricks permet d'illustrer ce modèle très convenablement.\r
+\r
+Pour résoudre numériquement le système de Lorenz :\r
+\[\r
+\left\{\r
+\begin{array}{rcl}\r
+\dfrac{\mathrm{d}x}{\mathrm{d}t}&=&\sigma(x-y)\\\r
+\dfrac{\mathrm{d}y}{\mathrm{d}t}&=&rx-y-z\\\r
+\dfrac{\mathrm{d}z}{\mathrm{d}t}&=&xy-\beta z\r
+\end{array}\r
+\right.\r
+\]\r
+j'utilise une version très simplifiée de la macro \verb+\psplotDiffEqn+ de Dominique Rodriguez qui est incluse dans le package \verb+pstricks-add+, mais qui était, à l'origine, un package `\verb+pst-eqdf+' à elle seule. Dominique m'a donné la permission de modifier sa macro afin de pouvoir sauvegarder dans un tableau \verb+postscript+, et/ou dans un fichier, toutes les valeurs nécessaires au dessin des figures et en particulier à la représentation en 3D du \textit{papillon }de Lorenz. Cette macro simplifiée, qui utilise la méthode Runge-Kutta~4 est incluse dans un tout petit package dont j'ai gardé le même nom \verb+pst-eqdf+, mais la macro a changé de nom \verb+\psequadiff+ car elle ne trace plus les fonctions directement.\r
+\r
+Pour les couleurs, j'utilise une macro \verb+\listplotHSB+ qui est un complément à celle-ci : \verb+\parametricplotHSB+\footnote{\url{http://melusine.eu.org/syracuse/G/pstricks/courbes-arc-en-ciel/}}, que nous avions mise au point avec Denis Girou.\r
+\r
+\section{Les étapes de la construction des figures}\r
+\subsection{Équations, paramètres et conditions initiales}\r
+Il faut d'abord définir les équations en notation algébrique pour la macro \verb+\psequadiff+ :\r
+\begin{verbatim}\r
+% y[0] y[1] y[2]\r
+% x    y    z\r
+\def\Lorenz{\r
+Pr*(y[1]-y[0])|%\r
+Rh*y[0]-y[1]-y[0]*y[2]|%\r
+y[0]*y[1]-b*y[2]%\r
+}\r
+\end{verbatim}\r
+ainsi que les paramètres :\r
+\begin{verbatim}\r
+\def\parametres{\r
+    /Pr 10 def\r
+    /Rh 28 def\r
+    /b 8 3 div def\r
+}%\r
+\end{verbatim}\r
+puis les conditions initiales :\r
+\begin{verbatim}\r
+                         x0 y0 z0\r
+\def\conditionsInitiales{10 10 30}\r
+\end{verbatim}\r
+Ce sont ces deux dernières définitions qu'il faudra modifier si on veut changer les conditions initiales et les paramètres.\r
+\subsection{L'utilisation de la commande \textbackslash{}psequadiff}\r
+\begin{verbatim}\r
+\pstVerb{\parametres}%\r
+  \psequadiff[% x,y\r
+  tabname=tabXY,\r
+  method=rk4,\r
+  whichabs=0,whichord=1,\r
+  saveData,filename=LorenzXY.dat,\r
+  plotpoints=2501,algebraic]{0}{25}{\conditionsInitiales}{\Lorenz}\r
+\end{verbatim}\r
+Dans cet exemple, l'intervalle de temps choisi est de 0 à 25 s. Les grandeurs prises sur la pile sont $(x,y)$. Le nombre de points calculés vaut 2501.\r
+Les valeurs, sur cet intervalle de temps, sont stockées dans le tableau \verb+postscript+ :  \textsf{[\textbf{tabname}=tabXY]} avec \textsf{tabXY} qui est le nom que l'on choisit soi-même. \r
+\r
+Pour ne pas refaire le calcul, on peut choisir d'enregistrer la liste de valeurs du couple $(x,y)$, en positionnant le booléen \textsf{[saveData]} à true, on choisit un nom pour le fichier avec : \textsf{[\textbf{filename}=LorenzXY.dat]}. Par défaut, aucun fichier n'est enregistré.\r
+\begin{verbatim}\r
+ saveData,filename=LorenzXY.dat,\r
+\end{verbatim}\r
+Pour utiliser ce fichier, il suffit de faire :\r
+\begin{verbatim}\r
+    \pstVerb{/XY {(LorenzXY.dat) run } def}%\r
+    \listplotHSB{XY}    \r
+\end{verbatim}\r
+Vous pouvez utiliser la commande \textbf{\textsf{lisplot}} du package \textsf{pst-plot} qui offre davantage d'options que \textsf{\textbf{listplotHSB}}.\r
+\subsection{Le tracé de la courbe}\r
+\begin{verbatim}\r
+\listplotHSB[unit=0.25]{tabXY aload pop}%\r
+\end{verbatim}\r
+\verb+\listplotHSB+ permet de faire varier la couleur tout au long du tracé. Par défaut le paramètre \textsf{hue} de la définition d'une couleur dans le système \textsf{hsb} varie de 0 à 1. On peut fixer la plage de valeurs avec les 2 options suivantes :\r
+\begin{itemize}\r
+  \item \textsf{\textbf{HueBegin}} avec une valeur comprise entre 0 et 1.\r
+  \item \textsf{\textbf{HueEnd}} avec une valeur comprise entre 0 et 1.\r
+\end{itemize}\r
+Pour avoir une couleur uniforme tout au long du tracé, il faut désactiver l'option \textsf{[\textbf{HSB}=false]} ainsi le tracé prendra la couleur que vous avez choisie avec l'option habituelle \textsf{linecolor}.\r
+\section{Le tracé des courbes}\r
+\subsection{Le tracé de XY}\r
+% y[0] y[1] y[2]\r
+ % x    y     z\r
+\def\Lorenz{\r
+Pr*(y[1]-y[0])|%\r
+Rh*y[0]-y[1]-y[0]*y[2]|%\r
+y[0]*y[1]-beta*y[2]%\r
+}\r
+\def\conditionsInitiales{10 10 30}\r
+\def\parametres{\r
+    /Pr 10 def\r
+    /Rh 28 def\r
+    /beta 8 3 div def\r
+}%\r
+\begin{center}\r
+\begin{pspicture}(-8,-6)(8,8)\r
+\psgrid[subgriddiv=0,gridcolor=lightgray,griddots=10,gridlabels=0pt]%\r
+\pstVerb{\parametres}%\r
+  \psequadiff[% x,y\r
+  tabname=tabXY,\r
+  method=rk4,\r
+  whichabs=0,whichord=1,\r
+  saveData,filename=LorenzXY.dat,\r
+  plotpoints=2501,algebraic]{0}{25}{\conditionsInitiales}{\Lorenz}\r
+\listplotHSB[unit=0.25]{tabXY aload pop}%\r
+\uput[r](8,0){$x$}\r
+\uput[u](0,8){$y$}\r
+\end{pspicture}\r
+\end{center}\r
+\begin{verbatim}\r
+\begin{pspicture}(-8,-6)(8,8)\r
+\psgrid[subgriddiv=0,gridcolor=lightgray,griddots=10,gridlabels=0pt]%\r
+\pstVerb{\parametres}%\r
+  \psequadiff[% x,y\r
+  tabname=tabXY,\r
+  method=rk4,\r
+  whichabs=0,whichord=1,\r
+  saveData,filename=LorenzXY.dat,\r
+  plotpoints=2501,algebraic]{0}{25}{\conditionsInitiales}{\Lorenz}\r
+\listplotHSB[unit=0.25]{tabXY aload pop}%\r
+\uput[r](8,0){$x$}\r
+\uput[u](0,8){$y$}\r
+\end{pspicture}\r
+\end{verbatim}\r
+\subsection{Le tracé de X(t)}\r
+\begin{center}\r
+\begin{pspicture}(0,-5)(13,5.5)\r
+\psgrid[subgriddiv=0,gridcolor=lightgray,griddots=10,gridlabels=0pt](0,-5)(13,5)%\r
+\pstVerb{\parametres}%\r
+  \psequadiff[% t,x\r
+  tabname=tabtX,\r
+  method=rk4,\r
+  whichord=0,\r
+  saveData,filename=LorenztX.dat,\r
+  plotpoints=2501,algebraic]{0}{25}{\conditionsInitiales}{\Lorenz}\r
+\listplotHSB[yunit=0.2,xunit=0.5,HSB=false]{tabtX aload pop}%\r
+\uput[r](13,0){$t$}\r
+\uput[u](0,5){$x$}\r
+\psline{<->}(13,0)(0,0)(0,5)\r
+\end{pspicture}\r
+\end{center}\r
+\begin{verbatim}\r
+\begin{pspicture}(0,-5)(13,5)\r
+\psgrid[subgriddiv=0,gridcolor=lightgray,griddots=10,gridlabels=0pt]%\r
+\pstVerb{\parametres}%\r
+  \psequadiff[% t,x\r
+  tabname=tabtX,\r
+  method=rk4,\r
+  whichord=0,\r
+  saveData,filename=LorenztX.dat,\r
+  plotpoints=2501,algebraic]{0}{25}{\conditionsInitiales}{\Lorenz}\r
+\listplotHSB[yunit=0.2,xunit=0.5,HSB=false]{tabtX aload pop}%\r
+\uput[r](12.5,0){$t$}\r
+\uput[u](0,5){$x$}\r
+\end{pspicture}\r
+\end{verbatim}\r
+\subsection{Le tracé de XZ}\r
+\begin{center}\r
+\begin{pspicture}(-8,0)(8,12)\r
+\psgrid[subgriddiv=0,gridcolor=lightgray,griddots=10,gridlabels=0pt]%\r
+\pstVerb{\parametres}%\r
+  \psequadiff[% x,z\r
+  tabname=tabXZ,\r
+  method=rk4,\r
+  whichabs=0,\r
+  whichord=2,\r
+  saveData,filename=LorenzXZ.dat,\r
+  plotpoints=2501,algebraic]{0}{25}{\conditionsInitiales}{\Lorenz}\r
+\listplotHSB[linecolor=green,unit=0.25,HueBegin=.25,HueEnd=0.65]{tabXZ aload pop}%\r
+\uput[r](8,0){$x$}\r
+\uput[u](0,12){$z$}\r
+\end{pspicture}\r
+\end{center}\r
+\begin{verbatim}\r
+\begin{pspicture}(-8,0)(8,12)\r
+\psgrid[subgriddiv=0,gridcolor=lightgray,griddots=10,gridlabels=0pt]%\r
+\pstVerb{\parametres}%\r
+  \psequadiff[% x,z\r
+  tabname=tabXZ,\r
+  method=rk4,\r
+  whichabs=0,\r
+  whichord=2,\r
+  saveData,filename=LorenzXZ.dat,\r
+  plotpoints=2501,algebraic]{0}{25}{\conditionsInitiales}{\Lorenz}\r
+\listplotHSB[linecolor=green,unit=0.25,HueBegin=.25,HueEnd=0.65]{tabXZ aload pop}%\r
+\uput[r](8,0){$x$}\r
+\uput[u](0,12){$z$}\r
+\end{pspicture}\r
+\end{verbatim}\r
+\subsection{Le tracé de YZ}\r
+\begin{center}\r
+\begin{pspicture}(-8,0)(8,12)\r
+\psgrid[subgriddiv=0,gridcolor=lightgray,griddots=10,gridlabels=0pt]%\r
+\pstVerb{\parametres}%\r
+  \psequadiff[% y,z\r
+  tabname=tabYZ,\r
+  method=rk4,\r
+  whichabs=1,\r
+  whichord=2,\r
+  saveData,filename=LorenzYZ.dat,\r
+  plotpoints=2501,algebraic]{0}{25}{\conditionsInitiales}{\Lorenz}\r
+\listplotHSB[linecolor=magenta,unit=0.25,HueBegin=0.65,HueEnd=1]{tabYZ aload pop}%\r
+\uput[r](8,0){$y$}\r
+\uput[u](0,12){$z$}\r
+\end{pspicture}\r
+\end{center}\r
+\begin{verbatim}\r
+\begin{pspicture}(-8,0)(8,12)\r
+\psgrid[subgriddiv=0,gridcolor=lightgray,griddots=10,gridlabels=0pt]%\r
+\pstVerb{\parametres}%\r
+  \psequadiff[% y,z\r
+  tabname=tabYZ,\r
+  method=rk4,\r
+  whichabs=1,\r
+  whichord=2,\r
+  saveData,filename=LorenzYZ.dat,\r
+  plotpoints=2501,algebraic]{0}{25}{\conditionsInitiales}{\Lorenz}\r
+\listplotHSB[linecolor=magenta,unit=0.25,HueBegin=0.65,HueEnd=1]{tabYZ aload pop}%\r
+\uput[r](8,0){$y$}\r
+\uput[u](0,12){$z$}\r
+\end{pspicture}\r
+\end{verbatim}\r
+\subsection{Le tracé du papillon de Lorenz en 3D}\r
+Le tracé en 3D est l'étape la plus délicate, puisqu'il faut réunir les fichiers $(x,y)$, $(x,z)$ et $(y,z)$ en un seul fichier $(x,y,z)$. Ce qu'on réalise ainsi :\r
+\begin{verbatim}\r
+\pstVerb{/XY [(LorenzXY.dat) run ] def\r
+         /XZ [(LorenzXZ.dat) run ] def\r
+         /YZ [(LorenzYZ.dat) run ] def\r
+/tabXYZ [\r
+    0 2 XY length 2 sub {/i exch def\r
+    [ XY i get\r
+      XY i 1 add get\r
+      YZ i 1 add get\r
+    ]\r
+    } for\r
+   ]def\r
+/fichierpoints (XYZLorenz.dat) (w) file def\r
+0 1 tabXYZ length 1 sub  {/i exch def\r
+    tabXYZ i get aload pop\r
+    /zi exch def\r
+    /yi exch def\r
+    /xi exch def\r
+      fichierpoints xi 15 string cvs writestring\r
+      fichierpoints 32 write %% espace\r
+      fichierpoints yi 15 string cvs writestring\r
+      fichierpoints 32 write %% espace\r
+      fichierpoints zi 15 string cvs writestring\r
+      fichierpoints 10 write %% CR\r
+} for\r
+fichierpoints closefile\r
+\end{verbatim}\r
+Les dernières lignes permettent d'enregistrer, si on le souhaite, le fichier de points.\r
+\begin{center}\r
+\begin{pspicture}(-6,-4)(6,12)\r
+\psset{THETA=-70,PHI=20,Dobs=2000,Decran=400}\r
+\pstVerb{/XY [(LorenzXY.dat) run ] def\r
+         /XZ [(LorenzXZ.dat) run ] def\r
+         /YZ [(LorenzYZ.dat) run ] def\r
+/tabXYZ [\r
+    0 2 XY length 2 sub {/i exch def\r
+    [ XY i get\r
+      XY i 1 add get\r
+      YZ i 1 add get\r
+    ]\r
+    } for\r
+   ]def\r
+/fichierpoints (XYZLorenz.dat) (w) file def\r
+0 1 tabXYZ length 1 sub  {/i exch def\r
+    tabXYZ i get aload pop\r
+    /zi exch def\r
+    /yi exch def\r
+    /xi exch def\r
+      fichierpoints xi 15 string cvs writestring\r
+      fichierpoints 32 write %% espace\r
+      fichierpoints yi 15 string cvs writestring\r
+      fichierpoints 32 write %% espace\r
+      fichierpoints zi 15 string cvs writestring\r
+      fichierpoints 10 write %% CR\r
+} for\r
+fichierpoints closefile\r
+}%\r
+\makeatletter\r
+\pstVerb{\r
+ /THETA \psk@TroisD@Theta def \r
+ /PHI \psk@TroisD@Phi def \r
+ /Dobs \psk@TroisD@Dobs def \r
+ /DScreen \psk@TroisD@Ecran def \r
+ /Sin1 THETA sin def\r
+ /Sin2 PHI sin def\r
+ /Cos1 THETA cos def\r
+ /Cos2 PHI cos def\r
+ /Cos1Sin2 Cos1 Sin2 mul def\r
+ /Sin1Sin2 Sin1 Sin2 mul def\r
+ /Cos1Cos2 Cos1 Cos2 mul def\r
+ /Sin1Cos2 Sin1 Cos2 mul def\r
+ /IIID {\r
+ 0 1 tabXYZ length 1 sub {/i exch def\r
+ /TAB tabXYZ i get def\r
+ /abscisse TAB 0 get def\r
+ /ordonnee TAB 1 get def\r
+ /cote TAB 2 get def\r
+ \formules} for\r
+ } def\r
+ }%\r
+ \makeatother\r
+\listplotHSB[unit=1]{IIID}\r
+\psset{unit=2.5,linestyle=dashed}\r
+\pnodeTroisD(0,0,0){O}\r
+\pnodeTroisD(0,0,5){Z}\r
+\pnodeTroisD(5,0,0){X}\r
+\pnodeTroisD(0,5,0){Y}\r
+\pnodeTroisD(-10,-10,0){A}\r
+\pnodeTroisD(-10,-10,20){B}\r
+\pnodeTroisD(-10,10,20){C}\r
+\pnodeTroisD(-10,10,0){D}\r
+\pnodeTroisD(10,-10,0){E}\r
+\pnodeTroisD(10,-10,20){F}\r
+\pnodeTroisD(10,10,20){G}\r
+\pnodeTroisD(10,10,0){H}\r
+\pspolygon(A)(B)(C)(D)\r
+\pspolygon(E)(F)(G)(H)\r
+\psline(A)(E)\r
+\psline(B)(F)\r
+\psline(D)(H)\r
+\psline(C)(G)\r
+\psset{linestyle=solid,linecolor=red}\r
+\psline{->}(O)(X)\r
+\psline{->}(O)(Y)\r
+\psline{->}(O)(Z)\r
+\end{pspicture}\r
+\end{center}\r
+\newpage\r
+Le tracé s'effectue grâce à la commande \verb+\pnodeTroisD+ et ses diverses options.\r
+\begin{verbatim}\r
+\makeatletter\r
+\pstVerb{\r
+ /THETA \psk@TroisD@Theta def\r
+ /PHI \psk@TroisD@Phi def\r
+ /Dobs \psk@TroisD@Dobs def\r
+ /DScreen \psk@TroisD@Ecran def\r
+ /Sin1 THETA sin def\r
+ /Sin2 PHI sin def\r
+ /Cos1 THETA cos def\r
+ /Cos2 PHI cos def\r
+ /Cos1Sin2 Cos1 Sin2 mul def\r
+ /Sin1Sin2 Sin1 Sin2 mul def\r
+ /Cos1Cos2 Cos1 Cos2 mul def\r
+ /Sin1Cos2 Sin1 Cos2 mul def\r
+ /IIID {\r
+ 0 1 tabXYZ length 1 sub {/i exch def\r
+ /TAB tabXYZ i get def\r
+ /abscisse TAB 0 get def\r
+ /ordonnee TAB 1 get def\r
+ /cote TAB 2 get def\r
+ \formules} for\r
+ } def\r
+ }%\r
+ \makeatother\r
+\listplotHSB[unit=1]{IIID}\r
+\psset{unit=2.5,linestyle=dashed}\r
+\pnodeTroisD(0,0,0){O}\r
+\pnodeTroisD(0,0,5){Z}\r
+\pnodeTroisD(5,0,0){X}\r
+\pnodeTroisD(0,5,0){Y}\r
+\pnodeTroisD(-10,-10,0){A}\r
+\pnodeTroisD(-10,-10,20){B}\r
+\pnodeTroisD(-10,10,20){C}\r
+\pnodeTroisD(-10,10,0){D}\r
+\pnodeTroisD(10,-10,0){E}\r
+\pnodeTroisD(10,-10,20){F}\r
+\pnodeTroisD(10,10,20){G}\r
+\pnodeTroisD(10,10,0){H}\r
+\pspolygon(A)(B)(C)(D)\r
+\pspolygon(E)(F)(G)(H)\r
+\psline(A)(E)\r
+\psline(B)(F)\r
+\psline(D)(H)\r
+\psline(C)(G)\r
+\psset{linestyle=solid,linecolor=red}\r
+\psline{->}(O)(X)\r
+\psline{->}(O)(Y)\r
+\psline{->}(O)(Z)\r
+\end{verbatim}\r
+\section{Animations avec le package animate}\r
+En préparation.\r
+\end{document}\r
+\r

Licence Creative Commons Les fichiers de Syracuse sont mis à disposition (sauf mention contraire) selon les termes de la
Licence Creative Commons Attribution - Pas d’Utilisation Commerciale - Partage dans les Mêmes Conditions 4.0 International.