\documentclass[11pt,a4paper,french]{article} % Code with metapost output thanks to YannD at texnique.fr % https://texnique.fr/osqa/questions/11076/comment-obtenir-le-code-metapost-et-la-figure-dans-un-document-avec-luamplib % To compile: % lualatex repere-doc.tex \usepackage{mathtools} \usepackage{unicode-math} \setmainfont{STIX Two Text} \setmathfont{STIX Two Math} \usepackage{geometry} \geometry{twoside,hmargin=2cm,vmargin={1.5cm,1.8cm},includefoot} \usepackage[bottom]{footmisc} \usepackage{mflogo} \usepackage[output-decimal-marker={,}]{siunitx} \usepackage{esvect} \usepackage{multicol} \setlength{\multicolsep}{3pt} \setlength{\columnsep}{0pt} \usepackage[toc]{multitoc} \usepackage{enumitem} \setlist[description]{font=\ttfamily\bfseries\color{blue}} \usepackage[svgnames]{xcolor} \usepackage{graphicx} \usepackage{url} \usepackage{verbatim} \usepackage{fancyvrb} \usepackage{array} \usepackage{colortbl} \usepackage{tabularx} \renewcommand{\tabularxcolumn}[1]{>{\arraybackslash}m{#1}} \newcolumntype{M}[1]{>{\arraybackslash}m{#1}} \usepackage{longtable} \usepackage{tabularray} \usepackage{luamplib} \everymplib{verbatimtex \leavevmode etex; input repere;} \mplibnumbersystem{decimal} \usepackage{tcolorbox} \tcbuselibrary{listings,skins} \usepackage{babel} \frenchbsetup{og=«,fg=»} \usepackage[colorlinks=true,urlcolor=blue]{hyperref} \usepackage{listings} \lstset{columns=flexible,% basicstyle=\color{darkgray}\ttfamily, literate={é}{{\'e}}1, keywordstyle=\color{black}\bfseries} \lstdefinestyle{mpost}{language={MetaPost}, morekeywords={repere,fin,couleur,epaisseur,avec} } \makeatletter \tcbset{% listing metapost/.code={% \def\tcbuselistingtext@input{\begin{mplibcode} input \jobname.listing; \end{mplibcode}}% } } \makeatother \definecolor{CoulParam}{rgb}{0.4,0,0.5} \definecolor{TestC}{rgb}{0.963,0.971,0.994} \colorlet{FondCommandes}{black!60!yellow!10!white} \tcbset{boites/.style={left=1em,right=1em, colback=white, boxrule=0pt, colframe=white, fonttitle=\bfseries\ttfamily, colbacktitle=FondCommandes, before title={\hspace{-1em}}, arc=0pt, after=\medskip, }} \DeclareTColorBox{rpobjet}{ v m }{ boites, title={#1}, coltitle=blue, colbacktitle=blue!5!white, after title={\hfill #2}, } \DeclareTColorBox{rpdeclaration}{ v }{ boites, title={#1}, coltitle=black, colbacktitle=black!5!white, } \DeclareTColorBox{rplabel}{ v }{ boites, title={#1}, coltitle=red, colbacktitle=red!50!black!5!white, } \DefTblrTemplate{contfoot-text}{default}{} \DefTblrTemplate{conthead-text}{default}{} \DefTblrTemplate{caption-tag}{default}{} \DefTblrTemplate{caption-sep}{default}{} \DefTblrTemplate{caption-text}{default}{} \NewDocumentEnvironment{rpparam}{ +b} {\par\medskip\begin{center} \begin{longtblr}[label=none,caption={}]{ rowhead=2, verb, hlines={2pt,white}, columns={c}, row{1}=white, row{2-Z}={bg=CoulParam!5!white,m}, column{4}={wd=8cm,fg=black,j}, cell{3-Z}{1-3}={cmd=\testparam}, cell{3-Z}{1}={cmd=\bfseries\testparam} } \SetCell[c=4]{c} Paramètres \\ Nom & Type & Défaut & \\ #1 \end{longtblr} \end{center}\bigskip} {} \tcbset{mot/.style={colback=FondCommandes, verbatim, arc=0pt, outer arc=0pt, top=0pt,bottom=0pt,left=0mm,right=0mm, boxrule=0pt}} \DeclareTotalTCBox{\rpdec}{v}{mot,coltext=black}{#1} \DeclareTotalTCBox{\rpfig}{v}{mot,coltext=blue}{#1} \DeclareTotalTCBox{\rplab}{v}{mot,coltext=red}{#1} \DeclareTotalTCBox{\rppar}{v}{mot,coltext=CoulParam}{#1} \NewDocumentCommand{\testparam}{v}{\textcolor{CoulParam}{\texttt{#1}}} \NewDocumentCommand{\desstab}{v}{\textbf{\texttt{#1}}} \NewDocumentCommand{\decfig}{m}{\raisebox{-.45\height}{#1}} \DeclareTCBListing[auto counter]{exemple}{ !O{} }{ enhanced, title=Exemple \thetcbcounter, coltitle=black, fonttitle=\bfseries, attach boxed title to top left, boxed title style={left=0pt, boxrule=0pt, colframe=white, colback=white, coltext=black}, colback=red!25!yellow!10!white, left=1mm,top=0mm,bottom=0mm, halign lower=center, listing metapost, listing outside text, % listing only, sidebyside gap=1mm, after skip=2em, listing options={style=mpost }, #1} \DeclareTCBListing{codelatex}{ !O{} }{ enhanced, notitle, colback=LightSteelBlue, left=2mm,top=0mm,bottom=0mm, listing only, listing options={language={[LaTeX]TeX} }, #1} \DeclareTCBListing{codempost}{ !O{} }{ enhanced, notitle, colback=LightGoldenrod, left=2mm,top=0mm,bottom=0mm, listing only, listing options={style=mpost }, #1} \newcommand{\vect}[1]{\overrightarrow{#1\rule{0.1em}{0ex}}} \begin{document} \DecimalMathComma \title{Documentation de \texttt{repere.mp}} \date{\today} \author{Olivier \textsc{Péault}% \footnote{E-mail : \href{mailto:o.peault@posteo.net}{\texttt{o.peault@posteo.net}}}} \maketitle \setcounter{tocdepth}{2} \setlength{\columnsep}{25pt} {\small \tableofcontents} \setlength{\columnsep}{10pt} \part{Repères et géométrie} \section{Utilisation du fichier} \subsection{Généralités} Les macros du fichier \verb+repere.mp+ ont pour but de simplifier la création de figures dans un repère du plan avec \MP{} notamment : \begin{itemize} \item Figures dans un repère, représentations graphiques de fonctions ; \item Figures usuelles de géométrie plane ; \item En complément, possibilité de tracer des grilles et tableaux.. \end{itemize} L'objectif principal est de répondre aux besoins de l'enseignement secondaire français de mathématiques. \subsection{Documentation} Les commandes et macros proposées sont de plusieurs types : \begin{itemize} \item Des \rpdec{déclarations}, qui définissent la figure, modifient certaines variables ou paramètres. \item Des \rpfig{objets}, au sens de \MP{} qui peuvent être des points (pair), des chemins (path), des figures (picture)... \item Des \rplab{« labels »} qui fonctionnent sur le même principe que la commande \verb|label| de \MP{} et affichent une étiquette qui peut être définie séparément. \item Des \rppar{paramètres} qui peuvent être modifiés pour changer l'apparence de la figure. \end{itemize} Les objets qui sont des « figures complètes » (dessins et étiquettes) ont des noms qui commencent par une majuscule. %Il est possible d'utiliser \verb+repere+ et \verb+geometriesyr+ (les macros de Christophe \textsc{Poulain} pour la géométrie disponibles à l'adresse \url{http://melusine.eu.org/syracuse/poulecl/macros/}) dans une même figure comme le montre l'exemple page \pageref{exgeom}. %Le fichier \verb+repere.mp+ doit être placé dans un répertoire accessible à \MP{} (Par ex. le répertoire \verb+metapost+ du \verb+texmf+). De plus, la ligne \verb+input repere;+ doit apparaître dans le document contenant les figures. % %Les étiquettes (noms de points, de courbes, de vecteurs...) sont composées automatiquement au format \LaTeX{} avec le package \verb+latexmp.mp+. Il est donc nécessaire de compiler deux fois les documents. Cette double compilation n'est pas nécessaire si on utilise Lua\LaTeX{} avec le package \verb|luamplib|. \subsection{Utilisation de \texttt{repere}} L'utilisation de Lua\LaTeX{} avec le package \verb|luamplib| est la manière la plus simple d'utiliser \verb|repere|. Il suffit juste de charger les packages \verb|siunitx| et \verb|esvect| utilisés par \verb|repere|. \medskip \noindent \begin{minipage}[t]{0.49\linewidth} {\centering \textbf{Figure isolée}\par} \verb|lualatex mafigure.tex| \begin{codelatex} \documentclass{standalone} \usepackage{fontspec} \usepackage{siunitx,esvect} \usepackage{luamplib} \mplibnumbersystem{decimal} %Si besoin \everymplib{input repere;} \begin{document} \begin{mplibcode} repere(); draw axes(1,1); fin; \end{mplibcode} \end{document} \end{codelatex} \end{minipage} \hfill \begin{minipage}[t]{0.49\linewidth} {\centering \textbf{Code embarqué}\par} \verb|lualatex monfichier.tex| \begin{codelatex} \documentclass{article} \usepackage{fontspec} \usepackage{siunitx,esvect} \usepackage{luamplib} \mplibnumbersystem{decimal} %Si besoin \everymplib{verbatimtex \leavevmode etex; input repere;} \begin{document} Mon texte, mon texte, mon texte \begin{mplibcode} repere(); draw axes(1,1); fin; \end{mplibcode} Mon texte, mon texte, mon texte \end{document} \end{codelatex} \end{minipage} \bigskip Il est aussi possible d'utiliser une compilation \verb|mpost| « traditionnelle ». Voir section \ref{compilmpost}. \section{Repère utilisateur} \subsection{Définition du repère} \begin{rpdeclaration}{repere(,,,,,,)} Débute une figure et définit le repère utilisateur : axe des abscisses de \verb+Xmin+ à \verb+Xmax+, unité \verb+Ux+, axe des ordonnées de \verb+Xmin+ à \verb+Ymax+, unité \verb+Uy+ et \verb+theta+ est l'angle en degrés entre les axes. Le paramètre \verb+theta+ est optionnel. Il est égal à 90 par défaut. \end{rpdeclaration} \begin{rpdeclaration}{repere.larg(,,,,,,)} Définit un repère tel que la largeur totale de la figure produite soit \verb+Lx+ et sa hauteur \verb+Ly+. \end{rpdeclaration} \begin{rpdeclaration}{repere.orth(,,,,)} Définit un repère orthonormé de largeur totale \verb+Lx+. \end{rpdeclaration} \begin{rpdeclaration}{repere() repere.larg() repere.orth()} Définit un repère en utilisant les valeurs des paramètres \verb+Xmin+, \verb|Xmax|... \end{rpdeclaration} \begin{rpdeclaration}{fin} Termine la figure et la découpe pour ne garder que la partie limitée par le repère utilisateur. \end{rpdeclaration} \begin{rpparam} Ux & numeric & 1cm & Unité sur l'axe des abscisses \\ Uy & numeric & 1cm & Unité sur l'axe des ordonnées \\ Uxy & numeric & & Si positif, unité sur les deux axes \\ Xmin & numeric & -10 & Valeur minimale sur l'axe des abscisses \\ Xmax & numeric & 10 & Valeur maximale sur l'axe des abscisses \\ Ymin & numeric & -10 & Valeur minimale sur l'axe des ordonnées \\ Ymax & numeric & 10 & Valeur maximale sur l'axe des ordonnées \\ theta & numeric & 90 & Angle entre les axes du repère \end{rpparam} \begin{rpobjet}{cadre}{path} Chemin fermé qui fait le tour du repère. \end{rpobjet} \begin{exemple} repere(-3,3,1cm,-2,2,1cm); draw (-3,-2)--(3,0)--(0,2)--cycle; draw cadre; fin; \end{exemple} \begin{exemple} Uxy:=0.5cm; Xmin:=-6;Xmax:=6; Ymin:=-4;Ymax:=4; repere(); draw (-6,-4)--(6,0)--(0,4)--cycle; draw cadre; fin; \end{exemple} \begin{exemple} repere(-3,3,1cm,-2,2,1cm,60); draw (-3,-2)--(3,0)--(0,2)--cycle; draw cadre; fin; \end{exemple} \subsection{Axes} \subsubsection{Généralités} \begin{rpobjet}{axex.(,)}{picture} Axe des abscisses gradué avec un pas de \verb+pas_grad+ et étiqueté avec un pas de \verb+pas_val+. Si \verb+pas_grad+ est négatif ou nul, l'axe n'est pas gradué et si \verb+pas_val+ est négatif ou nul, l'axe n'est pas étiqueté. \verb+pos+ est un paramètre optionnel qui désigne la position (au sens de \MP : \verb+rt+, \verb+urt+, \verb+top+, \verb+ulft+, \verb+lft+, \verb+llft+, \verb+bot+ ou \verb+lrt+) des étiquettes. \verb+pos+ peut être omis, la valeur par défaut est \verb+bot+. Les étiquettes qui ne sont pas entièrement à l'intérieur du cadre ne sont pas dessinées. \end{rpobjet} \begin{rpobjet}{axey.(,)}{picture} Axe des ordonnées. La valeur par défaut de \verb+pos+ est \verb+lft+. \end{rpobjet} \begin{exemple} repere(-3,3,1cm,-1,1,1cm); draw axex(1,1); fin; \end{exemple} \begin{exemple} repere(-3,3,1cm,-1,1,1cm); draw axex.top(1,1); fin; \end{exemple} \begin{exemple} repere(-3,3,1cm,-1,1,1cm); draw axex(1,0); fin; \end{exemple} Au niveau de l'intersection des axes, les étiquettes sont tracées à la position \verb+pos+ si l'abscisse est différente de l'ordonnée ou si un seul axe est tracé. Dans le cas contraire, une seule étiquette est tracée pour les deux axes à une position \og intermédiaire \fg{} (pour \verb+axex.bot+ et \verb+axey.lft+, on obtient la position \verb+llft+) \begin{exemple} repere(-3,3,1cm,-3,3,0.5cm); draw axex(1,1); draw axey(1,2); fin \end{exemple} \begin{rpobjet}{axes.(,)}{picture} Figure formée par les deux axes gradués avec le même pas \verb+pas_grad+ et étiquetés avec le même pas \verb+pas_val+. \verb+pos+ désigne la position de l'étiquette de l'intersection des axes, sa valeur par défaut est \verb|llft|. La position des étiquettes des axes est définie à partir de \verb+pos+ (pour \verb+urt+ on obtient \verb+top+ pour l'axe des abscisses et \verb+rt+ pour l'axe des ordonnées. \end{rpobjet} \begin{exemple} repere(-3,3,0.8cm,-2.5,2.5,0.8cm); draw axes(1,1); draw cadre; fin; \end{exemple} \begin{exemple} repere(-3,3,0.8cm,-2.5,2.5,1cm,60); draw axes.lrt(1,1); draw cadre; fin; \end{exemple} \begin{rpobjet}{axexo.(,)}{picture} Axe des abscisses. L'étiquette correspondant à l'intersection des axes est dessinée à la position \verb|pos|. \end{rpobjet} \begin{rpobjet}{axeyo.(,)}{picture} Axe des ordonnées. L'étiquette correspondant à l'intersection des axes est dessinée à la position \verb|pos|. \end{rpobjet} \begin{rpobjet}{axeso.(,)}{picture} Les deux axes. Les étiquettes correspondant à l'intersection des axes sont dessinées en fonction de la position \verb|pos|. \end{rpobjet} \begin{rpobjet}{axexn.(,)}{picture} Axe des abscisses. L'étiquette correspondant à l'intersection des axes n'est pas dessinée. \end{rpobjet} \begin{rpobjet}{axeyn.(,)}{picture} Axe des ordonnées. L'étiquette correspondant à l'intersection des axes n'est pas dessinée. \end{rpobjet} \begin{rpobjet}{axesn.(,)}{picture} Les deux axes. Les étiquettes correspondant à l'intersection des axes ne sont pas dessinées. \end{rpobjet} \begin{exemple} repere.larg(-3,3,6cm,-3,4,3.5cm,60); draw axexn(1,2); draw axeyn(1,1); draw cadre; fin; \end{exemple} \subsubsection{Réglages des axes} %Les axes sont dessinés, gradués et étiquetés par défaut sur toute la longueur du repère utilisateur. Pour des valeurs différentes on peut utiliser les macros suivantes : \begin{rpdeclaration}{interaxes(,)} Définit les coordonnées du point d'intersection des axes. Par défaut ces coordonnées sont $(0,0)$. \end{rpdeclaration} \begin{rpdeclaration}{setaxes(,,,)} Définit les valeurs minimales et maximales pour les axes. \end{rpdeclaration} \begin{rpdeclaration}{setgrad(,,,)} Définit les valeurs minimales et maximales pour les graduations. \end{rpdeclaration} \begin{rpdeclaration}{setval(,,,)} Définit les valeurs minimales et maximales pour l'étiquetage. \end{rpdeclaration} \begin{exemple} repere.larg(110,160,5cm,2000,7000,5cm); interaxes(120,3000); setaxes(120,160,3000,7000); draw axex(10,10); draw axey(1000,1000); fin; \end{exemple} \begin{exemple} repere(-0.5,3,0.8cm,-0.5,2.5,1cm); setaxes(0,3,0,2.5); draw axeso(1,1); fin; \end{exemple} \begin{rpparam} flecheaxe & boolean & true & Trace les flèches (ou non) au bout des axes \\ defaultscale & numeric & 1 & Échelle à laquelle sont dessinées les étiquettes \end{rpparam} \begin{exemple} repere(-0.5,3,1cm,-0.5,2.5,1cm); flecheaxe:=false; draw axes(1,1); fin; \end{exemple} \begin{exemple} repere(-0.75,3,1cm,-0.75,2.5,1cm); defaultscale:=1.5; draw axes(1,1); fin; \end{exemple} \subsubsection{Graduations multiples de $\pi$} \begin{rpobjet}{axexpi.(,)}{picture} Axe des abscisses gradué et étiqueté avec un pas de $\frac{n\pi}{d}$. \end{rpobjet} \begin{rpobjet}{axexpi.(,)}{picture} Axe des ordonnées gradué et étiqueté avec un pas de $\frac{n\pi}{d}$. \end{rpobjet} \begin{rpobjet}{axespi.(,)}{picture} Les deux axes gradués et étiquetés avec un pas de $\frac{n\pi}{d}$. \end{rpobjet} \begin{exemple} repere(-2.5,2.5,1.5cm,-3.5,3.5,0.8cm); defaultscale:=0.8; draw axexpi(1,6); draw axeypi(1,4); draw cadre; fin; \end{exemple} \begin{rpobjet}{axexpio.(,) axeypio.(,) axespio.(,)}{picture} Axes gradués et étiquetés avec un pas de $\frac{n\pi}{d}$ sans l'étiquette correspondant à l'intersection des axes. \end{rpobjet} \begin{rpobjet}{axexpin.(,) axeypin.(,) axespin.(,)}{picture} Axes gradués et étiquetés avec un pas de $\frac{n\pi}{d}$ avec l'étiquette correspondant à l'intersection dessinées sur chacun des axes. \end{rpobjet} \begin{rpparam} displayfrac & boolean & false & Permet d'obtenir les fractions en mode \og displaystyle \fg \end{rpparam} \subsubsection{Graduations isolées} \begin{rpobjet}{axexpart.(,,,,...)}{picture} Graduations et étiquetages partiels de l'axe des abscisses pour les valeurs \verb+x1+, \verb+x2+... et les étiquettes \verb+lab1+, \verb+lab2+... à la position \verb+pos+. Si \verb+pos+ est omis, les étiquettes sont placées à la position \verb+bot+. Les étiquettes peuvent être soit des chaînes de caractères (\verb|string|), soit des figures (\verb|picture|). Si \verb+labn+ est omis, la valeur de \verb+xn+ sera utilisée comme étiquette. Pour obtenir une graduation sans étiquette, on peut utiliser la chaîne vide \verb+""+. \end{rpobjet} \begin{rpobjet}{axeypart.(,,,,...)}{picture} Même chose que précédemment mais sur l'axe des ordonnées. Si \verb+pos+ est omis, les étiquettes sont placées à la position \verb+lft+. \end{rpobjet} %On peut désactiver le dessin de la graduation en donnant la valeur \verb|false| à \verb|boolgradxpart|. \begin{exemple}[lefthand ratio=0.55] repere.orth(-4,5,6cm,-2,3); draw axes(0,0); draw axexpart(-1.8,-pi,"$-\pi$",3,"dd"); draw axeypart.rt(-1,2,""); fin; \end{exemple} \begin{rpparam} gradxpart & boolean & true & Contrôle l'affichage des graduations isolées sur l'axe des abscisses.\\ gradypart & boolean & true & Contrôle l'affichage des graduations isolées sur l'axe des ordonnées. \end{rpparam} \begin{exemple}[lefthand ratio=0.55] repere.orth(-4,5,6cm,-2,3); draw axes(0,0); gradxpart:=false;gradypart:=false; draw axexpart(-1.8,-pi,"$-\pi$",3,"dd"); draw axeypart.rt(-1,2,""); fin; \end{exemple} \subsubsection{Ajout de texte sur les graduations} \begin{rpparam} extranumx & string & "" & Chaine de caractères qui sera ajoutée après les valeurs des graduations sur l'axe des abscisses avant d'être composées avec la commande \verb|\num| de \verb|siunitx|.\\ extranumy & string & "" & Même chose sur l'axe des ordonnées. \end{rpparam} \begin{exemple} repere(-1,4,1.2cm,-1,3.5,1cm); extranumx:="e3"; extranumy:="0000"; draw axes(1,1); draw cadre; fin; \end{exemple} \subsection{Quadrillages} \begin{rpobjet}{quadrillage(,)}{picture} Quadrillage avec un pas de \verb+x+ sur l'axe des abscisses et de \verb+y+ sur l'axe des ordonnées. \end{rpobjet} \begin{exemple} repere(-3,3,0.8cm,-2.5,2.5,1cm); draw quadrillage(1,0.5); draw axes(1,1); draw cadre; fin; \end{exemple} \begin{exemple}[lefthand ratio=0.62] repere(-3,3,0.8cm,-2.5,2.5,1cm); draw quadrillage(1,1) dashed evenly withcolor red; draw axes(1,1); draw cadre; fin; \end{exemple} \begin{rpobjet}{papiermillimetre}{picture} Quadrillage en \si{cm} et dixièmes de \si{cm}. \end{rpobjet} \begin{exemple} repere(-2.5,2.5,1cm,-2.5,2.5,1cm); draw papiermillimetre; draw axes(1,1); fin; \end{exemple} \begin{rpobjet}{papierpointe(,)}{picture} quadrillage formé de points avec un pas de \verb+x+ sur l'axe des abscisses et de \verb+y+ sur l'axe des ordonnées. \end{rpobjet} \begin{exemple} repere(-2.5,2.5,1cm,-2.5,2.5,1cm); draw papierpointe(0.5,0.5); draw axes(1,1); fin; \end{exemple} \begin{rpparam} q_ep & numeric & 0.3 & Épaisseur des traits des quadrillages \\ q_coul & color & 0.7white & Couleur des traits des quadrillages \\ pm_epa & numeric & 0.2 & Épaisseur des traits des dixièmes de \si{cm} du papier millimétré \\ pm_epb & numeric & 0.4 & Épaisseur des traits des demis \si{cm} du papier millimétré \\ pm_epc & numeric & 0.6 & Épaisseur des traits des \si{cm} du papier millimétré \\ pm_coula & color & 0.6white & Couleur des traits des dixièmes de \si{cm} du papier millimétré \\ pm_coulb & color & 0.2white & Couleur des traits des demis \si{cm} du papier millimétré \\ pm_coulc & color & black & Couleur des traits des \si{cm} du papier millimétré \\ pp_ep & numeric & 2 & Taille des points du papier pointé \\ pp_coul & color & black & Couleur des points du papier pointé \\ \end{rpparam} \begin{rpdeclaration}{setquad(,,,)} Définit les valeurs minimales et maximales pour les divers quadrillages. \end{rpdeclaration} \begin{rpdeclaration}{setrepere(,,,)} Définit les valeurs minimales et maximales pour les axes, les graduations, les étiquettes et les quadrillages. \end{rpdeclaration} \begin{exemple} repere(-3,3,0.8cm,-2.5,2.5,1cm); setquad(0,3,0,2.5); draw papierpointe(0.5,0.5); setquad(-3,0,-2.5,2.5); draw quadrillage(1,1); setquad(0,3,-2.5,0); draw papiermillimetre; draw axes(1,1); draw cadre; fin; \end{exemple} \subsection{Base} \begin{rpobjet}{base(,,)}{picture} Figure formée par le point d'intersection des axes et son nom (\verb+O+), ainsi que des deux vecteurs de la base et leurs noms (surmontés d'une flèche). Si les noms sont de la forme \og lettre + nombre\fg, le nombre est affiché en indice. \end{rpobjet} \begin{exemple} repere(-1.5,3.5,1cm,-1,3,1cm); flecheaxe:=false; draw axesn(1,1); drawoptions(withcolor blue); draw base(O,i,j); interaxes(2,1); draw base(I,e1,e2); drawoptions(); draw cadre; fin; \end{exemple} \begin{rpobjet}{basep(,,)}{picture} Figure formée par le point d'intersection des axes et son nom (\verb+O+), ainsi que des deux points qui définissent le repère. \end{rpobjet} \begin{exemple} repere(-1,2.5,1cm,-1,2,1cm); flecheaxe:=false; draw axes(1,0); draw basep(O,I,J); draw cadre; fin; \end{exemple} \section{Points, vecteurs} \subsection{Points} \label{points} \begin{rpobjet}{(,)}{pair} Point (ou vecteur) de coordonnées cartésiennes \verb+x+ et \verb+y+ dans le repère utilisateur. \end{rpobjet} \begin{rpobjet}{pol(,)}{pair} Point (ou vecteur) de coordonnées $(r\cos t;r\sin t)$ dans le repère utilisateur. \end{rpobjet} \begin{rpobjet}{pold(,)}{pair} Même chose avec l'angle donné en degrés. \end{rpobjet} Les macros suivantes sont directement inspirées des macros similaires de \verb+geometriesyr16.mp+. \begin{rpobjet}{marquepointFig()}{picture} Dessin du point \verb+A+ selon le paramètre \verb+marque_p+. \end{rpobjet} \begin{rplabel}{marquepoint()} Dessine le point \verb+A+ selon le paramètre \verb+marque_p+. C'est en réalité \verb|draw marquepointFig(A)|. C'est un peu l'équivalent de \verb|drawdot|. \end{rplabel} \begin{rplabel}{marquepoints(,,...)} Permet de marquer plusieurs points. \end{rplabel} \begin{rpparam} marque_p & string & "*" & Définit le dessin du point. Les valeurs possibles sont \verb|"*"|, \verb|"o"|, \verb|"x"|, \verb|"+"| et \verb|""|. \\ taillepoint & numeric & 3 & Diamètre du cercle représentant le point dans les cas \verb|"*"| et \verb|"o"|.\\ taillecroix & numeric & 5 & Largeur de la croix représentant le point dans le cas \verb|"+"| et \verb|"x"|.\\ \end{rpparam} \begin{exemple} repere(-1,4,1cm,-1,3,1cm); pair A,B,C,D,E,F; A=(1,1);B=(2,1);C=(3,1); D=(1,2);E=(2,2);F=(3,2); draw axes(1,0); marquepoint(A); marque_p:="o";taillepoint:=5; marquepoint(B); marque_p:="x";marquepoint(C); marque_p:="+";marquepoints(D,E); taillecroix:=8;marquepoint(F); fin; \end{exemple} \begin{rplabel}{nomme.(,)} Marque le point et affiche son nom à la position \verb+pos+ (qui peut être \verb|rt|, \verb|urt|, \verb|top|, \verb|ulft|...). \verb+nom+ peut être soit une chaîne de caractères, soit une autre figure. Si \verb+nom+ est omis, le nom \verb+A+ est affiché. S'il s'agit d'un élément d'un tableau de points (\verb+A1+, \verb+A2+...), le nombre est affiché en indice. \end{rplabel} \begin{exemple}[lefthand ratio=0.55] repere(-3,3,1cm,-2.5,5,1cm); pair A,B,C,D[]; A=(-1,-1);B=(1,1);C=(2,3); draw axes(1,0); nomme.lft(A); marque_p:=""; nomme.llft(B);nomme.urt(C); draw B--C; marque_p:="o"; drawoptions(withcolor red); nomme.bot(pol(sqrt(2),-pi/4), "$\sqrt{2}e^{-i\frac{\pi}{4}}$"); marque_p:="*"; for i=2 upto 4: D[i]=(-3+i/2,i); nomme.lft(D[i]) withcolor blue; endfor fin; \end{exemple} \begin{rplabel}{nomme.[](,)} Il est possible d'obtenir un placement plus fin des étiquettes en remplaçant la position au sens de \MP{} (\verb|rt|, \verb|urt|...) par un nombre \verb|a| qui représente alors la position de l'étiquette par rapport au point en degrés. \end{rplabel} \begin{exemple}[lefthand ratio=0.55] repere(-3,3.5,1cm,-3,3,1cm); pair A,B,C[]; A=(-2,-1);B=(1,-2); nomme[40](A);nomme[70](A);nomme[100](A); nomme[-110](B); for i=0 upto 8: C[i]:= (1+1.5*cosd(40i),1+1.5*sind(40i)); nomme[40*i](C[i]) withcolor 0.6red; endfor draw cadre; fin; \end{exemple} \begin{rplabel}{nommerot.(,)()} Même chose que \verb|nomme.pos(A,nom)| mais l'étiquette est tournée d'un angle \verb|angle|. \end{rplabel} \begin{rplabel}{nommerot.[](,)()} Même chose que \verb|nomme[a](A,nom)| mais l'étiquette est tournée d'un angle \verb|angle|.\end{rplabel} \begin{exemple}[lefthand ratio=0.5] repere(-2,3,1cm,-1,3,1cm); pair A,B,C; A=(2,2);B=(-1,1);C=(1,0); nommerot.bot(A)(60); nommerot[120](B)(180); nommerot[-45](C,"Nom")(40); draw cadre; fin; \end{exemple} \begin{rplabel}{nommedef.(,)} Définit la variable \verb|A|, lui donne la valeur \verb|point| et affiche le point. C'est donc un raccourci pour : \verb|pair A;A:=point;nomme.pos(A)|. \end{rplabel} \begin{exemple} repere(); nommedef.[150](A,(0,0)); nommedef.bot(B,(3,-3)); draw A--B; fin; \end{exemple} \subsection{Vecteurs} \begin{rplabel}{drawvecteur(A,u)} Trace le représentant d'origine \verb|A| du vecteur \verb|u|. C'est l'équivalent de la commande \verb|drawarrow A--A+u| \end{rplabel} \begin{exemple}[lefthand ratio=0.6] repere(-1,5,1cm,-1,4,1cm); pair A,u; A=(1,0);u=(3,3); draw quadrillage(1,1); draw axes(1,1); drawvecteur(A,u) withcolor blue; drawvecteur((1,3),(2,-2)); fin; \end{exemple} \section{Droites} \subsection{Droites} \begin{rpobjet}{droite(,)}{path} Droite $(AB)$. Il s'agit en réalité d'un segment coupé au niveau des limites du repère. \end{rpobjet} \begin{rpobjet}{droite(,,)}{path} Droite d'équation $ax+by+c=0$ dans le repère utilisateur. \end{rpobjet} \begin{rpobjet}{droite(,)}{path} Droite d'équation $y=ax+b$ dans le repère utilisateur. \end{rpobjet} \begin{rpobjet}{droite()}{path} Droite d'équation $x=c$ dans le repère utilisateur. \end{rpobjet} \begin{exemple}[lefthand ratio=0.65] repere(-2,3,1cm,-2,3,1cm); pair A,B; A=(-0.5,-1);B=(1.5,1.5); draw axes(1,0); nomme.ulft(A); nomme.lrt(B); drawoptions(withpen pencircle scaled 1); draw droite(A,B); draw droite(1) withcolor red; %x=1 draw droite(1/3,3/2) withcolor 0.7green; %y=(1/3)x+3/2 draw droite(2,3,-1) withcolor blue; %2x+3y-1=0 fin; \end{exemple} \subsection{Demi-droites} \begin{rpobjet}{demidroite(,)}{path} Demi-droite $[AB)$. \end{rpobjet} \begin{rpobjet}{demidroite(,)}{path} Demi-droite d'origine $A$ qui fait un angle $a$ avec la direction $(Ox)$. \end{rpobjet} \begin{exemple} repere(-4,4,0.9cm,-3,4,0.9cm); pair A,B,C; numeric a; A=(-1,1);B=(2,2);C=(-1,-2); draw axes(1,0); draw demidroite(A,B); nomme.llft(A);nomme.lrt(B); draw demidroite(C,0) dashed evenly; draw demidroite(C,120); nomme.llft(C); fin; \end{exemple} \section{Courbes et fonctions} \subsection{Courbes} \MP{} permet de définir simplement des fonctions (en utilisant par exemple la syntaxe suivante : \verb|vardef f(expr x)=2x+1 enddef;|) et de définir des courbes passant par des points donnés (\verb+A..B..C+). Ces possibilités sont utilisées dans les macros qui suivent. \begin{rpobjet}{courbefonc()()}{path} Courbe représentant la fonction $f$ sur l'intervalle \verb|[Xmin;Xmax]| définissant le repère. \end{rpobjet} \begin{exemple} repere(-2,5,1cm,-2,2.5,1cm); vardef f(expr x)=-0.5(x**2)+2*x enddef; path C_f; draw axes(1,1); C_f=courbefonc(f)(); draw C_f withpen pencircle scaled 1; fin; \end{exemple} \begin{rpobjet}{courbefonc()(,)}{path} Courbe représentant la fonction $f$ sur l'intervalle \verb|[xminf;xmaxf]|. Ces valeurs peuvent aussi être données de manière globale. \end{rpobjet} \begin{exemple} repere(-2,5,1cm,-2,2.5,1cm); vardef f(expr x)=-0.5(x**2)+2*x enddef; path C_f; draw axes(1,1); C_f=courbefonc(f)(-0.5,3); draw C_f withpen pencircle scaled 1; fin; \end{exemple} \begin{rpobjet}{courbefonc()(,,)}{path} Courbe représentant la fonction $f$ sur l'intervalle \verb|[xminf;xmaxf]|. Le chemin est tracé avec \verb|nbf| points d'interpolation. Ces valeurs peuvent aussi être données de manière globale. \end{rpobjet} \begin{rpparam} xminf & numeric & Xmin & Valeur minimale de l'abscisse pour le tracé des représentations graphiques de fonctions. \\ xmaxf & numeric & Xmax & Valeur maximale de l'abscisse pour le tracé des représentations graphiques de fonctions. \\ nbf & numeric & 50 & Nombre de points d'interpolation pour le tracé des représentations graphiques de fonctions \end{rpparam} \begin{exemple} repere(-2,5,1cm,-2,2.5,1cm); vardef f(expr x)=-0.5(x**2)+2*x enddef; path C_f; draw axes(1,1); xminf:=1;xmaxf:=4; C_f=courbefonc(f)(); draw C_f withpen pencircle scaled 1; fin; \end{exemple} \begin{rpobjet}{courbepoint()(,,)}{picture} Ne trace que les \verb+n+ points sans les relier. Les points sont dessinés en fonction de la valeur de \verb+marque_p+ (voir \ref{points}). \end{rpobjet} \begin{exemple} repere(-2,4,1cm,-2.5,2,1cm); vardef g(expr x)=exp(x)/10-2 enddef; draw axes(1,1); draw courbepoints(g)(0,4,9); fin; \end{exemple} \begin{rpobjet}{fonccourbe(

)()}{numeric} Image de \verb+x+ par la fonction dont la courbe représentative est le chemin \verb+p+. La macro renvoie 0 si la fonction n'est pas définie. \end{rpobjet} \begin{exemple} repere(-2,4,1cm,-2,3,1cm); path p; numeric a,b; p=(-2,3)..(-1,0)..(0,-1)..(1,0) ..(2,1)..(3,0)..(4,-3); draw axes(1,1); draw p withpen pencircle scaled 1; drawoptions(withcolor blue); a=1.5;b=fonccourbe(p)(a); marquepoint((a,b)); b:=arrondi(1000,b); label("$f(1.5)\approx"& decimal(b) &"$", (2,2)); fin; \end{exemple} \begin{rplabel}{marquepointcourbe(

