Info file: asy-faq.info, -*-Text-*- produced by bfnnconv.pl from the Bizarre Format With No Name. INFO-DIR-SECTION Languages START-INFO-DIR-ENTRY * asymptote FAQ: (asy-faq). Asymptote Frequently Asked Questions. END-INFO-DIR-ENTRY  File: asy-faq.info, Node: Top, Next: Question 1.1, Up: (dir) ASYMPTOTE FREQUENTLY ASKED QUESTIONS 2024-03-23 This is the list of Frequently Asked Questions about Asymptote (asy). Index * Menu: * Section 1:: About Asymptote * Section 2:: Questions about installation and setup * Section 3:: Questions about paths * Section 4:: Questions about labels * Section 5:: Questions about arrows * Section 6:: Questions about 2D graphs * Section 7:: Questions about programming * Section 8:: Questions about differences between Asymptote and MetaPost * Section 9:: Questions about output Section 1, About Asymptote * Question 1.1:: What is Asymptote? * Question 1.2:: How do I obtain Asymptote? * Question 1.3:: Where can I ask questions about Asymptote? * Question 1.4:: Why was the name Asymptote chosen? * Question 1.5:: In the internal Asymptote source code, what does the name camp refer to? Section 2, Questions about installation and setup * Question 2.1:: Is it possible to install Asymptote on Mac OS X? * Question 2.2:: Why do I get the error Bad CPU type in executable on installing Asymptote from the MAC OS binary? * Question 2.3:: What do I do if I get the error: Error: pdfetex (file pdftex.cfg): cannot open config file...texinfo.tex appears to be broken? * Question 2.4:: What do I do if I get the error: ! Undefined control sequence. l.6 @copying? * Question 2.5:: Is it possible to integrate Asymptote into LaTeX? * Question 2.6:: Is it possible to integrate Asymptote into latex or pdflatex? * Question 2.7:: Do I need the tkinter package to install an Asymptote rpm binary? * Question 2.8:: What does the path %USERPROFILE%\.asy\config.asy mean? * Question 2.9:: Why do I get the error "string not terminated" when I try to set settings.dir="C:\asymptote\";? * Question 2.10:: How do I change environment variables in Microsoft Windows, for example, in order to change the default PostScript viewer? * Question 2.11:: Under Microsoft Windows XP, why do I get an error like "Invalid Parameter - 432x432"? * Question 2.12:: Why does Asymptote freeze upon trying to draw a label with my MikTex installation under Microsoft Windows? Section 3, Questions about paths * Question 3.1:: Why do I get a syntax error message when I specify an integer value for the path tension? * Question 3.2:: Shouldn't dots always be the same size? Section 4, Questions about labels * Question 4.1:: How do I get Greek letters like omega to show up in my labels? * Question 4.2:: Can Asymptote use matrices as labels? * Question 4.3:: How do I tell Asymptote to load a particular LaTeX package, like mathptmx? * Question 4.4:: How can I use international fonts in Asymptote labels? * Question 4.5:: How can I use Fourier fonts? * Question 4.6:: Is there any way to change the default appearance of the decimal separator, using a comma instead of a dot? * Question 4.7:: How can I get a rotated label with the filled box rotated as well so that it fits the text? * Question 4.8:: How can I rotate labels in a 3D figure? * Question 4.9:: How can I draw some squares and circles of a fixed size and put a label in the middle of them? * Question 4.10:: The binary operator * can be used to scale the color of a pen by a real number. Does this scaling factor have to be less than 1? * Question 4.11:: Why is the space after the comma decimal separator in my locale so large? * Question 4.12:: How can I prevent texpreamble("\usepackage[pdftex]{hyperref}") from changing the page size? Section 5, Questions about arrows * Question 5.1:: How do I draw two arrows at arbitrary positions along a path? * Question 5.2:: How do I reverse the direction of an arrowhead? * Question 5.3:: How do I change the size of all arrows? * Question 5.4:: Can I create other arrowhead styles? Section 6, Questions about 2D graphs * Question 6.1:: How can I draw x axis ticks on the right side, with the tick labels on the left side (relative to the axis path)? * Question 6.2:: How can I reposition the x axis label to three-quarters along the axis length? * Question 6.3:: How can I move the x axis label down 10bp? * Question 6.4:: Can I use different pens for the axis, the axis label, and the tick labels? * Question 6.5:: How can I change the font type of the axes label? * Question 6.6:: How can I change the font type of the tick labels on an axis? * Question 6.7:: How can I prevent axes tick labels from rendering on top of each other? * Question 6.8:: How do I make the plot region of a graph, ignoring labels and legends, have a fixed size? * Question 6.9:: How can I plot a function f(x) within [0,1]x[0,2] without explicitly calculating the x values for which f(x) hits the boundary? * Question 6.10:: Is it possible to define customized palettes? * Question 6.11:: Is there an easy way to graph factorial functions nicely? * Question 6.12:: How do I indicate that a certain length should be exactly the size I prescribe with no rescaling, within a picture which has its own size? * Question 6.13:: How can I make the y axis display base-2 logarithmic values? * Question 6.14:: How can I align the x axes of two graphs on the same figure? * Question 6.15:: How can I change the direction of the y-axis, such that negatives values are on the upper y-axis? * Question 6.16:: How can I fill a path with a function that defines the color of each location? * Question 6.17:: Is there a way to draw a function that is not explicitly given, such as (y - 2)^2 = x - 1 ? * Question 6.18:: Is it possible to reverse or stretch an axis? * Question 6.19:: Why can't I use the UnFill option to draw graphs with empty markers? * Question 6.20:: How can I force several images to use the same palette range (e.g. the entire 0-255 grayscale range)? Section 7, Questions about programming * Question 7.1:: Is Asymptote an interpreter or a compiler? * Question 7.2:: What is the difference between a frame and a picture? * Question 7.3:: What is the difference between a path and a guide? * Question 7.4:: What is a convenient way to declare and initialize an array of pictures? * Question 7.5:: Is there a way to define functions that act on arrays in general (i.e. work for arrays of any type)? * Question 7.6:: Is there any way to declare structures ahead of their definition, e.g. where struct A performs some operation on struct B, but B contains an A member? * Question 7.7:: Where are static variables in for loops allocated? * Question 7.8:: Is there a debugger for asy? * Question 7.9:: Do you accept patches for Asymptote? Section 8, Questions about differences between Asymptote and MetaPost * Question 8.1:: What is the equivalent of the MetaPost c[a,b] interpolation operator? * Question 8.2:: How does picture scaling differ in Asymptote and MetaPost? * Question 8.3:: How can I avoid automatic scaling of a picture? * Question 8.4:: What is the equivalent of MetaPost ... command? * Question 8.5:: What is the equivalent of the MetaPost pickup command? * Question 8.6:: What is the equivalent of the MetaPost whatever command? * Question 8.7:: What is the equivalent for the MetaPost command for lray - horiz*v - verti*u = whatever*(LightSource - R), a system of three linear equations for three unknowns: horiz, verti, whatever? * Question 8.8:: In MetaPost, it is possible to have a drawing remain the same size in different pictures by defining a unit u and explicitly multiply all the coordinates by u. Is there a better way to do this in Asymptote? * Question 8.9:: In MetaPost, one could produce tiling pictures by generating a picture, and then clipping the picture to a rectangle of fixed dimensions around the center of the picture. How is that done in Asymptote? Section 9, Questions about output * Question 9.1:: How can I disable automatic invocation of the PS viewer after an asy file is done processing? * Question 9.2:: How do I output jpeg images? * Question 9.3:: Can I embed bitmaps (photos) into my drawings and position and scale them? * Question 9.4:: Does Asymptote support direct PDF output? * Question 9.5:: How to I produce large pictures of high quality in raster format (e.g. png, giff etc). * Question 9.6:: Is it possible to produce multi-page documents with asymptote?  File: asy-faq.info, Node: Section 1, Next: Section 2, Previous: Top, Up: Top About Asymptote * Menu: * Question 1.1:: What is Asymptote? * Question 1.2:: How do I obtain Asymptote? * Question 1.3:: Where can I ask questions about Asymptote? * Question 1.4:: Why was the name Asymptote chosen? * Question 1.5:: In the internal Asymptote source code, what does the name camp refer to?  File: asy-faq.info, Node: Question 1.1, Next: Question 1.2, Previous: Top, Up: Section 1 Question 1.1. What is Asymptote? Asymptote is a vector graphics language designed for technical graphics, inspired by MetaPost but with IEEE floating-point numerics, native three-dimensional graphics, Grayscale/RGB/CMYK colourspaces, and a C++-like syntax. Unlike MetaPost, it natively supports multiple-segment paths (and hence regions other than simply connected ones), tiling patterns, Gouraud shading, tensor patch shading, and PostScript images.  File: asy-faq.info, Node: Question 1.2, Next: Question 1.3, Previous: Question 1.1, Up: Section 1 Question 1.2. How do I obtain Asymptote? Binary releases are available for Linux, MacOS X, and Microsoft Windows platforms, in addition to full source code, from the website https://asymptote.sourceforge.io/. Many Linux distributions (such as RedHat and Debian) now include an Asymptote package (check your distribution's documentation for further information about this).  File: asy-faq.info, Node: Question 1.3, Next: Question 1.4, Previous: Question 1.2, Up: Section 1 Question 1.3. Where can I ask questions about Asymptote? If you have a question, please try to find an answer in this FAQ, in the extensive Asymptote documentation at https://asymptote.sourceforge.io/doc/, or search the forum: http://sourceforge.net/forum/forum.php?forum_id=409349.  File: asy-faq.info, Node: Question 1.4, Next: Question 1.5, Previous: Question 1.3, Up: Section 1 Question 1.4. Why was the name Asymptote chosen? Well, it isn't the perfect graphics package, but we do think it is getting there asymptotically...  File: asy-faq.info, Node: Question 1.5, Next: Question 2.1, Previous: Question 1.4, Up: Section 1 Question 1.5. In the internal Asymptote source code, what does the name camp refer to? That was our original tentative name for this project, which stood for "C's Answer to MetaPost" (the language that inspired Asymptote). However, we eventually decided that the name Asymptote better emphasizes the mathematical and graphical nature of this language.  File: asy-faq.info, Node: Section 2, Next: Section 3, Previous: Section 1, Up: Top Questions about installation and setup * Menu: * Question 2.1:: Is it possible to install Asymptote on Mac OS X? * Question 2.2:: Why do I get the error Bad CPU type in executable on installing Asymptote from the MAC OS binary? * Question 2.3:: What do I do if I get the error: Error: pdfetex (file pdftex.cfg): cannot open config file...texinfo.tex appears to be broken? * Question 2.4:: What do I do if I get the error: ! Undefined control sequence. l.6 @copying? * Question 2.5:: Is it possible to integrate Asymptote into LaTeX? * Question 2.6:: Is it possible to integrate Asymptote into latex or pdflatex? * Question 2.7:: Do I need the tkinter package to install an Asymptote rpm binary? * Question 2.8:: What does the path %USERPROFILE%\.asy\config.asy mean? * Question 2.9:: Why do I get the error "string not terminated" when I try to set settings.dir="C:\asymptote\";? * Question 2.10:: How do I change environment variables in Microsoft Windows, for example, in order to change the default PostScript viewer? * Question 2.11:: Under Microsoft Windows XP, why do I get an error like "Invalid Parameter - 432x432"? * Question 2.12:: Why does Asymptote freeze upon trying to draw a label with my MikTex installation under Microsoft Windows?  File: asy-faq.info, Node: Question 2.1, Next: Question 2.2, Previous: Question 1.5, Up: Section 2 Question 2.1. Is it possible to install Asymptote on Mac OS X? It is easy to compile Asymptote directly from the source code at http://sourceforge.net/project/showfiles.php?group_id=120000 We recommend first upgrading to the latest GNU readline library, unless you don't care about interactive readline support (in which case configure will automatically detect and disable obsolete versions of the readline library). Marius Schamschula also maintains a binary package for various MacOS X platforms http://www.hmug.org/pub/MacOS_X/X/Applications/Publishing/asymptote.  File: asy-faq.info, Node: Question 2.2, Next: Question 2.3, Previous: Question 2.1, Up: Section 2 Question 2.2. Why do I get the error Bad CPU type in executable on installing Asymptote from the MAC OS binary? This means either that you have a binary distribution for another MAC architecture, or (according to Marius Schamschula) that you may have a missing library. The simplest solution is to compile Asymptote directly from the official source: http://sourceforge.net/project/showfiles.php?group_id=120000.  File: asy-faq.info, Node: Question 2.3, Next: Question 2.4, Previous: Question 2.2, Up: Section 2 Question 2.3. What do I do if I get the error: Error: pdfetex (file pdftex.cfg): cannot open config file...texinfo.tex appears to be broken? Simply put https://asymptote.sourceforge.io/asymptote.pdf in the directory doc and repeat the command make all. Or, if you don't want to build a local copy of the documentation, simply proceed with make install-asy.  File: asy-faq.info, Node: Question 2.4, Next: Question 2.5, Previous: Question 2.3, Up: Section 2 Question 2.4. What do I do if I get the error: ! Undefined control sequence. l.6 @copying? Either upgrade your texinfo package or follow one of the easy work arounds in *Note Question 2.3:: `What do I do if I get the error: Error: pdfetex (file pdftex.cfg): cannot open config file...texinfo.tex appears to be broken?'.  File: asy-faq.info, Node: Question 2.5, Next: Question 2.6, Previous: Question 2.4, Up: Section 2 Question 2.5. Is it possible to integrate Asymptote into LaTeX? Yes, see the example latexusage.tex. Dario Teixeira has also written a detailed guide on the topic. You can download it from http://dario.dse.nl/projects/asylatex/. Philippe Ivaldi has contributed an Asymptote mode for Emacs users https://asymptote.sourceforge.io/doc/Editing-modes.html, which includes a lasy-mode that allows one to compile and view the output of one \begin{asy}...\end{asy} section at a time.  File: asy-faq.info, Node: Question 2.6, Next: Question 2.7, Previous: Question 2.5, Up: Section 2 Question 2.6. Is it possible to integrate Asymptote into latex or pdflatex? Yes, as of version 1.14, Asymptote supports latex and pdflatex (both in EPS/PDF and inline mode), as illustrated by the example latexusage.tex: pdflatex latexusage asy latexusage pdflatex latexusage  File: asy-faq.info, Node: Question 2.7, Next: Question 2.8, Previous: Question 2.6, Up: Section 2 Question 2.7. Do I need the tkinter package to install an Asymptote rpm binary? No, you don't need tkinter unless you want to try out the GUI xasy. Try rpm -Uvh --nodeps asymptote-x.xx-1.i386.rpm where x.xx represents the version number.  File: asy-faq.info, Node: Question 2.8, Next: Question 2.9, Previous: Question 2.7, Up: Section 2 Question 2.8. What does the path %USERPROFILE%\.asy\config.asy mean? That is the way that Microsoft Windows refers to the user profile directory. There's nothing really to understand here, just put your configuration commands in the file config.asy in a new folder %USERPROFILE%\.asy.  File: asy-faq.info, Node: Question 2.9, Next: Question 2.10, Previous: Question 2.8, Up: Section 2 Question 2.9. Why do I get the error "string not terminated" when I try to set settings.dir="C:\asymptote\";? The backslash is an escape character here, so \" is interpreted as a verbatim quotation mark, leaving the string without a terminating quotation mark. Fortunately, this is the only escaped character in double-quoted strings. A final backslash isn't needed here anyway, but should you really want one somewhere, you can say: settings.dir="C:\asymptote"+'\\';.  File: asy-faq.info, Node: Question 2.10, Next: Question 2.11, Previous: Question 2.9, Up: Section 2 Question 2.10. How do I change environment variables in Microsoft Windows, for example, in order to change the default PostScript viewer? While it is easier to set the corresponding Asymptote configuration variable in your config.asy file, here is the procedure for changing Microsoft Windows environment variables: Click on the [Start] button * RIGHT-click on 'My Computer' * Choose 'Properties' from the popup menu * Click the 'Advanced' tab * Click the 'Environment Variables' button.  File: asy-faq.info, Node: Question 2.11, Next: Question 2.12, Previous: Question 2.10, Up: Section 2 Question 2.11. Under Microsoft Windows XP, why do I get an error like "Invalid Parameter - 432x432"? This means that ImageMagick wasn't properly installed and you are using the MSDOS convert program rather than the ImageMagick one. Or you may have installed ImageMagick but ran Asymptote from an existing MSDOS window. In that case, simply open a new window and try again. If that doesn't work, check that convert --version returns something like Version: ImageMagick 6.2.8 06/27/06 Q16 http://www.imagemagick.org  File: asy-faq.info, Node: Question 2.12, Next: Question 3.1, Previous: Question 2.11, Up: Section 2 Question 2.12. Why does Asymptote freeze upon trying to draw a label with my MikTex installation under Microsoft Windows? Likely, this means that latex and dvips are not in your default path. Try adding the appropriate paths in your config.asy file, for example: import settings; latex="C:\Program Files\MiKTeX 2.7\miktex\bin\latex.exe"; dvips="C:\Program Files\MiKTeX 2.7\miktex\bin\dvips.exe";  File: asy-faq.info, Node: Section 3, Next: Section 4, Previous: Section 2, Up: Top Questions about paths * Menu: * Question 3.1:: Why do I get a syntax error message when I specify an integer value for the path tension? * Question 3.2:: Shouldn't dots always be the same size?  File: asy-faq.info, Node: Question 3.1, Next: Question 3.2, Previous: Question 2.12, Up: Section 3 Question 3.1. Why do I get a syntax error message when I specify an integer value for the path tension? What is happening here is that draw((0,0)..tension 2..(0,50)..(100,100)); is read as draw((0,0)..tension 2. .(0,50)..(100,100)); So the first . after the two is treated as a decimal point. Just put a space after the integer tension value: draw((0,0)..tension 2 ..(0,50)..(100,100));  File: asy-faq.info, Node: Question 3.2, Next: Question 4.1, Previous: Question 3.1, Up: Section 3 Question 3.2. Shouldn't dots always be the same size? From the documentation: "The dot command defined in the module plain draws a dot having a diameter equal to an explicit pen linewidth or the default linewidth magnified by dotfactor (6 by default)." Thus, when you use the default pen, the dot will have size 6*linewidth, but when you give a pen with an explicit width specified, you will have a dot of size linewidth. If you want the first case to behave like the second, you may set dotfactor=1.  File: asy-faq.info, Node: Section 4, Next: Section 5, Previous: Section 3, Up: Top Questions about labels * Menu: * Question 4.1:: How do I get Greek letters like omega to show up in my labels? * Question 4.2:: Can Asymptote use matrices as labels? * Question 4.3:: How do I tell Asymptote to load a particular LaTeX package, like mathptmx? * Question 4.4:: How can I use international fonts in Asymptote labels? * Question 4.5:: How can I use Fourier fonts? * Question 4.6:: Is there any way to change the default appearance of the decimal separator, using a comma instead of a dot? * Question 4.7:: How can I get a rotated label with the filled box rotated as well so that it fits the text? * Question 4.8:: How can I rotate labels in a 3D figure? * Question 4.9:: How can I draw some squares and circles of a fixed size and put a label in the middle of them? * Question 4.10:: The binary operator * can be used to scale the color of a pen by a real number. Does this scaling factor have to be less than 1? * Question 4.11:: Why is the space after the comma decimal separator in my locale so large? * Question 4.12:: How can I prevent texpreamble("\usepackage[pdftex]{hyperref}") from changing the page size?  File: asy-faq.info, Node: Question 4.1, Next: Question 4.2, Previous: Question 3.2, Up: Section 4 Question 4.1. How do I get Greek letters like omega to show up in my labels? In (La)TeX, Greek letters can be obtained in math mode by prepending a backslash to the letter name. So for a omega symbol, use "$\omega$". Everything between the dollar signs is considered to be a math formula. Uppercase Greek letters can be used by capitalizing the first letter of the name: label("$\omega$",(0,0)); label("$\Omega$",(20,0));  File: asy-faq.info, Node: Question 4.2, Next: Question 4.3, Previous: Question 4.1, Up: Section 4 Question 4.2. Can Asymptote use matrices as labels? Yes: usepackage("amsmath"); label("$\begin{matrix} 1 & 2 \\\ 1 & 1 \end{matrix}$",(0,0));  File: asy-faq.info, Node: Question 4.3, Next: Question 4.4, Previous: Question 4.2, Up: Section 4 Question 4.3. How do I tell Asymptote to load a particular LaTeX package, like mathptmx? Put usepackage("mathptmx"); at the beginning of your file. Note: to enable the Adobe Times Roman font for text, you will also need to say: defaultpen(TimesRoman());  File: asy-faq.info, Node: Question 4.4, Next: Question 4.5, Previous: Question 4.3, Up: Section 4 Question 4.4. How can I use international fonts in Asymptote labels? See https://asymptote.sourceforge.io/doc/Pens.html.  File: asy-faq.info, Node: Question 4.5, Next: Question 4.6, Previous: Question 4.4, Up: Section 4 Question 4.5. How can I use Fourier fonts? usepackage("fourier"); defaultpen(font("T1","fut\textfamilyextension","m","n"));  File: asy-faq.info, Node: Question 4.6, Next: Question 4.7, Previous: Question 4.5, Up: Section 4 Question 4.6. Is there any way to change the default appearance of the decimal separator, using a comma instead of a dot? Just set your locale appropriately: locale("it_IT"); usepackage("icomma"); label(format(0.5));  File: asy-faq.info, Node: Question 4.7, Next: Question 4.8, Previous: Question 4.6, Up: Section 4 Question 4.7. How can I get a rotated label with the filled box rotated as well so that it fits the text? frame f; label(f,"This is some text",white,Fill(blue)); add(rotate(65)*f);  File: asy-faq.info, Node: Question 4.8, Next: Question 4.9, Previous: Question 4.7, Up: Section 4 Question 4.8. How can I rotate labels in a 3D figure? You need to first project the triple to a pair like this: import three; size(100,100); draw(rotate(90,project(Z))*"A",O--X);  File: asy-faq.info, Node: Question 4.9, Next: Question 4.10, Previous: Question 4.8, Up: Section 4 Question 4.9. How can I draw some squares and circles of a fixed size and put a label in the middle of them? Fixed-size objects should be drawn on a separate picture and then added to currentpicture. Here is one way (see also https://asymptote.sourceforge.io/gallery/subpictures.asy and https://asymptote.sourceforge.io/gallery/mosquito.asy): real u=2cm; picture square; draw(square,scale(u)*shift(-0.5,-0.5)*unitsquare); picture circle; draw(circle,scale(0.5u)*unitcircle); void add(picture pic=currentpicture, Label L, picture object, pair z) { add(pic,object,z); label(pic,L,z); } add("square",square,(0,0)); add("circle",circle,(5cm,0));  File: asy-faq.info, Node: Question 4.10, Next: Question 4.11, Previous: Question 4.9, Up: Section 4 Question 4.10. The binary operator * can be used to scale the color of a pen by a real number. Does this scaling factor have to be less than 1? The scaling factor can be greater than 1. But keep in mind that the rgb color components saturate at 1. Try write(cyan); write(0.8*cyan); write(1.5*cyan); and you will quickly see what is going on. To get a lighter cyan you can say white+cyan, which yields rgb(0.5,1,1). If you want something even lighter specify the rgb colors directly, for example, rgb(0.9,1,1). Alternatively, work in cmyk colour space, which is nicer in that it handles saturation separately from hue: 0.1*Cyan is light and 0.9*Cyan is dark. You can also say 0.1*cmyk(red).  File: asy-faq.info, Node: Question 4.11, Next: Question 4.12, Previous: Question 4.10, Up: Section 4 Question 4.11. Why is the space after the comma decimal separator in my locale so large? LaTeX is treating the comma as punctuation and not as a decimal separator. The solution is to load the icomma package near the beginning of your file: usepackage("icomma");  File: asy-faq.info, Node: Question 4.12, Next: Question 5.1, Previous: Question 4.11, Up: Section 4 Question 4.12. How can I prevent texpreamble("\usepackage[pdftex]{hyperref}") from changing the page size? texpreamble("\usepackage[pdftex,setpagesize=false]{hyperref}");  File: asy-faq.info, Node: Section 5, Next: Section 6, Previous: Section 4, Up: Top Questions about arrows * Menu: * Question 5.1:: How do I draw two arrows at arbitrary positions along a path? * Question 5.2:: How do I reverse the direction of an arrowhead? * Question 5.3:: How do I change the size of all arrows? * Question 5.4:: Can I create other arrowhead styles?  File: asy-faq.info, Node: Question 5.1, Next: Question 5.2, Previous: Question 4.12, Up: Section 5 Question 5.1. How do I draw two arrows at arbitrary positions along a path? Assuming that at least one of the arrowheads is to be filled, you can do this: size(200); path g = (0,0)..(1,3)..(3,0); draw(g,Arrow(Relative(0.9))); add(arrow(g,invisible,FillDraw(black),Relative(0.5))); add(arrow(reverse(g),invisible,FillDraw(white,black),Relative(0.9))); If both of the arrowheads are to be drawn with filltype NoFill, one will need to create a specialized version of the arrow routine in plain_arrows.asy: void arrow(frame f, arrowhead arrowhead=DefaultHead, path g, pen p=currentpen, real size=0, real angle=arrowangle, filltype filltype=arrowhead.defaultfilltype, position position=EndPoint, bool forwards=true, margin margin=NoMargin, bool center=false);  File: asy-faq.info, Node: Question 5.2, Next: Question 5.3, Previous: Question 5.1, Up: Section 5 Question 5.2. How do I reverse the direction of an arrowhead? Simply reverse the direction of the path. path g=((0,0)--(5cm,0)); draw(reverse(g),Arrow(Relative(0.55)));  File: asy-faq.info, Node: Question 5.3, Next: Question 5.4, Previous: Question 5.2, Up: Section 5 Question 5.3. How do I change the size of all arrows? To override the arrowsize you can give every Arrow drawing attribute a real size argument. If you want to do this globally, you can override the pen-dependent arrowsize function like this: DefaultHead.size=new real(pen p=currentpen) {return 2mm;};  File: asy-faq.info, Node: Question 5.4, Next: Question 6.1, Previous: Question 5.3, Up: Section 5 Question 5.4. Can I create other arrowhead styles? Yes, you can build custom arrowheads like this (see the predefined arrowhead styles in plain_arrows.asy for further examples): arrowhead DotHead; DotHead.head=new path(path g, position position=EndPoint, pen p=currentpen, real size=0, real angle=arrowangle) { if(size == 0) size=DotHead.size(p); bool relative=position.relative; real position=position.position.x; if(relative) position=reltime(g,position); path r=subpath(g,position,0); pair x=point(r,0); real t=arctime(r,size); pair y=point(r,t); return circle(0.5(x+y),0.5size); }; size(100); draw((0,0)..(1,1)..(2,0),Arrow(DotHead)); dot((2,0),red); If you submit your alternate arrowheads to the Forum or the Patch Tracking System, we'll consider including them in a future release.  File: asy-faq.info, Node: Section 6, Next: Section 7, Previous: Section 5, Up: Top Questions about 2D graphs * Menu: * Question 6.1:: How can I draw x axis ticks on the right side, with the tick labels on the left side (relative to the axis path)? * Question 6.2:: How can I reposition the x axis label to three-quarters along the axis length? * Question 6.3:: How can I move the x axis label down 10bp? * Question 6.4:: Can I use different pens for the axis, the axis label, and the tick labels? * Question 6.5:: How can I change the font type of the axes label? * Question 6.6:: How can I change the font type of the tick labels on an axis? * Question 6.7:: How can I prevent axes tick labels from rendering on top of each other? * Question 6.8:: How do I make the plot region of a graph, ignoring labels and legends, have a fixed size? * Question 6.9:: How can I plot a function f(x) within [0,1]x[0,2] without explicitly calculating the x values for which f(x) hits the boundary? * Question 6.10:: Is it possible to define customized palettes? * Question 6.11:: Is there an easy way to graph factorial functions nicely? * Question 6.12:: How do I indicate that a certain length should be exactly the size I prescribe with no rescaling, within a picture which has its own size? * Question 6.13:: How can I make the y axis display base-2 logarithmic values? * Question 6.14:: How can I align the x axes of two graphs on the same figure? * Question 6.15:: How can I change the direction of the y-axis, such that negatives values are on the upper y-axis? * Question 6.16:: How can I fill a path with a function that defines the color of each location? * Question 6.17:: Is there a way to draw a function that is not explicitly given, such as (y - 2)^2 = x - 1 ? * Question 6.18:: Is it possible to reverse or stretch an axis? * Question 6.19:: Why can't I use the UnFill option to draw graphs with empty markers? * Question 6.20:: How can I force several images to use the same palette range (e.g. the entire 0-255 grayscale range)?  File: asy-faq.info, Node: Question 6.1, Next: Question 6.2, Previous: Question 5.4, Up: Section 6 Question 6.1. How can I draw x axis ticks on the right side, with the tick labels on the left side (relative to the axis path)? import graph; size(250,200,IgnoreAspect); draw(graph(exp,-1,1),red); xaxis("$x$",RightTicks(Label(align=left))); yaxis("$y$",RightTicks);  File: asy-faq.info, Node: Question 6.2, Next: Question 6.3, Previous: Question 6.1, Up: Section 6 Question 6.2. How can I reposition the x axis label to three-quarters along the axis length? import graph; size(250,200,IgnoreAspect); draw(graph(exp,-1,1),red); xaxis(Label("$x$",0.75),LeftTicks); yaxis("$y$",RightTicks);  File: asy-faq.info, Node: Question 6.3, Next: Question 6.4, Previous: Question 6.2, Up: Section 6 Question 6.3. How can I move the x axis label down 10bp? import graph; size(250,200,IgnoreAspect); draw(graph(exp,-1,1),red); xaxis(shift(0,-10)*"$x$",LeftTicks); yaxis("$y$",RightTicks);  File: asy-faq.info, Node: Question 6.4, Next: Question 6.5, Previous: Question 6.3, Up: Section 6 Question 6.4. Can I use different pens for the axis, the axis label, and the tick labels? Yes: import graph; size(300,200,IgnoreAspect); xlimits(-50,50); ylimits(0,100); xaxis(Label("$x$",MidPoint,red),Bottom,blue,LeftTicks(green)); yaxis("$y$",Left,RightTicks);  File: asy-faq.info, Node: Question 6.5, Next: Question 6.6, Previous: Question 6.4, Up: Section 6 Question 6.5. How can I change the font type of the axes label? import graph; size(300,200,IgnoreAspect); xlimits(-50,50); ylimits(0,100); xaxis("x",Bottom,Courier("m","n"),LeftTicks); yaxis("$y$",Left,RightTicks);  File: asy-faq.info, Node: Question 6.6, Next: Question 6.7, Previous: Question 6.5, Up: Section 6 Question 6.6. How can I change the font type of the tick labels on an axis? Tick labels are by default typeset in (TeX) math mode, so to use other fonts you need to override the default tick format: import graph; size(300,200,IgnoreAspect); xlimits(-50,50); ylimits(0,100); xaxis("$x$",Bottom,LeftTicks("%.4g",Courier("m","n")+fontsize(12))); yaxis("$y$",Left,RightTicks);  File: asy-faq.info, Node: Question 6.7, Next: Question 6.8, Previous: Question 6.6, Up: Section 6 Question 6.7. How can I prevent axes tick labels from rendering on top of each other? Either: (i) give LeftTicks/RightTicks/Ticks the arguments beginlabel=false and/or endlabel=false; (ii) explicitly remove specific ticks and their labels (drawing them manually; see http://www.github.com/vectorgraphics/asymptote/base/graph.asy for the definition of NoZero): import graph; size(10cm); real f(real x) {return x^2;} draw(graph(f,-2,2)); xaxis(Ticks(NoZero)); yaxis(Ticks(NoZero)); label("$0$",(0,0),SW); (iii) explicitly remove specific tick labels and draw them manually (see http://www.github.com/vectorgraphics/asymptote/base/graph.asy for the definition of NoZeroFormat): import graph; size(10cm); real f(real x) {return x^2;} draw(graph(f,-2,2)); xaxis(Ticks(NoZeroFormat)); yaxis(Ticks(NoZeroFormat)); label("$0$",(0,0),SW); (iv) use the xasy GUI to move overlapping labels; (v) change the Label argument of LeftTicks, RightTicks, or Ticks to: Label(currentpen+overwrite(Move)) Solution (v) will move labels that might otherwise overwrite a previous label. Other possible overwrite arguments are Allow (allows overlapping labels; the default), Suppress (an overlapping label will not be written at all), SuppressQuiet, and MoveQuiet. The last two achieve the same result as the non-quiet types, but will not notify you which labels are overlapping. See: https://asymptote.sourceforge.io/doc/Pens.html. In the case of a user-specified tick array, you can change which labels get suppressed/moved by changing the order of array entries.  File: asy-faq.info, Node: Question 6.8, Next: Question 6.9, Previous: Question 6.7, Up: Section 6 Question 6.8. How do I make the plot region of a graph, ignoring labels and legends, have a fixed size? Either: i) Specify an explicit unitsize, which overrides any call to size: unitsize(x=1cm,y=2cm); ii) Explicitly tell Asymptote to map the plot region to a specific size: import graph; real[] x={0,1,2,3}; real[] y=x^2; draw(graph(x,y),red); xaxis("$x$",BottomTop,LeftTicks); yaxis("$y$",LeftRight,RightTicks); size(5cm,5cm,point(SW),point(NE)); label("$f_\mathrm{T}$",point(N),2N); iii) Specify the points in user coordinates that should correspond to a given picture size: import graph; size(250,200,IgnoreAspect); draw(graph(exp,-1,1),red); xaxis("$x$",BottomTop,LeftTicks); yaxis("$y$",LeftRight,RightTicks); fixedscaling((-1.5,-0.5),(1.5,3.5)); In this example, the user coordinate (-1.5,-0.5) will end up being the lower left corner of the figure and (1.5,3.5) will be the upper right corner. You can use this option to ensure multiple figures have the same scaling and same resulting figure size (just ensure the two coordinates given to fixedscaling() leaves room for any labels). See also https://asymptote.sourceforge.io/doc/Frames-and-pictures.html.  File: asy-faq.info, Node: Question 6.9, Next: Question 6.10, Previous: Question 6.8, Up: Section 6 Question 6.9. How can I plot a function f(x) within [0,1]x[0,2] without explicitly calculating the x values for which f(x) hits the boundary? Call limits with the Crop option before drawing the graph: import graph; size(250,200,IgnoreAspect); draw(graph(exp,-1,1),red); limits((0,0),(1,2),Crop); xaxis("$x$",BottomTop,LeftTicks); yaxis("$y$",LeftRight,RightTicks); See also https://asymptote.sourceforge.io/doc/graph.html.  File: asy-faq.info, Node: Question 6.10, Next: Question 6.11, Previous: Question 6.9, Up: Section 6 Question 6.10. Is it possible to define customized palettes? Yes, you may generate your own pen[] array. For example: int NColors=32768; pen[] MyPalette=new pen[NColors]; real step=1/(NColors-1.0); // Start at black: rgb(0,0,0) // End at yellow: rgb(1,1,0) for(int i=0; i < NColors; ++i) { real rgval=i*step; MyPalette[i]=rgb(rgval,rgval,0.0); }  File: asy-faq.info, Node: Question 6.11, Next: Question 6.12, Previous: Question 6.10, Up: Section 6 Question 6.11. Is there an easy way to graph factorial functions nicely? The example below shows a continuous function and two methods for placing markers at integer values of x: import graph; size(200,200,IgnoreAspect); real factorial(real t) {return gamma(t+1);} scale(Linear,Log); // Graph the factorial function. draw(graph(factorial,0,10)); // Method 1: Draw nodes, but hide line pair F(int t) {return (t,factorial(t));} // Graph of factorial function from 0 to 10 pair[] z=sequence(F,11); draw(graph(z),invisible,marker(scale(0.8mm)*unitcircle,blue,Fill)); // Method 2: Nongraphing routines require explicit scaling: pair dotloc(int t) {return Scale(F(t));} pair[] dotlocs=sequence(dotloc,11); dot(dotlocs); xaxis("$x$",BottomTop,LeftTicks); yaxis("$y$",LeftRight,RightTicks);  File: asy-faq.info, Node: Question 6.12, Next: Question 6.13, Previous: Question 6.11, Up: Section 6 Question 6.12. How do I indicate that a certain length should be exactly the size I prescribe with no rescaling, within a picture which has its own size? Here's an easy way to do this. size(12cm,0); void distance(picture pic=currentpicture, pair A, pair B, Label L="", real n=0, pen p=currentpen) { real d=3mm; path g=A--B; transform T=shift(-n*d*unit(B-A)*I); pic.add(new void(frame f, transform t) { picture opic; path G=T*t*g; draw(opic,Label(L,Center,UnFill(1)),G,p,Arrows(NoFill),Bars,PenMargins); add(f,opic.fit()); }); pic.addBox(min(g),max(g),T*min(p),T*max(p)); } pair A=(0,0), B=(3,3); dot(A); dot(B); distance(A,B,"$\ell$",1);  File: asy-faq.info, Node: Question 6.13, Next: Question 6.14, Previous: Question 6.12, Up: Section 6 Question 6.13. How can I make the y axis display base-2 logarithmic values? See the example https://asymptote.sourceforge.io/gallery/2D graphs/log2graph.asy.  File: asy-faq.info, Node: Question 6.14, Next: Question 6.15, Previous: Question 6.13, Up: Section 6 Question 6.14. How can I align the x axes of two graphs on the same figure? An easy way to do this, if the axes to be aligned have the same scaling and size, is illustrated in the example https://asymptote.sourceforge.io/gallery/2D graphs/alignedaxis.asy. Here is a more general solution to the problem of aligning two arbitrary axes. One fits the second picture to a frame based on the horizontal scaling for the first picture: import graph; real width=15cm; real aspect=0.3; picture pic1,pic2; size(pic1,width,aspect*width,IgnoreAspect); size(pic2,width,aspect*width,IgnoreAspect); scale(pic1,false); scale(pic2,false); real xmin1=6; real xmax1=9; real xmin2=8; real xmax2=16; real a1=1; real a2=0.001; real f1(real x) {return a1*sin(x/2*pi);} real f2(real x) {return a2*sin(x/4*pi);} draw(pic1,graph(pic1,f1,xmin1,xmax1)); draw(pic2,graph(pic2,f2,xmin2,xmax2)); xaxis(pic1,Bottom,LeftTicks()); yaxis(pic1,"$f_1(x)$",Left,RightTicks); xaxis(pic2,"$x$",Bottom,LeftTicks(Step=4)); yaxis(pic2,"$f_2(x)$",Left,RightTicks); yequals(pic1,0,Dotted); yequals(pic2,0,Dotted); pair min1=point(pic1,SW); pair max1=point(pic1,NE); pair min2=point(pic2,SW); pair max2=point(pic2,NE); real scale=(max1.x-min1.x)/(max2.x-min2.x); real shift=min1.x/scale-min2.x; transform t1=pic1.calculateTransform(); transform t2=pic2.calculateTransform(); transform T=xscale(scale*t1.xx)*yscale(t2.yy); add(pic1.fit()); real height=truepoint(N,user=false).y-truepoint(S,user=false).y; add(shift(0,-height)*(shift(shift)*pic2).fit(T));  File: asy-faq.info, Node: Question 6.15, Next: Question 6.16, Previous: Question 6.14, Up: Section 6 Question 6.15. How can I change the direction of the y-axis, such that negatives values are on the upper y-axis? Here is a simple example (see also the example https://asymptote.sourceforge.io/gallery/2D graphs/diatom.asy or the discussion of Linear(-1) in the documentation): import graph; size(250,200,IgnoreAspect); scale(Linear,Linear(-1)); draw(graph(log,0.1,10),red); xaxis("$x$",LeftTicks); yaxis("$y$",RightTicks);  File: asy-faq.info, Node: Question 6.16, Next: Question 6.17, Previous: Question 6.15, Up: Section 6 Question 6.16. How can I fill a path with a function that defines the color of each location? Use functionshade with a PDF tex engine, as illustrated by the example {functionshading.asy}. If you want to produce PostScript output, an approximate solution for now would be to superimpose a fine grid and specify colors to latticeshade that depend on position as a single pen[][] lattice. Alternatively, it may be more efficient to use tensorshade}.  File: asy-faq.info, Node: Question 6.17, Next: Question 6.18, Previous: Question 6.16, Up: Section 6 Question 6.17. Is there a way to draw a function that is not explicitly given, such as (y - 2)^2 = x - 1 ? Yes, use the parametric form y=t x=(t-2)^2+1 See the example https://asymptote.sourceforge.io/gallery/2D graphs/parametricgraph.asy.  File: asy-faq.info, Node: Question 6.18, Next: Question 6.19, Previous: Question 6.17, Up: Section 6 Question 6.18. Is it possible to reverse or stretch an axis? The real scaling argument to Linear is used to stretch (or reverse) the axis. To see the effect of axis stretching, be sure not to specify IgnoreAspect in the picture size command. A secondary axis has the same length as the primary axis, so stretching cannot have any effect. But one can still reverse the axis, with Linear(-1).  File: asy-faq.info, Node: Question 6.19, Next: Question 6.20, Previous: Question 6.18, Up: Section 6 Question 6.19. Why can't I use the UnFill option to draw graphs with empty markers? UnFill won't work here because it only affects the local frame the markers are initially drawn on, before being added to currentpicture. Here is a way of achieving the desired effect (assuming a white background): import graph; size(10cm,0); pair[] z={(0,0),(0.5,0.5),(1,1)}; path g=graph(z); draw(shift(0,.5)*g,marker(scale(5)*unitcircle,FillDraw(white))); xaxis(BottomTop,LeftTicks); yaxis(LeftRight,RightTicks);  File: asy-faq.info, Node: Question 6.20, Next: Question 7.1, Previous: Question 6.19, Up: Section 6 Question 6.20. How can I force several images to use the same palette range (e.g. the entire 0-255 grayscale range)? The palette color space corresponds to a range of values specified by the argument range, which can be Full, Automatic or an explicit range Range(pair min, pair max). Here Full} specifies a range varying from the minimum to maximum values of the function over the sampling interval, while Automatic selects "nice" limits.  File: asy-faq.info, Node: Section 7, Next: Section 8, Previous: Section 6, Up: Top Questions about programming * Menu: * Question 7.1:: Is Asymptote an interpreter or a compiler? * Question 7.2:: What is the difference between a frame and a picture? * Question 7.3:: What is the difference between a path and a guide? * Question 7.4:: What is a convenient way to declare and initialize an array of pictures? * Question 7.5:: Is there a way to define functions that act on arrays in general (i.e. work for arrays of any type)? * Question 7.6:: Is there any way to declare structures ahead of their definition, e.g. where struct A performs some operation on struct B, but B contains an A member? * Question 7.7:: Where are static variables in for loops allocated? * Question 7.8:: Is there a debugger for asy? * Question 7.9:: Do you accept patches for Asymptote?  File: asy-faq.info, Node: Question 7.1, Next: Question 7.2, Previous: Question 6.20, Up: Section 7 Question 7.1. Is Asymptote an interpreter or a compiler? Asymptote compiles Asymptote commands into its own virtual machine code. It then runs this pseudocode on a virtual machine to produce PostScript code.  File: asy-faq.info, Node: Question 7.2, Next: Question 7.3, Previous: Question 7.1, Up: Section 7 Question 7.2. What is the difference between a frame and a picture? Frames are canvases for drawing in PostScript coordinates. While working with frames directly is occasionally necessary for constructing deferred drawing routines, pictures are usually more convenient to work with. See *Note Question 8.8:: `In MetaPost, it is possible to have a drawing remain the same size in different pictures by defining a unit u and explicitly multiply all the coordinates by u. Is there a better way to do this in Asymptote?'.  File: asy-faq.info, Node: Question 7.3, Next: Question 7.4, Previous: Question 7.2, Up: Section 7 Question 7.3. What is the difference between a path and a guide? A path is a cubic spline with fixed endpoint conditions. A guide is an unresolved cubic spline (list of cubic-spline nodes and control points). A guide is like a path except that the computation of the cubic spline is deferred until drawing time (when it is resolved into a path); this allows two guides with free endpoint conditions to be joined together smoothly.  File: asy-faq.info, Node: Question 7.4, Next: Question 7.5, Previous: Question 7.3, Up: Section 7 Question 7.4. What is a convenient way to declare and initialize an array of pictures? You could write yourself a routine such as: picture[] picture(int n) { picture[] pic; for(int i=0; i < n; ++i) { pic[i]=new picture; size(pic[i],19cm,0); } return pic; } picture[] pic=picture(6);  File: asy-faq.info, Node: Question 7.5, Next: Question 7.6, Previous: Question 7.4, Up: Section 7 Question 7.5. Is there a way to define functions that act on arrays in general (i.e. work for arrays of any type)? Generic types aren't yet implemented. But for now you can at least say typedef string T; include F; typedef real T; include F; where F.asy contains some type-dependent code like T[] operator $(T A, T B) {return new T[] {A,B};}  File: asy-faq.info, Node: Question 7.6, Next: Question 7.7, Previous: Question 7.5, Up: Section 7 Question 7.6. Is there any way to declare structures ahead of their definition, e.g. where struct A performs some operation on struct B, but B contains an A member? Asymptote does not support forward declaration of types. You can, however, nest structures, so that both types are visible for parts of the bodies of both structure definitions. For example: struct B { typedef void someroutine(B b); static struct A { someroutine routine; void operator init(someroutine routine) { this.routine=routine; } } string test="Testing"; } typedef B.A A; A a=B.A(new void(B b){write(b.test);}); B b; a.routine(b);  File: asy-faq.info, Node: Question 7.7, Next: Question 7.8, Previous: Question 7.6, Up: Section 7 Question 7.7. Where are static variables in for loops allocated? In the example void f() { for(int i=0; i < 3; ++i) { static int n; ++n; write(n); } } f(); // Writes 1, 2, 3 the static qualifier means that n is allocated not just outside of the for loop, but also outside the function. This is clear if you call f multiple times; there is still only one instance of n. The "level" of a variable (where it is allocated) has nothing to do with the "scope" of a variable (how long it can be referred to by name). The curly braces enclosing a block affect only a variable's scope, not its level. Static modifiers are meaningless at the top level; they generate a warning and are simply ignored: for(int i=0; i < 3; ++i) { static int n; ++n; write(n); } // Writes warning about top-level static modifier and then 1, 1, 1 Since version 1.22, non-static variables allocated in a loop body are allocated anew every iteration. This is only noticable in obscure cases where a variable in a loop is accessed in the closure of a function defined in the loop: int f(); for(int i=0; i < 10; ++i) { int j=10*i; if(i == 5) f=new int() {return j;}; } write(f()); // Writes 50 Variables in the body of a loop last as long as that iteration of the loop, unless they are kept alive by a function closure as in the example above. In a function body, variables will last at least as long as the function call, though because of closures and garbage collection, they may last longer than that. If defined at the top level of a file or at the interactive prompt, they will last at least until the end of the file or prompt's run.  File: asy-faq.info, Node: Question 7.8, Next: Question 7.9, Previous: Question 7.7, Up: Section 7 Question 7.8. Is there a debugger for asy? Yes, Asymptote includes a line-based debugger: https://asymptote.sourceforge.io/doc/Debugger.html  File: asy-faq.info, Node: Question 7.9, Next: Question 8.1, Previous: Question 7.8, Up: Section 7 Question 7.9. Do you accept patches for Asymptote? Yes, in fact we would prefer that users submit patches for customized features (to http://sourceforge.net/tracker/?atid=685685&group_id=120000) instead of relying on us to do all of the coding. Development will proceed faster that way.  File: asy-faq.info, Node: Section 8, Next: Section 9, Previous: Section 7, Up: Top Questions about differences between Asymptote and MetaPost * Menu: * Question 8.1:: What is the equivalent of the MetaPost c[a,b] interpolation operator? * Question 8.2:: How does picture scaling differ in Asymptote and MetaPost? * Question 8.3:: How can I avoid automatic scaling of a picture? * Question 8.4:: What is the equivalent of MetaPost ... command? * Question 8.5:: What is the equivalent of the MetaPost pickup command? * Question 8.6:: What is the equivalent of the MetaPost whatever command? * Question 8.7:: What is the equivalent for the MetaPost command for lray - horiz*v - verti*u = whatever*(LightSource - R), a system of three linear equations for three unknowns: horiz, verti, whatever? * Question 8.8:: In MetaPost, it is possible to have a drawing remain the same size in different pictures by defining a unit u and explicitly multiply all the coordinates by u. Is there a better way to do this in Asymptote? * Question 8.9:: In MetaPost, one could produce tiling pictures by generating a picture, and then clipping the picture to a rectangle of fixed dimensions around the center of the picture. How is that done in Asymptote?  File: asy-faq.info, Node: Question 8.1, Next: Question 8.2, Previous: Question 7.9, Up: Section 8 Question 8.1. What is the equivalent of the MetaPost c[a,b] interpolation operator? interp(a,b,c);  File: asy-faq.info, Node: Question 8.2, Next: Question 8.3, Previous: Question 8.1, Up: Section 8 Question 8.2. How does picture scaling differ in Asymptote and MetaPost? Asymptote includes an optional facility to do automatic scaling of pictures to achieve a given overall picture size, whereas Metapost only supports manual scaling. Asymptote defers drawing of objects drawn to pictures and distinguishes between true-size objects and objects that should scale with the picture size. The resulting linear programming problem is solved via the Simplex method. See the https://asymptote.sourceforge.io/gallery/dimension.asy example for an example of how deferred drawing is used to accomodate both user and true-size (PostScript) coordinates.  File: asy-faq.info, Node: Question 8.3, Next: Question 8.4, Previous: Question 8.2, Up: Section 8 Question 8.3. How can I avoid automatic scaling of a picture? If you really like Metapost-style manual (hard-wired) scaling either: (i) use the default size(0,0) for the entire picture and do all of the scaling by hand, just like in MetaPost; (ii) draw to a separate picture pic and add(pic.fit()); (iii) use frames.  File: asy-faq.info, Node: Question 8.4, Next: Question 8.5, Previous: Question 8.3, Up: Section 8 Question 8.4. What is the equivalent of MetaPost ... command? The connector :: is a macro for tension atleast 1: size(100); pair z0=(0,0); pair z1=(1,0.25); pair z2=(2,0); draw(z0{up}::z1{right}::z2{down});  File: asy-faq.info, Node: Question 8.5, Next: Question 8.6, Previous: Question 8.4, Up: Section 8 Question 8.5. What is the equivalent of the MetaPost pickup command? Just say, for example: currentpen=red;  File: asy-faq.info, Node: Question 8.6, Next: Question 8.7, Previous: Question 8.5, Up: Section 8 Question 8.6. What is the equivalent of the MetaPost whatever command? Asymptote does not implicitly solve linear equations and therefore does not have the notion of a whatever unknown. Such a facility could certainly be added (perhaps using the notation ?= since = means assignment). However, the most common uses of whatever in MetaPost are covered by functions like extension in math.asy: pair extension(pair P, pair Q, pair p, pair q); this returns the intersection point of the extensions of the line segments PQ and pq. We find using routines like extension more explicit and less confusing to new users. But we could be persuaded to add something similar if someone can justify the need. In the meantime, one can always use the explicit built-in linear solver solve (see https://asymptote.sourceforge.io/doc/solve.html), which uses LU decomposition.  File: asy-faq.info, Node: Question 8.7, Next: Question 8.8, Previous: Question 8.6, Up: Section 8 Question 8.7. What is the equivalent for the MetaPost command for lray - horiz*v - verti*u = whatever*(LightSource - R), a system of three linear equations for three unknowns: horiz, verti, whatever? Since horiz*v+verti*u spans a plane, you could use real intersect(vector P, vector Q, vector n, vector Z); to find the intersection time for the line lray-whatever*(LightSource - R) and then extract the three desired values from there. (You'll still need to use the built-in explicit linear solver to solve a 2x2 system to get horiz and verti.)  File: asy-faq.info, Node: Question 8.8, Next: Question 8.9, Previous: Question 8.7, Up: Section 8 Question 8.8. In MetaPost, it is possible to have a drawing remain the same size in different pictures by defining a unit u and explicitly multiply all the coordinates by u. Is there a better way to do this in Asymptote? Yes, Asymptote has a better way: you definitely don't want to manually scale all of your coordinates. To make the user coordinates represent multiples of exactly 1cm: unitsize(1cm); draw(unitsquare); One can also specify different x and y unit sizes: unitsize(x=1cm,y=2cm); draw(unitsquare); Another way is to draw your fixed size object to a frame and add it to currentpicture like this: path p=(0,0)--(1,0); frame object; draw(object,scale(100)*p); add(object); add(object,(0,-10)); To understand the difference between frames and pictures, try this: size(300,300); path p=(0,0)--(1,0); picture object; draw(object,scale(100)*p); add(object); add(object,(0,-10)); // Adds truesize object to currentpicture  File: asy-faq.info, Node: Question 8.9, Next: Question 9.1, Previous: Question 8.8, Up: Section 8 Question 8.9. In MetaPost, one could produce tiling pictures by generating a picture, and then clipping the picture to a rectangle of fixed dimensions around the center of the picture. How is that done in Asymptote? If you are using currentpicture the way one would in MetaPost (drawing in raw PostScript coordinates), you can simply do something like: fill((0,0)--(100,100)--(200,0)--cycle); pair center(picture pic=currentpicture) {return 0.5*(pic.min()+pic.max());} real height=100; real width=100; pair delta=0.5(width,height); pair c=center(); clip(box(c-delta,c+delta)); However, drawing in PostScript coordinates is often inconvenient. Here's the Asymptote way of doing the same thing, using deferred drawing: size(200,100); fill((0,0)--(1,1)--(2,0)--cycle); void clip(picture pic=currentpicture, real width, real height) { pic.clip(new void (frame f, transform) { pair center=0.5(min(f)+max(f)); pair delta=0.5(width,height); clip(f,box(center-delta,center+delta)); }); } clip(100,100); See also the discussion of tilings in the documentation: https://asymptote.sourceforge.io/doc/Pens.html.  File: asy-faq.info, Node: Section 9, Previous: Section 8, Up: Top Questions about output * Menu: * Question 9.1:: How can I disable automatic invocation of the PS viewer after an asy file is done processing? * Question 9.2:: How do I output jpeg images? * Question 9.3:: Can I embed bitmaps (photos) into my drawings and position and scale them? * Question 9.4:: Does Asymptote support direct PDF output? * Question 9.5:: How to I produce large pictures of high quality in raster format (e.g. png, giff etc). * Question 9.6:: Is it possible to produce multi-page documents with asymptote?  File: asy-faq.info, Node: Question 9.1, Next: Question 9.2, Previous: Question 8.9, Up: Section 9 Question 9.1. How can I disable automatic invocation of the PS viewer after an asy file is done processing? It's actually not on by default, unless you happen to be using Microsoft Windows (because that is what most Microsoft Windows users expect). Microsoft Windows users can turn this feature off with the command-line option -noV or by putting import settings; interactiveView=false; batchView=false; in their config.asy file. See https://asymptote.sourceforge.io/doc/Options.html.  File: asy-faq.info, Node: Question 9.2, Next: Question 9.3, Previous: Question 9.1, Up: Section 9 Question 9.2. How do I output jpeg images? If you have the ImageMagick convert program installed, simply type asy -f jpg test.asy  File: asy-faq.info, Node: Question 9.3, Next: Question 9.4, Previous: Question 9.2, Up: Section 9 Question 9.3. Can I embed bitmaps (photos) into my drawings and position and scale them? Convert them to eps format and use the graphic(string) function just like a Label: label(graphic("file"),(0,0)); See the example https://asymptote.sourceforge.io/gallery/orthocenter.asy and https://asymptote.sourceforge.io/doc/label.html.  File: asy-faq.info, Node: Question 9.4, Next: Question 9.5, Previous: Question 9.3, Up: Section 9 Question 9.4. Does Asymptote support direct PDF output? Yes, PDF output can be produced by the -f pdf option or -tex pdflatex option. This supports transparency, annotations, embedded movies, and U3D/PRC content.  File: asy-faq.info, Node: Question 9.5, Next: Question 9.6, Previous: Question 9.4, Up: Section 9 Question 9.5. How to I produce large pictures of high quality in raster format (e.g. png, giff etc). Try using some of the options to convert, mainly -geometry and -density. For example: convert -geometry 1000x3000 example.eps example.png You can also change the default resolution of the image with: convert -geometry 1000x3000 -density 300 -units PixelsPerInch example.eps example.png This does not change the number of pixels in the image, but just gives a hint as to how large each pixel should be displayed. If you include the -density option without the -geometry option, convert will keep the image size constant (so a 4cm x 3cm eps figure will generate a 4cm x 3cm png image).  File: asy-faq.info, Node: Question 9.6, Previous: Question 9.5, Up: Section 9 Question 9.6. Is it possible to produce multi-page documents with asymptote? Yes, simply call the newpage() function. This is used by the slide.asy package to produce high-quality slide presentations (easier to use than Prosper).