--- /dev/null
+<h1 id="fonctions-et-macros-graphiques">Fonctions et macros graphiques</h1>
+<p>Ces fonctions et macros créent un élément graphique au moment de leur évaluation et renvoient un résultat égal à <em>Nil</em>, elles ne sont utilisables <strong>que lors de la création d’un élément graphique "Utilisateur"</strong><sup><a href="#fn1" class="footnoteRef" id="fnref1">1</a></sup>.</p>
+<p>Elles peuvent être utilisées dans des macros, mais elles ne seront évaluées que si ces macros sont exécutées lors de la création d’un élément graphique "Utilisateur".</p>
+<h2 id="fonctions-graphiques-prédéfinies">Fonctions graphiques prédéfinies</h3>
+<p>Notations:</p>
+<p><argument>: signifie que l’argument est <strong>obligatoire</strong>.</p>
+<p>[, argument]: signifie que l’argument est <strong>facultatif</strong>.</p>
+<h3 id="Axes">Axes</h3>
+<ul>
+<li><p><b>Axes( <origine>, <graduationX + i*graduationY> [, position label origine] )</b>.</p></li>
+<li><p><u>Description</u> : dessine les axes, <<em>origine</em>> est l’affixe du point d’intersection des axes, <<em>graduationX</em>> est le pas pour les graduations sur l’axe Ox, et <<em>graduationY</em>> celui de l’axe Oy, une graduation égale à zéro signifie l’absence de graduation. La longueur des graduations est dans la variable globale <span style="color:red">xyticks</span> que l’on peut modifier, la distance des labels à l’extrêmité des graduations est dans la variable <span style="color:red">xylabelsep</span> qui peut également être modifiée.</p>
+<p>Le troisième paramètre est facultatif, il permet de préciser la position des labels de l’origine (à l’intersection des axes), c’est un complexe: <span class="math"><em>a</em> + <em>i</em><em>b</em></span>, la partie réelle concerne l’abscisse de l’origine et l’autre concerne l’ordonnée. Ces deux nombres peuvent prendre trois valeurs:</p>
+<ul>
+<li><p><span class="math">0</span>: le label n’apparaît pas,</p></li>
+<li><p><span class="math">1</span>: le label est affiché comme celui des autres graduations,</p></li>
+<li><p><span class="math">2</span>: le label est décalé pour ne pas chevaucher l’autre axe (valeur par défaut).</p></li>
+</ul></li>
+<li><p>On peut modifier dans les <em>Attributs</em>: le style de ligne, l’épaisseur, la couleur et la taille des labels.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-5,4,-5,5),Marges(0.5,0,0,0.5), size(7.5), Width:=2, Color:=lightgray, Grille(-5-5*i,(1+i)/2), Width:=4, Color:=gray, Grille(-5-5*i,(1+i)), Color:=black, Arrows:=1, Axes(-5-5*i,1+i,1+i),Arrows:=0, LabelAxe(x,-pi-5*i,"<span class="math"> - π</span>",2-i,1), LabelAxe(x,pi-5*i,"<span class="math">π</span>",2+i,1), SaveAttr(), FillStyle:=full, FillColor:=lightblue, FillOpacity:=0.5, domaine2(3*sin(x)^3, -5,-pi,pi), RestoreAttr(), Color:=red, Arrows:=0, Width:=8, Cartesienne( 3*sin(x)^3 )</p>
+</blockquote>
+</blockquote>
+<h3 id="poly-bezier">(Poly-)Bezier</h3>
+<ul>
+<li><p><b>Bezier( <liste de points> )</b>.</p></li>
+<li><p><u>Description</u> : dessine une succession de courbes de {Bezier} (avec éventuellement des segments de droite). Il y a plusieurs possibilités pour la liste de points:</p>
+<ol>
+<li><p>une liste de trois points <span class="math">[<em>A</em>, <em>C</em>, <em>B</em>]</span>, il s’agit alors d’une courbe de Bezier d’origine <<em>A</em>> et d’extrémité <<em>B</em>> avec un point de contrôle <<em>C</em>>, c’est la courbe paramétrée par:</p>
+<p><br /><span class="math">(1 - <em>t</em>)<sup>2</sup><em>A</em> + 2<em>t</em>(1 - <em>t</em>)<em>C</em> + <em>t</em><sup>2</sup><em>B</em></span><br /></p></li>
+<li><p>une liste de 4 points ou plus: [A1, C1, C2, A2, C3, C4, A3...]: il s’agit alors d’une succession de courbes de Bezier à 2 points de contrôles, la première va de A1 à A2, elle est contrôlée par C1, C2 (paramétrée par <span class="math">(1 - <em>t</em>)<sup>3</sup><em>t</em><em>A</em>1 + 3(1 - <em>t</em>)<sup>2</sup><em>t</em><em>C</em>1] + 3(1 - <em>t</em>)<em>t</em><sup>2</sup><em>C</em>2 + <em>t</em><sup>3</sup><em>A</em>2</span>), la deuxième va de A2 à A3 et est contrôlée par C3,C4 ...etc. Une exception toutefois, on peut remplacer les deux points de contrôle par la constante <em>jump</em>, dans ce cas on saute directement de A1 à A2 en traçant un segment de droite.</p></li>
+</ol></li>
+<li><p>Le nombre de points calculés (par courbe) est modifiable dans les <em>Attributs</em> (variable <span style="color:red">NbPoints</span>).</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-4,4,-4,5),Marges(0,0,0,0), size(7.5), Width:=8, A:=-3+4*i, B:=3+i, C:=3-3*i, D:=-3-3*i, C1:=4.5*i,C2:=-2*i, C3:=2-i, C4:=-2, FillStyle:=full, FillColor:=lightblue,Color:=red, Bezier(A,C1,C2,B,jump,C,C3,C4,D,jump,A), FillStyle:=none, DotStyle:=cross, DotScale:=2,Color:=black, LabelDot(A,"<span class="math"><em>A</em></span>","N",1), LabelDot(B,"<span class="math"><em>B</em></span>","E",1), LabelDot(C,"<span class="math"><em>C</em></span>","SE",1), LabelDot(D,"<span class="math"><em>D</em></span>","SO",1), LabelDot(C1,"<span class="math"><em>C</em><sub>1</sub></span>","E",1), LabelDot(C2,"<span class="math"><em>C</em><sub>2</sub></span>","SO",1), LabelDot(C3,"<span class="math"><em>C</em><sub>3</sub></span>","N",1), LabelDot(C4,"<span class="math"><em>C</em><sub>4</sub></span>","N",1), LineStyle:=userdash, DashPattern:=[5,2,0.5,2], Width:=6, LineCap:=round, Ligne([A,C1,C2,B,jump,C,C3,C4,D],0)</p>
+</blockquote>
+</blockquote>
+<h3 id="Cartesienne">Cartesienne</h3>
+<ul>
+<li><p><b>Cartesienne( <f(x)> [, n, 1] )</b>.</p></li>
+<li><p><u>Description</u> : trace la courbe cartésienne d’équation <span class="math"><em>y</em> = <em>f</em>(<em>x</em>)</span>. Le paramètre optionnel <<em>n</em>> est un entier (égal à 5 par défaut) qui permet de faire varier le pas de la manière suivante: lorsque la distance entre deux points consécutifs est supérieur à un certain seuil alors on calcule un point intermédiaire [par dichotomie], ceci peut être répété n fois. Si au bout de n itérations la distance entre deux points consécutifs est toujours supérieure au seuil, et si la valeur optionnelle <span class="math">1</span> est présente, alors une discontinuité (<em>jump</em>) est insérée dans la liste des points.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-2,2,-0.1,2),Marges(0.5,0.5,0.5,0.5), size(7.5), tMin:=-2, tMax:=2, Color:=darkgray, Width:=8, LineStyle:=dotted, Grille(0,0.5*(1+i)), Color:=black, LineStyle:=solid,Axes(0,1+i,1), NbPoints:=100, Width:=8, Color:=darkseagreen, Cartesienne(x*Ent(1/x),5,1)</p>
+</blockquote>
+</blockquote>
+<h3 id="Courbe">Courbe</h3>
+<ul>
+<li><p><b>Courbe( <f(t)> [, n, 1] )</b>.</p></li>
+<li><p><u>Description</u> : trace la courbe paramétrée par <<em>f(t)</em>> où <span class="math"><em>f</em></span> est à valeurs complexes.</p>
+<p>Le paramètre optionnel <<em>n</em>> est un entier (égal à 5 par défaut) qui permet de faire varier le pas de la manière suivante: lorsque la distance entre deux points consécutifs est supérieur à un certain seuil alors on calcule un point intermédiaire (par dichotomie), ceci peut être répété <span class="math"><em>n</em></span> fois. Si au bout de <span class="math"><em>n</em></span> itérations la distance entre deux points consécutifs est toujours supérieure au seuil, et si la valeur optionnelle <span class="math">1</span> est présente, alors une discontinuité (<em>jump</em>) est insérée dans la liste des points.</p></li>
+</ul>
+<h3 id="Droite">Droite</h3>
+<ul>
+<li><p><b>Droite( <A>, <B> [, C] )</b>.</p></li>
+<li><p><u>Description</u> : trace la droite <span class="math">(<em>A</em><em>B</em>)</span> lorsque le troisième argument <<em>C</em>> est omis, sinon c’est la droite d’équation cartésienne <<em>A</em>>x+<<em>B</em>>y=<<em>C</em>>.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-5,5,-5,5),Marges(0,0,0,0), size(7.5), F:=sqrt(7), F’:=-F, {foyers} Width:=1, Color:=darkgray, for t from -pi to pi step 0.1 do M:=4*cos(t)+3*i*sin(t), Vn:=(M-F)/abs(M-F)+(M-F’)/abs(M-F’), Droite(M,M+Vn),{normale à l’ellipse} od, Width:=8, Color:=red, Ellipse(0,4,3), LabelDot(F,"<span class="math"><em>F</em></span>","S",1), LabelDot(F’,"<span class="math"><em>F</em>ʹ</span>","S",1)</p>
+</blockquote>
+</blockquote>
+<h3 id="Ellipse">Ellipse</h3>
+<ul>
+<li><p><b>Ellipse( <A>, <Rx>, <Ry> [, inclinaison] )</b>.</p></li>
+<li><p><u>Description</u> : trace une ellipse de centre <<em>A</em>> de rayons <<em>Rx</em>> et <<em>Ry</em>> sur les axes respectifs <span class="math"><em>O</em><em>x</em></span> et <span class="math"><em>O</em><em>y</em></span>. Le dernier paramètre <<em>inclinaison</em>> est un angle en degrés (nul par défaut) qui indique l’inclinaison de l’ellipse par rapport à l’horizontale.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-5.25,5.25,-5.25,5.25), Marges(0,0,0,0), size(7.5), background(full,blue), Width:=4, Color:=white, inclin:=[0,35,-35], for z in inclin do Ellipse(0,5,2,z) od, Width:=2*mm, Ellipse(0,1.5,4.5), Label(-0.1, "{6cm} {3.5cm} {R T F}")</p>
+</blockquote>
+</blockquote>
+<h3 id="EllipticArc">EllipticArc</h3>
+<ul>
+<li><p><b>EllipticArc( <B>, <A>, <C>, <Rx>, <Ry> [, sens] )</b>.</p></li>
+<li><p><u>Description</u> : trace un arc d’ellipse dont les axes sont <span class="math"><em>O</em><em>x</em></span> et <span class="math"><em>O</em><em>y</em></span> et le centre <<em>A</em>>, le rayon sur <span class="math"><em>O</em><em>x</em></span> est <<em>Rx</em>>, et celui sur <span class="math"><em>O</em><em>y</em></span> est <<em>Ry</em>>. L’arc est tracé partant de la droite <span class="math">(<em>A</em><em>B</em>)</span> jusqu’à la droite <span class="math">(<em>A</em><em>C</em>)</span>, l’argument facultatif <<em>sens</em>> indique: le sens trigonométrique si sa valeur est <span class="math">1</span> (valeur par défaut), le sens contraire si sa valeur est <span class="math"> - 1</span>.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-2.25,3.75,-2,5),Marges(0,0,0,0),size(7.5), A:=0, B:=3+i, C:=2+4*i, DotScale:=2, Width:=8, Ligne([B,A,C],0), Color:=red, LabelDot(A,"<span class="math"><em>A</em></span>","S",1), LabelDot(B,"<span class="math"><em>B</em></span>","N",1), LabelDot(C,"<span class="math"><em>C</em></span>","SE",1), Arrows:=1, Color:=blue, EllipticArc(B,A,C,2,1,-1), EllipticArc(B,A,C,2,3,1)</p>
+</blockquote>
+</blockquote>
+<p>Remarque: pour un arc de cercle, il suffit de prendre <<em>Rx</em>> et <<em>Ry</em>> égaux. Mais le plus simple est d’utiliser la macro <a href="#Arc">Arc</a> qui remplace la commande <strong>Arc</strong> de l’ancienne version.</p>
+<h3 id="EquaDif">EquaDif</h3>
+<ul>
+<li><p><b>EquaDif( <f(t,x,y)>, <t0>, <x0 + i*y0> [, mode] )</b>.</p></li>
+<li><p><u>Description</u> : trace une solution approchée de l’équation différentielle: <span class="math"><em>x</em>ʹ(<em>t</em>) + <em>i</em><em>y</em>ʹ(<em>t</em>) = <em>f</em>(<em>t</em>, <em>x</em>, <em>y</em>)</span> avec la condition initiale <span class="math"><em>x</em>(<em>t</em>0) = <em>x</em>0</span> et <span class="math"><em>y</em>(<em>t</em>0) = <em>y</em>0</span>. Le dernier paramètre est facultatif et peut valoir 0, 1 ou 2:</p>
+<ul>
+<li><p><<em>mode</em>>=0: la courbe représente les points de coordonnées <span class="math">(<em>x</em>(<em>t</em>), <em>y</em>(<em>t</em>))</span>, c’est la valeur par défaut.</p></li>
+<li><p><<em>mode</em>>=1: la courbe représente les points de coordonnées <span class="math">(<em>t</em>, <em>x</em>(<em>t</em>))</span>.</p></li>
+<li><p><<em>mode</em>>=2: la courbe représente les points de coordonnées <span class="math">(<em>t</em>, <em>y</em>(<em>t</em>))</span>.</p></li>
+</ul>
+<p>C’est la méthode de {Runge-Kutta} d’ordre 4 qui est utilisée.</p></li>
+<li><p><u>Exemple(s)</u> : l’équation <span class="math"><em>x</em>ʹʹ - <em>x</em>ʹ - <em>t</em><em>x</em> = sin(<em>t</em>)</span> avec la condition initiale <span class="math"><em>x</em>(0) =  - 1</span> et <span class="math"><em>x</em>ʹ(0) = 1 / 2</span>, se met sous la forme: <br /><span class="math">$\begin{pmatrix}
+X'\\Y'\end{pmatrix}=\begin{pmatrix} 0&1\\t&1\end{pmatrix}\begin{pmatrix}X\\Y\end{pmatrix}+
+\begin{pmatrix}0\\\sin(t)\end{pmatrix}$</span><br /> en posant <span class="math"><em>X</em> = <em>x</em></span> et <span class="math"><em>Y</em> = <em>x</em>ʹ</span>:</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-10.5,2.5,-1.5,4.5),Marges(0,0,0,0), size(7.5,0), Arrows:=1, Width:=4, Axes(0,1+i), Arrows:=0, LabelAxe(y,4.25*i,"<span class="math"><em>x</em></span>"), LabelAxe(x,2,"<span class="math"><em>t</em></span>",2), Width:=8, Color:=red, tMin:=-10, tMax:=2, EquaDif(y+i*(t*x+y+sin(t)),0,-1+i/2, 1), Color:=black, LabelStyle:=stacked, Label(-6+2*i, "<span class="math"><em>x</em>ʹʹ - <em>t</em><em>x</em>ʹ - <em>x</em> = sin(<em>t</em>)</span><br /> avec <span class="math"><em>x</em>(0) =  - 1</span> et <span class="math">$x'(0)=\frac12$</span>")</p>
+</blockquote>
+</blockquote>
+<h3 id="Grille">Grille</h3>
+<ul>
+<li><p><b>Grille( <origine>, <graduationX + i*graduationY> )</b>.</p></li>
+<li><p><u>Description</u> : dessine une grille, <<em>origine</em>> est l’affixe du point considéré comme origine, <<em>graduationX</em>> est le pas des graduations sur l’axe Ox, et <<em>graduationY</em>> celui de l’axe Oy, une graduation égale à zéro signifie l’absence de graduation.</p></li>
+<li><p>On peut modifier dans les <em>Attributs</em> le style de ligne, l’épaisseur et la couleur. La grille de ne fait pas appraître de graduations, on peut dessiner des axes par dessus.</p></li>
+</ul>
+<h3 id="Implicit">Implicit</h3>
+<ul>
+<li><p><b>Implicit( <f(x,y)> [, n, m] )</b>.</p></li>
+<li><p><u>Description</u> : trace la courbe implicite d’équation <span class="math"><em>f</em>(<em>x</em>, <em>y</em>) = 0</span>. L’intervalle des abscisses est subdivisé en <<em>n</em>> parties et l’intervalle des ordonnées en <<em>m</em>> parties, par défaut <span class="math"><em>n</em> = <em>m</em> = 25</span>. Sur chaque pavé ainsi obtenu on teste s’il y a un changement de signe, auquel cas on applique une dichotomie sur les bords du pavé.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-5,5,-5,5),Marges(0,0,0,0), size(7.5), Arrows:=1, Width:=4, Axes(0,1+i), Arrows:=0, Width:=8, Color:=red, Implicit( sin(x*y) )</p>
+</blockquote>
+</blockquote>
+<h3 id="Label">Label</h3>
+<ul>
+<li><p><b>Label( <affixe1>, <texte1>,..., <affixeN>, <texteN> )</b>.</p></li>
+<li><p><u>Description</u> : place la chaîne de caractères <<em>texte1</em>> à la position <<em>affixe1</em>> ... etc. Les paramètres <<em>texte1</em>>,..., <<em>texteN</em>> sont donc interprétés comme des <a href="#chaine">chaînes de caractères</a>.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-5,5,-5,5),Marges(0,0,0,0), size(7.5,0), C:=Cube(Origin, M(3,3,0)), S:=Sommets(C), Point3D(S), DrawPoly(C,0), k:=0, for Z in S by 2 do Inc(k,1), Label(Proj3D(Z)+ if k>4 then 0.5*i else -0.5*i fi, ["<span class="math">$S_",k,"$</span>"]) od</p>
+</blockquote>
+</blockquote>
+<h3 id="Ligne">Ligne</h3>
+<ul>
+<li><p><b>Ligne( <liste>, <fermée> [, rayon] )</b>.</p></li>
+<li><p><u>Description</u> : trace la ligne polygonale définie par la liste, si le paramètre <<em>fermée</em>> vaut 1, la ligne polygonale sera fermée, si sa valeur est 0 la ligne est ouverte. Si l’argument <<em>rayon</em>> est précisé (0 par défaut), alors les "angles" de la ligne polygonale sont arrondis avec un arc de cercle dont le rayon correspond à l’argument <<em>rayon</em>>.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>Marges(0,0,0,0), size(7.5), A:=-5-5*i, B:=5*i, C:=5-5*i,niv:=6, Tr:=[A,B,C,jump], {initial} for k from 1 to niv do Tr:=[hom(Tr,A,0.5),hom(Tr,B,0.5), hom(Tr,C,0.5)] od, FillStyle:=full,FillColor:=blue, Ligne(Tr,1)</p>
+</blockquote>
+</blockquote>
+<h3 id="Path">Path</h3>
+<ul>
+<li><p><b>Path( <liste> [, fermé (0/1)]</b></p></li>
+<li><p><u>Description</u> : trace le chemin représenté par <<em>liste</em>> et ferme la dernière composante de celui-ci si l’argument optionnel vaut <span class="math">1</span> (sa valeur par défaut est <span class="math">0</span>). La liste est une succession de points (affixes) et d’instructions indiquant à quoi correspondent ces points, ces instructions sont:</p>
+<ul>
+<li><p><strong>line</strong>: relie les points par une ligne polygonale,</p></li>
+<li><p><strong>linearc</strong>: relie les points par une ligne polygonale mais les angles sont arrondis par un arc de cercle, la valeur précédent la commande linearc est interprétée comme le rayon de ces arcs.</p></li>
+<li><p><strong>arc</strong>: dessine un arc de cercle, ce qui nécessite quatre arguments: 3 points et le rayon, plus éventuellement un cinquième argument: le sens (+/- 1), le sens par défaut est 1 (sens trigonométrique).</p></li>
+<li><p><strong>ellipticArc</strong>: dessine un arc d’ellipse, ce qui nécessite cinq arguments: 3 points, le rayonX, le rayonY, plus éventuellement un sixième argument: le sens (+/- 1), le sens par défaut est 1 (sens trigonométrique), plus éventuellement un septième argument: l’inclinaison en degrés du grand axe par rapport à l’horizontale.</p></li>
+<li><p><strong>curve</strong>: relie les points par une spline cubique naturelle.</p></li>
+<li><p><strong>bezier</strong>: relie le premier et le quatrième point par une courbe de bézier (les deuxième et troisième points sont les points de contrôle).</p></li>
+<li><p><strong>circle</strong>: desine un cercle, ce qui necessite deux arguments: un point et le centre, ou bien trois arguments qui sont trois points du cercle.</p></li>
+<li><p><strong>ellipse</strong>: dessine une ellipse, les arguments sont: un point, le centre, rayon rX, rayon rY, inclinaison du grand axe en degrés par rapport à l’horizontale (facultatif).</p></li>
+<li><p><strong>move</strong>: indique un déplacement sans tracé.</p></li>
+<li><p><strong>closepath</strong>: ferme la composante en cours.</p></li>
+</ul>
+<p>Par convention, le premier point du tronçon numéro n+1 est le dernier point du tronçon numéro n.</p></li>
+<li><p><u>Exemple(s)</u> : </p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-5,5,-4,6),Marges(0,0,0,0),size(7.5), Axes(2*i,1+i),Eofill:=1, FillStyle:=full,FillOpacity:=0.9, FillColor:= blue, Width:=8, Path([-4,i,circle, -3+2*i,move,-3,-2,line, 0,2,2,-1,arc, 3,3+3*i,0.5,linearc, 1,-1+5*i,-3+2*i,bezier, closepath, ])</p>
+</blockquote>
+</blockquote>
+<h3 id="Point">Point</h3>
+<ul>
+<li><p><b>Point( <A1>, ..., <An> )</b>.</p></li>
+<li><p><u>Description</u> : représente le nuage de points <<em>A1</em>> ... <<em>An</em>>.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(2.75,4,0,1), Marges(0.75,0.5,0.5,0.5),size(7.5), Axes(Xmin+i*Ymin,0.25+0.2*i,1+i), pas:=0.001, Color:=red, DotScale:=0.1, Point( for r from Xmin to Xmax step pas do u:=0.5, for k from 1 to 25 do u:=r*u*(1-u) od, for k from 1 to 25 do u:=r*u*(1-u), r+i*u od od)</p>
+</blockquote>
+</blockquote>
+<h3 id="Polaire">Polaire</h3>
+<ul>
+<li><p><b>Polaire( <r(t)> [, n, 0/1] )</b>.</p></li>
+<li><p><u>Description</u> : trace la courbe polaire d’équation <span class="math">ρ = <em>r</em>(<em>t</em>)</span>, <<em>expression</em>>. Le paramètre optionnel <<em>n</em>> est un entier (égal à 5 par défaut) qui permet de faire varier le pas de la manière suivante: lorsque la distance entre deux points consécutifs est supérieur à un certain seuil alors on calcule un point intermédiaire (par dichotomie), ceci peut être répété <span class="math"><em>n</em></span> fois. Si au bout de <span class="math"><em>n</em></span> itérations la distance entre deux points consécutifs est toujours supérieure au seuil, et si la valeur optionnelle <span class="math">1</span> est présente, alors une discontinuité (<em>jump</em>) est insérée dans la liste des points.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-3,2,-2,3),Marges(0.25,0.25,0.25,0.25), size(7.5),Width:=4, Axes(0,1+i),NbPoints:=250,tMin:=-25,tMax:=25, courbe:=Get(Polaire((t+1)/(t-1))), ptDoubles:= courbe InterL courbe, Width:=8, Color:= blue, Ligne(courbe,0), DotStyle:=dotcircle, DotScale:=2, Point(ptDoubles), Label(1+2*i,"<span class="math">$r(t)=\dfrac{t+1}{t-1}$</span>")</p>
+</blockquote>
+</blockquote>
+<h3 id="Spline">Spline</h3>
+<ul>
+<li><p><b>Spline( <V0>, <A0>,..., <An>, <Vn> )</b>.</p></li>
+<li><p><u>Description</u> : trace la spline cubique passant par les points <<em>A0</em>> jusqu’à <<em>An</em>>. <<em>V0</em>> et <<em>Vn</em>> désignent les vecteurs vitesses aux extrémités [contraintes], si l’un d’eux est nul alors l’extrémité correspondante est considérée comme libre (sans contrainte).</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-5,5,-5,5),Marges(0.25,0.25,0.25,0.25), size(7.5),Width:=4,Axes(0,1+i), A:= -4-3*i, B:=-2+2*i, C:=1-3*i, D:=4+3*i, LabelDot(A,"<span class="math"><em>A</em></span>","S",1),LabelDot(B,"<span class="math"><em>B</em></span>","N",1), LabelDot(C,"<span class="math"><em>C</em></span>","S",1),LabelDot(D,"<span class="math"><em>D</em></span>","O",1), Width:=8,Color:=red, Spline(0,A,B,C,D,0), Ligne([-4.5+4.5*i,-4+4.5*i],0), LabelStyle:=left, Label(-3.5+4.5*i,"libre"), Color:=blue,Spline(5,A,B,C,D,5*i), Ligne([-4.5+3.5*i,-4+3.5*i],0), Label(-3.5+3.5*i,"contrainte"), Width:=4, Arrows:=1, Ligne([A,A+2,jump,D,D+2*i],0)</p>
+</blockquote>
+</blockquote>
+<h2 id="commandes-de-dessin-bitmap">Commandes de dessin bitmap</h3>
+<p>La version propose quelques commandes de base pour faire du dessin bitmap. Ce dessin bitmap peut être enregistré (au format <em>bmp</em>) mais il n’est pas pris en compte par les autres exports du logiciel. Ces commandes ne sont fonctionnelles qu’avec la version GUI de TeXgraph. Chaque pixel est repéré son affixe <span class="math"><em>x</em> + <em>i</em><em>y</em></span> où <span class="math"><em>x</em></span> et <span class="math"><em>y</em></span> sont deux entiers, l’origine est en haut à gauche de la zone de dessin <strong>marges exclues</strong>, l’axe <span class="math"><em>O</em><em>x</em></span> est dirigé vers la droite et l’axe <span class="math"><em>O</em><em>y</em></span> vers le bas.</p>
+<h3 id="DelBitmap">DelBitmap</h3>
+<ul>
+<li><p><b>DelBitmap()</b>.</p></li>
+<li><p><u>Description</u> : détruit le bitmap en cours.</p></li>
+</ul>
+<h3 id="MaxPixels">MaxPixels</h3>
+<ul>
+<li><p><b>MaxPixels()</b>.</p></li>
+<li><p><u>Description</u> : renvoie la taille de la zone graphique en pixels sous la forme: <span style="font-style:italic">maxX+i*maxY</span>, ainsi pour les coordonnées des pixels (coordonnées entières), l’intervalle des abscisses est <span style="font-style:italic">[0 .. maxX]</span> et celui des ordonnées <span style="font-style:italic">[0 .. maxY]</span>. Chaque pixel est repéré par des coordonnées entières, donc chaque pixel a une affixe <span class="math"><em>a</em> + <em>i</em><em>b</em></span> avec <span class="math"><em>a</em></span> dans <span style="font-style:italic">[0 .. maxX]</span> et <span class="math"><em>b</em></span> dans <span style="font-style:italic">[0 .. maxY]</span>. L’origine étant le coin supérieur gauche de la zone graphique <strong>marges exclues</strong>.</p></li>
+</ul>
+<h3 id="NewBitmap">NewBitmap</h3>
+<ul>
+<li><p><b>NewBitmap( [fond] )</b>.</p></li>
+<li><p><u>Description</u> : permet de créer un nouveau bitmap (vide). Par défaut la couleur du fond est le blanc.</p></li>
+</ul>
+<h3 id="Pixel">Pixel</h3>
+<ul>
+<li><p><b>Pixel( <liste> )</b>.</p></li>
+<li><p><u>Description</u> : permet de d’allumer une <<em>liste</em>> de pixels. Cette liste est de la forme: <span style="font-style:italic">[affixe, couleur, affixe, couleur, ...]</span>. Les affixes des pixels sont de la forme <span class="math"><em>a</em> + <em>i</em><em>b</em></span> avec <span class="math"><em>a</em></span> et <span class="math"><em>b</em></span> des entiers positifs ou nuls, l’origine étant le coin supérieur gauche de la zone graphique <strong>marges exclues</strong>.</p></li>
+</ul>
+<h3 id="Pixel2Scr">Pixel2Scr</h3>
+<ul>
+<li><p><b>Pixel2Scr( <affixe> )</b>.</p></li>
+<li><p><u>Description</u> : permet de convertir l’<<em>affixe</em>> d’un pixel (coordonnées entières) en affixe dans le repère de l’utilisateur à l’écran.</p></li>
+</ul>
+<h3 id="Scr2Pixel">Scr2Pixel</h3>
+<ul>
+<li><p><b>Scr2Pixel( <affixe> )</b>.</p></li>
+<li><p><u>Description</u> : permet de convertir l’<<em>affixe</em>> d’un point dans le repère de l’utilisateur à l’écran en coordonnées entières (affixe du pixel correspondant au point).</p></li>
+<li><p><u>Exemple(s)</u> : un ensemble de Julia, la commande est à placer dans un élément graphique utilisateur. L’image <em>png</em> a été obtenue à partir du bouton <em>snapshot</em> de l’interface graphique en prenant l’export <em>bmp</em> puis une conversion en <em>png</em>:</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-1.5,1.5,-1,1),Marges(0,0,0,0),size(7.5), NewBitmap(), T:=100, m:=MaxPixels(), c:=-0.181-0.667*i, for x from 0 to Re(m) do Pixel( for y from 0 to Im(m) do N:=0, z:=Pixel2Scr(x+i*y), repeat z:=z^2+c, Inc(N,1) until (N=T) Or (abs(z)>2) od, x+i*y, MixColor(darkred,1-N/T,yellow,N/T) od ) od</p>
+</blockquote>
+</blockquote>
+<h2 id="macros-graphiques-de-texgraph.mac">Macros graphiques de TeXgraph.mac</h3>
+<h3 id="angleD">angleD</h3>
+<ul>
+<li><p><b>angleD( <B>, <A>, <C>, <r> )</b>.</p></li>
+<li><p><u>Description</u> : dessine l’angle <span class="math">$\widehat{BAC}$</span> avec un parallèlogramme de coté r.</p></li>
+</ul>
+<h3 id="Arc">Arc</h3>
+<ul>
+<li><p><b>Arc( <B>, <A>, <C>, <R> [, sens] )</b>.</p></li>
+<li><p><u>Description</u> : trace un arc de cercle de centre <<em>A</em>> et de rayon <<em>R</em>>. L’arc est tracé partant de la droite <span class="math">(<em>A</em><em>B</em>)</span> jusqu’à la droite <span class="math">(<em>A</em><em>C</em>)</span>, l’argument facultatif <<em>sens</em>> indique: le sens trigonométrique si sa valeur est <span class="math">1</span> (valeur par défaut), le sens contraire si valeur est <span class="math"> - 1</span>.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-2.25,3.75,-2,5),Marges(0,0,0,0),size(7.5), A:=0, B:=3+i, C:=2+4*i, DotScale:=2, Width:=8, Ligne([B,A,C],0), Color:=red, LabelDot(A,"<span class="math"><em>A</em></span>","S",1), LabelDot(B,"<span class="math"><em>B</em></span>","N",1), LabelDot(C,"<span class="math"><em>C</em></span>","SE",1), Arrows:=1, Color:=blue, Arc(B,A,C,1,-1), Arc(B,A,C,2,1)</p>
+</blockquote>
+</blockquote>
+<h3 id="arcBezier">arcBezier</h3>
+<ul>
+<li><p><b>arcBezier( <B>, <A>, <C>, <r> [,sens] )</b>.</p></li>
+<li><p><u>Description</u> : a le même effet que la macro graphique <span style="font-style:italic">Arc</span> mais l’arc est dessiné avec des courbes de Bezier.</p></li>
+</ul>
+<h3 id="axes-1">axes</h3>
+<ul>
+<li><p><b>axes( <[origine, etendueX, etendueY]>, <gradX+i*gradY> [, subdivX+i*subdivY, posOriginX+i*posOriginY, num, "texte", den, firstnum] )</b>.</p></li>
+<li><p><u>Description</u> : pour tracer et graduer les axes passant par <<em>origine</em>> (affixe), elle s’utilise comme la commande <a href="#Axes">Axes</a> et utilise donc les variables <em>xylabelpos</em> et <em>xyticks</em>. Par défaut les axes occupent toute la fenêtre si les paramètres optionnels <<em>etendueX</em>> et <<em>etendueY</em>> sont omis. Le paramètre <<em>etendueX</em>> représente sous forme complexe l’intervalle des abcisses: <code>xmin+i*xmax</code>, de même pour les ordonnées avec le paramètre <<em>etendueY</em>>, les axes sont alors limités à ces intervalles. Remarque: pour préciser une valeur de <<em>etendueY</em>> sans préciser de valeur pour <<em>etendueX</em>>, il suffit de mettre <em>jump</em> à la place de <<em>etendueX</em>> (et non pas <em>Nil</em>!).</p></li>
+<li><p>Le paramètre optionnel <<em>subdivX+i*subdivY</em>> indique le nombre de subdivisions par unité sur chaque axe (0 par défaut).</p></li>
+<li><p>Le paramètre optionnel <<em>posOriginX+i*posOriginY</em>> permet de positionner le label de l’origine:</p>
+<ul>
+<li><p><<em>posOriginX</em>>=0: pas de label à l’origine (idem pour <<em>posOriginY</em>>=0),</p></li>
+<li><p><<em>posOriginX</em>>=1: label normal à l’origine (idem pour <<em>posOriginY</em>>=1),,</p></li>
+<li><p><<em>posOriginX</em>>=2: label décalé à droite de l’origine et en haut pour <<em>posOriginY</em>>=2 (valeurs par défaut),</p></li>
+<li><p><<em>posOriginX</em>>=-2 label décalé à gauche de l’origine et en bas pour <<em>posOriginY</em>>=-2.</p></li>
+</ul></li>
+<li><p>Sur les 2 axes, chaque label est multiplié par la fraction <<em>num/den</em>> (1 par défaut), ajouté à <<em>firstnum/den</em>> (l’origine par défaut) et accompagné du <<em>"texte"</em>> au numérateur. Pour que le séparateur décimal soit la virgule à la place du point, il suffit de mettre la variable <span style="font-style:italic;color:red">usecomma</span> à la valeur <span class="math">1</span>. Cette macro est également sensible aux variables <span style="font-style:italic;color:red">dollar</span> (pour ajouter ou non des $ autour des labels des graduations), et <span style="font-style:italic;color:red">nbdeci</span> qui fixe le nombre de décimales affichées.</p></li>
+<li><p><u>Exemple(s)</u> : pour avoir des axes gradués en <span class="math">π / 2</span> en <span class="math">π / 2</span>: <span style="color:red">axes(0, pi*(1+i)/2, 1+i, 2+2*i, 1, "\pi", 2, 0)</span>. Contrairement à la commande Axes, cette macro est sensible aux modifications de la matrice courante.</p></li>
+</ul>
+<h3 id="axeX">axeX</h3>
+<ul>
+<li><p><b>axeX( <[origine, posOrigine, etendue]>, <Xpas> [, Subdiv, labelPos , num, ""texte"", den, firstnum] )</b>.</p></li>
+<li><p><u>Description</u> : pour tracer et graduer un axe des abscisses passant par <<em>origine</em>> et avec un pas de <<em>Xpas</em>>. Le paramètre <<em>etendue</em>> représente sous forme complexe l’intervalle des abscisses <span style="font-style:italic">xmin+i*xmax</span>, si celui-ci est omis, alors le tracé occupe la fenêtre. Remarque: pour préciser une valeur de <<em>etendue</em>> sans préciser de valeur pour <<em>posOrigine</em>>, il suffit de mettre <em>jump</em> à la place de <<em>posOrigine</em>> (et non pas <em>Nil</em>!).</p></li>
+<li><p><<em>Subdiv</em>> est le nombre de subdivisions par unité, chaque abscisse est multipliée par la fraction <<em>num/den</em>> (1 par défaut), ajoutée à <<em>firstnum/den</em>> (l’origine par défaut) et accompagnée du <<em>"texte"</em>> au numérateur. Pour que le séparateur décimal soit la virgule à la place du point, il suffit de mettre la variable <span style="font-style:italic;color:red">usecomma</span> à la valeur <span class="math">1</span>. Cette macro est également sensible aux variables <span style="font-style:italic;color:red">dollar</span> (pour ajouter ou non des $ autour des labels des graduations), et <span style="font-style:italic;color:red">nbdeci</span> qui fixe le nombre de décimales affichées.</p></li>
+<li><p>Les paramètres optionnels <<em>posOrigine</em>> et <<em>labelpos</em>> permettent de positionner les labels:</p>
+<ul>
+<li><p><<em>posOrigine</em>>=0: pas de label à l’origine,</p></li>
+<li><p><<em>posOrigine</em>>=1: label normal à l’origine,</p></li>
+<li><p><<em>posOrigine</em>>=2: label décalé à droite à l’origine (valeur par défaut),</p></li>
+<li><p><<em>posOrigine</em>>=-2 label décalé à gauche à l’origine,</p></li>
+<li><p><<em>labelPos</em>>=0 : pas de label du tout,</p></li>
+<li><p><<em>Re(labelpos)</em>>=top: labels au-dessus,</p></li>
+<li><p>Re(<<em>labelPos</em>>)=bottom : labels en-dessous (valeur par défaut),</p></li>
+<li><p>Im(<<em>Im(labelPos</em>>)=1: labels orthogonaux à l’axe.</p></li>
+</ul></li>
+</ul>
+<h3 id="axeY">axeY</h3>
+<ul>
+<li><p><b>axeY(<[origine, posOrigine, etendue]>, <Ypas> [, Subdiv, labelPos , num, ""texte"", den, firstnum] )</b>.</p></li>
+<li><p><u>Description</u> : pour tracer et graduer un axe des abscisses passant par <<em>origine</em>> et avec un pas de <<em>Ypas</em>>. Le paramètre <<em>etendue</em>> représente sous forme complexe l’intervalle des ordonnées <span style="font-style:italic">ymin+i*ymax</span>, si celui-ci est omis, alors le tracé occupe la fenêtre. Remarque: pour préciser une valeur de <<em>etendue</em>> sans préciser de valeur pour <<em>posOrigine</em>>, il suffit de mettre <em>jump</em> à la place de <<em>posOrigine</em>> (et non pas <em>Nil</em>!).</p></li>
+<li><p><<em>Subdiv</em>> est le nombre de subdivisions par unité, chaque ordonnée est multipliée par la fraction <<em>num/den</em>> (1 par défaut), ajoutée à <<em>firstnum/den</em>> (l’origine par défaut) et accompagnée du <<em>"texte"</em>> au numérateur. Pour que le séparateur décimal soit la virgule à la place du point, il suffit de mettre la variable <span style="font-style:italic;color:red">usecomma</span> à la valeur <span class="math">1</span>. Cette macro est également sensible aux variables <span style="font-style:italic;color:red">dollar</span> (pour ajouter ou non des $ autour des labels des graduations), et <span style="font-style:italic;color:red">nbdeci</span> qui fixe le nombre de décimales affichées.</p></li>
+<li><p>Les paramètres optionnels <<em>posOrigine</em>> et <<em>labelpos</em>> permettent de positionner les labels:</p>
+<ul>
+<li><p><<em>posOrigine</em>>=0: pas de label à l’origine,</p></li>
+<li><p><<em>posOrigine</em>>=1: label normal à l’origine,</p></li>
+<li><p><<em>posOrigine</em>>=2: label décalé vers le haut à l’origine (valeur par défaut),</p></li>
+<li><p><<em>posOrigine</em>>=-2 label décalé vers le bas à l’origine,</p></li>
+<li><p><<em>labelPos</em>>=0 : pas de label du tout,</p></li>
+<li><p><<em>Re(labelpos)</em>>=left: labels à gauche de l’axe (valeur par défaut),</p></li>
+<li><p>Re(<<em>labelPos</em>>=right : labels à droite de l’axe,</p></li>
+<li><p>Im(<<em>labelPos</em>>)=1: labels orthogonaux à l’axe.</p></li>
+</ul></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-5,5,-5,5),size(7.5), LabelSize:=footnotesize, //graphique du haut SaveWin(), view(-5,5,0.25,5),Width:=6, Arrows:=1, SetMatrix([2.5*i,2/pi,2*i]), axeX(0,pi/2,Nil,Nil,1,"",2), axeY(0,1), Arrows:=0, Color:=red, Width:=8, tMin:=-2*pi, tMax:=2*pi, Cartesienne(sin(x)), Label(pi*1.65+i,"<span class="math"><em>f</em>(<em>x</em>) = sin(<em>x</em>)</span>"),RestoreWin(), //graphique du bas SaveWin(), Color:=black, view(-5,5,-5,-0.25), SetMatrix([-5.5*i,2,i]), Width:=6, Arrows:=1, usecomma:=1, axeX([i,0],0.5), axeY([i,0],1,Nil,Nil,1,"a"), Arrows:=0, Color:=blue, Width:=8, Cartesienne(x^2+1), Label(1+4.75*i,"<span class="math"><em>g</em>(<em>x</em>) = <em>x</em><sup>2</sup> + <em>a</em></span>"), RestoreWin()</p>
+</blockquote>
+</blockquote>
+<h3 id="background">background</h3>
+<ul>
+<li><p><b>background( <fillstyle>, <fillcolor> )</b>.</p></li>
+<li><p><u>Description</u> : permet de remplir le fond de la fenêtre graphique avec le style et la couleur demandée. Cette macro met à jour la variable <span style="font-style:italic;color:red">backcolor</span>.</p></li>
+</ul>
+<h3 id="bbox">bbox</h3>
+<ul>
+<li><p><b>bbox()</b>.</p></li>
+<li><p><u>Description</u> : permet d’ajuster la fenêtre à la "bounding box" autour du dessin courant. Cette macro est destinée à être utilisée dans la ligne de commande en bas de la fenêtre principale, et non pas dans un élément graphique.</p></li>
+</ul>
+<h3 id="centerView">centerView</h3>
+<ul>
+<li><p><b>centerView( <affixe> )</b>.</p></li>
+<li><p><u>Description</u> : permet de centrer la fenêtre graphique sur le point représenté par <<em>affixe</em>>, sans changer les dimensions courantes du graphique. Cette macro est plutôt destinée à être utilisée dans la ligne de commande en bas de la fenêtre principale.</p></li>
+</ul>
+<h3 id="Cercle">Cercle</h3>
+<ul>
+<li><p><b>Cercle( <A>, <r> [, B] )</b>.</p></li>
+<li><p><u>Description</u> : trace un cercle de centre <<em>A</em>> et de rayon <<em>r</em>> lorsque le troisième paramètre est omis, sinon c’est le cercle défini par les trois points <<em>A</em>>, <<em>r</em>> et <<em>B</em>>.</p>
+<p>Pour les macros <span style="font-style:italic">Arc</span> et <span style="font-style:italic">Cercle</span>, on peut s’attendre à des surprises dans le résultat final si le repère n’est pas orthonormé! Le repère est orthonormé lorsque les variables <span style="font-style:italic;color:red">Xscale</span> et <span style="font-style:italic;color:red">Yscale</span> sont égales, voir option <a href="#param">Paramètres/Fenêtre</a>.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-5,5,-1,3),Marges(0,0,0,0), size(7.5), Seg(-5,5), for t in [-4,-1.85,0,1.85,3] do M:=t-sin(t)+i*(1-cos(t)), I:=t+i, DotStyle:=cross, Point(I), DotStyle:=bigdot, Point(M), Cercle(I,1), Seg(M,I), Arrows:=1, Arc(M,I,t,0.5,t), Arrows:=0, LineStyle:=dashed, Seg(I,t), LineStyle:=solid od, Width:=8,Color:=red, Courbe( t-sin(t)+i*(1-cos(t)))</p>
+</blockquote>
+</blockquote>
+<h3 id="Clip">Clip</h3>
+<ul>
+<li><p><b>Clip( <liste> )</b>.</p></li>
+<li><p><u>Description</u> : permet de clipper les éléments graphiques déjà dessinés avec la <<em>liste</em>> qui doit être une courbe fermée et simple. La macro peint l’extérieur de la courbe représentée par la <<em>liste</em>>.</p></li>
+</ul>
+<h3 id="Dbissec">Dbissec</h3>
+<ul>
+<li><p><b>Dbissec( <B>, <A>, <C>, <1 ou 2> )</b>.</p></li>
+<li><p><u>Description</u> : dessine la bissectrice de l’angle <span class="math">$\widehat{BAC}$</span>, intérieure si le dernier paramètre vaut <span class="math">1</span> et extérieure pour la valeur <span class="math">2</span>.</p></li>
+</ul>
+<h3 id="Dcarre">Dcarre</h3>
+<ul>
+<li><p><b>Dcarre( <A>, <B>, <+/-1> [, rayon] )</b>.</p></li>
+<li><p><u>Description</u> : dessine de carré de sommets consécutifs <<em>A</em>> et <<em>B</em>> dans le sens direct si le troisième paramètre vaut <span class="math">1</span> (indirect pour <span class="math"> - 1</span>). Si le paramètre <<em>rayon</em>> est présent, alors les øg coins de la figure seront arrondis par un arc de cercle ayant le rayon mentionné.</p></li>
+</ul>
+<h3 id="Ddroite">Ddroite</h3>
+<ul>
+<li><p><b>Ddroite( <A>, <B> )</b>.</p></li>
+<li><p><u>Description</u> : dessine la demi-droite <span class="math">[<em>A</em>, <em>B</em>)</span>.</p></li>
+</ul>
+<h3 id="Dmed">Dmed</h3>
+<ul>
+<li><p><b>Dmed( <A>, <B> [, angle droit(0/1)] )</b>.</p></li>
+<li><p><u>Description</u> : dessine la médiatrice du segment <span class="math">[<em>A</em>, <em>B</em>]</span>. Si le troisième paramètre vaut <span class="math">1</span> (<span class="math">0</span> par défaut) alors un angle droit est dessiné.</p></li>
+</ul>
+<h3 id="domaine1">domaine1</h3>
+<ul>
+<li><p><b>domaine1( <f(x)> [, a, b] )</b>.</p></li>
+<li><p><u>Description</u> : dessine la partie du plan comprise entre la courbe Cf, l’axe <span class="math"><em>O</em><em>x</em></span> et les droites <span class="math"><em>x</em> = <em>a</em></span>, <span class="math"><em>x</em> = <em>b</em></span> si a et b sont précisés, sinon <span class="math"><em>x</em> = </span><span style="font-style:italic">tMin</span> et <span class="math"><em>x</em> = </span><span style="font-style:italic">tMax</span>.</p></li>
+</ul>
+<h3 id="domaine2">domaine2</h3>
+<ul>
+<li><p><b>domaine2( <f(x)>, <g(x)> [, a, b] )</b>.</p></li>
+<li><p><u>Description</u> : dessine la partie du plan comprise entre les courbes Cf, Cg et les droites <span class="math"><em>x</em> = <em>a</em></span>, <span class="math"><em>x</em> = <em>b</em></span> si a et b sont précisés, sinon <span class="math"><em>x</em> = </span><span style="font-style:italic">tMin</span> et <span class="math"><em>x</em> = </span><span style="font-style:italic">tMax</span>.</p></li>
+</ul>
+<h3 id="domaine3">domaine3</h3>
+<ul>
+<li><p><b>domaine3( <f(x)>, <g(x)> )</b>.</p></li>
+<li><p><u>Description</u> : délimite la partie du plan comprise entre les courbes Cf et Cg avec <span class="math"><em>x</em></span> dans l’intervalle <span style="font-style:italic">[tMin,tMax]</span>, en recherchant les points d’intersection.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-5,5,-4,5),size(7.5),tMin:=-5, Axes(-5,1+i,2+2*i), tMax:=-1, Cartesienne(sin(x)), tMax:=5, Cartesienne(2*cos(x)),tMin:=-3,tMax:=3, Cartesienne(x^2), A:=-4.5+(Ymin+1.75)*i, FillStyle:=full, FillOpacity:=0.5,FillColor:=green, LabelStyle:=left, LabelSize:=footnotesize, Dcarre(A+0.25*(-1+i), A+0.25*(1+i), -1), Label(A+0.4,"domaine2 sur <span class="math">[ - 4 ;   - 1. 5]</span> "), Inc(A,-0.75*i), FillColor:=blue, Dcarre(A+0.25*(-1+i), A+0.25*(1+i),-1), Label(A+0.4,"domaine3 entre <span class="math">2cos(<em>x</em>)</span> et <span class="math"><em>x</em><sup>2</sup></span> "), Inc(A,-0.75*i), FillColor:=red, Dcarre(A+0.25*(-1+i), A+0.25*(1+i),-1), Label(A+0.4,"domaine1 sur <span class="math">[1. 1 ;  4]</span>"), FillColor:=red, domaine1(2*cos(x), 1.1, 4), FillColor:=green, domaine2(2*cos(x), sin(x),-4,-1.5), FillColor:=blue, domaine3(2*cos(x),x^2), Arrows:=2, tangente(2*cos(x),0.5,1.5)</p>
+</blockquote>
+</blockquote>
+<h3 id="Dparallel">Dparallel</h3>
+<ul>
+<li><p><b>Dparallel( <[A, B]> , <C> )</b>.</p></li>
+<li><p><u>Description</u> : dessine la parallèle à la droite <<em>[A,B]</em>> passant par <<em>C</em>>.</p></li>
+</ul>
+<h3 id="Dparallelo">Dparallelo</h3>
+<ul>
+<li><p><b>Dparallelo( <A>, <B> , <C> [, rayon] )</b>.</p></li>
+<li><p><u>Description</u> : dessine le parallèlogramme de sommets consécutifs <<em>A</em>>, <<em>B</em>> et <<em>C</em>>. Si le paramètre <<em>rayon</em>> est présent, alors les øg coins de la figure seront arrondis par un arc de cercle ayant le rayon mentionné.</p></li>
+</ul>
+<h3 id="Dperp">Dperp</h3>
+<ul>
+<li><p><b>Dperp( <[A, B]> , <C> [, angle droit(0/1)] )</b>.</p></li>
+<li><p><u>Description</u> : dessine la perpendiculaire à la droite <<em>[A,B]</em>> passant par <<em>C</em>>. Si le troisième paramètre vaut <span class="math">1</span> (<span class="math">0</span> par défaut) alors un angle droit est dessiné.</p></li>
+</ul>
+<h3 id="Dpolyreg">Dpolyreg</h3>
+<ul>
+<li><p><b>Dpolyreg( <centre> , <sommet>, <nombre de côtés> [, rayon] )</b>.</p></li>
+<li><p><u>Description</u> : dessine le polygône régulier défini par le <<em>centre</em>>, un <<em>sommet</em>> et le <<em>nb de côtés</em>>. Si le paramètre <<em>rayon</em>> est présent, alors les øg coins de la figure seront arrondis par un arc de cercle ayant le rayon mentionné.</p></li>
+</ul>
+<p><div style="text-align:center">ou</div></p>
+<ul>
+<li><p><b>Dpolyreg( <sommet1>, <sommet2>, <nombre de cotés +sens*i> [, rayon] )</b>.</p></li>
+<li><p><u>Description</u> : dessine le polygône régulier défini par deux sommets consécutifs <<em>sommet1</em>> et <<em>sommet2</em>>, le <<em>nb de côtés</em>>, et le <<em>sens</em>> (<span class="math">1</span> pour direct et <span class="math"> - 1</span> pour indirect). Si le paramètre <<em>rayon</em>> est présent, alors les øg coins de la figure seront arrondis par un arc de cercle ayant le rayon mentionné.</p></li>
+</ul>
+<h3 id="DpqGoneReg">DpqGoneReg</h3>
+<ul>
+<li><p><b>DpqGoneReg( <centre> , <sommet>, <[p,q]> )</b>.</p></li>
+<li><p><u>Description</u> : dessine le <<em>p/q</em>>-gône régulier défini par le <<em>centre</em>> et un <<em>sommet</em>>.</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-5,5,-6,6),Marges(0,0,0,0),size(7.5), FillStyle:=full, FillColor:=lightpink, Color:=blue, Width:=8, DpqGoneReg(-2.5+2.5*i,-2.5+0.25*i, [7,3]), Label(-2.5+5*i,"[7,3]"), DpqGoneReg(2.5+2.5*i,2.5+0.25*i, [7,2]), Label(2.5+5*i,"[7,2]"), DpqGoneReg(-2.5-2.5*i,-2.5-0.25*i, [7,1]), Label(-2.5-5*i,"[7,1]"), DpqGoneReg(2.5-2.5*i,2.5-0.25*i, [6,2]), Label(2.5-5*i,"[6,2]")</p>
+</blockquote>
+</blockquote>
+<h3 id="drawSet">drawSet</h3>
+<ul>
+<li><p><b>drawSet( <ensemble> )</b>.</p></li>
+<li><p><u>Description</u> : dessine un ensemble produit par les macros <a href="#capB">capB</a>, <a href="#cupB">cupB</a> ou <a href="#setminusB">setminusB</a>.</p></li>
+</ul>
+<h3 id="Drectangle">Drectangle</h3>
+<ul>
+<li><p><b>Drectangle( <A>, <B> , <C> [, rayon] )</b>.</p></li>
+<li><p><u>Description</u> : dessine le rectangle de sommets consécutifs <<em>A</em>>, <<em>B</em>>, le côté opposé passant par <<em>C</em>>. Si le paramètre <<em>rayon</em>> est présent, alors les øg coins de la figure seront arrondis par un arc de cercle ayant le rayon mentionné.</p></li>
+</ul>
+<h3 id="ellipticarc-1">ellipticArc</h3>
+<ul>
+<li><p><b>ellipticArc( <B>, <A>, <C>, <RX>, <RY>, <sens(+/-1)> [, inclinaison] )</b>.</p></li>
+<li><p><u>Description</u> : dessine un arc d’ellipse de centre <<em>A</em>>, allant de <<em>B</em>> à <<em>C</em>> de rayons <<em>RX</em>> et <<em>RY</em>>, l’axe portant le rayon <<em>RX</em>> ayant une certaine <<em>inclinaison</em>> par rapport à l’horizontale, celle-ci est en degrés et vaut 0 par défaut, le paramètre <<em>sens</em>> indique le sens de rotation, 1 pour le sens trigonométrique.</p></li>
+</ul>
+<h3 id="flecher">flecher</h3>
+<ul>
+<li><p><b>flecher( <liste>, <pos1, ..., posN> )</b>.</p></li>
+<li><p><u>Description</u> : dessine des flèches le long de la ligne polygonale <<em>liste</em>>, la position de chaque flèche (pos1, ...) est un nombre entre <span class="math">0</span> et <span class="math">1</span> (<span class="math">0</span> pour début de la ligne et <span class="math">1</span> pour fin de ligne), les flèches sont dessinées dans le sens de parcourt de la ligne, pour inverser une flèche on ajoute +i à la position.</p></li>
+<li><p><u>Exemple(s)</u> : <span style="color:red">flecher(Get(Cercle(0,3)), [0,0.5] )</span></p></li>
+</ul>
+<h3 id="GradDroite">GradDroite</h3>
+<ul>
+<li><p><b>GradDroite( <[A, origine + i*posOrigine, etendue]>, <[u, unit]>, <hautDiv>, <subdiv> [, poslab, orientation, num, ""texte"", den, firstnum] )</b></p></li>
+<li><p><u>Description</u> : gradue la droite passant par <<em>A</em>> et dirigée par le vecteur <<em>u</em>> (celui-ci n’est pas forcément unitaire), <<em>hautdiv</em>> est la hauteur des graduations en cm, <<em>subdiv</em>> est le nombre de subdivisions par unité.</p>
+<p>Paramètres optionnels:</p>
+<ul>
+<li><p><<em>origin</em>>: indique la graduation de l’origine <<em>A</em>> (0 par défaut),</p></li>
+<li><p><<em>posOrigin</em>>: indique la position du label à l’origine <<em>A</em>>, plusieurs cas:</p>
+<ul>
+<li><p><<em>posOrigin</em>>=0: pas de label à l’origine,</p></li>
+<li><p><<em>posOrigin</em>>=1: label normal à l’origine (comme les autres)</p></li>
+<li><p><<em>posOrigin</em>>=2: label à l’origine décalé dans le sens du vecteur <<em>u</em>> (valeur par défaut),</p></li>
+<li><p><<em>posOrigin</em>>=-2: label à l’origine décalé dans le sens opposé du vecteur <<em>u</em>>.</p></li>
+</ul></li>
+<li><p><<em>etendue</em>>: représente l’intervalle des graduations sous forme complexe: <span style="font-style:italic">min+i*max</span>, le tracé de l’axe sera limité à cet intervalle. Si ce paramètre est omis, le tracé occupera la fenêtre.</p></li>
+<li><p><<em>unit</em>>: indique le pas des graduations sur l’axe (1 par défaut), cette valeur doit être positive.</p></li>
+<li><p><<em>poslab</em>> indique la position des labels par rapport à l’axe, ce paramètre prend les valeurs <span style="color:red">top</span> ou <span style="color:red">bottom</span>,</p></li>
+<li><p><<em>orientation</em>>: orientation des labels, la valeur <span class="math"><em>i</em></span> signifie que les labels sont orthogonaux à l’axe, sinon l’orientation représente le <span style="font-style:italic;color:red">LabelStyle</span> (left, right, top, ...),</p></li>
+<li><p>chaque graduation est multipliée par la fraction <<em>num/den</em>> (1 par défaut), ajoutée à <<em>firstnum/den</em>> (l’origine par défaut) et accompagnée du <<em>"texte"</em>> au numérateur. Pour avoir une virgule comme spérateur décimal au lieu du point, il faut mettre la variable <span style="font-style:italic;color:red">usecomma</span> à la valeur <span class="math">1</span>. Cette macro est également sensible aux variables <span style="font-style:italic;color:red">dollar</span> (pour ajouter ou non des $ autour des labels des graduations), et <span style="font-style:italic;color:red">nbdeci</span> qui fixe le nombre de décimales affichées. Le nombre maximal de graduations est fixé par la variable <span style="font-style:italic;color:red">maxGrad</span> qui vaut <span class="math">100</span> par défaut.</p></li>
+</ul></li>
+<li><p><u>Exemple(s)</u> : <span style="color:red">GradDroite([0,1+2*i],[1,0.5], xyticks, 1, bottom, i)</span>: signifie que la graduation de l’origine sera 1 avec un label décalé à droite, les graduations iront de 0.5 en 0.5, les labels seront sous l’axe et orthogonaux à l’axe.</p></li>
+</ul>
+<h3 id="LabelArc">LabelArc</h3>
+<ul>
+<li><p><b>LabelArc( <B>, <A>, <C>, <R>, <sens>, <"texte">, [, options] )</b>.</p></li>
+<li><p><u>Description</u> : cette macro dessine un arc de cercle de centre <<em>A</em>>, de rayon <<em>R</em>> partant de la droite <span class="math">(<em>A</em><em>B</em>)</span> jusqu’à la droite <span class="math">(<em>A</em><em>C</em>)</span>, l’argument facultatif <<em>sens</em>> indique: le sens trigonométrique si sa valeur est 1 (valeur par défaut), le sens contraire si valeur est -1. La macro ajoute également le <<em>"texte"</em>>. Le paramètre <<em>options</em>> est une liste (facultative) de la forme <span style="font-style:italic">[ option1:= valeur1, ..., optionN:=valeurN ]</span>, les options sont:</p>
+<ul>
+<li><p><span style="color:blue">labelpos := < inside/outside ></span>: positionnement du label (outside par defaut)),</p></li>
+<li><p><span style="color:blue">labelsep := < distance en cm ></span>: distance du label à l’arc (0.25cm par défaut).</p></li>
+<li><p><span style="color:blue">rotation := < nombre ></span>: angle en degrés que fait le label par rapport à l’horizontale (<span class="math">0</span> par défaut).</p></li>
+</ul>
+<p>Il est possible dans la liste des options, de modifier des attributs comme <span style="font-style:italic;color:red">Color</span> par exemple.</p></li>
+</ul>
+<h3 id="LabelAxe">LabelAxe</h3>
+<ul>
+<li><p><b>LabelAxe( <x ou y>, <affixe>, <label> [, [labelPos,décalage en cm], mark(0/1)] )</b>.</p></li>
+<li><p><u>Description</u> : permet d’ajouter un label sur un des axes <<em>x ou y</em>>, <<em>affixe</em>> désigne l’affixe du point où se fait l’ajout, <<em>label</em>> contient le texte à ajouter. Paramètres optionnels, <<em>[labelPos, décalage en cm]</em>> et <<em>mark</em>>:</p>
+<ul>
+<li><p>Re(<<em>labelpos</em>>)=1 signifie en dessous pour Ox et à droite pour Oy (par défaut pour Ox),</p></li>
+<li><p>Re(<<em>labelpos</em>>)=2 signifie au dessus pour Ox et à gauche pour Oy (par défaut pour Oy),</p></li>
+<li><p>Im(<<em>labelpos</em>>)=-1 signifie un décalage sur la gauche pour Ox, vers le bas pour Oy, si le décalage n’est pas précisé, il vaut 0.25 cm par défaut,</p></li>
+<li><p>Im(<<em>labelpos</em>>)=1 signifie un décalage sur la droite pour Ox, vers le haut pour Oy, si le décalage n’est pas précisé, il vaut 0.25 cm par défaut,</p></li>
+<li><p>Im(<<em>labelpos</em>>)=0 signifie pas de décalage (valeur par défaut),</p></li>
+<li><p><<em>mark</em>>: indique si le point doit être marqué (dans le dotsyle courant).</p></li>
+</ul></li>
+</ul>
+<h3 id="LabelDot">LabelDot</h3>
+<ul>
+<li><p><b>LabelDot( <affixe>, <"texte">, <orientation> [, DrawDot, distance] )</b>.</p></li>
+<li><p><u>Description</u> : cette macro affiche un texte à coté du point <<em>affixe</em>>. L’orientation peut être "N" pour nord, "NE" pour nord-est ...etc, ou bien une liste de la forme [longueur, direction] où direction est un complexe, dans ce deuxième cas, le paramètre optionnel <<em>distance</em>> est ignoré. Le point est également affiché lorsque <<em>DrawDot</em>> vaut <span class="math">1</span> (0 par défaut) et on peut redéfinir la <<em>distance</em>> en cm entre le point et le texte (0.25cm par défaut).</p></li>
+</ul>
+<h3 id="LabelSeg">LabelSeg</h3>
+<ul>
+<li><p><b>LabelSeg( <A>, <B>, <"texte">, [, options] )</b>.</p></li>
+<li><p><u>Description</u> : cette macro dessine le segment défini par <<em>A</em>> et <<em>B</em>>, et ajoute le <<em>"texte"</em>>. Le paramètre <<em>options</em>> est une liste (facultative) de la forme <span style="font-style:italic">[ option1:= valeur1, ..., optionN:=valeurN ]</span>, les options sont:</p>
+<ul>
+<li><p><span style="color:blue">labelpos := < center/top/bottom ></span>: positionnement du label (center par défaut),</p></li>
+<li><p><span style="color:blue">labelsep := < distance en cm ></span>: distance du label au segment lorsque labelpos vaut top ou bottom (0.25cm par défaut).</p></li>
+<li><p><span style="color:blue">rotation := < nombre ></span>: angle en degrés que fait le label par rapport à l’horizontale (par défaut le label est parallèle au segment).</p></li>
+</ul>
+<p>Il est possible dans la liste des options, de modifier des attributs comme <span style="font-style:italic;color:red">Color</span> par exemple.</p></li>
+</ul>
+<h3 id="markangle">markangle</h3>
+<ul>
+<li><p><b>markangle( <B>, <A>, <C>, <r>, <n>, <espacement>, <longueur> )</b>.</p></li>
+<li><p><u>Description</u> : même chose que <a href="#markseg">markseg</a> mais pour marquer un arc de cercle.</p></li>
+</ul>
+<h3 id="markseg">markseg</h3>
+<ul>
+<li><p><b>markseg( <A>, <B>, <n>, <espacement>, <longueur> [, angle] )</b>.</p></li>
+<li><p><u>Description</u> : marque le segment <span class="math">[<em>A</em>, <em>B</em>]</span> avec <<em>n</em>> petits segments, l’<<em>espacement</em>> est en unité graphique, et la <<em>longueur</em>> en cm. Le paramètre optionnel <<em>angle</em>> permet de définir en degré l’angle que feront les marques par rapport à la droite <span class="math">(<em>A</em><em>B</em>)</span> (45 degrés par défaut).</p></li>
+</ul>
+<h3 id="periodic">periodic</h3>
+<ul>
+<li><p><b>periodic( <f(x)>, <a>, <b> [, divisions, discontinuités] )</b>.</p></li>
+<li><p><u>Description</u> : trace la courbe de la fonction périodique définie par <span class="math"><em>y</em> = <em>f</em>(<em>x</em>)</span> sur la période <span class="math">[<em>a</em>; <em>b</em>]</span>, puis translate le motif pour couvrir l’intervalle [tMin; tMax]. Les deux paramètres optionnels sont identiques à ceux des courbes paramétrées (nombre de divisions et discontinuités).</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-5,5,-5,5), size(7.5), Axes(0,1+i), Width:=8, Color:=red, periodic(if t>0 then 4 else 2 fi,-1,1,5,1), Color:=blue, periodic(2*abs(t)-1,-1,1), Color:=magenta, periodic(sin(t)-3,-pi/2,pi/2)</p>
+</blockquote>
+</blockquote>
+<h3 id="Rarc">Rarc</h3>
+<ul>
+<li><p><b>Rarc( <B>, <A>, <C>, <R>, <sens> )</b>.</p></li>
+<li><p><u>Description</u> : comme la macro <a href="#Arc">Arc</a> sauf que l’arc de cercle est rond même si le repère n’est pas orthonormé, le rayon <<em>R</em>> est en centimètres.</p></li>
+</ul>
+<h3 id="Rcercle">Rcercle</h3>
+<ul>
+<li><p><b>Rcercle( <A>, <R> )</b> ou <strong>Rcercle( <A>, <B>, <C> )</strong>.</p></li>
+<li><p><u>Description</u> : dessine un cercle rond même si le repère n’est pas orthonormé. Dans la première forme, le rayon <<em>R</em>> est en centimètres.</p></li>
+</ul>
+<h3 id="Rellipse">Rellipse</h3>
+<ul>
+<li><p><b>Rellipse( <O>, <RX>, <RY> [, inclinaison] )</b>.</p></li>
+<li><p><u>Description</u> : comme la commande <a href="#Ellipse">Ellipse</a> sauf que celle-ci est insensible au repère écran, les rayons sont en centimètres.</p></li>
+</ul>
+<h3 id="RellipticArc">RellipticArc</h3>
+<ul>
+<li><p><b>RellipticArc( <B>, <A>, <C>, <RX>, <RY>, <sens(+/-1)> [, inclinaison] )</b>.</p></li>
+<li><p><u>Description</u> : comme la macro <a href="#ellipticArc">ellipticArc</a> sauf que celle-ci est insensible au repère écran, les rayons sont en centimètres.</p></li>
+</ul>
+<h3 id="RestoreWin">RestoreWin</h3>
+<ul>
+<li><p><b>RestoreWin()</b>.</p></li>
+<li><p><u>Description</u> : restaure la fenêtre graphique ainsi que la matrice 2D enregistrées lors du dernier appel à la macro <a href="#SaveWin">SaveWin</a>.</p></li>
+</ul>
+<h3 id="SaveWin">SaveWin</h3>
+<ul>
+<li><p><b>SaveWin()</b>.</p></li>
+<li><p><u>Description</u> : enregistre la fenêtre graphique ainsi que la matrice 2D courantes, sur une pile. Cette macro va de paire avec la macro <a href="#RestoreWin">RestoreWin</a>.</p></li>
+<li><p><u>Exemple(s)</u> : plusieurs graphiques sur un seul: voir <a href="#axeXY">cet exemple</a>.</p></li>
+</ul>
+<h3 id="Seg">Seg</h3>
+<ul>
+<li><p><b>Seg( <A>, <B> )</b>.</p></li>
+<li><p><u>Description</u> : dessine le segment <span class="math">[<em>A</em>, <em>B</em>]</span>.</p></li>
+</ul>
+<h3 id="set">set</h3>
+<ul>
+<li><p><b>set( <nom>, <affixe centre> [, options] )</b>.</p></li>
+<li><p><u>Description</u> : dessine un ensemble en forme de patatoïde, <<em>affixe centre</em>> désigne le centre de cet ensemble, et le paramètre <<em>nom</em>> est une chaîne contenant le nom de cet ensemble. Le paramètre <<em>options</em>> est une liste (facultative) de la forme <span style="font-style:italic">[ option1:= valeur1, ..., optionN:=valeurN ]</span>, les options sont:</p>
+<ul>
+<li><p><span style="color:blue">scale := < entier positif ></span>: représente l’échelle (1 par défaut),</p></li>
+<li><p><span style="color:blue">rotation := < angle en degrés ></span>: permettant d’incliner le dessin (0 degré par défaut),</p></li>
+<li><p><span style="color:blue">labels := < 0/1 ></span>: pour afficher ou non le nom de l’ensemble.</p></li>
+<li><p><span style="color:blue">labelsep := < distance en cm ></span>: distance du label au bord de l’ensemble (0.45cm par défaut)</p></li>
+</ul>
+<p>Il est possible dans la liste des options, de modifier des attributs comme <span style="color:red">LabelStyle</span> par exemple.</p></li>
+<li><p>La macro renvoie en résultat la liste des points de la courbe dessinant l’ensemble.</p></li>
+</ul>
+<h3 id="setB">setB</h3>
+<ul>
+<li><p><b>setB( <nom>, <affixe centre> [, options] )</b>.</p></li>
+<li><p><u>Description</u> : dessine un ensemble en forme de patatoïde à l’aide de courbes de Bézier, <<em>affixe centre</em>> désigne le centre de cet ensemble, et le paramètre <<em>nom</em>> est une chaîne contenant le nom de cet ensemble. Le paramètre <<em>options</em>> est une liste (facultative) de la forme <span style="font-style:italic">[ option1:= valeur1, ..., optionN:=valeurN ]</span>, les options sont:</p>
+<ul>
+<li><p><span style="color:blue">scale := < entier positif ></span>: représente l’échelle (1 par défaut),</p></li>
+<li><p><span style="color:blue">rotation := < angle en degrés ></span>: permettant d’incliner le dessin (0 degré par défaut),</p></li>
+<li><p><span style="color:blue">labels := < 0/1 ></span>: pour afficher ou non le nom de l’ensemble.</p></li>
+<li><p><span style="color:blue">labelsep := < distance en cm ></span>: distance du label au bord de l’ensemble (0.45cm par défaut)</p></li>
+</ul>
+<p>Il est possible dans la liste des options, de modifier des attributs comme <span style="color:red">LabelStyle</span> par exemple.</p></li>
+<li><p>La macro renvoie en résultat la liste des points de contrôle de la courbe représentant l’ensemble. Cette liste peut-être utilisée ensuite pour déterminer une intersection (voir <a href="#capB">capB</a>), une réunion (voir <a href="#capB">capB</a>) ou une différence (voir <a href="#setminusB">setminusB</a>).</p></li>
+</ul>
+<h3 id="size">size</h3>
+<ul>
+<li><p><b>size( <largeur + i*hauteur> [, ratio(Xscale/Yscale)] )</b></p></li>
+<li><p><u>Description</u> : permet de fixer les tailles du graphique: <<em>largeur</em>> et <<em>hauteur</em>> (marges incluses) en cm. Si le paramètre <<em>hauteur</em>> est nul, alors on considère que hauteur=largeur.</p>
+<p>Si le paramètre <<em>ratio</em>> est omis, les échelles sur les deux axes sont calculées pour que la figure entre au plus juste dans le cadre fixé, tout en conservant le ratio courant.</p>
+<p>Si <<em>ratio</em>> est égal à <span class="math">0</span> alors les échelles sont calculées de manière à obtenir exactement la taille souhaitée (le ratio courant n’est donc vraisemblablement pas conservé).</p>
+<p>Le repère est orthonormé lorsque le paramètre <<em>ratio</em>> vaut 1.</p>
+<p><strong>NB</strong>: un appel aux fonctions <span style="font-style:italic">Fenetre</span> <span style="font-style:italic">Marges</span> ou à la macro <span style="font-style:italic">view</span>, modifiera la taille du graphique. Il est donc préférable de déterminer les marges et la fenêtre graphique <strong>avant</strong> de fixer la taille.</p>
+<p>La largeur d’un graphique est donnée par la formule:</p>
+<p><div style="text-align:center"><span style="font-style:italic">(Xmax-Xmin)*Xscale+margeG+margeD</span></div></p>
+<p>et la hauteur est donnée par:</p>
+<p><div style="text-align:center"><span style="font-style:italic">(Ymax-Ymin)*Yscale+margeH+margeB</span></div></p></li>
+</ul>
+<h3 id="suite">suite</h3>
+<ul>
+<li><p><b>suite( <f(x)>, <u0>, <n> )</b>.</p></li>
+<li><p><u>Description</u> : représentation graphique de la suite définie par <span class="math"><em>u</em><sub><em>n</em> + 1</sub> = <em>f</em>(<em>u</em><sub><em>n</em></sub>)</span>, de premier terme <<em>u0</em>> et jusqu’au rang <<em>n</em>>. Cette macro ne représente que les "escaliers".</p></li>
+</ul>
+<blockquote>
+<blockquote>
+<p>view(-0.1,1.1,-0.1,1.1),size(7.5), Arrows:=1,Axes(0,1/2+i/4),Arrows:=0, u0:=0.3,nb:=20, Width:=6, Color:=darkseagreen, Droite(1,-1,0), Color:=red, tMin:=0, tMax:=1, Width:=8, Cartesienne(4*x*(1-x)), Width:=6, Color:=blue, Label(0.5+1.05*i,"<span class="math"><em>u</em><sub><em>n</em> + 1</sub> = 4<em>u</em><sub><em>n</em></sub>(1 - <em>u</em><sub><em>n</em></sub>)</span>"), LabelDot(u0, "<span class="math"><em>u</em><sub>0</sub></span>","S",1), suite(4*x*(1-x), u0,nb)</p>
+</blockquote>
+</blockquote>
+<h3 id="tangente">tangente</h3>
+<ul>
+<li><p><b>tangente( <f(x)>, <x0> [, longueur] )</b>.</p></li>
+<li><p><u>Description</u> : trace la tangente à la courbe cartésienne <span class="math"><em>y</em> = <em>f</em>(<em>x</em>)</span> au point d’abscisse <<em>x0</em>>, on trace un segment de la <<em>longueur</em>> indiquée (en cm) ou la droite entière si la longueur est omise.</p></li>
+</ul>
+<h3 id="tangenteP">tangenteP</h3>
+<ul>
+<li><p><b>tangenteP( <f(t)>, <t0> [,longueur] )</b>.</p></li>
+<li><p><u>Description</u> : trace la tangente à la courbe paramétrée par <<em>f(t)</em>> au point de paramètre <<em>t0</em>>, on trace un segment de la <<em>longueur</em>> indiquée (en cm) ou la droite entière si la longueur est omise.</p></li>
+</ul>
+<h3 id="view">view</h3>
+<ul>
+<li><p><b>view( <xmin>, <xmax>, <ymin>, <ymax> )</b> ou <strong>view( <[xmin+i*ymin, xmax+i*ymax]> )</strong></p></li>
+<li><p><u>Description</u> : change la fenêtre graphique courante et conserve l’échelle. Attention: ceci change la taille du graphique, celle-ci peut-être modifiée avec la macro <a href="#size">size</a>.</p></li>
+<li><p><u>Exemple(s)</u> : dans un élément graphique utilisateur, la commande <span style="color:red">[ view(-4, 4,-3, 3), size(12) ]</span> va fixer la fenêtre graphique à <span class="math">[ - 4, 4] × [ - 3, 3]</span>, et la taille du graphique à 12cm en conservant le ratio courant. Il est important de respecter l’ordre (view avant size).</p></li>
+</ul>
+<h3 id="wedge">wedge</h3>
+<ul>
+<li><p><b>wedge( <B>, <A>, <C>, <r> )</b></p></li>
+<li><p><u>Description</u> : dessine le secteur angulaire défini par l’angle <span class="math">$\widehat{BAC}$</span> avec un rayon <<em>r</em>>.</p></li>
+</ul>
+<h3 id="zoom">zoom</h3>
+<ul>
+<li><p><b>zoom( <+/-1> )</b></p></li>
+<li><p><u>Description</u> : permet de faire un zoom arrière/avant.</p></li>
+</ul>
+<div class="footnotes">
+<hr />
+<ol>
+<li id="fn1"><p>Option <span style="font-style:italic">Elément graphique/Créer/Utilisateur</span> du menu. <a href="#fnref1" class="footnoteBackLink" title="Jump back to footnote 1">↩</a></p></li>
+</ol>
+</div>