,,,...)} Marque les points de la courbe \verb+p+ d'abscisses \verb+x1+, \verb+x2+... La marque dépend de la valeur de \verb+marque_p+. \end{rplabel} \begin{exemple} repere(-2,4,1cm,-2,2.5,1cm); path C_f; vardef f(expr x)= x**2-2x enddef; C_f= courbefonc(f)(-2,3); draw axes(1,1); draw C_f withpen pencircle scaled 1; drawoptions(withcolor red); marquepointcourbe(C_f,-0.5,0.8,2.2,2.6); fin; \end{exemple} \begin{rplabel}{marquepointchemin(

,,,...)} Dans le cas d'un chemin défini par \verb+A..B..C..+, marque le \verb+n1+-ième point, le \verb+n2+-ième point... La marque dépend de la valeur de \verb+marque_p+. Attention, le premier point est numéroté 0. \end{rplabel} \begin{exemple} repere(-2.5,4.5,1cm,-3.5,2.5,1cm); path p; p=(-2,-2)..(-1,1)..(0,2) ..(1,1)..(2,-2)..(3,-3) ..(3.5,-2.5)..(4,-1); draw axes(1,1); draw p withpen pencircle scaled 1; drawoptions(withcolor red); marquepointchemin(p,0,2,3,5); fin; \end{exemple} \begin{rpdeclaration}{antecedents(,,

)} Stocke dans le tableau de nombres \verb+X+ (qu'il n'est pas nécessaire de déclarer) les antécédents de \verb+y+ par la fonction dont la courbe représentative est le chemin \verb+p+. \end{rpdeclaration} \begin{rpdeclaration}{ptantecedents(

,,

)} Stocke dans le tableau de points \verb+P+ (qu'il n'est pas nécessaire de déclarer) les points du chemin \verb+p+ d'ordonnée \verb+y+. \end{rpdeclaration} \begin{exemple} repere(-2.5,4.5,1cm,-3.5,2.5,1cm); path p; p=(-2,-2)..(-1,1)..(0,2)..(1,1) ..(2,-2)..(3,-3)..(3.5,-2.5) ..(4,-1); draw axes(1,1); draw p withpen pencircle scaled 1; drawoptions(withcolor blue); draw droite(0,-1.5) dashed evenly; antecedents(n,-1.5,p); draw axexpart.top(n1,"$n_1$",n2,"$n_2$", n3,"$n_3$"); ptantecedents(A,-1.5,p); nomme.lrt(A1);nomme.llft(A2); nomme.lrt(A3); fin; \end{exemple} \begin{rpdeclaration}{intercourbes(

,

,)} Stocke dans le tableau de points \verb+P+ (qu'il n'est pas nécessaire de déclarer) les points d'intersection des chemins \verb+p+ et \verb+q+. \end{rpdeclaration} \begin{exemple} repere(-2.5,3,1cm,-2.5,2.5,1cm); path p,C_f; vardef f(expr x)= x**2-2x enddef; p=(-2,-2)..(-1,1)..(0,2)..(1,1) ..(2,-2)..(3,-3)..(3.5,-2.5) ..(4,-1); C_f= courbefonc(f)(-2,2.5); draw axes(1,1); drawoptions(withpen pencircle scaled 1); draw p withcolor blue; draw C_f withcolor red; intercourbes(I,C_f,p); drawoptions(withcolor black); nomme.lft(I1);nomme.rt(I2); fin; \end{exemple} \subsection{Nom des courbes} \begin{rplabel}{nomme.(

,,)} Affiche \verb+nom+ au point d'abscisse \verb+x+ de la courbe \verb+p+ à la position \verb+pos+. Si \verb+nom+ est omis, le nom \verb+p+ est affiché. S'il s'agit d'un élément d'un tableau de points (\verb+p1+, \verb+p2+...), le nombre est affiché en indice. \end{rplabel} \begin{exemple} repere(-5,5,0.7cm,-5,5,0.7cm); path d,C_f; d=droite(-1,3); vardef f(expr x)=0.5(x**2)-x -4 enddef; C_f=courbefonc(f)(); draw axes(1,1); draw cadre; drawoptions(withcolor blue); draw d epaisseur 1; nomme.urt(d,1,"$d_2$"); drawoptions(withcolor red); draw C_f epaisseur 1; nomme.lrt(C_f,2); fin; \end{exemple} \begin{rplabel}{nomme(

,)} Affiche \verb|nom| (qui peut être omis) au niveau d'un point d'intersection de \verb|p| et du contour de la figure. La position est choisie automatiquement en fonction de la chaine \verb|prefnomme| et de la place restante. \end{rplabel} \begin{rpparam} prefnomme & string & "right" & indique le placement préféré du nom des courbes. Les valeurs possibles sont \verb|"right"|, \verb|"left"|, \verb|"top"| ou \verb|"bottom"|. \end{rpparam} \begin{exemple} repere(-5,5,0.7cm,-5,5,0.7cm); path d,C_f; d=droite(-1,3); vardef f(expr x)=0.5(x**2)-x -4 enddef; C_f=courbefonc(f)(); draw axes(1,1); draw cadre; drawoptions(withcolor blue); draw d epaisseur 1; nomme(d,"$d_2$"); drawoptions(withcolor red); draw C_f epaisseur 1; nomme(C_f); fin; \end{exemple} \begin{exemple} prefnomme:="top"; repere(-5,5,0.7cm,-5,5,0.7cm); path d,C_f; d=droite(-1,3); vardef f(expr x)=0.5(x**2)-x -4 enddef; C_f=courbefonc(f)(); draw axes(1,1); draw cadre; drawoptions(withcolor blue); draw d epaisseur 1; nomme(d,"$d_2$"); drawoptions(withcolor red); draw C_f epaisseur 1; nomme(C_f); fin; \end{exemple} \subsection{Dérivée et tangentes} \begin{rpobjet}{der(

)()}{numeric} Image de \verb+x+ par la dérivée de la fonction dont la courbe représentative est \verb+p+. \end{rpobjet} \begin{exemple} repere(-2.5,4.5,1cm,-3.5,2.5,1cm); path f,f'; f=(-2,-2){dir 60}..(-1,1) ..(0,2){right}..(1,1)..(2,-2) ..(3,-3){right}..(4,-2){(1,2)}; vardef df(expr x)= der(f)(x) enddef; f'= courbefonc(df)(-1,4); draw axes(1,1); drawoptions(withpen pencircle scaled 1); draw f; nomme(f); draw f' withcolor red; nomme(f') withcolor red; fin; \end{exemple} \begin{rpobjet}{tangente(

,)}{path} Droite tangente à la courbe \verb+p+ au point d'abscisse \verb+x+. \end{rpobjet} \begin{rpobjet}{tangente.gauche(

,,)}{picture} Flèche de longueur \verb+long+ représentant la demi-tangente gauche à la courbe \verb+p+ au point d'abscisse \verb+x+. \verb+long+ est optionnel, la valeur par défaut est donnée par le paramètre \verb|longtan|. \end{rpobjet} \begin{rpobjet}{tangente.droite(

,,)}{picture} Même chose à droite. \end{rpobjet} \begin{rpobjet}{tangente.gauche(

,,)}{picture} Même chose des deux côtés \end{rpobjet} \begin{rpparam} longtan & numeric & 20 & Longueur des « demi-flèches » dans les tracés de tangentes. \end{rpparam} \begin{exemple} repere(-2.5,4.5,1cm,-3.5,2.5,1cm); path p; p=(-2,-2){dir 60}..(-1,1) ..(0,2){right}..(1,1)..(2,-2) ..(3,-3){right}..(4,-2){(1,2)}; draw axes(1,1); drawoptions(withpen pencircle scaled 1); draw p; drawoptions(withcolor red); draw tangente.double(p,0); draw tangente.droite(p,-2,40); longtan:=30; draw tangente.gauche(p,4); draw tangente(p,2.5); fin; \end{exemple} \subsection{Interpolation} \MP{} propose les commandes suivantes (qui peuvent être combinées dans une même courbe) : \begin{description} \item[A-{}-B-{}-C-{}-] Ligne brisée passant par les points $A$, $B$, $C$... \item[A..B..C..] Courbe de Bézier passant par les points $A$, $B$, $C$... \end{description} \subsubsection*{Interpolation polynomiale} Ce n'est bien sûr pas toujours la meilleure méthode d'approximation. Il est conseillé de compiler avec \verb|numbersystem| réglé sur \verb|decimal| pour gagner en précision. \begin{rpobjet}{lagrange(,,,...)()}{path} Courbe passant par $A$, $B$, $C$... représentant le polynôme de degré maximal $n-1$ tel que $P(x_A)=y_A$, $P(x_B)=y_B$... sur l'intervalle \verb|[Xmin;Xmax]| définissant le repère. \end{rpobjet} \begin{rpobjet}{lagrange(,,,...)(,)}{path} Même courbe que précédemment mais sur l'intervalle \verb|[xminf;xmaxf]|. \end{rpobjet} \begin{rpobjet}{lagrange(,,,,,...)()}{path} Courbe passant par les points $(x_1;y_1)$, $(x_2;y_2)$, $(x_3;y_3)$... représentant le polynôme de degré maximal $n-1$ tel que $P(x_i)=y_i$ sur l'intervalle \verb|[Xmin;Xmax]| définissant le repère. \end{rpobjet} \begin{rpobjet}{lagrange(,,,,,...)(,)}{path} Même courbe que précédemment mais sur l'intervalle \verb|[xminf;xmaxf]|. \end{rpobjet} \begin{exemple}[lefthand ratio=0.55] repere.orth(-1,10,7cm,-1,10); pair A[],B[]; A[1]=(1,1);A[2]=(3,5);A[3]=(5,8); A[4]=(7,2);A[5]=(9,4); B[1]=(1,6);B[2]=(3,7);B[3]=(6,4);B[4]=(8,9); path L;L=lagrange(A[1],A[2],A[3],A[4],A[5])(); path C;C=lagrange(1,6,3,7,6,4,8,9)(0,8); draw quadrillage(1,1); draw axes(1,1); drawoptions(withcolor red); draw L epaisseur 1; for i=1 upto 5: nomme.llft(A[i]); endfor drawoptions(withcolor blue); draw C epaisseur 1; for i=1 upto 4: nomme.llft(B[i]); endfor fin; \end{exemple} \begin{rpobjet}{hermite((,,),(,,)...)()}{path} Courbe passant par les points $(x_1;y_1)$, $(x_2;y_2)$, $(x_3;y_3)$... représentant le polynôme de degré maximal $2n-1$ tel que $P(x_i)=y_i$ et $P'(x_i)=y'_i$ sur l'intervalle \verb|[Xmin;Xmax]| définissant le repère. \end{rpobjet} \begin{rpobjet}{hermite((,,),(,,)...)(,)}{path} Même courbe que précédemment mais sur l'intervalle \verb|[xminf;xmaxf]|. \end{rpobjet} \begin{rpobjet}{hermite(,),(B,)...)()}{path} Courbe passant par les points $A$, $B$, $C$... représentant le polynôme de degré maximal $2n-1$ tel que $P(x_A)=y_A$ et $P'(x_A)=y'_A$... sur l'intervalle \verb|[Xmin;Xmax]| définissant le repère. \end{rpobjet} \begin{rpobjet}{hermite(,),(B,)...)(,)}{path} Même courbe que précédemment mais sur l'intervalle \verb|[xminf;xmaxf]|. \end{rpobjet} \begin{exemple}[lefthand ratio=0.55] repere.orth(-1,10,7cm,-1,10); draw quadrillage(1,1); draw axes(1,1); path H;H=hermite((1,2,0.5),(4,8,0),(8,2,2))(); drawoptions(withcolor blue); draw H withpen pencircle scaled 1; draw tangente.double(H,1); draw tangente.double(H,4); draw tangente.double(H,8); pair A,B,C; A:=(1,8);B:=(4,4);C:=(7,6); path I;I=hermite(A,-1,B,0.5,C,2)(0,7.5); drawoptions(withcolor red); draw I withpen pencircle scaled 1; draw tangente.double(I,1); draw tangente.double(I,4); draw tangente.double(I,7); fin; \end{exemple} \subsubsection*{Interpolation à l'aide de splines cubiques} \begin{rpobjet}{spline(,,...)()}{path} Courbe passant par les points $A$, $B$, $C$ représentant une fonction cubique par morceaux telle que $f(x_A)=y_A$, $f(x_B)=y_B$... sur l'intervalle \verb|[Xmin;Xmax]| définissant le repère. \end{rpobjet} \begin{rpobjet}{spline(,,...)(,)}{path} Même courbe que précédemment mais sur l'intervalle \verb|[xminf;xmaxf]|. \end{rpobjet} \begin{rpobjet}{spline(,,,,,...)()}{path} Même courbe que précédemment mais les valeurs sont données sous forme de liste. \end{rpobjet} \begin{rpobjet}{spline(,,,,,...)(,)}{path} Même courbe que précédemment mais sur l'intervalle \verb|[xminf;xmaxf]|. \end{rpobjet} \begin{exemple}[lefthand ratio=0.55] repere.orth(-1,10,7cm,-1,10); pair A[],B[]; A[1]=(1,1);A[2]=(3,5);A[3]=(5,8); A[4]=(7,2);A[5]=(9,4); B[1]=(1,6);B[2]=(3,7);B[3]=(6,4);B[4]=(8,9); path L;L=spline(A[1],A[2],A[3],A[4],A[5])(); path C;C=spline(1,6,3,7,6,4,8,9)(0,8); draw quadrillage(1,1); draw axes(1,1); drawoptions(withpen pencircle scaled 1); draw L withcolor red; draw C withcolor blue; for i=1 upto 5: nomme.llft(A[i]) withcolor red; endfor for i=1 upto 4: nomme.llft(B[i]) withcolor blue; endfor fin; \end{exemple} \begin{rpobjet}{spline(,,,,,...)()}{path} Courbe passant par les points $A$, $B$, $C$ représentant une fonction cubique par morceaux telle que $f(x_A)=y_A$, $f'(x_A)=y'_A$, $f(x_B)=y_B$, $f'(x_B)=y'_B$... sur l'intervalle \verb|[Xmin;Xmax]| définissant le repère. Les valeurs \verb|y'A|, \verb|y'B|... peuvent être omises \end{rpobjet} \begin{rpobjet}{spline(,,,,,...)(,)}{path} Même courbe que précédemment mais sur l'intervalle \verb|[xminf;xmaxf]|. \end{rpobjet} \begin{exemple}[lefthand ratio=0.55] repere.orth(-1,10,7cm,-1,10); pair A,B,C,D; A=(0,1);B=(3,7);C=(6,2);D=(9,6); path S,T; S=spline(A,B,C,D)(); T=spline(A,0.5,B,C,0,D,-2)(); draw quadrillage(1,1); draw axes(1,1); drawoptions(withpen pencircle scaled 1); draw S withcolor blue; draw T withcolor red; draw tangente.double(T,0) withcolor red; draw tangente.double(T,6) withcolor red; draw tangente.double(T,9) withcolor red; nomme.lrt(A);nomme.top(B); nomme.llft(C);nomme.rt(D); fin; \end{exemple} Attention : lorsque la courbure est importante, l'utilisation de \verb|tangente| peut donner des résultats erronés... \section{Suites} \begin{rpobjet}{suite(,,)}{picture} Figure formée des points $(i;u_i)$ pour $i$ variant entre \verb+deb+ et \verb+fin+. \end{rpobjet} \begin{exemple} repere(-0.9,7,0.8cm,-1.2,1.2,1.5cm); vardef u(expr n)=(-1)**n/n enddef; taillepoint:=4; draw axes(1,1); draw suite(u,1,6) withcolor 0.5green; fin; \end{exemple} \begin{rpobjet}{Suiterec(f,deb,fin,init)}{picture} Figure complète formée d'une ligne brisée (\og escalier \fg{} ou \og escargot \fg) permettant de visualiser les termes de la suite définie par $u_{n+1}=f(u_n)$ de premier terme $u_{deb}=init$ et de dernier terme $u_{fin}$, des projections des différents termes sur les axes et des valeurs ou nom des termes. Des paramètres permettent de contrôler ce qui doit être affiché (voir plus bas). \end{rpobjet} \begin{exemple}[lefthand ratio=0.55] repere(-2,4.5,1cm,-1,4,1cm); vardef f(expr x)=sqrt(2*x+4) enddef; path C_f; C_f= courbefonc(f)(); draw axes(1,0); draw Suiterec(f,0,3,-1) withcolor red; drawoptions(withpen pencircle scaled 1); draw C_f withcolor blue; draw droite(1,0); fin; \end{exemple} \begin{rpparam} suite_nom & string & "u"& Chaine indiquant le nom de la suite pour affichage\\ suite_affx & boolean & true & Booléen qui indique si les projections sur l'axe des abscisses doivent être tracées.\\ suite_affy& boolean & true & Booléen qui indique si les projections sur l'axe des ordonnées doivent être tracées.\\ suite_labx & string & "nom" & Chaine qui indique le type d'affichage des étiquettes sur l'axe des abscisses. Les valeurs sont \verb|"nom"| (le nom du terme est affiché), \verb|"val"| (la valeur du terme est affichée) ou \verb|""| (rien n'est affiché).\\ suite_laby & string & "" & Chaine qui indique le type d'affichage des étiquettes sur l'axe des ordonnées. Les valeurs sont \verb|"nom"| (le nom du terme est affiché), \verb|"val"| (la valeur du terme est affichée) ou \verb|""| (rien n'est affiché).\\ suite_arrondi & numeric & 1 & Nombre qui indique, dans le cas où un des paramètres précédents vaut \verb|"val"|, la précision des valeurs à afficher.\\ suite_posx & string & "bot" & Chaine qui indique la position des étiquettes sur l'axe des abscisses.\\ suite_posy & string & "lft" & Chaine qui indique la position des étiquettes sur l'axe des ordonnées.\\ suite_styleproj & string & "dashed evenly" & Chaine qui indique le style des tracés des projections sur les axes.\\ \end{rpparam} \begin{exemple}[lefthand ratio=0.55] repere(-2,4.5,1cm,-1,4,1cm); vardef f(expr x)=sqrt(2*x+4) enddef; path C_f; C_f= courbefonc(f)(); draw axes(1,0); suite_labx:="val"; suite_laby:="nom"; suite_posy:="ulft"; draw Suiterec(f,0,3,-1) withcolor red; drawoptions(withpen pencircle scaled 1); draw C_f withcolor blue; draw droite(1,0); fin; \end{exemple} \begin{exemple}[lefthand ratio=0.55] repere(-0.5,5,1cm,-0.5,5,1cm); vardef f(expr x)=4-0.8*x enddef; path C_f; C_f= courbefonc(f)(); draw axes(1,0); suite_nom:="v"; suite_affy:=false; suite_styleproj:="withcolor 0.5green"; draw Suiterec(f,0,5,0.2) withcolor red; drawoptions(withpen pencircle scaled 1); draw C_f withcolor blue; draw droite(1,0); fin; \end{exemple} \section{Surfaces} \subsection{Calcul intégral} \begin{rpobjet}{souscourbe(

,,)}{(closed) path} Chemin fermé délimitant la zone comprise entre la courbe \verb+p+, l'axe des abscisses et les droites d'équations $y=\verb+xmin+$ et $y=\verb+xmax+$. \end{rpobjet} \begin{exemple} repere(-1,6,0.8cm,-1,3,0.8cm); vardef f(expr x)= -(x/4)**3+0.75x enddef; path C_f,q; C_f:= courbefonc(f)(); q:=souscourbe(C_f,2,5); fill q withcolor (1,0.7,0.7); draw q dashed evenly withcolor red; draw axes(1,1); drawoptions( withpen pencircle scaled 1); draw C_f withcolor red; draw cadre; fin; \end{exemple} \begin{rpobjet}{entrecourbes(

,,,)}{(closed) path} Chemin fermé délimitant la zone comprise entre les courbes \verb+p+ et \verb+q+ et les droites d'équations $y=\verb+xmin+$ et $y=\verb+xmax+$. \end{rpobjet} \begin{exemple} repere(-3.5,4,0.8cm,-2.5,4.5,0.8cm); vardef f(expr x)= -(x/4)**3+0.75x enddef; vardef g(expr x)= -((x-2)**2)/9+4 enddef; path C_f,C_g,p; C_f:= courbefonc(f)(); C_g:= courbefonc(g)(); p:=entrecourbes(C_f,C_g,-2,1.5); fill p withcolor (0.8,0.6,0.7); draw p withcolor (0.5,0,0.25); draw axes(1,1); drawoptions(withpen pencircle scaled 1); draw C_f withcolor red; draw C_g withcolor 0.5blue; draw cadre; fin; \end{exemple} \begin{rpobjet}{rectangles.(

,,,)}{(closed) path} Ligne brisée représentant la figure formée de \verb+n+ rectangles s'appuyant sur la courbe \verb+p+ entre les abscisses \verb+a+ et \verb+b+. \verb+type+ peut être \verb+min+, \verb+max+, \verb+droite+ ou \verb+gauche+. \end{rpobjet} \begin{exemple} repere(-2.5,6,0.8cm,-2,5,0.8cm); vardef f(expr x)= -((x-2)**4)/32+((x-2)**2)/2+1 enddef; path Cf,r[]; Cf= courbefonc(f)(); r1=rectangles.droite(Cf,-2,1,10); fill r1 withcolor 0.5red+blue; draw r1; r2=rectangles.max(Cf,2,5.5,8); r3=rectangles.min(Cf,2,5.5,8); fill r2 withcolor (1,0.2,0.2); fill r3 withcolor (1,0.6,0.6); draw r2; draw r3 withcolor (1,0.2,0.2); draw axes(1,0); draw Cf withcolor 0.5blue withpen pencircle scaled 1; fin; \end{exemple} \subsection{Demi-plans} \begin{rpobjet}{demiplaninf()}{(closed) path} Chemin fermé délimité par la droite \verb+d+ et par la partie inférieure de \verb+cadre+ (ou la partie gauche si \verb+d+ est parallèle à l'axe des ordonnées). \end{rpobjet} \begin{rpobjet}{demiplansup()}{(closed) path} Chemin fermé délimité par la droite \verb+d+ et par la partie supérieure de \verb+cadre+ (ou la partie droite si \verb+d+ est parallèle à l'axe des ordonnées). \end{rpobjet} \begin{exemple} repere(-2.5,3.5,1cm,-2.5,3.5,1cm); path d[],dp[]; d1=droite(2); d2=droite(1,1); d3=droite(-0.5,-0.5); dp1=demiplansup(d1); dp2=demiplansup(d2); dp3=demiplaninf(d3); for i=1 upto 3: fill dp[i] withcolor (0.7,1,0.4); endfor draw axes(1,1); drawoptions(withpen pencircle scaled 1 withcolor 0.5green); draw d1;draw d2;draw d3; drawoptions(); draw cadre; fin; \end{exemple} \section{Projections sur les axes} \subsection{Projetés} \begin{rpobjet}{projetex()}{pair} Projeté de \verb+A+ sur l'axe des abscisses parallèlement à l'axe des ordonnées. \end{rpobjet} \begin{rpobjet}{projetey()}{pair} Projeté de \verb+A+ sur l'axe des ordonnées parallèlement à l'axe des abscisses. \end{rpobjet} \begin{exemple}[lefthand ratio=0.6] repere(-0.5,3,1cm,-0.5,3,1cm); pair A; A=(2.5,2); draw axes(1,1); nomme.urt(A); draw projetex(A)--A--projetey(A) dashed evenly; fin; \end{exemple} \begin{rpobjet}{Projectionx.(,)}{picture} Figure constituée du segment joignant \verb+A+ à son projeté sur l'axe des abscisses ainsi que de l'étiquette \verb+lab+ placée à la position \verb+pos+ par rapport à ce projeté. L'étiquette est optionnelle, si elle est omise, rien n'est affiché. \end{rpobjet} \begin{rpobjet}{Projectiony.(,)}{picture} Figure constituée du segment joignant \verb+A+ à son projeté sur l'axe des ordonnées ainsi que de l'étiquette \verb+lab+ placée à la position \verb+pos+ par rapport à ce projeté. L'étiquette est optionnelle, si elle est omise, rien n'est affiché. \end{rpobjet} \begin{exemple}[lefthand ratio=0.63] repere(-1.5,3.5,1cm,-1.5,2.5,1cm); path Cf; pair A[]; vardef f(expr x)= x**2-2x enddef; Cf= courbefonc(f)(); ptantecedents(A,2,Cf); draw axes(1,1); drawoptions(dashed evenly withcolor red); draw Projectionx.lrt(A1,"$x_1$"); draw Projectionx(A2); draw Projectiony(A1); draw Projectiony.urt(A2,"$y$"); drawoptions(); draw Cf withpen pencircle scaled 1 withcolor blue; fin; \end{exemple} \begin{rpobjet}{Projectionaxes(,,)}{picture} Figure constituée des segments joignant \verb+A+ à ses projetés sur les axes ainsi que des étiquettes \verb+labx+ et \verb+laby+ positionnées automatiquement par rapport aux axes. Les étiquettes sont optionnelles. \end{rpobjet} \begin{exemple}[lefthand ratio=0.63] repere(-1.5,3.5,1cm,-2.2,2.5,1cm); path Cf; pair A[]; vardef f(expr x)= x**2-2x-0.5 enddef; Cf= courbefonc(f)(); A1=(-0.5,f(-0.5));A2=(2.8,f(2.8)); A3=(0.75,f(0.75)); draw axes(1,1); drawoptions(dashed evenly withcolor red); draw Projectionaxes(A1,"$x$","$f(x)$"); draw Projectionaxes(A2,"$x$","$f(x)$"); draw Projectionaxes(A3,"$x$","$f(x)$"); drawoptions(); draw Cf withpen pencircle scaled 1 withcolor blue; fin; \end{exemple} \subsection{Intervalles} \begin{rpobjet}{intervallex.(,)}{picture} Intervalle dessiné sur l'axe des abscisses entre \verb+a+ et \verb+b+ avec une épaisseur par défaut de \verb+1.5bp+. \verb+bornes+ peut être \verb+OO+ (ouvert à gauche, ouvert à droite), \verb+OF+, \verb+FO+ ou \verb+FF+. \end{rpobjet} \begin{rpobjet}{intervalley.(,)}{picture} Même chose sur l'axe des ordonnées. \end{rpobjet} \begin{exemple}[lefthand ratio=0.6] repere(-1,5,0.9cm,-1,4.5,1cm); vardef f(expr x)=x**2-5x+7 enddef; draw axes(1,1); drawoptions(withcolor blue); draw courbefonc(f)() withpen pencircle scaled 1; drawoptions(dashed evenly withcolor red); draw projectionx.bot((1,f(1))); draw projectiony.llft((2.5,f(2.5)),"0,75"); draw projectionaxes((4,f(4))); drawoptions(withcolor (0.5,0,0.5)); draw intervallex.OF(1,4); draw intervalley.FF(0.75,3); label("$f(]1;4])=[0,75;3]$",(2.5,4)); draw cadre; fin; \end{exemple} \begin{rpparam} int_ep & numeric & 2bp & Épaisseur du tracé des intervalles. \end{rpparam} \section{Statistiques et probabilités} \subsection{Boite à moustache} \begin{rpobjet}{diagrammeboite(,,,,)}{(closed) path} Diagramme en boite ou \og boite à moustache \fg{} correspondant aux données en argument. Il s'agit d'un chemin fermé et peut donc être rempli. Les données sont optionnelles. En cas d'absence, les données du diagramme précédent sont utilisées. \end{rpobjet} \begin{exemple} repere(-0.5,10,0.7cm,-1,5,1cm); setaxes(0,10,0,1); draw axex(1,1); fill diagrammeboite(1,4,5,7,9) withcolor 0.7white; draw diagrammeboite(); fin; \end{exemple} \begin{rpparam} boite_dec & numeric & 1.5 & Valeur qui indique le décalage de la boite par rapport à l'axe des abscisses (l'unité est celle de l'axe des ordonnées).\\ boite_larg & numeric & 1 & Valeur qui indique la largeur de la boite (l'unité est celle de l'axe des ordonnées). \end{rpparam} \begin{rpobjet}{Diagrammeboite(,,,,)}{picture} Figure complète qui contient le dessin du diagramme ainsi que les projections des points importants avec éventuellement une étiquette. Des paramètres contrôlent ce qui doit être affiché. Les données sont optionnelles. En cas d'absence, les données du diagramme précédent sont utilisées. \end{rpobjet} \begin{exemple} repere(-0.5,10,0.7cm,-1,5,1cm); setaxes(0,10,0,1); draw axex(1,0); fill diagrammeboite(1,4,5,7,9) withcolor 0.7white; draw Diagrammeboite(); fin; \end{exemple} \begin{rpparam} boite_points & boolean & true & Booléen qui indique si les points aux extrémités du diagramme doivent être marqués.\\ boite_proj & boolean & true & Booléen qui indique si les projection doivent être tracées.\\ boite_lab & string & "nom" & Chaine qui indique le type d'affichage des étiquettes sur l'axe des abscisses. Les valeurs sont \verb|"nom"| (le nom est affiché, voir ci-dessous), \verb|"val"| (la valeur du terme est affichée) ou \verb|""| (rien n’est affiché).\\ boite_pos & string & "bot" & Chaine qui indique la position des étiquettes sur l’axe des abscisses.\\ boite_styleproj & string & "dashed evenly" & Chaine qui indique le style des tracés des projections sur les axes. \end{rpparam} \begin{rpdeclaration}{def_boite_lab(,,,,)} Fonction qui permet de définir les 5 chaines qui seront affichées en abscisses si le paramètre \verb|boite_lab| vaut \verb|"nom"|. Cette fonction est appelée par défaut avec les paramètres \verb|"$X_{\text{min}}$"|, \verb|"$Q_1$"|, \verb|"$M$"|, \verb|"$Q_3$"|, \verb|"$X_{\text{max}}$"|. \end{rpdeclaration} \begin{exemple}[listing above text] repere(-0.5,10.5,0.8cm,-1,5,1cm); draw axex(1,0); boite_larg:=0.7; drawoptions(withcolor red); boite_dec:=1; boite_lab:="val"; draw Diagrammeboite(1.2,3.9,5,7.2,9.1); drawoptions(withcolor blue); boite_dec:=2; boite_lab:="nom"; def_boite_lab(0.03,"$\pi$","$\numproduct{2x3}$","$x$","Max"); boite_styleproj:="dashed withdots"; draw Diagrammeboite(0,3.14,6,8,10); fin; \end{exemple} \subsection{Diagrammes divers} \begin{rpobjet}{diagrammebatons((,),(,),...,(,))}{picture} Figure formée des \verb|n| segments joignant les points \verb|(v1,e1),(v2,e2),...(vn,en)| et leur projeté sur l'axe des abscisses. Les bâtons sont surmontés d'un point. \end{rpobjet} \begin{exemple}[lefthand ratio=0.6] repere(-0.5,5,1cm,-0.5,5,1cm); picture diag; draw axes(1,1); diag:=diagrammebatons((1,2),(2,4),(3,2),(4,1)); draw diag withcolor red; fin \end{exemple} \begin{rpparam} batons_diampoint & numeric & 5 & Diamètre des points sur les bâtons. \end{rpparam} \begin{exemple}[lefthand ratio=0.6] repere(-0.5,5,1cm,-0.5,5,1cm); picture diag; draw axes(1,1); batons_diampoints:=10; diag:=diagrammebatons((1,2),(2,4),(3,2),(4,1)); draw diag withpen pencircle scaled 2 withcolor red dashed evenly; fin \end{exemple} \begin{rpobjet}{diagrammebarres((,

),(,

),...(,))}{(closed) path} Chemin fermé qui forme \verb|n| barres rectangulaires de hauteurs \verb|h1| \dots \verb|hn| aux abscisses \verb|a1| \dots \verb|an|. %La largeur de ces barres est le nombre \verb|largbarres| qui vaut \verb|20bp| par défaut. \end{rpobjet} \begin{exemple}[lefthand ratio=0.61] repere(-0.5,5,1cm,-0.5,5,1cm); gradxpart:=false; flecheaxe:=false; draw axey(1,1); draw axex(0,0); draw axexpart.bot(1,"A",2,"B",3,"C",4,"D"); path diag; diag:=diagrammebarres((1,2),(2,4),(3,2),(4,1)); fill diag withcolor (0,1,1); draw diag withpen pencircle scaled 1 withcolor 0.5blue; fin \end{exemple} \begin{rpparam} barres_larg & numeric & 20 & Largeur des barres des diagrammes en barres. \end{rpparam} \begin{exemple}[lefthand ratio=0.61] repere(-0.5,5,1cm,-0.5,5,1cm); gradxpart:=false; flecheaxe:=false; barres_larg:=1cm; draw axey(1,1); draw axex(0,0); draw axexpart.bot(1,"A",2,"B",3,"C",4,"D"); path diag; diag:=diagrammebarres((1,2),(2,4),(3,2),(4,1)); fill diag withcolor (0,1,1); draw diag withpen pencircle scaled 1 withcolor 0.5blue; fin \end{exemple} \subsection{Probabilités} \subsubsection*{Calculs} Quelques fonctions mathématiques sont proposées. Pour les grandes valeurs, on dépasse rapidement les capacités de \MP. Il est dans ce cas conseillé de compiler en utilisant la ligne de commande \verb|mpost -numbersystem="decimal" .mp| ou, avec Lua\LaTeX{} et le package \verb|luamplib|, d'utiliser \verb|\mplibnumbersystem{decimal}|. \begin{rpobjet}{factorielle()}{numeric} Entier égal à $n!$. \end{rpobjet} \begin{rpobjet}{binom(,)}{numeric} Entier égal à $\binom{n}{k}$. \end{rpobjet} \begin{rpobjet}{binomiale(,

,)}{numeric} $P(X=k)$ pour $X$ suivant la loi binomiale de paramètres $n$ et $p$. \end{rpobjet} \subsubsection*{Diagrammes} \begin{rpobjet}{diagrammebinomiale(,

)}{picture} Diagramme en bâtons de la loi binomiale de paramètres $n$ et $p$. \end{rpobjet} \begin{exemple} repere(-2,16,0.45cm,-0.1,0.25,15cm); setrepere(0,16,0,0.25); draw axex(1,1); draw axey(0.1,0.1); picture diag; batons_diampoints:=0; diag:=diagrammebinomiale(15,0.6); draw diag withcolor 0.5green withpen pencircle scaled 4; fin; \end{exemple} \begin{rpobjet}{diagrammeuniforme(,)}{picture} Diagramme en bâtons de la loi uniforme discrète sur les entiers consécutifs de \verb|n| à \verb|m|. \end{rpobjet} \begin{rpobjet}{diagrammegeometrique(

)}{picture} Diagramme en bâtons de la loi géométrique de paramètre \verb|p|. \end{rpobjet} \begin{exemple} repere.larg(-2,10,8cm,-0.1,0.5,6cm); setrepere(0,10,0,0.5); draw axex(1,1); draw axey(0.05,0.05); draw diagrammegeometrique(0.4) withpen pencircle scaled 2 withcolor blue; fin; \end{exemple} \begin{rpobjet}{diagrammepoisson()}{picture} Diagramme en bâtons de la loi de Poisson de moyenne \verb|lambda|. \end{rpobjet} \begin{exemple} repere(-2,16,0.45cm,-0.1,0.25,15cm); setrepere(0,16,0,0.25); draw axex(1,1); draw axey(0.1,0.1); picture diag; batons_diampoints:=0; diag:=diagrammepoisson(6); draw diag withcolor (1,0.5,0) withpen pencircle scaled 4; fin; \end{exemple} \begin{rpobjet}{densitenormale(,)()}{path} Courbe représentant la densité de la loi normale de moyenne \verb|mu| et d'écart type \verb|sigma| sur l'intervalle \verb|[Xmin;Xmax]| définissant le repère. \end{rpobjet} \begin{rpobjet}{densitenormale(,)(,)}{path} Courbe représentant la densité de la loi normale de moyenne \verb|mu| et d'écart type \verb|sigma| sur l'intervalle \verb|[xminf;xmaxf]|. \end{rpobjet} \begin{exemple}[lefthand ratio=0.45] repere.larg(-4,32,8cm,-0.01,0.12,6cm); draw axex(2,2); draw axey(0.02,0.02); path C,d; C=densitenormale(16,4)(); fill souscourbe(C,0,14) withcolor 0.7white; draw souscourbe(C,0,14); draw C withpen pencircle scaled 2 withcolor red; d=droite(16); draw d dashed evenly; drawarrow (5,0.06)--(11,0.02); label.top("$P(X\leq 14)$",(5,0.06)); nomme(d,"$\mu$"); fin; \end{exemple} \begin{rpobjet}{densiteexponentielle(lambda)()}{path} Courbe représentant la densité de la loi exponentielle de paramètre \verb|lambda| sur l'intervalle \verb|[Xmin;Xmax]| définissant le repère. \end{rpobjet} \begin{rpobjet}{densiteexponentielle(lambda)(,)}{path} Courbe représentant la densité de la loi exponentielle de paramètre \verb|lambda| sur l'intervalle \verb|[xminf;xmaxf]|. \end{rpobjet} \begin{exemple} repere.larg(-1,9,8cm,-0.05,0.6,6cm); setrepere(0,9,0,0.6); draw axex(1,1); draw axey(0.1,0.1); path C,D; C=densiteexponentielle(0.5)(); D=densiteexponentielle(0.3)(); drawoptions(withpen pencircle scaled 2); draw C withcolor red; draw D withcolor (0.3,0,0.6); fin; \end{exemple} \section{Géométrie} Certaines des macros suivantes sont inspirées des macros de \verb|geometriesyr16.mp| de Christophe \bsc{Poulain} disponible \href{https://melusine.eu.org/syracuse/poulecl/geometriesyr16/}{ici}. \subsection{Codage des segments et des angles} \subsubsection*{Segments} \begin{rpobjet}{marquesegment(,)}{picture} Figure formée d'une marque sur le segment $[AB]$. Des paramètres permettent de contrôler la forme et la taille de la marque. \end{rpobjet} \begin{rpobjet}{marquesegment(

)}{picture} Figure formée d'une marque sur le chemin \verb|p|. Des paramètres permettent de contrôler la forme et la taille de la marque. \end{rpobjet} \begin{rpobjet}{marquesegment(,,,...)}{picture} Plusieurs segments peuvent être marqués simultanément. \end{rpobjet} \begin{rpobjet}{marquesegment(,,)}{picture} Figure formée de \verb|n| marques sur le segment $[AB]$. L'espace entre les marques est contrôlé par le paramètre \verb|sep_marque_s|. \end{rpobjet} \begin{exemple} repere(); pair A,B,C; A=(1,2);B=(3,1);C=(5,4); nomme.lft(A);nomme.urt(C); nomme.bot(B); draw triangle(A,B,C) withcolor blue; draw marquesegment(A,B,B,C); draw marquesegment(A,C,2); fin; \end{exemple} \begin{rpobjet}{marquesegment(,,)}{picture} Figure formée d'une marque sur le segment $[AB]$. Le paramètre \verb|formemarque| indique la forme du dessin de la marque. Il peut aussi être donné de manière globale. \end{rpobjet} \begin{rpparam} forme_marque_s & string & "/" & Chaine de caractères permettant de choisir la forme et le nombre de marques. Les valeurs possibles sont : \verb|"/"| (ou \verb|"//"|, ou \verb|"///"|...), \verb|"x"| (ou \verb|"xx"|...), \verb|"o"|, \verb|"s"|.\\ echelle_marque_s & numeric & 1 & Facteur permettant de contrôler la taille des marques.\\ angle_marque_s & numeric & 60 & Angle de la marque par rapport au segment dans les cas \verb|"/"| et \verb|"s"|.\\ sep_marque_s & numeric & 2 & Écart entre les marques dans le cas où il y en a plusieurs. \end{rpparam} \begin{exemple}[lefthand ratio=0.6] repere(); pair A[],B[]; path p; for i=1 upto 6: A[i]:=(0,-i);B[i]:=(3,-i); draw A[i]--B[i]; nomme.lft(A[i]);nomme.rt(B[i]); endfor p:=A[6]..(1,-6.5)..B[6]; draw marquesegment(A[1],B[1],"o"); draw marquesegment(A[2],B[2],"ss"); draw marquesegment(A[3],B[3],"/",3); sep_marque_s:=6; draw marquesegment(A[4],B[4],"xxx"); angle_marque_s:=90;echelle_marque_s:=2; draw marquesegment(A[5],B[5],"/"); sep_marque_s:=2; angle_marque_s:=60;echelle_marque_s:=1; draw p; draw marquesegment(p,"/"); fin; \end{exemple} \subsubsection*{Angles} \begin{rpobjet}{marqueangle(,,,)}{(closed) path} Chemin formé de \verb|n| arcs de cercle de centre $O$ permettant de marquer l'angle géométrique $\widehat{AOB}$. Il s'agit d'un chemin fermé qui peut donc être rempli. \end{rpobjet} \begin{rpobjet}{marqueangle(,,)}{path} Arc de cercle de centre \verb|O| permettant de marquer l'angle $\widehat{AOB}$. On peut utiliser \verb|drawarrow| pour marquer un angle orienté.. \end{rpobjet} \begin{exemple} repere(); pair A,B,C; A=(0,0);B=(4,0);C=(3,2.5); draw A--B--C--cycle; nomme.llft(A);nomme.lrt(B);nomme.top(C); fill marqueangle(C,B,A,3) withcolor red; draw marqueangle(C,B,A,3); drawarrow marqueangle(A,C,B); fill marqueangle(B,A,C,1) withcolor green; draw marqueangle(B,A,C,1); fin; \end{exemple} \begin{rpobjet}{marqueangledroit(,,)}{(closed) path} Chemin fermé permettant de marquer l'angle droit $\widehat{AOB}$ sous forme d'un losange (il s'agit donc d'un carré si l'angle est réellement droit). \end{rpobjet} \begin{exemple}[lefthand ratio=0.55] repere(); pair A,B,C,D; A=(0,0);B=(4,0);C=(0,2.5);D=(5,1.5); draw C--A--B--D; nomme.llft(A);nomme.lrt(B); nomme.top(C);nomme.urt(D); fill marqueangledroit(B,A,C) withcolor blue; draw marqueangledroit(B,A,C); draw marqueangledroit(D,B,A); fin; \end{exemple} \begin{rpparam} echelle_marque_ad & numeric & 1 & Facteur permettant de contrôler la taille des marques des angles droits.\\ \end{rpparam} \begin{rplabel}{nomme.pos(,,,)} Place le texte à la position \verb|pos| par rapport au point central de l'arc de cercle de centre $O$ et de rayon \verb|taille_marque_a|. \verb|pos| peut être \verb|rt|, \verb|urt|, \verb|top|, etc. ou un angle donné par rapport à la direction $(Ox)$. \end{rplabel} \begin{rplabel}{nomme(,,,)} Même chose que précédemment mais la position est calculée automatiquement en fonction de l'angle. \end{rplabel} \begin{exemple} repere(); pair A,B,C; A=(0,0);B=(4,0);C=(3,2.5); draw A--B--C--cycle; nomme.llft(A);nomme.lrt(B);nomme.top(C); fill marqueangle(C,B,A,3) withcolor red; draw marqueangle(C,B,A,3); fill marqueangle(B,A,C,1) withcolor green; draw marqueangle(B,A,C,1); nomme[15](B,A,C,"\ang{45}"); nomme(C,B,A,"$\alpha$"); fin; \end{exemple} \begin{rplabel}{nomme.pos(,,,,)} Même chose que précédemment avec en plus le tracé de \verb|n| arcs de cercle pour marquer l'angle. \end{rplabel} \begin{rplabel}{nomme(,,,,)} Même chose que précédemment mais la position est calculée automatiquement en fonction de l'angle. \end{rplabel} \begin{exemple} repere(); pair A,B,C; A=(0,0);B=(4,0);C=(3,2.5); draw A--B--C--cycle; nomme.llft(A);nomme.lrt(B);nomme.top(C); nomme[15](B,A,C,"\ang{45}",1); nomme(C,B,A,"$\alpha$",2); fin; \end{exemple} \subsection{Cotes} \begin{rplabel}{cote(,,)} Figure formée du texte orienté dans la direction du segment $[AB]$, placé au niveau du milieu et situé « sous » le segment. \end{rplabel} \begin{rplabel}{cote.top(,,)} Même chose mais le texte est placé au-dessus du segment. \end{rplabel} \begin{exemple}[lefthand ratio=0.51] repere(0,6,1cm,0,6,1cm); pair A,B,C; A=(1,1);B=(2,5);C=(5,2); nomme.llft(A);nomme.top(B);nomme.lrt(C); draw triangle(A,B,C); cote(A,C,"\SI{5}{cm}"); cote(B,C,"de $B$ vers $C$") withcolor red; cote(C,B,"de $C$ vers $B$") withcolor blue; cote.top(A,B,"au-dessus"); fin; \end{exemple} \begin{rplabel}{cotefleche(,,)} Figure formée d'une double flèche et du texte orienté dans la direction du segment $[AB]$, placés au niveau du milieu et situés « sous » le segment. \end{rplabel} \begin{rplabel}{cotefleche.top(,,)} Même chose mais la double flèche et le texte sont placés au-dessus du segment. \end{rplabel} \begin{exemple}[lefthand ratio=0.52] repere(0,6,1cm,0,6,1cm); pair A,B,C; A=(1,1);B=(2,5);C=(5,2); nomme.llft(A);nomme.top(B);nomme.lrt(C); draw triangle(A,B,C); cotefleche(A,C,"\SI{5}{cm}"); cotefleche.top(A,B,"Texte") withcolor red; fin; \end{exemple} \begin{rpparam} angle_cote & numeric & -1 & Variable numérique qui fixe l'angle de rotation de l'étiquette. La valeur par défaut de $-1$ indique que l'étiquette est tournée en fonction de l'angle du segment.\\ dec_cote & numeric & 4mm & Variable numérique qui indique le décalage entre le segment et la double flèche.\\ traits_cote & boolean & false & Variable booléenne qui indique si des traits délimitant la double flèche doivent être tracés. \end{rpparam} \begin{exemple}[lefthand ratio=0.52] repere(0,6,1cm,0,6,1cm); pair A,B,C; A=(1,1);B=(2,5);C=(5,2); nomme.llft(A);nomme.top(B);nomme.lrt(C); draw triangle(A,B,C); angle_cote:=90; cote.top(A,B,"10"); angle_cote:=0; cote(A,C,"5"); angle_cote:=-1; traits_cote:=true; dec_cote:=0.8cm; cotefleche.top(B,C,"Avec traits"); fin; \end{exemple} \subsection{Polygones} \begin{rpobjet}{polygone(,,,...)}{(closed) path} Chemin fermé représentant le polygone $ABC...$ \end{rpobjet} \begin{rpobjet}{triangle(,,)}{(closed) path} Cas particulier du précédent. Chemin fermé représentant le triangle $ABC$. \end{rpobjet} \begin{rpobjet}{parallelogramme(,,)}{(closed) path} Chemin fermé représentant $ABCD$ où $D$ est le quatrième point du parallélogramme. \end{rpobjet} \begin{exemple}[lefthand ratio=0.53] repere(-1,5,1cm,-1,4,1cm); draw axes(1,1); pair A,B,C,D,E,F,G; A=(0,1);B=(2,0);C=(4,2);D=(3,3);E=(1,3); F=(4,0);G=(3,2); fill triangle(A,F,G) withcolor (1,0.5,0); draw triangle(A,F,G); draw polygone(A,B,C,D,E); draw parallelogramme(D,G,E) withcolor green; fin; \end{exemple} \begin{rpobjet}{polygoneregulier(,,)}{(closed) path} Chemin fermé représentant le polygone régulier de sens direct à $n$ côtés dont un des côtés est $[AB]$. \end{rpobjet} \begin{rpobjet}{equilateral(,)}{(closed) path} Cas particulier du précédent. Triangle équilatéral de sens direct de côté $[AB]$. \end{rpobjet} \begin{rpobjet}{carre(,)}{(closed) path} Autre cas particulier. Carré de sens direct de côté $[AB]$. \end{rpobjet} \begin{rpobjet}{sommetpolygoneregulier(,,,)}{pair} Sommet numéro $i$ du polygone régulier à $n$ côtés dont un des côtés est $[AB]$. $A$ est le sommet numéro 1 et $B$ est le sommet numéro 2. \end{rpobjet} \begin{exemple}[lefthand ratio=0.55] repere(-1,5,1cm,-1,4,1cm); draw axes(1,1); pair A,B,M; A=(1,1);B=(3,0.5); fill polygoneregulier(A,B,5) withcolor blue; fill equilateral(A,B) withcolor (0,1,1); draw polygoneregulier(A,B,5); M=sommetpolygoneregulier(A,B,5,3); nomme.rt(M); draw equilateral(A,B); fin; \end{exemple} \subsection{Cercles et arcs} \begin{rpobjet}{cercle(,,)}{(closed) path} Cercle circonscrit au triangle $ABC$. \end{rpobjet} \begin{rpobjet}{cercle(,)}{(closed) path} Cercle de centre $O$ passant par $A$. \end{rpobjet} \begin{exemple} repere(-1,5,1cm,-0.5,4,1cm); draw axes(1,1); pair A,B,C; A=(1,1);B=(2,0);C=(3.5,2); nomme.lft(A);nomme.urt(C);nomme.top(B); drawoptions(withpen pencircle scaled 1); draw triangle(A,B,C) withcolor blue; draw cercle(A,B,C) withcolor 0.5blue; draw A--B withcolor red; draw cercle(A,B) withcolor red; fin; \end{exemple} \begin{rpobjet}{cercle(,)}{(closed) path} Cercle de centre $O$ et de rayon $r$. L'unité de longueur est l'unité de l'axe des abscisses. \end{rpobjet} \begin{rpobjet}{arccercle(,,)}{path} Arc de cercle de sens direct de centre $O$, passant par $A$ et s'appuyant sur la demi-droite $[OB)$. \end{rpobjet} \begin{exemple} repere(-1,5,1cm,-2,8,0.5cm); draw axes(1,1); pair A,M,B; A=(2,2);M=(2,6);B=(3,2); nomme.bot(A);nomme.rt(B);nomme.top(M); draw B--A--M; draw cercle(A,2); draw arccercle(B,A,M); fin; \end{exemple} \subsection{Figures complètes} \label{figcomp} Les figures « complètes » sont des figures composées d'un chemin, du nom des points et éventuellement des cotes et angles. Pour les distinguer des chemins, leur nom commence par une capitale. \begin{rpobjet}{Segment(,)()()}{picture} Figure formée du segment $[AB]$ et des noms des points, et éventuellement des cotes. Les étiquettes sont composées automatiquement mais peuvent être modifiées en passant des valeurs à \verb|(points)| ou \verb|(cote)|. \end{rpobjet} \begin{exemple} repere(); pair A,B,C; A=(0,0);B=(2,-1);C=(4,2); drawoptions(withpen pencircle scaled 1); draw Segment(A,B)()(); draw Segment(C,B)("$E$","")("$\ell$"); fin; \end{exemple} \begin{rpobjet}{Triangle(,,)()()()}{picture} Figure formée du triangle $ABC$ et des noms des points, et éventuellement des cotes et angles. Les étiquettes sont composées automatiquement mais peuvent être modifiées en passant des valeurs à \verb|(points)|, \verb|(cotes)| ou \verb|(angles)|. \end{rpobjet} \begin{exemple} repere(); pair D,E,F; D:=(0,0);E:=(4,1);F:=(2,3); draw Triangle(D,E,F)()()(); fin; \end{exemple} \begin{exemple} repere(); pair D,E,F; D:=(0,0);E:=(4,1);F:=(2,3); angle_cote:=0; draw Triangle(D,E,F)("$A$","$B$","$C$") ("$a$","$b$","$c$") ("$\alpha$","$\beta$","$\gamma$"); fin; \end{exemple} \begin{rpparam} AffPoints & boolean & true & Booléen qui indique si les noms des points doivent être affichés. Les noms sont affichés quelle que soit la valeur de \verb|AffPoints| si le nom est donné explicitement.\\ AffCotes & boolean & false & Booléen qui indique si la cote des segment doit être affichée. La cote est affichée quelle que soit la valeur de \verb|AffCotes| si une cote est donnée explicitement.\\ UnitCotes & string & "" & Chaine de caractère qui indique l'unité à rajouter à la cote lorsqu'elle est composée automatiquement.\\ ArrondiCotes & numeric & 2 & Valeur entière qui indique à quelle décimale la cote doit être arrondie lorsqu'elle est affichée automatiquement.\\ AffAngles & boolean & false & Booléen qui indique si les angles doivent être marqués et leur nom affiché. Les noms sont affichés quelle que soit la valeur de \verb|AffAngles| si le nom est donné explicitement.\\ ArrondiAngles & numeric & 1 & Valeur entière qui indique à quelle décimale l'angle doit être arrondi lorsqu'il est affiché automatiquement.\\ EchelleAngles & numeric & 0.8 & Valeur numérique indiquant le facteur d'échelle de l'affichage des angles.\\ AutoAngleDroit & boolean & false & Booléen qui indique si les angles droits doivent être marqués comme tels. \end{rpparam} \begin{exemple} repere(); pair A,B,C; A=(0,0);B=(2,-1);C=(4,2); drawoptions(withpen pencircle scaled 1); AffCotes:=true; ArrondiCotes:=1;UnitCotes:="cm"; draw Segment(A,B)()(); angle_cote:=0; draw Segment(C,B)("$E$","")("$\ell$"); fin; \end{exemple} Pour les points, cotes ou angles, la chaine \verb|"~"| permet de laisser les valeurs calculées tout en passant d'autres valeurs à l'affichage. \begin{exemple} repere(-1,6,1cm,-4,6,1cm); pair A,B,C,D,E,F,G,H,I; A=(0,3);B=(4,3);C=(3,5); D=(0,0);E=(5,0);F=(2,2); G=(0,-3);H=(5,-3);I=(1,-1); draw quadrillage(1,1); angle_cote:=0;AffCotes:=true; draw Triangle(A,B,C)()()() withcolor blue; AffAngles:=true;angle_cote:=-1; ArrondiCotes:=1;UnitCotes:="cm"; draw Triangle(D,E,F)()()() withcolor red; EchelleAngles:=0.6;AutoAngleDroit:=true; ArrondiAngles:=2;angle_cote:=0; draw Triangle(G,H,I) ("$O$")("$a$","~","$c$")(); fin; \end{exemple} \subsection{Figures définies à l'aide de propriétés géométriques} \subsubsection*{Segments} \begin{rpdeclaration}{defSegmentL(,)(,,)} Définit les points $A$ et $B$ de telle sorte que le segment $[AB]$ mesure \verb|long|, commence à \verb|ptdep| et fasse un angle \verb|angle| avec l'horizontale. Les valeurs \verb|ptdep| et \verb|angle| peuvent être omises, les valeurs par défaut sont respectivement \verb|(0,0)| et \verb|0|. Il n'est pas nécessaire de déclarer les points $A$ et $B$. S'ils existent déjà, leur valeur n'est pas modifiée. \end{rpdeclaration} \begin{exemple} repere(0,5,1cm,0,5,1cm); draw quadrillage(1,1); defSegmentL(A,B)(3,(1,1),70); defSegmentL(B,C)(2); draw A--B--C; nomme.llft(A);nomme.ulft(B); nomme.rt(C); fin; \end{exemple} \begin{rpobjet}{segmentL(,)(,,)}{path} Définit les points $A$ et $B$ comme précédemment et renvoie la ligne \verb|A--B|. \end{rpobjet} \begin{exemple} repere(0,5,1cm,0,3,1cm); draw quadrillage(1,1); draw segmentL(A,B)(3,(1,1),30); nomme.llft(A);nomme.urt(B); fin; \end{exemple} \begin{rpobjet}{SegmentL(,)(,,)()()}{picture} Définit les points $A$ et $B$ comme précédemment et renvoie le segment complet (voir \ref{figcomp}). \end{rpobjet} \begin{exemple} repere(0,5,1cm,0,3,1cm); draw quadrillage(1,1); AffCotes:=true; draw SegmentL(A,B)(3,(1,1),30)()(); fin; \end{exemple} \subsubsection*{Triangles} \begin{rpdeclaration}{defTriangleLLL(,,)(,,,,)} Définit les points $A$, $B$ et $C$ de telle sorte que $AB=\verb|longAB|$, $AC=\verb|longAC|$, $BC=\verb|longBC|$, \verb|A=ptdepart| et l'angle entre $[AB]$ et l'horizontale vaut \verb|angle|. Les valeurs \verb|ptdep| et \verb|angle| peuvent être omises, leurs valeurs par défaut sont respectivement \verb|(0,0)| et \verb|0|. Il n'est pas nécessaire de déclarer les points $A$, $B$ et $C$. Si certains de ces points existent déjà, leur valeur n'est pas modifiée, les autres valeurs sont calculées au mieux. \end{rpdeclaration} \begin{exemple} repere(-1,5,1cm,-1,3,1cm); draw quadrillage(1,1); defTriangleLLL(A,B,C)(4,3,2,10); AffCotes:=true; draw Triangle(A,B,C)()()(); fin; \end{exemple} \begin{rpdeclaration}{defTriangleLLA(,,)(,,,,)} Définit les points $A$, $B$ et $C$ de telle sorte que $AB=\verb|longAB|$, $AC=\verb|longAC|$, $\widehat{BAC}=\verb|angleA|$, \verb|A=ptdepart| et l'angle entre $[AB]$ et l'horizontale vaut \verb|angle|. Les valeurs \verb|ptdep| et \verb|angle| peuvent être omises, leurs valeurs par défaut sont respectivement \verb|(0,0)| et \verb|0|. Il n'est pas nécessaire de déclarer les points $A$, $B$ et $C$. Si certains de ces points existent déjà, leur valeur n'est pas modifiée, les autres valeurs sont calculées au mieux. \end{rpdeclaration} \begin{exemple} repere(-1,5,1cm,-1,3,1cm); draw quadrillage(1,1); defTriangleLLA(A,B,C)(4,3,40); AffCotes:=true;AffAngles:=true; draw Triangle(A,B,C)()("")("~"); fin; \end{exemple} \begin{rpdeclaration}{defTriangleLAA(,,)(,,,,)} Définit les points $A$, $B$ et $C$ de telle sorte que $AB=\verb|longAB|$, $\widehat{BAC}=\verb|angleA|$, $\widehat{CBA}=\verb|angleB|$, \verb|A=ptdepart| et l'angle entre $[AB]$ et l'horizontale vaut \verb|angle|. Les valeurs \verb|ptdep| et \verb|angle| peuvent être omises, leurs valeurs par défaut sont respectivement \verb|(0,0)| et \verb|0|. Il n'est pas nécessaire de déclarer les points $A$, $B$ et $C$. Si certains de ces points existent déjà, leur valeur n'est pas modifiée, les autres valeurs sont calculées au mieux. \end{rpdeclaration} \begin{exemple} repere(-1,5,1cm,-1,3,1cm); draw quadrillage(1,1); defTriangleLAA(A,B,C)(4,40,60); AffCotes:=true;AffAngles:=true; draw Triangle(A,B,C)()("","")("~","~"); fin; \end{exemple} \begin{rpobjet}{triangleLLL(,,)()}{(closed) path} Définit les points $A$, $B$ et $C$ comme précédemment et renvoie la ligne \verb|A--B--C--cycle|. \end{rpobjet} \begin{rpobjet}{TriangleLLL(,,)()()()()}{picture} Définit les points $A$, $B$ et $C$ comme précédemment et renvoie le triangle complet (voir \ref{figcomp}). \end{rpobjet} \begin{exemple} repere(-1,5,1cm,-1,2,1cm); draw quadrillage(1,1); angle_cote:=0; AffCotes:=true;AffAngles:=true; draw TriangleLLL(A,B,C)(4,3,2)()()() withcolor blue; fin; \end{exemple} \begin{rpobjet}{triangleLLA(,,)()}{(closed) path} Définit les points $A$, $B$ et $C$ comme précédemment et renvoie la ligne \verb|A--B--C--cycle|. \end{rpobjet} \begin{rpobjet}{TriangleLLA(,,)()()()()}{picture} Définit les points $A$, $B$ et $C$ comme précédemment et renvoie le triangle complet (voir \ref{figcomp}). \end{rpobjet} \begin{exemple} repere(-1,5,1cm,-1,3,1cm); draw quadrillage(1,1); angle_cote:=0; AffCotes:=true;AffAngles:=true; ArrondiAngles:=2; EchelleAngles:=0.6; draw TriangleLLA(D,E,F)(4,3,45)()()() withcolor red; fin; \end{exemple} \begin{rpobjet}{triangleLAA(,,)()}{(closed) path} Définit les points $A$, $B$ et $C$ comme précédemment et renvoie la ligne \verb|A--B--C--cycle|. \end{rpobjet} \begin{rpobjet}{TriangleLAA(,,)()()()()}{picture} Définit les points $A$, $B$ et $C$ comme précédemment et renvoie le triangle complet (voir \ref{figcomp}). \end{rpobjet} \begin{exemple} repere(-1,6,1cm,-2,3,1cm); draw quadrillage(1,1); angle_cote:=0; AffCotes:=true;AffAngles:=true; ArrondiAngles:=2; EchelleAngles:=0.8; AutoAngleDroit:=true; pair I; I:=(1,2); draw TriangleLAA(G,H,I)(5,60,30,10) ("$O$")("$a$","$b$","~")(); fin; \end{exemple} \begin{rpparam} AffDonnees & string & false & Booléen qui permet de n’afficher que les valeurs des côtés et des angles correspondant aux données. \end{rpparam} \begin{exemple} repere(-1,6,1cm,-5,6,1cm); angle_cote:=0; AffDonnees:=true; draw quadrillage(1,1); draw TriangleLLL(A,B,C)(4,3,2,(0,4))()()() withcolor blue; draw TriangleLLA(D,E,F)(4,3,45) ()()("$\alpha$","$\beta$","$\gamma$") withcolor red; pair I; I:=(1,-2); draw TriangleLAA(G,H,I)(4,60,40,10) ("$O$")("$a$","$b$","~")(); fin; \end{exemple} \subsection{Transformations} Un certain nombre de transformations sont prédéfinies dans \MP{}. Elles sont ici reprises et, parfois, légèrement modifiées, notamment en ce qui concerne la syntaxe. \begin{rpobjet}{translation()()}{pair, path ou picture} Image de \verb|obj| par la translation de vecteur \verb|vect|. \end{rpobjet} \begin{exemple} repere(); pair A,B,C,C',u; path c; u=(1,-2); A=(1,1);B=(2,2);C=(4,2); nomme.ulft(B); c=cercle(B,A);draw c; draw translation(u)(c); C'=translation(u)(C); nomme.urt(C);nomme.urt(C'); drawvecteur(B,u) withcolor red; fin; \end{exemple} \begin{rpobjet}{rotation(,)()}{pair, path ou picture} Image de \verb|obj| par la rotation de centre \verb|pt| et d'angle \verb|ang|. \end{rpobjet} \begin{exemple} repere(); pair A,B,C,B'; A=(2,1);B=(3,3);C=(5,2); nomme.lrt(A);nomme.ulft(B); nomme.urt(C); B'=rotation(A,110)(B); nomme.llft(B'); draw B--A--B'; nomme(B,A,B',"\ang{110}",1); draw marquesegment(B,A,A,B'); path seg; seg:=B--C; draw seg withcolor blue; draw rotation(A,110)(seg) withcolor blue; fin; \end{exemple} \begin{rpobjet}{symetrie()()}{pair, path ou picture} Image de \verb|obj| par la symétrie de centre \verb|pt|. \end{rpobjet} \begin{exemple} repere(); pair C,D,O; path s,c; C=(3,3);D=(1,4); O=(0,2.5); s=C--D; c=cercle(D,1); draw s;draw c; nomme.bot(O) withcolor blue; draw symetrie(O)(s); draw symetrie(O)(c); fin; \end{exemple} \begin{rpobjet}{symetrie(,)()}{pair, path ou picture} Image de \verb|obj| par la symétrie d'axe \verb|(AB)|. \end{rpobjet} \begin{exemple} repere(-4,4,1cm,0,5,1cm); pair C,D,O,I; path s,c; C=(3,3);D=(1,4); O=(1,0);I=(-1,4); s=C--D; c=cercle(D,1); draw s;draw c; draw droite(O,I) withcolor blue; draw symetrie(O,I)(s); draw symetrie(O,I)(c); fin; \end{exemple} \begin{rpobjet}{homothetie(,)()}{pair, path ou picture} Image de \verb|obj| par l'homothétie de centre \verb|pt| et de rapport \verb|rap|. \end{rpobjet} \begin{exemple} repere(); pair O,A,B,C,D; O=(1,1); A=(2,1);B=(3,2);C=(3,3);D=(1,3); path p;p:= polygone(A,B,C,D); nomme.llft(O); draw p; draw homothetie(O,2)(p); fin \end{exemple} \begin{rpobjet}{similitude(,,)()}{pair, path ou picture} Image de \verb|obj| par la similitude de centre \verb|pt|, de rapport \verb|rap| et d’angle \verb|ang|. \end{rpobjet} \bigskip À titre expérimental, on dispose du paramètre suivant qui permet de définir les points créés par l'image d'une figure par transformation. \begin{rpparam} extratransf & string & "" & Chaine qui désigne les caractères à ajouter au nom des points lors du dessin de l'image de certaines figures (notamment \verb|Triangle|, \verb|Segment|) par transformation. La valeur peut être \verb|"'", "''",...| ou un nombre. Les nouveaux points sont créés. \end{rpparam} \begin{exemple}[lefthand ratio=0.55] repere(); extratransf:="'"; pair A,B,C,u; u=(1,-2); A=(1,1);B=(2,2);C=(4,2); draw Triangle(A,B,C)()()(); draw translation(u)(Triangle(A,B,C)()()()); draw B'--C withcolor blue; drawvecteur(A,u) withcolor red; fin; \end{exemple} \begin{exemple}[lefthand ratio=0.55] repere(); extratransf:="1"; pair A,B,C,D,u,O; A=(2,1);B=(3,3);C=(5,2); O=(0,1); nomme.llft(O); draw Triangle(A,B,C)()()() withcolor blue; draw rotation(O,60)(Triangle(A,B,C)()()()) withcolor blue; draw B--O--B1 dashed evenly; fin; \end{exemple} \section{Dessin à main levée} L'idée de dessiner une figure comme si elle était faite à main levée vient de Christophe \bsc{Poulain} dans les macros de \verb|geometriesyr16.mp|\footnote{\url{https://melusine.eu.org/syracuse/poulecl/geometriesyr16/}} . Cette idée est reprise par Toby \bsc{Thurston} dans le document « Drawing with MetaPost »\footnote{\url{https://github.com/thruston/Drawing-with-Metapost/blob/master/Drawing-with-Metapost.pdf}}. Le principe est de modifier le tracé des chemins en changeant légèrement les angles de départ et d'arrivée pour créer une déformation qui rappelle le dessin à main levée. C. \bsc{Poulain} ajoute un angle de \ang{5}. Dans son document, T. \bsc{Thurston} reprend l'idée et ajoute une composante aléatoire. Dans la version proposée ici, la valeur par défaut est aléatoire mais peut être modifiée. \medskip \begin{rpdeclaration}{drawmainlevee} Dessine une figure en représentant les chemins comme s'ils étaient dessinés à main levée \end{rpdeclaration} \begin{exemple}[lefthand ratio=0.6] repere(-0.5,5,1cm,-0.5,5,1cm); pair A,B,C,D; A=(0.5,0.5);B=(4,1);C=(3,4); drawmainlevee axes(1,1); drawmainlevee Triangle(A,B,C)()()() withcolor red; drawmainlevee cercle(A,B,C) withcolor blue; fin; \end{exemple} \begin{rpparam} type_trace & string & "" & Paramètre qui peut prendre la valeur \verb|"mainlevee"| pour indiquer que tous les dessins qui suivent seront faits « à main levée ». Toute autre valeur donne un dessin normal. \end{rpparam} \begin{exemple} repere(-0.5,5,1cm,-0.5,5,1cm); pair A,B,C,D; A=(0.5,0.5);B=(4,1);C=(3,4); draw axes(1,1); type_trace:="mainlevee"; draw Triangle(A,B,C)()()() withcolor red; draw cercle(A,B,C) withcolor blue; fin; \end{exemple} \begin{rpobjet}{mainlevee()}{path ou picture} Transforme le chemin ou la figure en un objet de même nature « dessiné à main levée ». \end{rpobjet} \begin{exemple} repere(-0.5,5,1cm,-0.5,5,1cm); pair A,B,C,D; A=(0.5,0.5);B=(4,1);C=(3,4); draw axes(1,1); picture tri; path cer; tri:=mainlevee(Triangle(A,B,C)()()()); cer:=mainlevee(cercle(A,B,C)); draw tri withcolor red; draw cer withcolor blue; fin; \end{exemple} \begin{rpdeclaration}{anglemainlevee()} Fonction qui permet de définir comment seront dessinés les figures à main levée : le \verb|nombre| sera ajouté à l'angle de départ et à l'angle d'arrivée des chemins pour créer une déformation. \verb|nombre| peut contenir un calcul avec les fonctions \verb|normaldeviate| et \verb|uniformdeviate()|. Au chargement de \verb|repere|, la fonction est appelée de la façon suivante : \verb|anglemainlevee(5*signe(normaldeviate)+normaldeviate);| \end{rpdeclaration} \begin{exemple} repere(-0.5,5,1cm,-0.5,5,1cm); pair A[],B[]; draw axes(1,1); for i=1 upto 4: A[i]:=(1,i);B[i]:=(4,i); nomme.lft(A[i]);nomme.rt(B[i]); endfor draw A[1]--B[1]; drawmainlevee A[2]--B[2]; anglemainlevee(10); drawmainlevee A[3]--B[3]; anglemainlevee(uniformdeviate 20 + 10); drawmainlevee A[4]--B[4]; fin; \end{exemple} \section{Divers} \subsection{Compilation avec \texttt{mpost}} \label{compilmpost} Il est possible de compiler une série de figure dans un document \texttt{mpost}. Chaque figure devra alors débuter par une instruction \verb|repere()| et se terminer par \verb|fin|. Il est possible de placer ces commandes en dehors d'un environnement \verb|beginfig()|-\verb|endfig|, la numérotation est alors automatique et est incrémentée d'une unité à chaque commande \verb|repere|. \bigskip \begin{minipage}[c]{0.33\linewidth} \begin{codempost} beginfig(2); repere(...); fin; endfig; \end{codempost} \end{minipage} \hfill \begin{minipage}[c]{0.6\linewidth} La figure porte le numéro 2 \end{minipage} \bigskip \begin{minipage}[c]{0.33\linewidth} \begin{codempost} repere(...); fin; \end{codempost} \end{minipage} \hfill \begin{minipage}[c]{0.6\linewidth} La numérotation est automatique. La figure porte le numéro qui suit la figure précédemment dessinée. S'il s'agit de la première, elle porte le numéro 1. \end{minipage} \subsection{Composition des étiquettes} Tous les textes et étiquettes peuvent être composés en utilisant la macro ci-dessous. \begin{rpobjet}{LaTeX()}{picture} \label{latex} Figure formée de la chaîne \verb+ch+ composée avec \LaTeX{} et mise à l'échelle \verb|defaultscale|. Cette macro utilise la commande \verb|textext| de \verb|luamplib| dans le cas de l'utilisation de Lua\LaTeX{} et \verb|textext| de \verb|latexmp| dans le cas d'une compilation \MP{} \og standard \fg. Ce dernier cas nécessite alors deux compilations. \end{rpobjet} \begin{exemple}[lefthand ratio=0.65] repere(-1,7,1cm,-1,1,1cm); for i=2 upto 6: label(LaTeX("$\frac{1}{"&decimal(i)&"}$"),(i,0)); endfor fin; \end{exemple} \begin{rplabel}{label.(,)} Commande de \MP{} qui permet de placer la figure \verb|fig| au niveau du point \verb|point|. \end{rplabel} \begin{exemple}[lefthand ratio=0.55] repere(-1,5,1cm,-1,4,1cm); draw axes(1,1); label.ulft("Abscisses",(5,0.1)); label.lrt("Ordonnées",(0.1,4)); label("$f(x)=\pi^2\sqrt{x}$",(2,2)); fin; \end{exemple} \begin{rplabel}{legende.(,

)} Figure formée du chemin \verb|p| dessiné avec une flèche et de la figure ou de la chaine \verb|fig| située à la position \verb|pos| par rapport au premier point du chemin. \end{rplabel} \begin{exemple}[lefthand ratio=0.6] repere(-0.5,5,1cm,-0.5,4,1cm); draw axes(1,1); pair A,B; A=(2,1);B=(2,2); nomme.rt(A) withcolor red; nomme.top(B) withcolor red; legende.top("Le point $A$",(1,3){down}..{down}A); legende.bot("Le point $B$",(4,1)--B); fin; \end{exemple} \subsection{Couleurs} Certaines couleurs sont définies par leur nom et peuvent être utilisées directement : \begin{center} \begin{mplibcode} repere(0,18,1cm,-3,1,1cm); path rectangle; save a,b,dech,decv; a:=25;b:=12;dech:=70;decv:=-20; rectangle = ((0,0)--(a,0)--(a,b)--(0,b)--cycle) transformed inverse _T; vardef couleur(expr t)= image(% fill rectangle withcolor scantokens(t); label.rt(LaTeX("\smash{" & t & "}"),(a,b/4) transformed inverse _T) ) enddef; draw couleur("rouge"); draw couleur("vert") shifted (dech,0); draw couleur("bleu") shifted (2*dech,0); draw couleur("cyan") shifted (3*dech,0); draw couleur("magenta") shifted (4*dech,0); draw couleur("jaune") shifted (5*dech,0); draw couleur("noir") shifted (6*dech,0); draw couleur("marron") shifted (0,decv); draw couleur("lime") shifted (dech,decv); draw couleur("orange") shifted (2*dech,decv); draw couleur("rose") shifted (3*dech,decv); draw couleur("pourpre") shifted (4*dech,decv); draw couleur("olive") shifted (5*dech,decv); draw couleur("violet") shifted (6*dech,decv); draw couleur("beige") shifted (0,2decv); draw couleur("marine") shifted (dech,2decv); draw couleur("moutarde") shifted (2*dech,2decv); draw couleur("grisclair") shifted (3*dech,2decv); draw couleur("gris") shifted (4*dech,2decv); draw couleur("grisfonce") shifted (5*dech,2decv); draw couleur("vertfonce") shifted (6*dech,2decv); fin; \end{mplibcode} \end{center} Toutes ces couleurs sont définies selon le modèle \og rgb \fg. Pour les obtenir selon le modèle \og cmyk \fg, remplacer la première lettre par une majuscule. \subsection{Remplissage} \begin{rpdeclaration}{avec} Pour remplir des chemins fermés avec autre chose que de la couleur, \verb+repere+ permet l'utilisation de la syntaxe \verb+fill p avec motif+ où \verb+motif+ est un des motifs décrits ci-dessous ou même une figure quelconque. Cette instruction peut être complétée par des options de dessin (\verb+withpen+, \verb+withcolor+...). \end{rpdeclaration} \begin{rpobjet}{hachures(,)}{picture} Hachures espacées de \verb+pas+ et formant un angle en degrés de \verb+angle+ avec l'horizontale. Si les valeurs sont omises, \verb|pas| vaut 5 et \verb+angle+ vaut 60. \end{rpobjet} \begin{exemple}[lefthand ratio=0.51] repere(); path c[]; c1=fullcircle scaled 3; c2=c1 shifted (3.5,0); fill c1 withcolor lime; fill c1 avec hachures(10,30) dashed evenly; fill c2 withcolor lime; fill c2 avec hachures(); draw c1;draw c2; fin; \end{exemple} \begin{rpobjet}{briques(,,)}{picture} briques de largeur \verb+larg+, de hauteur \verb+haut+ et décalées d'une ligne à l'autre de \verb+dec+. Si les valeurs sont omises, \verb|larg| vaut 12, \verb|haut| vaut 6 et \verb+dec+ vaut 6. \end{rpobjet} \begin{exemple} repere(); path c[]; c1=fullcircle scaled 3; c2=c1 shifted (3.5,0); fill c1 withcolor (0,0.65,0.8,0.48); fill c1 avec briques(15,5,4); fill c2 withcolor (0,0.65,0.8,0.48); fill c2 avec briques(); draw c1;draw c2; fin; \end{exemple} \begin{rpobjet}{vagues(,,)}{picture} \og Vagues \fg{} de période \verb+per+, d'amplitude \verb+amp+ et décalées d'une ligne à l'autre de \verb+dec+ (d'après le manuel de l'utilisateur). Si les valeurs sont omises, \verb|per| vaut 20, \verb|amp| vaut 3 et \verb+dec+ vaut 10. \end{rpobjet} \begin{exemple} repere(); path c[]; c1=fullcircle scaled 3; c2=c1 shifted (3.5,0); fill c1 withcolor (1,0,0,0.2); fill c1 avec vagues(30,10,20) withpen pencircle scaled 2; fill c2 withcolor (1,0,0,0.2); fill c2 avec vagues(); draw c1;draw c2; fin; \end{exemple} \subsection{Couleur de fond} Il est possible de modifier la couleur de fond en modifiant la couleur \verb|fond_coul|. \begin{rpparam} fond_coul & color & white & Couleur du fond de la figure \end{rpparam} \begin{exemple} repere(-3.5,3.5,1cm,-3.5,3.5,1cm); fond_coul:=(0.9,0.9,1); setquad(-3,3,-3,3); draw quadrillage(1,1); draw axes(1,1); fin; \end{exemple} \subsection{Francisation} Quelques mot-clefs ont été traduits. \par\medskip \begin{center} \begin{longtblr}[label=none,caption={}]{ rowhead=2, verb, hlines={2pt,white}, columns={c}, row{1}=white, row{2-Z}={bg=CoulParam!5!white,m}, row{3-Z}={cmd=\bfseries\testparam} } \SetCell[c=2]{c} Mots-clefs \\ Nom français & Nom original \\ couleur & withcolor \\ epaisseur & withpen pencircle scaled \\ \end{longtblr} \end{center} \bigskip \newpage \part{Tableaux et grilles} Il est possible d'utiliser \verb|repere| pour représenter des tableaux ou « damiers » et placer des objets dans chacune des cases. La figure devra alors débuter par une commande \verb|tableau| au lieu de la commande \verb|repere| et la numérotation sera automatique. \section{Définition et grilles} \subsection{Définition du tableau} \begin{rpdeclaration}{tableau(,,)} Débute une figure et définit un tableau de $n$ colonnes et $m$ lignes. La largeur des colonnes est égale à la hauteur des lignes et vaut \verb|u|. \end{rpdeclaration} \begin{rpdeclaration}{tableau(,,,)} Débute une figure et définit un tableau de $n$ colonnes et $m$ lignes. La largeur des colonnes vaut \verb|ux| et la hauteur des lignes vaut \verb|uy|. \end{rpdeclaration} \begin{rpdeclaration}{fin} Termine la figure. \end{rpdeclaration} \subsection{Grille} \begin{rpobjet}{grille(,)}{picture} Quadrillage avec un pas de \verb|x| sur les colonnes et de \verb|y| sur les lignes. \end{rpobjet} \begin{exemple} tableau(6,6,0.5cm); draw grille(1,1); fin; \end{exemple} \bigskip La couleur et l'épaisseur des lignes peuvent être modifiées localement mais on peut aussi les changer globalement. \begin{rpparam} grille_coul & color & black & Couleur des traits de la grille \\ grille_ep & numeric & 0.7 & Épaisseur des traits de la grille \\ \end{rpparam} \begin{exemple}[lefthand ratio=0.51] tableau(8,8,0.5cm); draw grille(1,1) couleur olive; draw grille(2,2) couleur olive epaisseur 2; fin; \end{exemple} \begin{exemple}[lefthand ratio=0.51] tableau(8,8,0.5cm); grille_coul:=olive; draw grille(1,1); grille_ep:=2; draw grille(2,2); fin; \end{exemple} \begin{rpobjet}{damier(,)}{picture} Figure formée de la grille et des cases coloriées alternativement. \end{rpobjet} \begin{exemple} tableau(5,5,1cm); draw damier(1,1); fin; \end{exemple} \begin{rpparam} table_coul[1] & color & 0.45white & Couleur de la case située en bas à gauche \\ table_coul[2] & color & 0.9white & Couleur de la case située à côté de la précédente \\ \end{rpparam} \begin{exemple} tableau(5,5,1cm); table_coul[1]:=jaune; table_coul[2]:=0.7rouge; draw damier(1,1); fin; \end{exemple} \subsection{Grille partielle} \begin{rpobjet}{lignesh()}{picture} Figure qui décrit les lignes horizontales qui doivent être tracées. De gauche à droite et de haut en bas. \end{rpobjet} \begin{rpobjet}{lignesv()}{picture} Figure qui décrit les lignes verticales qui doivent être tracées. De gauche à droite et de haut en bas. \end{rpobjet} \begin{exemple} tableau(3,3,1cm); draw grille(1,1); draw lignesh(1,1,1, 1,0,1, 0,1,0, 1,1,1) epaisseur 3; draw lignesv(1,0,0,1, 1,1,1,1, 1,0,1,1) epaisseur 3; fin; \end{exemple} \section{Repérage et cases} \subsection{Coordonnées} \begin{rpobjet}{coordx}{picture} Figure formée des numéros de colonnes placée par défaut en bas. \end{rpobjet} \begin{rpobjet}{coordy}{picture} Figure formée des numéros de lignes placée par défaut à gauche. \end{rpobjet} \begin{rpobjet}{coord}{picture} Figure formée des deux figures précédentes. \end{rpobjet} \begin{exemple} tableau(5,5,1cm); draw grille(1,1); draw coord; fin; \end{exemple} \begin{rpparam} style_coord_x & string & "1" & Variable qui indique comment doivent être composées les coordonnées des colonnes. Les valeurs possibles sont \verb|"1"| (nombres), \verb|"a"| (lettres minuscules), \verb|"A"| (lettres majuscules), \verb|"i"| (chiffres romains minuscules) et \verb|"I"| (chiffres romains majuscules).\\ style_coord_y & string & "1" & Même chose pour les lignes.\\ deb_coord_x & numeric & 1 & Variable qui indique la première valeur des colonnes. \\ deb_coord_y & numeric & 1 & Variable qui indique la première valeur des lignes. \\ align_coord_y & string & "c" & Variable qui indique comment doivent être alignés horizontalement les numéros de lignes. Les valeurs possibles sont \verb|"c"| (centré), \verb|"g"| ou \verb|"l"| (gauche) et \verb|"d"| ou \verb|"r"| (droite).\\ place_coord & string & "bg" & Variable qui indique où les coordonnées doivent être affichées. On peut utiliser une combinaison des lettres \verb|"b"| (en bas), \verb|"h"| (en haut), \verb|"g"| (à gauche) et \verb|"d"| (à droite).\\ inverse_coord_x & boolean & false & Variable qui indique si le sens par défaut dans lequel les numéros de colonnes doivent être écrits (de gauche à droite) doit être inversé.\\ inverse_coord_y & boolean & false & Variable qui indique si le sens par défaut dans lequel les numéros de lignes doivent être écrits (de bas en haut) doit être inversé.\\ \end{rpparam} \begin{exemple} tableau(5,5,1cm); draw grille(1,1); style_coord_x:="a"; style_coord_y:="I"; deb_coord_x:=5; deb_coord_y:=3; draw coord; fin; \end{exemple} \begin{exemple} tableau(5,5,1cm); draw grille(1,1); style_coord_x:="A"; style_coord_y:="I"; place_coord:="hg"; inverse_coord_y:=true; align_coord_y:="r"; draw coord; fin; \end{exemple} \begin{rpobjet}{numerotationdames}{picture} Figure formée par les numéros des cases comme au jeu de dames. \end{rpobjet} \begin{exemple} tableau(10,10,0.7cm); draw damier(1,1); draw numerotationdames; fin; \end{exemple} \subsection{Placement d'objets dans les cases} \begin{rpobjet}{case(,)}{picture} Figure formée de la case de coordonnées \verb|(x,y)| remplie ainsi que de son contour dessiné avec l'épaisseur et la couleur de la grille. \end{rpobjet} \begin{rpobjet}{cases((,),(,),...)}{picture} Toutes les cases \verb|(x1,y1)|, \verb|(x2,y2)|... \end{rpobjet} \begin{exemple}[lefthand ratio=0.6] tableau(5,5,1cm); draw damier(1,1); draw coord; draw case(2,4) couleur rouge; draw cases((1,2),(3,3),(5,1)) couleur bleu; fin; \end{exemple} On peut utiliser une variante de \verb|label| pour placer des objets dans les cases : \begin{rplabel}{tablabel(,,)} Place l'objet \verb|obj| dans la case de coordonnées \verb|(x,y)|. L'objet peut être une chaine de caractère, un chemin ou une figure. \end{rplabel} \begin{rplabel}{tablabels()((,),(,)...)} Place l'objet \verb|obj| dans toutes les cases indiquées. \end{rplabel} \begin{exemple}[lefthand ratio=0.6] tableau(8,8,0.6cm); draw grille(1,1); draw coord; tablabel(fullcircle scaled 0.8,5,3); tablabels("X")((3,4),(6,1),(2,2)) couleur vert; for i=5 upto 8: for j=5 upto 8: tablabel(decimal(i*j),i,j) couleur bleu; endfor endfor fin; \end{exemple} \begin{exemple} tableau(5,5,0.8cm); draw grille(1,1); inverse_coord_x:=true; inverse_coord_y:=true; deb_coord_x:=3; deb_coord_y:=4; draw coord; tablabels("X")((3,4),(6,7),(4,8)); fin; \end{exemple} \section{Pixel art} Il est possible d'utiliser les tableaux pour dessiner des figures en pixel art. \begin{rpobjet}{pixart( ou )}{picture} Figure composée de carrés remplis d'une couleur qui est soit la couleur indiquée explicitement soit une couleur qui dépend de l'entier indiqué (celles-ci sont définies au départ mais peuvent être modifiées). On peut remplacer un entier par \verb|_| pour que la case ne soit pas remplie. Les pixels doivent être donnés de gauche à droite et de haut en bas. \end{rpobjet} \begin{exemple} tableau(3,3,1cm); draw pixart(0,1,2, 3,4,5, 6,7,_); fin; \end{exemple} \begin{exemple} tableau(3,3,1cm); fond_coul:=grisclair; draw pixart(0,1,2, 3,4,5, 6,7,_); fin; \end{exemple} \begin{exemple} tableau(3,3,1cm); draw pixart(blanc,noir,rouge, vert,bleu,cyan, magenta,jaune,_); fin; \end{exemple} \begin{rpdeclaration}{pixcoul()} Macro qui permet de définir les couleurs qui seront utilisées. La première correspond à 0, la deuxième à 1... Au départ la macro est appelée de la façon suivante : \qquad \verb|pixcoul(blanc,noir,rouge,vert,bleu,cyan,magenta,jaune);| \end{rpdeclaration} \begin{exemple} tableau(3,3,1cm); pixcoul(marron,lime,orange,rose, pourpre,olive,violet,beige); draw pixart(0,1,2, 3,4,5, 6,7,_); fin; \end{exemple} \begin{rpparam} pixart_ep & numeric & 0.3 & Écart laissé vide entre les cases. \end{rpparam} \begin{exemple} tableau(3,3,1cm); pixart_ep:=2; draw pixart(0,1,2, 3,4,5, 6,7,_); fin; \end{exemple} \section{Quelques dessins} \begin{center} \begin{longtblr}[label=none,caption={}]{ rowhead=1, verb, hlines,vlines, columns={c}, % row{1}=white, row{2-Z}={m,ht=1.5cm}, column{1-2}={wd=5.5cm}, cell{2-Z}{3}={wd=4cm,cmd=\decfig}, cell{2-Z}{1-2}={cmd=\desstab}, } Syntaxe & Exemple & Résultat \\ Pion()(,) & Pion(1)(noir,0.85blanc) & \begin{mplibcode} tableau(1,1,2cm); draw Pion(1)(noir,0.85blanc); fin; \end{mplibcode} \\ & Pion(1)(0.9blanc,noir) & \begin{mplibcode} tableau(1,1,2cm); draw Pion(1)(0.9blanc,noir); fin; \end{mplibcode} \\ & Pion(2)(noir,0.85blanc) & \begin{mplibcode} tableau(1,1,2cm); draw Pion(2)(noir,0.85blanc); fin; \end{mplibcode} \\ & Pion(2)(0.9blanc,noir) & \begin{mplibcode} tableau(1,1,2cm); draw Pion(2)(0.9blanc,noir); fin; \end{mplibcode} \\ Dame()(,) & Dame(1)(noir,0.85blanc) & \begin{mplibcode} tableau(1,1,2cm); draw Dame(1)(noir,0.85blanc); fin; \end{mplibcode} \\ & Dame(1)(0.9blanc,noir) & \begin{mplibcode} tableau(1,1,2cm); draw Dame(1)(0.9blanc,noir); fin; \end{mplibcode} \\ & Dame(2)(noir,0.85blanc) & \begin{mplibcode} tableau(1,1,2cm); draw Dame(2)(noir,0.85blanc); fin; \end{mplibcode} \\ & Dame(2)(0.9blanc,noir) & \begin{mplibcode} tableau(1,1,2cm); draw Dame(2)(0.9blanc,noir); fin; \end{mplibcode} \\ Croix & & \begin{mplibcode} tableau(1,1,2cm); draw Croix; fin; \end{mplibcode} \\ Trou & & \begin{mplibcode} tableau(1,1,2cm); draw Trou; fin; \end{mplibcode} \\ Marque()() & Marque(1)((0.9,0.7,0.7)) & \begin{mplibcode} tableau(1,1,2cm); draw Marque(1)((0.9,0.7,0.7)); fin; \end{mplibcode} \\ & Marque(2)((0.8,0.65,0.5)) & \begin{mplibcode} tableau(1,1,2cm); draw Marque(2)((0.8,0.65,0.5)); fin; \end{mplibcode} \\ Mur(,) & Mur(rouge,noir) & \begin{mplibcode} tableau(1,1,2cm); draw Mur(rouge,noir); fin; \end{mplibcode} \\ Plot(,) & Plot(0.7rouge,0.5rouge) & \begin{mplibcode} tableau(1,1,2cm); draw Plot(0.7rouge,0.5rouge); fin; \end{mplibcode} \\ Caisse(,) & Caisse(orange,marron) & \begin{mplibcode} tableau(1,1,2cm); draw Caisse(orange,marron); fin; \end{mplibcode} \\ Robotdroite(,) & Robotdroite(noir,0.6vert) & \begin{mplibcode} tableau(1,1,2cm); draw Robotdroite(noir,0.6vert); fin; \end{mplibcode} \\ Robotgauche(,) & Robotgauche(marine,0.6rouge) & \begin{mplibcode} tableau(1,1,2cm); draw Robotgauche(marine,0.6rouge); fin; \end{mplibcode} \\ Bateau(,) & Bateau(1,violet) & \begin{mplibcode} tableau(1,1,2cm); draw Bateau(1,violet); fin; \end{mplibcode} \\ & Bateau(2,marron) & \begin{mplibcode} tableau(1,1,2cm); draw Bateau(2,marron); fin; \end{mplibcode} \\ Eau() & Eau(marine) & \begin{mplibcode} tableau(1,1,2cm); draw Eau(marine); fin; \end{mplibcode} \\ Fleche(,) & Fleche(jaune,marine) & \begin{mplibcode} tableau(1,1,2cm); draw Fleche(jaune,marine); fin; \end{mplibcode} \\ \end{longtblr} \end{center} \section{Exemples} \subsection{Mots croisés} \begin{exemple} def moth(expr ch,n,m)= for i=1 upto length ch: tablabel(substring(i-1,i) of ch,n+i-1,m); endfor enddef; tableau(8,8,0.8cm); draw grille(1,1); inverse_coord_y:=true; style_coord_y:="I"; place_coord:="hg"; draw coord; draw cases((3,3),(3,5),(2,7),(6,6),(7,4)); moth("OMELETTE",1,2); moth("AMIES",4,3); fin; \end{exemple} \subsection{Sudokus} \begin{exemple} tableau(9,9,0.8cm); draw grille(1,1); draw grille(3,3) epaisseur 2; tablabels("1",(1,4),(4,8),(6,5),(7,3)); tablabels("2",(3,9),(5,6),(6,2)); tablabels("3",(1,1),(4,2),(9,6)); tablabels("4",(3,8),(8,7)); tablabels("5",(2,7),(4,9),(6,6),(7,1)); tablabels("6",(2,4),(5,8)); tablabels("7",(6,3),(7,2),(8,9),(9,5)); tablabels("8",(1,3),(3,7),(5,5),(8,8)); tablabels("9",(3,2)); fin; \end{exemple} \subsection{Dames} \begin{exemple} tableau(10,10,0.8cm); picture pionblanc,pionnoir,dameblanche; picture fleche; pionblanc:=Pion(2)(0.9blanc,noir); pionnoir:=Pion(2)(noir,0.85blanc); dameblanche:=Dame(2)(0.9blanc,noir); table_coul[1]:=0.7marron+0.3blanc; table_coul[2]:=beige; fleche:=Fleche(rouge,noir) rotated 135; draw damier(1,1); draw numerotationdames; tablabels(pionblanc,31,36,39); tablabels(pionnoir,3,7,16,19,23,30); tablabels(dameblanche,15); tablabel(fleche,5.5,5.5); fin; \end{exemple} \subsection{Bataille navale} \begin{exemple}[listing above text] tableau(10,10,0.8cm); draw grille(1,1); inverse_coord_y:=true; style_coord_x:="A"; place_coord:="hg"; draw coord; tablabel(Bateau(4,marron),5.5,3); tablabel(Bateau(3,0.5vert),7,8); tablabel(Bateau(3,0.5vert) rotated 90,2,9); tablabels(Bateau(1,violet),(4,10),(3,5),(8,1),(9,4)); tablabels(Eau(marine),(2,7),(3,7),(4,9),(4,2),(5,2)); tablabels(Croix,(5,3),(8,8)); fin; \end{exemple} \subsection{Algoréa} \begin{exemple}[listing above text] tableau(13,5,1cm); table_coul[1]:=(1,0.9,0.7); table_coul[2]:=(1,0.9,0.7); draw damier(1,1); tablabels(Mur(0.8rouge,noir),(1,2),(1,3),(1,4),(13,2),(13,3),(13,4)); for i=1 upto 13: tablabels(Mur(0.8rouge,noir),(i,1),(i,5)); endfor tablabel(Robotdroite(noir,0.7vert),2,2); for i=4,6,7,10,12: tablabel(Caisse(orange,marron),i,3); tablabel(Marque(2)((0.8,0.65,0.5)),i,4); endfor fin; \end{exemple} \subsection{Pixel art} \begin{exemple} tableau(11,8,0.4cm); pixart_ep:=0; draw pixart(0,0,1,0,0,0,0,0,1,0,0, 0,0,0,1,0,0,0,1,0,0,0, 0,0,1,1,1,1,1,1,1,0,0, 0,1,1,0,1,1,1,0,1,1,0, 1,1,1,1,1,1,1,1,1,1,1, 1,0,1,1,1,1,1,1,1,0,1, 1,0,1,0,0,0,0,0,1,0,1, 0,0,0,1,1,0,1,1,0,0,0); fin; \end{exemple} \begin{exemple} tableau(14,15,0.3cm); pixart_ep:=0; color b,n,v,r,c; b:=blanc;n:=noir;v:=0.6vert; r:=0.7rouge;c:=(1,0.2,0.2); draw pixart(_,_,_,_,_,_,_,_,_,_,_,n,n,_, _,_,_,_,_,_,_,_,_,_,n,v,v,n, _,_,_,_,_,_,_,n,n,n,n,v,v,n, _,_,_,_,_,_,n,v,v,v,v,v,n,_, _,_,_,_,_,n,v,n,n,n,v,n,_,_, _,_,n,n,n,v,n,_,_,n,v,n,_,_, _,n,c,c,v,c,n,_,n,v,n,_,_,_, n,c,c,c,c,c,c,n,v,n,n,_,_,_, n,c,c,c,c,c,n,c,v,c,c,n,_,_, n,c,b,c,c,n,c,c,v,c,c,c,n,_, n,c,c,b,r,n,c,c,c,c,c,c,n,_, _,n,r,r,r,n,c,c,c,c,c,r,n,_, _,_,n,n,n,n,c,c,c,b,r,r,n,_, _,_,_,_,_,_,n,r,r,r,r,n,_,_, _,_,_,_,_,_,_,n,n,n,n,_,_,_ ); fin; \end{exemple} \end{document}