void drawstrokepath(picture pic=, path g, pen strokepen, pen p=); real legendlinelength; coord[] maxcoords(coord[] in, bool operator <=(coord, coord)); string outdirectory(); bool prc(string format=); light currentlight; pen royalblue; real arrowdir; filltype filltype(int type=, pen fillpen=, pen drawpen=, void fill2(frame f, path[] g, pen fillpen)); string file(string s); int Suppress; align NoAlign; filltype RadialShade(pen penc, pen penr); real[] arrowbasepoints(path base, path left, path right, real default=); real bp; pen mean(pen[] p, real opacity(real[])=); pen[] mean(pen[][] palette, real opacity(real[])=); string[] split(string s, string delimiter=); path plus; cputime cputime(); real inches; pair SW; real inch; marginT EndMargin(path, pen); pen mediumgrey; pen darkcyan; real legendhskip; void addSaveFunction(void s()()); pen olive; pen zerowinding; pen deepmagenta; path[] margin(path[] g, real xmargin, real ymargin); pen mediumyellow; slice lastcut(path p, path knife); pen darkgreen; string verbatim(string s); pen heavygray; pen darkred; pair E; plain_bounds plain_bounds; pen darkgray; frame orientation(frame); void progress(bool3 init=); pen salmon; pen mediummagenta; pair arcdir(path p, real L); pen mediumcyan; pen Pentype(int n); triple gettriple(string name=, triple default=, string prompt=, bool store=); pen Yellow; real cm; pen mediumgreen; pen heavygreen; void copyPairOrTriple(pairOrTriple dest, pairOrTriple src); projection centered(projection P, picture pic=); pen dashdotted; pen deepblue; string graphicscale(real x); pen mediumblue; transform invert; pair NNW; pair SE; pen thick(pen p=); pen mediumred; marginT EndDotMargin(path, pen); bool ArcArrows(picture, path, pen, marginT(path, pen))(arrowhead arrowhead=, real size=, real angle=, filltype filltype=); bool ArcArrows(picture, path, pen, marginT(path, pen)); void filloutside(picture pic=, path[] g, pen p=, bool copy=); void filloutside(frame f, path[] g, pen p=, bool copy=); marginT BeginDotMargin(path, pen); frame enclose(string prefix=, object F, string format=); marker[] Mark; marker Mark(int n); pen darkolive; pen Dotted; pen Dotted(pen p=); string math(string s); transform fixedscaling(picture pic=, pair min, pair max, pen p=, bool warn=); pen Symbol(string series=, string shape=); int count; path circle(pair c, real r); path ellipse(frame dest, frame src=, real xmargin=, real ymargin=, pen p=, filltype filltype=, bool above=); path ellipse(frame f, Label L, real xmargin=, real ymargin=, pen p=, filltype filltype=, bool above=); path ellipse(pair c, real a, real b); pen beveljoin; pen orange; pen green; bool EndBar(picture, path, pen, marginT(path, pen)); bool EndBar(picture, path, pen, marginT(path, pen))(real size=); file stdin; void fillbox(frame dest, path g, pen p=, filltype filltype=, bool above=); int debuggerlines; frame bbox(picture pic=, real xmargin=, real ymargin=, pen p=, filltype filltype=); path unitcircle; arrowhead DefaultHead; pen white; position EndPoint; transform Rotate(transform)(pair z); transform Rotate(transform t); Legend Legend(string label, pen plabel=, pen p=, frame mark=, bool above=); void exitfunction(); void drawarrow(frame f, arrowhead arrowhead=, path g, pen p=, real size=, real angle=, filltype filltype=, position position=, bool forwards=, marginT margin(path, pen)=, bool center=); string cputimeformat; pair arcpoint(path p, real L); bool interior(int windingnumber, pen fillrule); pen fuchsia; pen brown; void bar(picture pic, pair a, pair d, pen p=); picture bar(pair a, pair d, pen p=); pen deepcyan; pen dotted; pair reldir(path p, real l); pen pink; pen TimesRoman(string series=, string shape=); pen palemagenta; int mantissaBits; pen lightolive; path arrowbase(path r, pair y, real t, real size); frame pack(pair align= ... object[] inset); pen[] monoPen; bool CW; pen Cyan; marginT EndPenMargin(path, pen); pair NNE; pen roundjoin; void addArrow(picture pic, arrowhead arrowhead, path g, pen p, real size, real angle, filltype filltype, real position); pen lightgray; picture arrow2(arrowhead arrowhead=, path g, pen p=, real size=, real angle=, filltype filltype=, marginT margin(path, pen)=); pair relative(picture pic=, pair z); position MidPoint; string Embed(string name, string text=, string options=, real width=, real height=); pen deepgrey; pen lightyellow; marginT Margin(path, pen)(real begin, real end=); marginT Margin(path, pen); side NoSide; file stdout; void mapArray(string From, string To); frame Seascape(frame f); pair up; pen ZapfChancery(string series=, string shape=); pair left; bool prconly(string format=); pen deepgreen; pen lightmagenta; real bracedefaultratio; transform Scale(transform t); string getstring(string name=, string default=, string prompt=, bool store=); marginT DotMargins(path, pen); path[] MarkPath; frame[] fit(string prefix=, picture[] pictures, string format=, bool view=, string options=, string script=, projection P=); pen Bookman(string series=, string shape=); path box(frame dest, frame src=, real xmargin=, real ymargin=, pen p=, filltype filltype=, bool above=); path box(frame f, Label L, real xmargin=, real ymargin=, pen p=, filltype filltype=, bool above=); path box(pair a, pair b); picture legenditem(Legend legenditem, real linelength); pen deepgray; string defaultformat(int n, string trailingzero=, bool fixed=, bool signed=); string defaultformat; pen lightcyan; pen paleblue; frame align(frame f, pair align); object align(object F, pair align); path[] align(path[] g, transform t=, pair position, pair align, pen p=); transform scaleless(transform t); pen RGB(int r, int g, int b); pen thin(); real arcarrowangle; void restoredefaults(); pen longdashdotted; void usepackage(string s, string options=); pen dashed; string TeXify(string s); string graphic(string name, string options=); frame Portrait(frame f); real braceinnerangle; guide operator ---(... guide[]); int JOIN_IN; real barfactor; void arrow(picture pic=, Label L=, pair b, pair dir, real length=, align align=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=); picture arrow(arrowhead arrowhead=, path g, pen p=, real size=, real angle=, filltype filltype=, position position=, bool forwards=, marginT margin(path, pen)=, bool center=); void unitsize(picture pic=, real x, real y=, real z=); pen lightgreen; transform zeroTransform; void endl(file file); bool ArcArrow(picture, path, pen, marginT(path, pen))(arrowhead arrowhead=, real size=, real angle=, filltype filltype=, position position=); bool ArcArrow(picture, path, pen, marginT(path, pen)); void usersetting(); bool prc0(string format=); object embed3(string, frame, string, string, string, light, projection); pair rectify(pair dir); arrowhead TeXHead; void beep(); real labelmargin; real labelmargin(pen p=); pen lightblue; real bracemidangle; path unitsquare; void savedefaults()(); bool MidArrow(picture, path, pen, marginT(path, pen))(arrowhead arrowhead=, real size=, real angle=, filltype filltype=); bool MidArrow(picture, path, pen, marginT(path, pen)); pen cyan; pen grey; transform rotation(transform t); pair W; pen magenta; pair WSW; pen nobasealign; frame Landscape(frame f); real camerafactor; pen lightred; path trim(path g, real begin, real end=); marginT DotMargin(path, pen)(real begin, real end=); marginT DotMargin(path, pen); pen squarepen; pen deepyellow; real barsize(pen p=); void begin(picture pic=, string name, string id=, bool visible=); bool BeginArcArrow(picture, path, pen, marginT(path, pen)); bool BeginArcArrow(picture, path, pen, marginT(path, pen))(arrowhead arrowhead=, real size=, real angle=, filltype filltype=, position position=); real legendmargin; bool None(picture, path, pen, marginT(path, pen)); pen AvantGarde(string series=, string shape=); real circleprecision; pen Black; pen Pen(int n); pair ENE; pen Courier(string series=, string shape=); void makedraw(frame f, path g, pen p, int depth=); pair down; path arc(pair c, real r, real angle1, real angle2); path arc(pair c, explicit pair z1, explicit pair z2, bool direction=); path arc(pair c, real r, real angle1, real angle2, bool direction); pair right; string outformat(string format=); string outprefix(string prefix=); object object(Label L); object object(Label L, path e(frame dest, frame src=, real xmargin=, real ymargin=, pen p=, filltype filltype=, bool above=), real xmargin=, real ymargin=, pen p=, filltype filltype=, bool above=); object object(frame f); filltype Fill; filltype Fill(real xmargin=, real ymargin=, pen p=); pen Palatino(string series=, string shape=); pair[] intersectionpoints(path p, path q, real fuzz=); pair[] intersectionpoints(explicit path[] p, explicit path[] q, real fuzz=); real arcarrowsize(pen p=); real calculateScaling(string dir, coord[] coords, real size, bool warn=); real calculateScaling(string dir, coord[] m, coord[] M, real size, bool warn=); real expansionfactor; position BeginPoint; real arrowhookfactor; bool finite(real x); bool finite(pair z); bool finite(triple v); filltype UnFill(real xmargin=, real ymargin=); filltype UnFill; bool Bars(picture, path, pen, marginT(path, pen)); bool Bars(picture, path, pen, marginT(path, pen))(real size=); pair I; pair SSW; transform Slant(transform t); pair intersectionpoint(path p, path q, real fuzz=); real getreal(string name=, real default=, string prompt=, bool store=); pen darkbrown; int sourceline(string file, string text); real RELEASE; void updatefunction(); bool implicitshipout; void buildRestoreDefaults()(); path[] operator ^^(path p, path q); path[] operator ^^(explicit path[] p, path q); path[] operator ^^(path p, explicit path[] q); path[] operator ^^(explicit path[] p, explicit path[] q); real arrow2sizelimit; filltype FillDraw; filltype FillDraw(real xmargin=, real ymargin=, pen fillpen=, pen drawpen=); bool debugging; void shipout(string prefix=, frame f, string format=, bool wait=, bool view=, string options=, string script=, light light=, projection P=, transform t=); void shipout(string prefix=, picture pic=, frame orientation(frame)=, string format=, bool wait=, bool view=, string options=, string script=, light light=, projection P=); void pause(string w=); int ocgindex; pen springgreen; pen heavygrey; void markuniform(picture pic=, frame f, path g)(pair z(real t), real a, real b, int n); void markuniform(picture pic=, frame f, path g)(bool centered=, int n, bool rotated=); bool BeginArrow(picture, path, pen, marginT(path, pen)); bool BeginArrow(picture, path, pen, marginT(path, pen))(arrowhead arrowhead=, real size=, real angle=, filltype filltype=, position position=); real circlescale; bool ignore; pen darkblue; real reltime(path p, real l); void marknodes(picture pic=, frame f, path g); int JOIN_OUT; projection currentprojection; real arrowsizelimit; pair endpoint(path p); arrowhead HookHead; arrowhead HookHead(real dir=, real barb=); real[] concat(... real[][]); pair[] concat(... pair[][]); pen[] concat(... pen[][]); picture[] concat(... picture[][]); path[] concat(... path[][]); coord[] concat(... coord[][]); marker[] concat(... marker[][]); int[] concat(... int[][]); void()()[] concat(... void()()[][]); bool3[] concat(... bool3[][]); string[] concat(... string[][]); object[] concat(... object[][]); Legend[] concat(... Legend[][]); triple[] concat(... triple[][]); Label[] concat(... Label[][]); frame[] concat(... frame[][]); guide[] concat(... guide[][]); bool[] concat(... bool[][]); slice firstcut(path p, path knife); frame UpsideDown(frame f); pair viewportmargin; pen nullpen; string ask(string prompt); frame[] fit2(picture[] pictures, picture all); void save()(); real dotfactor; pen palecyan; node node(void d(frame f, transform t, transform T, pair lb, pair rt), string key=); marginT BeginMargin(path, pen); path buildcycle(... path[] p); marker markthin(path g, pen p=, real thin(real fraction)=, filltype filltype=); void activatequote(picture pic=); int undefined; void drawarrow2(frame f, arrowhead arrowhead=, path g, pen p=, real size=, real angle=, filltype filltype=, marginT margin(path, pen)=); pen roundcap; void buildRestoreThunk()(); void overloadedMessage(file file); bool EndArrow(picture, path, pen, marginT(path, pen))(arrowhead arrowhead=, real size=, real angle=, filltype filltype=, position position=); bool EndArrow(picture, path, pen, marginT(path, pen)); frame currentpatterns; real arrowfactor; pen heavyred; pen black; void Draw(picture pic=, path g, pen p=); filltype Draw; void Draw(picture pic=, explicit path[] g, pen p=); filltype Draw(real xmargin=, real ymargin=, pen p=); void tab(file file); marker marker(frame f=, void markroutine(picture pic=, frame f, path g)=, bool above=); marker marker(path[] g, void markroutine(picture pic=, frame f, path g)=, pen p=, filltype filltype=, bool above=); bool CCW; void usetypescript(string s, string encoding=); path randompath(int n, bool cumulate=, guide join(... guide[])=); void()()[] array(int n, void value()(), int depth=); bool[] array(int n, bool value, int depth=); string[] array(int n, string value, int depth=); pair[][] array(int n, pair[] value, int depth=); bool3[] array(int n, bool3 value, int depth=); Label[] array(int n, Label value, int depth=); picture[] array(int n, picture value, int depth=); real[][] array(int n, real[] value, int depth=); real[] array(int n, real value, int depth=); triple[] array(int n, triple value, int depth=); path[] array(int n, path value, int depth=); frame[] array(int n, frame value, int depth=); pen[][] array(int n, pen[] value, int depth=); coord[] array(int n, coord value, int depth=); object[] array(int n, object value, int depth=); marker[] array(int n, marker value, int depth=); Legend[] array(int n, Legend value, int depth=); int[] array(int n, int value, int depth=); string[][] array(int n, string[] value, int depth=); pair[] array(int n, pair value, int depth=); guide[] array(int n, guide value, int depth=); pen[] array(int n, pen value, int depth=); string[] array(string s); real[] uniform(real a, real b, int n); pair viewportsize; picture currentpicture; pen palegreen; Label Label(Label L, pair position, align align=, pen p=, transform embed(transform)=, filltype filltype=); Label Label(string s, string size=, explicit position position, align align=, pen p=, transform embed(transform)=, filltype filltype=); Label Label(Label L, explicit position position, align align=, pen p=, transform embed(transform)=, filltype filltype=); Label Label(explicit pair position, align align=, pen p=, transform embed(transform)=, filltype filltype=); Label Label; Label Label(string s=, string size=, align align=, pen p=, transform embed(transform)=, filltype filltype=); Label Label(string s, string size=, pair position, align align=, pen p=, transform embed(transform)=, filltype filltype=); Label Label(Label L, align align=, pen p=, transform embed(transform)=, filltype filltype=); hsv hsv(real h, real s, real v); hsv hsv(pen p); projection projection(triple camera, triple up=, triple target=, triple normal=, real zoom=, real angle=, pair viewportshift=, bool showtarget=, bool autoadjust=, bool center=, transformation projector(triple camera, triple up, triple target)); pair N; real dotsize(pen p=); real pt; settings settings; int MoveQuiet; pair WNW; pen palegray; pen miterjoin; arrowhead SimpleHead; real arrowangle; frame dotframe(pen p=, filltype filltype=); frame dotframe; path diamond; real arcarrowfactor; real mm; pen heavyblue; filltype dotfilltype; plain plain; int getint(string name=, int default=, string prompt=, bool store=); int bitreverse(int a, int bits); int popcount(int a); int CLZ(int a); int NOT(int a); int XOR(int a, int b); int OR(int a, int b); real[][] scale3(real s); int AND(int a, int b); real[] cubicroots(real a, real b, real c, real d); void attach(picture dest=, frame src, pair position, pair align, bool group=, filltype filltype=, bool above=); void attach(picture dest=, frame src, pair position=, bool group=, filltype filltype=, bool above=); real[] quadraticroots(real a, real b, real c); pair[] quadraticroots(explicit pair a, explicit pair b, explicit pair c); path[] strokepath(path g, pen p=); real erf(real x); real Yn(int n, real x); real Jn(int n, real x); light light(pen diffuse=, pen specular=, pen background=, real x, real y, real z); light light(explicit light light); light light(pen diffuse=, pen specular=, pen background=, real specularfactor= ... triple[] position); light light(pen[] diffuse, pen[] specular=, pen background=, real specularfactor=, triple[] position); real remainder(real x, real y); int choose(int n, int k); real hypot(real x, real y); int Round(real x); int Ceil(real x); marginT BeginPenMargin(path, pen); int round(real x); int floor(real x); pen extendcap; int ceil(real x); int rand(); int sgn(real x); int quotient(int x, int y); path3 path3(triple[] pre, triple[] point, triple[] post, bool[] straight, bool cyclic); real incircle(pair a, pair b, pair c, pair d); real atan2(real y, real x); bool inside(explicit path[] g, pair z, pen fillrule=); bool inside(path g, pair z, pen fillrule=); int inside(path p, path q, pen fillrule=); pair inside(path p, pen fillrule=); real erfc(real x); int windingnumber(path[] p, pair z); real relativedistance(real theta, real phi, real t, bool atleast); string[] file3; real[] maxtimes(path p); real[] maxtimes(path3 p); real[] mintimes(path p); real[] mintimes(path3 p); pair maxAfterTransform(transform t, path[] p); pair minAfterTransform(transform t, path[] p); pair extension(pair p, pair q, pair p, pair q); string mapArrayString(string From, string To); real[][] intersections(path p, path q, real fuzz=); real[] intersections(path p, explicit pair a, explicit pair b, real fuzz=); real[][] intersections(path3 p, path3 q, real fuzz=); real[][] intersections(path3 p, triple[][] p, real fuzz=); real[] intersect(path p, path q, real fuzz=); real[] intersect(path3 p, path3 q, real fuzz=); real[] intersect(path3 p, triple[][] p, real fuzz=); real dirtime(path p, pair z); real arctime(path p, real l); real arctime(path3 p, real dval); position Relative(real position); side Relative(explicit pair align); marginT Margins(path, pen); pair truepoint(picture pic=, pair dir, bool user=); real arclength(path p); real arclength(pair z0, pair c0, pair c1, pair z1); real arclength(path3 p); real arclength(triple z0, triple c0, triple c1, triple z1); bool piecewisestraight(path p); bool piecewisestraight(path3 p); path nurb(pair z0, pair z1, pair z2, pair z3, real w0, real w1, real w2, real w3, int m); path subpath(path p, int a, int b); path subpath(path p, real a, real b); path3 subpath(path3 p, int a, int b); path3 subpath(path3 p, real a, real b); real radius(path p, real t); real radius(path3 p, real t); real radius(triple z0, triple c0, triple c1, triple z1, real t); pair accel(path p, int t, int sign=); pair accel(path p, real t); triple accel(path3 p, int t, int sign=); triple accel(path3 p, real t); pair precontrol(path p, int t); pair precontrol(path p, real t); triple precontrol(path3 p, int t); triple precontrol(path3 p, real t); string defaultfilename; real longitude(triple v, bool warn=); filltype NoFill; real colatitude(triple v, bool warn=); marker nomarker; pair beginpoint(path p); real azimuth(triple v, bool warn=); real polar(triple v, bool warn=); real zpart(triple v); pair bezierPPP(pair a, pair b, pair c, pair d); triple bezierPPP(triple a, triple b, triple c, triple d); pair SSE; pair bezierP(pair a, pair b, pair c, pair d, real t); triple bezierP(triple a, triple b, triple c, triple d, real t); pair realmult(pair z, pair w); triple realmult(triple u, triple v); int Floor(real x); pair gamma(explicit pair z); real gamma(real x); pair expi(real angle); triple expi(real polar, real azimuth); pair dir(real degrees); pair dir(explicit pair z); triple dir(explicit triple z); triple dir(real colatitude, real longitude); pair dir(path p, int t, int sign=, bool normalize=); pair dir(path p, real t, bool normalize=); triple dir(path3 p, int t, int sign=, bool normalize=); triple dir(path3 p, real t, bool normalize=); pair dir(path p); pair dir(path p, path q); real aTan(real x); real aCos(real x); real aSin(real x); real arrowsize(pen p=); real Tan(real deg); real Cos(real deg); frame legend(picture pic=, int perline=, real xmargin=, real ymargin=, real linelength=, real hskip=, real vskip=, real maxwidth=, real maxheight=, bool hstretch=, bool vstretch=, pen p=); picture legend(Legend[] Legend, int perline=, real linelength, real hskip, real vskip, real maxwidth=, real maxheight=, bool hstretch=, bool vstretch=); real Degrees(real radians); frame pad(picture pic=, real xsize=, real ysize=, filltype filltype=); real radians(real degrees); real angle(pair z, bool warn=); real angle(transform t); side Center; real ypart(pair z); real ypart(triple v); real xpart(pair z); real xpart(triple v); int seconds(string t=, string format=); pen rgba(real[] a); real[] rgba(pen p); string time(string format=); string time(int seconds, string format=); string string(int x); string string(real x, int digits=); int ascii(string s); side RightSide; string replace(string s, string[][] translate); string replace(string s, string before, string after); pen lightgrey; string upcase(string s); pen mediumgray; string downcase(string s); string substr(string s, int pos, int n=); string insert(string s, int pos, string t); int rfind(string s, string t, int pos=); void purge(int divisor=); int animate(string args=, string file=, string format=); int convert(string args=, string file=, string format=); real sqrtEpsilon; string stripextension(string s); string stripfile(string s); string stripdirectory(string s); void warning(string s, string t, bool position=); pair S; real abs2(pair z); real abs2(triple v); void nowarn(string s); void warn(string s); void breakpoints(); string locatefile(string file, bool full=); void breakpoint(code s=); void atbreakpoint(string f(string, int, int, code)); string phantom(string s); void atexit(void f()); void atexit()(); void atupdate(void f()); void atupdate()(); string outname(); string mktemp(string s); int rename(string from, string to); real arrowbarb; pen yellow; int delete(string s); void seekeof(file f); pen heavymagenta; marginT PenMargins(path, pen); void newl(file file); void seek(file f, int pos); bool Arrows(picture, path, pen, marginT(path, pen))(arrowhead arrowhead=, real size=, real angle=, filltype filltype=); bool Arrows(picture, path, pen, marginT(path, pen)); int tell(file f); void DOSendl(file file); string debugger(string file, int line, int column, code s=); string getc(file f); void flush(file f); pen blue; pen evenodd; int precision(file f=, int digits=); void close(file f); void clear(file f); void clear(string file, int line); void clear(); void clear(string file, string text); void unfill(frame f, path[] g, bool copy=); void unfill(picture pic=, path[] g, bool copy=); bool Bar(picture, path, pen, marginT(path, pen))(real size=); bool Bar(picture, path, pen, marginT(path, pen)); bool eol(file f); bool eof(file f); pen paleyellow; file output(string name=, bool update=, string comment=, string mode=); file input(string name=, bool check=, string comment=, string mode=); pair bezierPP(pair a, pair b, pair c, pair d, real t); triple bezierPP(triple a, triple b, triple c, triple d, real t); real[] _projection(); triple maxbezier(triple[][] p, triple b); triple minbezier(triple[][] p, triple b); real legendvskip; pen darkmagenta; real change2(triple[][] a); pair NW; real norm(real[] a); real norm(real[][] a); real norm(triple[][] a); int[][] triangulate(pair[] z); pair[] fft(pair[] a, int sign=); pair[][] fft(pair[][] a, int sign=); pair[][][] fft(pair[][][] a, int sign=); real simpson(real f(real), real a, real b, real acc=, real dxmax=); pen[] colorPen; real _findroot(real f(real), real a, real b, real tolerance, real fa, real fb); real newton(int iterations=, real f(real), real fprime(real), real x, bool verbose=); real newton(int iterations=, real f(real), real fprime(real), real x1, real x2, bool verbose=); real[] tridiagonal(real[] a, real[] b, real[] c, real[] f); void filldraw(picture pic=, path[] g, pen fillpen=, pen drawpen=); void filldraw(frame f, path[] g, pen fillpen=, pen drawpen=); real dot(real[] a, real[] b); pair dot(pair[] a, pair[] b); real dot(explicit pair z, explicit pair w); real dot(triple u, triple v); void dot(picture pic=, Label[] L=, explicit path g, align align=, string format=, pen p=, filltype filltype=); marker dot(pen p=, filltype filltype=); void dot(picture pic=, pair z, pen p=, filltype filltype=); void dot(frame f, pair z, pen p=, filltype filltype=); void dot(picture pic=, Label L, pen p=, filltype filltype=); void dot(picture pic=, Label[] L=, pair[] z, align align=, string format=, pen p=, filltype filltype=); void dot(picture pic=, path[] g, pen p=, filltype filltype=); marker dot; void dot(picture pic=, Label L, pair z, align align=, string format=, pen p=, filltype filltype=); pair ESE; pair project(triple v, real[][] t); real[][] AtA(real[][] a); real[] solve(real[][] a, real[] b, bool warn=); real[][] solve(real[][] a, real[][] b, bool warn=); scaleT scaleT(real T(real x), real Tinv(real x), bool logarithmic=, bool automin=, bool automax=); string baseline(string s, string template=); int[] findall(bool[] a); bool BeginBar(picture, path, pen, marginT(path, pen)); bool BeginBar(picture, path, pen, marginT(path, pen))(real size=); triple perp(triple v, triple u); int find(bool[] a, int n=); int find(string s, string t, int pos=); real degrees(pair z, bool warn=); real degrees(real radians); bool[] operator !(bool[] a); bool operator !(bool b); int[] sequence(int n); pen[][] sequence(pen[] f(int), int n); coord[] sequence(coord f(int), int n); object[] sequence(object f(int), int n); marker[] sequence(marker f(int), int n); Legend[] sequence(Legend f(int), int n); int[] sequence(int f(int), int n); string[][] sequence(string[] f(int), int n); pair[] sequence(pair f(int), int n); int[] sequence(int n, int m, int skip); guide[] sequence(guide f(int), int n); pen[] sequence(pen f(int), int n); void()()[] sequence(void f()()(int), int n); bool[] sequence(bool f(int), int n); string[] sequence(string f(int), int n); pair[][] sequence(pair[] f(int), int n); bool3[] sequence(bool3 f(int), int n); Label[] sequence(Label f(int), int n); picture[] sequence(picture f(int), int n); real[][] sequence(real[] f(int), int n); real[] sequence(real f(int), int n); int[] sequence(int n, int m); triple[] sequence(triple f(int), int n); path[] sequence(path f(int), int n); frame[] sequence(frame f(int), int n); int[] complement(int[] a, int n); path[] complement(frame f, path[] g); void saveline(string name, string value, bool store=); string readline(string prompt=, string name=, bool tabcompletion=); real unitrand(); string[] history(string name, int n=); string[] history(int n=); path[] _strokepath(path g, pen p=); path[][] textpath(string[] s, pen[] p); marginT NoMargin(path, pen); marginT NoMargin(path, pen)(); path[][] _texpath(string[] s, pen[] p); int SuppressQuiet; real[] texsize(string s, pen p=); bool labels(frame f); slice cut(path p, path knife, int n); bool is3D(frame f); bool is3D(string format=); transformation transformation(real[][] modelview); transformation transformation(real[][] modelview, real[][] projection); pair maxratio(frame f); pair maxratio(triple[][] p, pair b); pair maxratio(path3 g); pair minratio(frame f); pair minratio(triple[][] p, pair b); pair minratio(path3 g); triple size3(frame f); void size3(picture pic=, real x, real y=, real z=, bool keepAspect=); triple max3(frame f); triple max3(pen p); int[] MarkFillable; pair unit(pair z); triple unit(triple v); triple min3(frame f); triple min3(pen p); void drawpixel(frame f, triple v, pen p, real width=); pair[] pairs(real[] x, real[] y); void eval(code s, bool embedded=); void eval(string s, bool embedded=); bool Arrow(picture, path, pen, marginT(path, pen))(arrowhead arrowhead=, real size=, real angle=, filltype filltype=, position position=); bool Arrow(picture, path, pen, marginT(path, pen)); void drawTube(frame f, triple[] g, real width, pen[] p, real opacity, real shininess, real metallic, real fresnel0, triple min, triple max, bool core=); void drawDisk(frame f, real[][] t, pen[] p, real opacity, real shininess, real metallic, real fresnel0); void stop(string file, int line, code s=); void stop(string file, string text, code s=); void drawCylinder(frame f, real[][] t, pen[] p, real opacity, real shininess, real metallic, real fresnel0, bool core=); real insphere(triple a, triple b, triple c, triple d, triple e); void drawSphere(frame f, real[][] t, bool half=, pen[] p, real opacity, real shininess, real metallic, real fresnel0, int type); string[] spinner; real[] times(path p, real x, real fuzz=); real[] times(path p, explicit pair z, real fuzz=); void drawbeziertriangle(frame f, triple[][] p, triple center, bool straight, pen[] p, real opacity, real shininess, real metallic, real fresnel0, pen[] colors, int interaction, int digits, bool primitive=); void draw(frame f, triple[][] p, triple center, bool straight, pen[] p, real opacity, real shininess, real metallic, real fresnel0, pen[] colors, int interaction, int digits, bool primitive=); void draw(frame f, triple[] p, real[] knot, real[] weights=, pen p); void draw(frame f, triple[][] p, real[] uknot, real[] vknot, real[][] weights=, pen[] p, real opacity, real shininess, real metallic, real fresnel0, pen[] colors); void draw(frame f, triple[] v, int[][] vi, triple center=, triple[] n, int[][] ni, pen[] p, real opacity, real shininess, real metallic, real fresnel0, pen[] c=, int[][] ci=, int interaction); void draw(picture pic=, path[] g, pen fillrule=, pen[] p); object draw(picture pic=, Label L, path e(frame dest, frame src=, real xmargin=, real ymargin=, pen p=, filltype filltype=, bool above=), pair position, real xmargin=, real ymargin=, pen p=, filltype filltype=, bool above=); void draw(frame f, explicit path[] g, pen p=); void draw(picture pic=, Label L=, path g, align align=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, bool bar(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, Label legend=, marker marker=); void draw(pair origin, picture pic=, Label L=, path g, align align=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, bool bar(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, Label legend=, marker marker=); object draw(picture pic=, Label L, path e(frame dest, frame src=, real xmargin=, real ymargin=, pen p=, filltype filltype=, bool above=), real xmargin=, real ymargin=, pen p=, filltype filltype=, bool above=); void draw(picture pic=, guide[] g, pen p=, Label legend=, marker marker=); void draw(pair origin, picture pic=, guide[] g, pen p=, Label legend=, marker marker=); void draw(frame f, guide[] g, pen p=); void draw(frame f, path g, pen p=); void draw(picture pic=, explicit path[] g, pen p=, Label legend=, marker marker=); void draw(pair origin, picture pic=, explicit path[] g, pen p=, Label legend=, marker marker=); void draw(frame f, path g, pen p=, bool arrow(picture, path, pen, marginT(path, pen))); void deconstruct(frame f, frame preamble=, transform t=); void deconstruct(picture pic=); void shipout3(string prefix, frame f, string format=, real width, real height, real angle, real zoom, triple m, triple m, pair shift, pair margin, real[][] t, real[][] tup, real[] background, triple[] lights, real[][] diffuse, real[][] specular, bool view=); void shipout3(string prefix, frame f, string format=); int CTZ(int a); void _shipout(string prefix=, frame f, frame preamble=, string format=, bool wait=, bool view=, transform t=); void asy(string format, bool overwrite= ... string[] s); bool latex(); string nativeformat(); path unstraighten(path p); path3 unstraighten(path3 p); void _image(frame f, real[][] data, pair initial, pair final, pen[] palette=, transform t=, bool copy=, bool antialias=); void _image(frame f, pen[][] data, pair initial, pair final, transform t=, bool copy=, bool antialias=); void _image(frame f, pen f(int, int), int width, int height, pair initial, pair final, transform t=, bool antialias=); void layer(frame f); void layer(picture pic=); void texreset(); void _labelpath(frame f, string s, string size, path g, string justify, pair offset, pen p); real arrowtexfactor; void comma(file file); void deletepreamble(); version version; void texpreamble(string s); real braceouterangle; void tex(frame f, string s); void tex(frame f, string s, pair min, pair max); void tex(picture pic=, string s); void tex(picture pic=, string s, pair min, pair max); void prepend(frame dest, frame src); void add(frame dest, frame src); void add(picture dest=, frame src, pair position, pair align, bool group=, filltype filltype=, bool above=); void add(frame dest, frame src, pair position, pair align, bool group=, filltype filltype=, bool above=); void add(picture src, bool group=, filltype filltype=, bool above=); void add(picture pic=, void d(frame f, transform t), bool exact=); void add(picture pic=, void d(frame f, real[][] t, picture pic, projection P), bool exact=); void add(picture pic=, void d(picture, real[][]), bool exact=); void add(picture pic=, Label L); void add(picture dest, picture src, bool group=, filltype filltype=, bool above=); void add(frame f, transform t=, Label L); void add(picture dest, picture src, pair position, bool group=, filltype filltype=, bool above=); void add(picture dest=, object F, pair position=, bool group=, filltype filltype=, bool above=); void add(frame dest, frame src, filltype filltype, bool above=); void add(frame dest, frame src, bool group, filltype filltype=, bool above=); void add(frame dest, frame src, pair position, bool group=, filltype filltype=, bool above=); void add(picture dest=, frame src, pair position=, bool group=, filltype filltype=, bool above=); void add(picture pic=, void d(picture, transform), bool exact=); void add(picture src, pair position, bool group=, filltype filltype=, bool above=); void endgroup3(frame f); void _begingroup3(frame f, string name, real compression, real granularity, bool closed, bool tessellate, bool dobreak, bool nobreak, triple center, int interaction); void endgroup(frame f); void endgroup(picture pic=); void begingroup(frame f); void begingroup(picture pic=); bool MidArcArrow(picture, path, pen, marginT(path, pen))(arrowhead arrowhead=, real size=, real angle=, filltype filltype=); bool MidArcArrow(picture, path, pen, marginT(path, pen)); void grestore(frame f); void beginclip(frame f, path[] g, bool stroke=, pen fillrule=, bool copy=); void beginclip(picture pic=, path[] g, bool stroke=, pen fillrule=, bool copy=); pen palegrey; void clip(frame f, path[] g, bool stroke=, pen fillrule=, bool copy=); void clip(picture pic=, path[] g, bool stroke=, pen fillrule=, bool copy=); int Allow; real determinant(real[][] a); void functionshade(frame f, path[] g, bool stroke=, pen fillrule=, string shader=, bool copy=); void functionshade(picture pic=, path[] g, bool stroke=, pen fillrule=, string shader, bool copy=); bool EndArcArrow(picture, path, pen, marginT(path, pen))(arrowhead arrowhead=, real size=, real angle=, filltype filltype=, position position=); bool EndArcArrow(picture, path, pen, marginT(path, pen)); void tensorshade(frame f, path[] g, bool stroke=, pen fillrule=, pen[][] p, path[] b=, pair[][] z=, bool copy=); void tensorshade(picture pic=, path[] g, bool stroke=, pen fillrule=, pen[][] p, path[] b=, pair[][] z=, bool copy=); void tensorshade(frame f, path[] g, bool stroke=, pen fillrule=, pen[] p, path b=, pair[] z=); void tensorshade(picture pic=, path[] g, bool stroke=, pen fillrule=, pen[] p, path b=, pair[] z=); file _outpipe; void gouraudshade(frame f, path[] g, bool stroke=, pen fillrule=, pen[] p, pair[] z, int[] edges, bool copy=); void gouraudshade(frame f, path[] g, bool stroke=, pen fillrule=, pen[] p, int[] edges, bool copy=); void gouraudshade(picture pic=, path[] g, bool stroke=, pen fillrule=, pen[] p, pair[] z, int[] edges, bool copy=); void gouraudshade(picture pic=, path[] g, bool stroke=, pen fillrule=, pen[] p, int[] edges, bool copy=); pair getpair(string name=, pair default=, string prompt=, bool store=); void axialshade(frame f, path[] g, bool stroke=, pen pena, pair a, bool extenda=, pen penb, pair b, bool extendb=, bool copy=); void axialshade(picture pic=, path[] g, bool stroke=, pen pena, pair a, bool extenda=, pen penb, pair b, bool extendb=, bool copy=); pen chartreuse; void latticeshade(frame f, path[] g, bool stroke=, pen fillrule=, pen[][] p, transform t=, bool copy=); void latticeshade(picture pic=, path[] g, bool stroke=, pen fillrule=, pen[][] p, bool copy=); void fill(frame f, path[] g, pen p=, bool copy=); path fill(frame dest, frame src, filltype filltype=, real xmargin=, real ymargin=); void fill(picture pic=, path[] g, pen p=, bool copy=); void fill(pair origin, picture pic=, path[] g, pen p=); void _draw(frame f, path g, pen p); void _draw(frame f, path3 g, triple center=, pen[] p, real opacity, real shininess, real metallic, real fresnel0, int interaction=); void _draw(picture pic, path g, pen p, marginT margin(path, pen)); void initdefaults(); void erase(frame f); string erase(string s, int pos, int n); void erase(picture pic=); string jobname(string name); void print_random_addresses(int n=); void generate_random_backtrace(); marginT TrueMargin(path, pen)(real begin, real end=); real bezier(real a, real b, real c, real d, real t); pair bezier(pair a, pair b, pair c, pair d, real t); triple bezier(triple a, triple b, triple c, triple d, real t); pen squarecap; bool isometry(transform t); guide operator ::(... guide[]); pen Helvetica(string series=, string shape=); transform reflect(pair a, pair b); transform rotate(real angle, pair z=); bool IgnoreAspect; void postscript(frame f, string s); void postscript(frame f, string s, pair min, pair max); void postscript(picture pic=, string s); void postscript(picture pic=, string s, pair min, pair max); transform slant(real s); transform yscale(real y); transform inverse(transform t); real[][] inverse(real[][] a); pen darkgrey; transform xscale(real x); transform shiftless(transform t); real[][] shiftless(real[][] t); real[] _cputime(); guide reverse(guide g); string reverse(string s); path reverse(path p); path3 reverse(path3 p); triple[] reverse(triple[] a); int[] reverse(int[] a); real[] reverse(real[] a); int[] reverse(int n); string[] reverse(string[] a); pair[] reverse(pair[] a); bool[] reverse(bool[] a); real[] curlSpecifier(guide g, int t); bool Blank(picture, path, pen, marginT(path, pen)); tensionSpecifier tensionSpecifier(guide g, int t); bool3 default; pair[] controlSpecifier(guide g, int t); pen red; pair[] dirSpecifier(guide g, int t); pen longdashed; pair point(guide g, int t); pair point(path p, int t); pair point(path p, real t); triple point(path3 p, int t); triple point(path3 p, real t); pair point(picture pic=, pair dir, bool user=); pair point(object F, pair dir, transform t=); pair point(frame f, pair dir); int length(guide g); int length(string s); real length(pair z); real length(triple v); int length(path p); int length(path3 p); int size(guide g); pair size(frame f); int size(path p); int size(path[] p); int size(path3 p); void size(picture dest, picture src); pair size(picture pic, bool user=); void size(picture pic=, transform t); void size(picture pic=, real x, real y=, bool keepAspect=); void size(picture pic=, real xsize, real ysize, pair min, pair max); string texify(string s); guide operator controls(pair zout, pair zin); guide operator controls(pair z); bool empty(frame f); tensionSpecifier operator tension(real tout, real tin, bool atleast); tensionSpecifier operator tension(real t, bool atLeast); void end(picture pic=); curlSpecifier operator curl(real gamma, int p); guide operator spec(pair z, int p); void list(string s, bool imports=); string cd(string s=); int Move; string location(); string xasyKEY(); void xasyKEY(string s); bool pdf(); void _eval(string s, bool embedded, bool interactivewrite=); void _eval(code s, bool embedded); void usleep(int microseconds); void sleep(int seconds); real Sin(real deg); void assert(bool b, string s=); pair Align; void exit(); void abort(string s=); string locale(string s=); string defaultseparator; string asydir(); bool view(); int system(string[] s); int system(string s); bool interactive(); pen colorless(pen p); bool straight(path p, int t); bool straight(path3 p, int t); pen makepen(path p); realschur schur(real[][] a); schur schur(pair[][] a); path nib(pen p); transform transform(pen p); pair relpoint(path p, real l); pair[][] transpose(pair[][] a); pen[][] transpose(pen[][] a); string[][] transpose(string[][] a); real[][] transpose(real[][] a); pen overwrite(int n); int overwrite(pen p=); real lineskip(pen p=); pen fontsize(real size, real lineskip); real fontsize(pen p=); pen fontsize(real size); string font(pen p=); pen font(string name, string options=); pen font(string encoding, string family, string series, string shape); pen font(string name, real size, string options=); void newpage(frame f); void newpage(picture pic=); pen fontcommand(string s); pen linewidth(real x); real linewidth(pen p=); real arrowlength; pen miterlimit(real x); real miterlimit(pen p=); pen linecap(int n); int linecap(pen p=); bool adjust(pen p); pen adjust(pen p, real arclength, bool cyclic); bool scale(pen p); transform scale(real x); transform scale(real x, real y); real[][] scale(real x, real y, real z); transform Shift(transform t); real fmod(real x, real y); real offset(pen p); real orient(pair a, pair b, pair c); real orient(triple a, triple b, triple c, triple d); pen linetype(real[] pattern, real offset=, bool scale=, bool adjust=); real[] linetype(pen p=); pen linetype(string pattern, real offset=, bool scale=, bool adjust=); string blend(pen p); void endclip(frame f); void endclip(picture pic=); pen opacity(real opacity=, string blend=); real opacity(pen p); pen fillrule(int n); int fillrule(pen p); real[][] identity4; marker[] MarkFill; pen pattern(string s); string pattern(pen p); pen solid; string colorspace(pen p); real byteinv(int x); int byte(real x); bool Aspect; string hex(pen p); int hex(string s); real[] colors(pen p); void DOSnewl(file file); pen cmyk(pen p); pen cmyk(real c, real m, real y, real k); pen rgb(pen p); pen rgb(real r, real g, real b); pen rgb(real[] a); pen rgb(string s); pen gray(pen p); pen gray(real gray); pen gray; bool invisible(pen p); pen invisible(); pen invisible; void defaultpen(pen p); pen defaultpen(); pen defaultpen; void defaultpen(real w); void resetdefaultpen(); bool isnan(real x); bool cyclic(guide g); bool cyclic(path p); bool cyclic(path3 p); void printBytecode(); pen currentpen; string VERSION; bool alias(pair[][] a, pair[][] b); bool alias(guide[] a, guide[] b); bool alias(marginT a, marginT b); bool alias(coord[] a, coord[] b); bool alias(Legend a, Legend b); bool alias(object a, object b); bool alias(marker[] a, marker[] b); bool alias(pair[] a, pair[] b); bool alias(scaling a, scaling b); bool alias(projection a, projection b); bool alias(picture a, picture b); bool alias(align a, align b); bool alias(Label[] a, Label[] b); bool alias(arrowhead a, arrowhead b); bool alias(int[] a, int[] b); bool alias(string[][] a, string[][] b); bool alias(slice a, slice b); bool alias(autoscaleT a, autoscaleT b); bool alias(position a, position b); bool alias(realschur a, realschur b); bool alias(real[][] a, real[][] b); bool alias(bool3 a, bool3 b); bool alias(bool3[] a, bool3[] b); bool alias(bounds a, bounds b); bool alias(node a, node b); bool alias(side a, side b); bool alias(string[] a, string[] b); bool alias(frame[] a, frame[] b); bool alias(coords2 a, coords2 b); bool alias(light a, light b); bool alias(coords3 a, coords3 b); bool alias(processtime a, processtime b); bool alias(bool[] a, bool[] b); bool alias(void()()[] a, void()()[] b); bool alias(pen[][] a, pen[][] b); bool alias(filltype a, filltype b); bool alias(ScaleT a, ScaleT b); bool alias(Label a, Label b); bool alias(picture[] a, picture[] b); bool alias(schur a, schur b); bool alias(path[] a, path[] b); bool alias(triple[] a, triple[] b); bool alias(coord a, coord b); bool alias(freezableBounds a, freezableBounds b); bool alias(transformation a, transformation b); bool alias(pairOrTriple a, pairOrTriple b); bool alias(object[] a, object[] b); bool alias(marker a, marker b); bool alias(Legend[] a, Legend[] b); bool alias(real[] a, real[] b); bool alias(pen[] a, pen[] b); bool alias(hsv a, hsv b); bool alias(scaleT a, scaleT b); bool alias(cputime a, cputime b); real pi; int randMax; pen heavycyan; marginT PenMargin(path, pen)(real begin, real end=); marginT PenMargin(path, pen); int realDigits; real realEpsilon; pair NE; real realMin; real realMax; real nan; real infinity; void xmap(string key, transform t=); real inf; int intMin; int intMax; pen palered; real[] map(real f(pair), pair[] a); int[] map(int f(real), real[] a); bool3[] map(bool3 f(bool3), bool3[] a); frame[] map(frame f(frame), frame[] a); coord[] map(coord f(coord), coord[] a); marker[] map(marker f(marker), marker[] a); pen[][] map(pen[] f(pen[]), pen[][] a); triple[] map(triple f(triple), triple[] a); pen[] map(pen f(pen), pen[] a); picture[] map(picture f(picture), picture[] a); pair[] map(pair f(pair), pair[] a); string[] map(string f(string), string[] a); void()()[] map(void f()()(void()()), void()()[] a); pair[][] map(pair[] f(pair[]), pair[][] a); real[] map(real f(real), real[] a); int[] map(int f(int), int[] a); string[][] map(string[] f(string[]), string[][] a); Label[] map(Label f(Label), Label[] a); bool[] map(bool f(bool), bool[] a); path[] map(path f(path), path[] a); real[][] map(real[] f(real[]), real[][] a); object[] map(object f(object), object[] a); Legend[] map(Legend f(Legend), Legend[] a); guide[] map(guide f(guide), guide[] a); real identity(real x); real[] identity(real[] a); transform identity(); real[][] identity(int n); transform identity; real pow10(real x); real[] pow10(real[] a); pen linejoin(int n); int linejoin(pen p=); real ldexp(real x, int e); real log1p(real x); real[] log1p(real[] a); void deactivatequote(picture pic=); path brace(pair a, pair b, real amplitude=); string format(string format, int x, string locale=); string format(string format, bool forcemath=, string separator, real x, string locale=); string format(string format=, bool forcemath=, real x, string locale=); real[][][] _schur(real[][] a); pair[][][] _schur(pair[][] a); real expm1(real x); real[] expm1(real[] a); void label(frame f, string s, string size, transform t, pair position, pair align, pen p); void label(picture pic=, Label L, align align=, pen p=, filltype filltype=); void label(pair origin, picture pic=, Label L, align align=, pen p=, filltype filltype=); void label(frame f, Label L, pair position, align align=, pen p=, filltype filltype=); void label(picture pic=, Label L, pair position, align align=, pen p=, filltype filltype=); void label(frame f, Label L, align align=, pen p=, filltype filltype=); void label(picture pic=, Label L, explicit guide g, align align=, pen p=, filltype filltype=); void label(picture pic=, Label L, explicit path g, align align=, pen p=, filltype filltype=); real fabs(real x); real[] fabs(real[] a); string stripsuffix(string f, string suffix=); real cbrt(real x); real[] cbrt(real[] a); real sqrt(real x); real[] sqrt(real[] a); pair sqrt(explicit pair z); bool all(bool[] a); real atanh(real x); real[] atanh(real[] a); real acosh(real x); real[] acosh(real[] a); transform shift(transform t); transform shift(pair z); transform shift(real x, real y); transform shift(frame f, pair align); real asinh(real x); real[] asinh(real[] a); pen ZapfDingbats(string series=, string shape=); real tanh(real x); real[] tanh(real[] a); real cosh(real x); real[] cosh(real[] a); real sinh(real x); real[] sinh(real[] a); real straightness(triple z0, triple c0, triple c1, triple z1); real straightness(path3 p, int t); real log10(real x); real[] log10(real[] a); pair midpoint(path p); real exp(real x); real[] exp(real[] a); pair exp(explicit pair z); pen purple; string italic(string s); real atan(real x); real[] atan(real[] a); real acos(real x); real[] acos(real[] a); path roundbox(frame dest, frame src=, real xmargin=, real ymargin=, pen p=, filltype filltype=, bool above=); path roundbox(frame f, Label L, real xmargin=, real ymargin=, pen p=, filltype filltype=, bool above=); real asin(real x); real[] asin(real[] a); real tan(real x); real[] tan(real[] a); pen Magenta; real cos(real x); real[] cos(real[] a); pair cos(explicit pair z); filltype RadialShadeDraw(real xmargin=, real ymargin=, pen penc, pen penr, pen drawpen=); real sin(real x); real[] sin(real[] a); pair sin(explicit pair z); path polygon(int n); guide operator --(... guide[]); void none(file file); int factorial(int n); real log(real x); real[] log(real[] a); pair log(explicit pair z); guide operator ..(... guide[]); guide operator ..(... guide[])(tensionSpecifier t); pair operator tuple(real x, real y); triple operator tuple(real x, real y, real z); transform operator tuple(real x, real y, real xx, real xy, real yx, real yy); int[][] diagonal(... int[]); real[][] diagonal(... real[]); pair[][] diagonal(... pair[]); path[] texpath(string s, pen p, bool tex=, bool bbox=); path[] texpath(Label L, bool tex=, bool bbox=); bool uptodate(); int operator #(int a, int b); int[] operator #(int a, int[] b); int[] operator #(int[] a, int b); int[] operator #(int[] a, int[] b); int operator %(int a, int b); int[] operator %(int a, int[] b); int[] operator %(int[] a, int b); int[] operator %(int[] a, int[] b); real operator %(real a, real b); real[] operator %(real a, real[] b); real[] operator %(real[] a, real b); real[] operator %(real[] a, real[] b); int search(int[] a, int key); int search(real[] a, real key); int search(string[] a, string key); int search(void()()[] a, void key()(), bool less(void()(), void()())); int search(real[] a, real key, bool less(real, real)); int search(guide[] a, guide key, bool less(guide, guide)); int search(pair[] a, pair key, bool less(pair, pair)); int search(picture[] a, picture key, bool less(picture, picture)); int search(frame[] a, frame key, bool less(frame, frame)); int search(coord[] a, coord key, bool less(coord, coord)); int search(marker[] a, marker key, bool less(marker, marker)); int search(int[] a, int key, bool less(int, int)); int search(bool3[] a, bool3 key, bool less(bool3, bool3)); int search(object[] a, object key, bool less(object, object)); int search(Legend[] a, Legend key, bool less(Legend, Legend)); int search(string[] a, string key, bool less(string, string)); int search(path[] a, path key, bool less(path, path)); int search(pen[] a, pen key, bool less(pen, pen)); int search(Label[] a, Label key, bool less(Label, Label)); int search(bool[] a, bool key, bool less(bool, bool)); int search(triple[] a, triple key, bool less(triple, triple)); int[] sort(int[] a); int[][] sort(int[][] a); real[] sort(real[] a); real[][] sort(real[][] a); string[] sort(string[] a); string[][] sort(string[][] a); coord[] sort(coord[] a, bool less(coord, coord), bool stable=); object[] sort(object[] a, bool less(object, object), bool stable=); marker[] sort(marker[] a, bool less(marker, marker), bool stable=); Legend[] sort(Legend[] a, bool less(Legend, Legend), bool stable=); path[] sort(path[] a, bool less(path, path), bool stable=); pen[][] sort(pen[][] a, bool less(pen[], pen[]), bool stable=); pair[][] sort(pair[][] a, bool less(pair[], pair[]), bool stable=); pen[] sort(pen[] a, bool less(pen, pen), bool stable=); bool[] sort(bool[] a, bool less(bool, bool), bool stable=); void()()[] sort(void()()[] a, bool less(void()(), void()()), bool stable=); frame[] sort(frame[] a, bool less(frame, frame), bool stable=); bool3[] sort(bool3[] a, bool less(bool3, bool3), bool stable=); Label[] sort(Label[] a, bool less(Label, Label), bool stable=); picture[] sort(picture[] a, bool less(picture, picture), bool stable=); int[] sort(int[] a, bool less(int, int), bool stable=); string[][] sort(string[][] a, bool less(string[], string[]), bool stable=); real[] sort(real[] a, bool less(real, real), bool stable=); string[] sort(string[] a, bool less(string, string), bool stable=); pair[] sort(pair[] a, bool less(pair, pair), bool stable=); real[][] sort(real[][] a, bool less(real[], real[]), bool stable=); triple[] sort(triple[] a, bool less(triple, triple), bool stable=); guide[] sort(guide[] a, bool less(guide, guide), bool stable=); pair postcontrol(path p, int t); pair postcontrol(path p, real t); triple postcontrol(path3 p, int t); triple postcontrol(path3 p, real t); int max(int a, int b); int[] max(int a, int[] b); int[] max(int[] a, int b); int[] max(int[] a, int[] b); int max(int[] a); int max(int[][] a); int max(int[][][] a); real max(real a, real b); real[] max(real a, real[] b); real[] max(real[] a, real b); real[] max(real[] a, real[] b); real max(real[] a); real max(real[][] a); real max(real[][][] a); string max(string a, string b); string[] max(string a, string[] b); string[] max(string[] a, string b); string[] max(string[] a, string[] b); string max(string[] a); string max(string[][] a); string max(string[][][] a); pair max(pen p); pair max(frame f); pair max(explicit path p); pair max(path[] p); triple max(path3 p); real max(real M, scaling s, coord[] c); int max(... int[] a); pair max(picture pic, bool user=); real max(... real[] a); void restore(); pen basealign(int n); int basealign(pen p=); pen basealign; int min(int a, int b); int[] min(int a, int[] b); int[] min(int[] a, int b); int[] min(int[] a, int[] b); int min(int[] a); int min(int[][] a); int min(int[][][] a); real min(real a, real b); real[] min(real a, real[] b); real[] min(real[] a, real b); real[] min(real[] a, real[] b); real min(real[] a); real min(real[][] a); real min(real[][][] a); string min(string a, string b); string[] min(string a, string[] b); string[] min(string[] a, string b); string[] min(string[] a, string[] b); string min(string[] a); string min(string[][] a); string min(string[][][] a); pair min(pen p); pair min(frame f); pair min(explicit path p); pair min(path[] p); triple min(path3 p); pair min(picture pic, bool user=); real min(... real[] a); real min(real m, scaling s, coord[] c); int min(... int[] a); void srand(int seed); bool operator >(int a, int b); bool[] operator >(int a, int[] b); bool[] operator >(int[] a, int b); bool[] operator >(int[] a, int[] b); bool operator >(real a, real b); bool[] operator >(real a, real[] b); bool[] operator >(real[] a, real b); bool[] operator >(real[] a, real[] b); bool operator >(string a, string b); bool[] operator >(string a, string[] b); bool[] operator >(string[] a, string b); bool[] operator >(string[] a, string[] b); bool operator >=(int a, int b); bool[] operator >=(int a, int[] b); bool[] operator >=(int[] a, int b); bool[] operator >=(int[] a, int[] b); bool operator >=(real a, real b); bool[] operator >=(real a, real[] b); bool[] operator >=(real[] a, real b); bool[] operator >=(real[] a, real[] b); bool operator >=(string a, string b); bool[] operator >=(string a, string[] b); bool[] operator >=(string[] a, string b); bool[] operator >=(string[] a, string[] b); bool operator >=(coord a, coord b); bool operator <=(int a, int b); bool[] operator <=(int a, int[] b); bool[] operator <=(int[] a, int b); bool[] operator <=(int[] a, int[] b); bool operator <=(real a, real b); bool[] operator <=(real a, real[] b); bool[] operator <=(real[] a, real b); bool[] operator <=(real[] a, real[] b); bool operator <=(string a, string b); bool[] operator <=(string a, string[] b); bool[] operator <=(string[] a, string b); bool[] operator <=(string[] a, string[] b); bool operator <=(coord a, coord b); bool operator <(int a, int b); bool[] operator <(int a, int[] b); bool[] operator <(int[] a, int b); bool[] operator <(int[] a, int[] b); bool operator <(real a, real b); bool[] operator <(real a, real[] b); bool[] operator <(real[] a, real b); bool[] operator <(real[] a, real[] b); bool operator <(string a, string b); bool[] operator <(string a, string[] b); bool[] operator <(string[] a, string b); bool[] operator <(string[] a, string[] b); pair[] conj(pair[] a); pair[][] conj(pair[][] a); pair conj(pair z); side LeftSide; path nullpath; guide[] copy(guide[] a, int depth=); real[] copy(real[] a, int depth=); triple[] copy(triple[] a, int depth=); bool[] copy(bool[] a, int depth=); real[][] copy(real[][] a, int depth=); pen[] copy(pen[] a, int depth=); coord[] copy(coord[] a, int depth=); object[] copy(object[] a, int depth=); marker[] copy(marker[] a, int depth=); Legend[] copy(Legend[] a, int depth=); pen[][] copy(pen[][] a, int depth=); path[] copy(path[] a, int depth=); string[] copy(string[] a, int depth=); void()()[] copy(void()()[] a, int depth=); int[] copy(int[] a, int depth=); string[][] copy(string[][] a, int depth=); frame[] copy(frame[] a, int depth=); pair[] copy(pair[] a, int depth=); bool3[] copy(bool3[] a, int depth=); Label[] copy(Label[] a, int depth=); picture[] copy(picture[] a, int depth=); pair[][] copy(pair[][] a, int depth=); real[] abs(pair[] a); real[] abs(triple[] a); real abs(real x); real[] abs(real[] a); real abs(pair z); real abs(triple v); int abs(int x); void radialshade(frame f, path[] g, bool stroke=, pen pena, pair a, real ra, bool extenda=, pen penb, pair b, real rb, bool extendb=, bool copy=); void radialshade(picture pic=, path[] g, bool stroke=, pen pena, pair a, real ra, bool extenda=, pen penb, pair b, real rb, bool extendb=, bool copy=); pair maxbound(pair a, pair b); triple maxbound(triple a, triple b); pair maxbound(pair[] a); pair maxbound(pair[][] a); pair maxbound(pair[][][] a); triple maxbound(triple[] a); triple maxbound(triple[][] a); triple maxbound(triple[][][] a); pair minbound(pair a, pair b); triple minbound(triple a, triple b); pair minbound(pair[] a); pair minbound(pair[][] a); pair minbound(pair[][][] a); triple minbound(triple[] a); triple minbound(triple[][] a); triple minbound(triple[][][] a); real operator /(real a, real b); real[] operator /(real a, real[] b); real[] operator /(real[] a, real b); real[] operator /(real[] a, real[] b); real[][] operator /(real[][] a, real b); pair operator /(pair a, pair b); pair[] operator /(pair a, pair[] b); pair[] operator /(pair[] a, pair b); pair[] operator /(pair[] a, pair[] b); pair[][] operator /(pair[][] a, pair b); triple[] operator /(triple[] a, real b); real operator /(int a, int b); real[] operator /(int[] a, int b); real[] operator /(int a, int[] b); real[] operator /(int[] a, int[] b); triple operator /(triple v, real x); real interp(real a, real b, real t); pair interp(explicit pair a, explicit pair b, real t); triple interp(triple a, triple b, real t); pen interp(pen a, pen b, real t); bool primitive(); int operator *(int a, int b); int[] operator *(int a, int[] b); int[] operator *(int[] a, int b); int[] operator *(int[] a, int[] b); int[][] operator *(int a, int[][] b); int[][] operator *(int[][] a, int b); real operator *(real a, real b); real[] operator *(real a, real[] b); real[] operator *(real[] a, real b); real[] operator *(real[] a, real[] b); real[][] operator *(real a, real[][] b); real[][] operator *(real[][] a, real b); pair operator *(pair a, pair b); pair[] operator *(pair a, pair[] b); pair[] operator *(pair[] a, pair b); pair[] operator *(pair[] a, pair[] b); pair[][] operator *(pair a, pair[][] b); pair[][] operator *(pair[][] a, pair b); triple[] operator *(real a, triple[] b); triple[][] operator *(real a, triple[][] b); triple[] operator *(triple[] a, real b); triple[][] operator *(triple[][] a, real b); pen operator *(real a, pen b); pen operator *(pen a, real b); transform operator *(transform a, transform b); pair operator *(transform t, pair z); path operator *(transform t, path g); pen operator *(transform t, pen p); frame operator *(transform t, frame f); frame operator *(real[][] t, frame f); real[] operator *(real[][] a, real[] b); real[] operator *(real[] a, real[][] b); int[][] operator *(int[][] a, int[][] b); real[][] operator *(real[][] a, real[][] b); pair[][] operator *(pair[][] a, pair[][] b); triple operator *(real[][] t, triple v); triple operator *(real x, triple v); triple operator *(triple v, real x); path3 operator *(real[][] t, path3 g); Label operator *(transform t, Label L); picture operator *(real[][] t, picture orig); side operator *(real x, side s); path[] operator *(transform t, explicit path[] p); picture operator *(transform t, picture orig); pair[] operator *(transform t, pair[] z); Label operator *(real[][] t, Label L); bounds operator *(transform t, bounds b); object operator *(transform t, explicit object F); real latitude(triple v, bool warn=); int sum(int[] a); real sum(real[] a); pair sum(pair[] a); triple sum(triple[] a); int sum(bool[] a); bool initialized(int a); bool initialized(real a); bool initialized(pair a); bool initialized(triple a); int operator -(int a, int b); int[] operator -(int a, int[] b); int[] operator -(int[] a, int b); int[] operator -(int[] a, int[] b); int[][] operator -(int[][] a, int[][] b); int operator -(int a); int[] operator -(int[] a); int[][] operator -(int[][] a); real operator -(real a, real b); real[] operator -(real a, real[] b); real[] operator -(real[] a, real b); real[] operator -(real[] a, real[] b); real[][] operator -(real[][] a, real[][] b); real operator -(real a); real[] operator -(real[] a); real[][] operator -(real[][] a); pair operator -(pair a, pair b); pair[] operator -(pair a, pair[] b); pair[] operator -(pair[] a, pair b); pair[] operator -(pair[] a, pair[] b); pair[][] operator -(pair[][] a, pair[][] b); pair operator -(pair a); pair[] operator -(pair[] a); pair[][] operator -(pair[][] a); triple operator -(triple a, triple b); triple[] operator -(triple a, triple[] b); triple[] operator -(triple[] a, triple b); triple[] operator -(triple[] a, triple[] b); triple[][] operator -(triple[][] a, triple[][] b); triple operator -(triple a); triple[] operator -(triple[] a); triple[][] operator -(triple[][] a); void gsave(frame f); void write(file file=, string s=, bool x, void suffix(file)= ... bool[]); void write(file file=, string s=, explicit bool[] a ... bool[][]); void write(file file=, bool[][]); void write(file file=, bool[][][]); void write(file file=, string s=, int x, void suffix(file)= ... int[]); void write(file file=, string s=, explicit int[] a ... int[][]); void write(file file=, int[][]); void write(file file=, int[][][]); void write(file file=, string s=, real x, void suffix(file)= ... real[]); void write(file file=, string s=, explicit real[] a ... real[][]); void write(file file=, real[][]); void write(file file=, real[][][]); void write(file file=, string s=, pair x, void suffix(file)= ... pair[]); void write(file file=, string s=, explicit pair[] a ... pair[][]); void write(file file=, pair[][]); void write(file file=, pair[][][]); void write(file file=, string s=, triple x, void suffix(file)= ... triple[]); void write(file file=, string s=, explicit triple[] a ... triple[][]); void write(file file=, triple[][]); void write(file file=, triple[][][]); void write(file file=, string s=, string x, void suffix(file)= ... string[]); void write(file file=, string s=, explicit string[] a ... string[][]); void write(file file=, string[][]); void write(file file=, string[][][]); void write(file file=, string s, void suffix(file)=); void write(file file=, string s=, transform x, void suffix(file)= ... transform[]); void write(file file=, string s=, guide x, void suffix(file)= ... guide[]); void write(file file=, string s=, pen x, void suffix(file)= ... pen[]); void write(file file, string s=, explicit guide[] x, void suffix(file)=); void write(string s=, cputime c, string format=, void suffix(file)=); void write(string s=, explicit path[] x, void suffix(file)=); void write(file file, void suffix(file)=); void write(file file=, string s=, pen[] p); void write(void suffix(file)=); void write(file file, string s=, explicit path[] x, void suffix(file)=); void write(file file, string s=, cputime c, string format=, void suffix(file)=); void write(pairOrTriple a); void write(string s=, bool3 b, void suffix(file)=); void write(file file, string s=, bool3 b, void suffix(file)=); void write(string s=, explicit guide[] x, void suffix(file)=); void write(file file=, align align, void suffix(file)=); void write(file file=, Label L, void suffix(file)=); bool operator !=(bool a, bool b); bool[] operator !=(bool a, bool[] b); bool[] operator !=(bool[] a, bool b); bool[] operator !=(bool[] a, bool[] b); bool operator !=(bool[][] a, bool[][] b); bool operator !=(int a, int b); bool[] operator !=(int a, int[] b); bool[] operator !=(int[] a, int b); bool[] operator !=(int[] a, int[] b); bool operator !=(int[][] a, int[][] b); bool operator !=(real a, real b); bool[] operator !=(real a, real[] b); bool[] operator !=(real[] a, real b); bool[] operator !=(real[] a, real[] b); bool operator !=(real[][] a, real[][] b); bool operator !=(pair a, pair b); bool[] operator !=(pair a, pair[] b); bool[] operator !=(pair[] a, pair b); bool[] operator !=(pair[] a, pair[] b); bool operator !=(pair[][] a, pair[][] b); bool operator !=(triple a, triple b); bool[] operator !=(triple a, triple[] b); bool[] operator !=(triple[] a, triple b); bool[] operator !=(triple[] a, triple[] b); bool operator !=(triple[][] a, triple[][] b); bool operator !=(string a, string b); bool[] operator !=(string a, string[] b); bool[] operator !=(string[] a, string b); bool[] operator !=(string[] a, string[] b); bool operator !=(string[][] a, string[][] b); bool[] operator !=(pen[] a, pen[] b); bool operator !=(pen a, pen b); bool operator !=(transform a, transform b); bool operator !=(file a, file b); bool operator !=(path a, path b); bool operator !=(path3 a, path3 b); bool operator !=(bool3 a, bool3 b); bool operator !=(bounds a, bounds b); bool operator !=(node a, node b); bool operator !=(side a, side b); bool operator !=(coords2 a, coords2 b); bool operator !=(light a, light b); bool operator !=(coords3 a, coords3 b); bool operator !=(processtime a, processtime b); bool operator !=(filltype a, filltype b); bool operator !=(ScaleT a, ScaleT b); bool operator !=(Label a, Label b); bool operator !=(schur a, schur b); bool operator !=(coord a, coord b); bool operator !=(freezableBounds a, freezableBounds b); bool operator !=(transformation a, transformation b); bool operator !=(pairOrTriple a, pairOrTriple b); bool operator !=(marker a, marker b); bool operator !=(hsv a, hsv b); bool operator !=(scaleT a, scaleT b); bool operator !=(cputime a, cputime b); bool operator !=(bool3 a, bool b); bool operator !=(marginT a, marginT b); bool operator !=(Legend a, Legend b); bool operator !=(object a, object b); bool operator !=(scaling a, scaling b); bool operator !=(projection a, projection b); bool operator !=(picture a, picture b); bool operator !=(align a, align b); bool operator !=(arrowhead a, arrowhead b); bool operator !=(bool a, bool3 b); bool operator !=(slice a, slice b); bool operator !=(autoscaleT a, autoscaleT b); bool operator !=(position a, position b); bool operator !=(realschur a, realschur b); bool operator ==(bool a, bool b); bool[] operator ==(bool a, bool[] b); bool[] operator ==(bool[] a, bool b); bool[] operator ==(bool[] a, bool[] b); bool operator ==(bool[][] a, bool[][] b); bool operator ==(int a, int b); bool[] operator ==(int a, int[] b); bool[] operator ==(int[] a, int b); bool[] operator ==(int[] a, int[] b); bool operator ==(int[][] a, int[][] b); bool operator ==(real a, real b); bool[] operator ==(real a, real[] b); bool[] operator ==(real[] a, real b); bool[] operator ==(real[] a, real[] b); bool operator ==(real[][] a, real[][] b); bool operator ==(pair a, pair b); bool[] operator ==(pair a, pair[] b); bool[] operator ==(pair[] a, pair b); bool[] operator ==(pair[] a, pair[] b); bool operator ==(pair[][] a, pair[][] b); bool operator ==(triple a, triple b); bool[] operator ==(triple a, triple[] b); bool[] operator ==(triple[] a, triple b); bool[] operator ==(triple[] a, triple[] b); bool operator ==(triple[][] a, triple[][] b); bool operator ==(string a, string b); bool[] operator ==(string a, string[] b); bool[] operator ==(string[] a, string b); bool[] operator ==(string[] a, string[] b); bool operator ==(string[][] a, string[][] b); bool[] operator ==(pen[] a, pen[] b); bool operator ==(pen a, pen b); bool operator ==(transform a, transform b); bool operator ==(file a, file b); bool operator ==(path a, path b); bool operator ==(path3 a, path3 b); bool operator ==(bool3 a, bool3 b); bool operator ==(bounds a, bounds b); bool operator ==(node a, node b); bool operator ==(side a, side b); bool operator ==(coords2 a, coords2 b); bool operator ==(light a, light b); bool operator ==(coords3 a, coords3 b); bool operator ==(processtime a, processtime b); bool operator ==(filltype a, filltype b); bool operator ==(ScaleT a, ScaleT b); bool operator ==(Label a, Label b); bool operator ==(schur a, schur b); bool operator ==(coord a, coord b); bool operator ==(freezableBounds a, freezableBounds b); bool operator ==(transformation a, transformation b); bool operator ==(pairOrTriple a, pairOrTriple b); bool operator ==(marker a, marker b); bool operator ==(hsv a, hsv b); bool operator ==(scaleT a, scaleT b); bool operator ==(cputime a, cputime b); bool operator ==(bool3 a, bool b); bool operator ==(marginT a, marginT b); bool operator ==(Legend a, Legend b); bool operator ==(object a, object b); bool operator ==(scaling a, scaling b); bool operator ==(projection a, projection b); bool operator ==(picture a, picture b); bool operator ==(align a, align b); bool operator ==(arrowhead a, arrowhead b); bool operator ==(bool a, bool3 b); bool operator ==(slice a, slice b); bool operator ==(autoscaleT a, autoscaleT b); bool operator ==(position a, position b); bool operator ==(realschur a, realschur b); bool operator ^(bool a, bool b); bool[] operator ^(bool a, bool[] b); bool[] operator ^(bool[] a, bool b); bool[] operator ^(bool[] a, bool[] b); int operator ^(int a, int b); int[] operator ^(int a, int[] b); int[] operator ^(int[] a, int b); int[] operator ^(int[] a, int[] b); real operator ^(real a, real b); real[] operator ^(real a, real[] b); real[] operator ^(real[] a, real b); real[] operator ^(real[] a, real[] b); pair operator ^(pair a, pair b); pair[] operator ^(pair a, pair[] b); pair[] operator ^(pair[] a, pair b); pair[] operator ^(pair[] a, pair[] b); transform operator ^(transform t, int n); real operator ^(real x, int y); pair operator ^(pair z, int y); bool operator |(bool a, bool b); bool[] operator |(bool a, bool[] b); bool[] operator |(bool[] a, bool b); bool[] operator |(bool[] a, bool[] b); pen NewCenturySchoolBook(string series=, string shape=); void()()[] saveFunctions; bool operator &(bool a, bool b); bool[] operator &(bool a, bool[] b); bool[] operator &(bool[] a, bool b); bool[] operator &(bool[] a, bool[] b); path operator &(path p, path q); path3 operator &(path3 p, path3 q); path operator &(path p, cycleToken tok); string minipage(string s, real width=); real legendmaxrelativewidth; real cross(explicit pair z, explicit pair w); triple cross(triple u, triple v); path cross(int n, bool round=, real r=); string operator +(string a, string b); int operator +(int a, int b); int[] operator +(int a, int[] b); int[] operator +(int[] a, int b); int[] operator +(int[] a, int[] b); int[][] operator +(int[][] a, int[][] b); int operator +(int a); int[] operator +(int[] a); real operator +(real a, real b); real[] operator +(real a, real[] b); real[] operator +(real[] a, real b); real[] operator +(real[] a, real[] b); real[][] operator +(real[][] a, real[][] b); real operator +(real a); real[] operator +(real[] a); pair operator +(pair a, pair b); pair[] operator +(pair a, pair[] b); pair[] operator +(pair[] a, pair b); pair[] operator +(pair[] a, pair[] b); pair[][] operator +(pair[][] a, pair[][] b); pair operator +(pair a); pair[] operator +(pair[] a); triple operator +(triple a, triple b); triple[] operator +(triple a, triple[] b); triple[] operator +(triple[] a, triple b); triple[] operator +(triple[] a, triple[] b); triple[][] operator +(triple[][] a, triple[][] b); triple operator +(triple a); triple[] operator +(triple[] a); pen operator +(pen a, pen b); transform operator +(transform a, transform b); pen operator +(pen p, real w); pen[] operator +(pen a, pen[] b); pen operator +(real w, pen p); string operator +(... string[] a); marginT operator +(path, pen)(marginT ma(path, pen), marginT mb(path, pen)); pen[] operator +(pen[] a, pen b); real operator cast(int); pair operator cast(int); pair operator cast(real); path operator cast(pair); guide operator cast(pair); guide operator cast(path); path operator cast(guide); file operator cast(null); real[] operator cast(int[]); pair[] operator cast(int[]); pair[] operator cast(real[]); real[][] operator cast(int[][]); pair[][] operator cast(int[][]); pair[][] operator cast(real[][]); bool operator cast(file); bool[] operator cast(file); bool[][] operator cast(file); bool[][][] operator cast(file); int operator cast(file); int[] operator cast(file); int[][] operator cast(file); int[][][] operator cast(file); real operator cast(file); real[] operator cast(file); real[][] operator cast(file); real[][][] operator cast(file); pair operator cast(file); pair[] operator cast(file); pair[][] operator cast(file); pair[][][] operator cast(file); triple operator cast(file); triple[] operator cast(file); triple[][] operator cast(file); triple[][][] operator cast(file); string operator cast(file); string[] operator cast(file); string[][] operator cast(file); string[][][] operator cast(file); guide operator cast(cycleToken tok); guide operator cast(curlSpecifier spec); guide operator cast(tensionSpecifier t); guide[] operator cast(path[] g); hsv operator cast(pen p); align operator cast(pair dir); bool3[] operator cast(bool[] b); align operator cast(triple dir); object operator cast(Label L); Label operator cast(object F); pair operator cast(pairOrTriple a); triple operator cast(pairOrTriple a); position operator cast(int x); object operator cast(string s); guide[] operator cast(pair[] z); path[] operator cast(guide[] g); bool operator cast(bool3 b); position operator cast(real x); Label operator cast(string s); path[] operator cast(guide g); frame operator cast(object F); path[] operator cast(pair[] z); path[] operator cast(path p); align operator cast(side side); bool[] operator cast(bool3[] b); position operator cast(pair x); pair operator cast(position P); bool3 operator cast(bool b); object operator cast(frame f); pen operator cast(hsv hsv); pen deepred; bool error(file f); string operator ecast(int); string operator ecast(real); string operator ecast(pair); string operator ecast(triple); int operator ecast(string); real operator ecast(string); pair operator ecast(string); triple operator ecast(string); int operator ecast(real); int[] operator ecast(real[]); real[] operator ecast(string[] a); int[] operator ecast(string[] a); bool operator init(); int operator init(); real operator init(); string operator init(); pair operator init(); triple operator init(); transform operator init(); guide operator init(); path operator init(); path3 operator init(); pen operator init(); frame operator init(); file operator init(); marginT operator init(); Legend operator init(); object operator init(); filltype operator init(); ScaleT operator init(); Label operator init(); schur operator init(); slice operator init(); autoscaleT operator init(); position operator init(); realschur operator init(); hsv operator init(); scaleT operator init(); cputime operator init(); coords2 operator init(); light operator init(); coords3 operator init(); processtime operator init(); scaling operator init(); projection operator init(); picture operator init(); align operator init(); arrowhead operator init(); coord operator init(); transformation operator init(); pairOrTriple operator init(); marker operator init(); bool3 operator init(); bounds operator init(); node operator init(); side operator init(); real animationdelay; frame NoBox(frame f); animation operator init(); frame BBox(frame)(real xmargin=, real ymargin=, pen p=, filltype filltype=); void annotate(picture pic=, string title, string text, pair position); void babel(string s); bool isDuplicate(pair a, pair b, real relSize); real maxrefinements; real[][] intersections(pair a, pair b, path p); path[] bezulate(path[] p); path[][] containmentTree(path[] paths); path section(path p, real t1, real t2, bool loop=); path removeDuplicates(path p); void connect(path[] paths, path[] result, path[] patch); real duplicateFuzz; int countIntersections(path[] p, pair start, pair end); bool checkSegment(path g, pair p, pair q); path uncycle(path p, real t); path subdivide(path p); real fuzz; key nil; real minDistDefault; binarytreeNode binarytreeNode(int key); binarytreeNode operator init(); key operator init(); binarytree operator init(); real nodeMarginDefault; key operator cast(int n); int operator cast(key k); int[] operator cast(key[] k); binarytree binarytree(... key[] keys); binarytree searchtree(... int[] keys); object draw(picture pic=, binarytreeNode node, pair pos, int height, real minDist, real levelDist, real nodeDiameter, pen p=, bool condensed=); void draw(picture pic=, binarytree tree, real minDist=, real nodeMargin=, pen p=, bool condensed=); key key(int n, bool active=); real epsilon; line intersection(face a, face b); picture operator cast(face f); face operator cast(path3 p); splitface split(face a, face cut, projection P); void add(picture pic=, face[] faces, projection P=); face operator init(); line operator init(); half operator init(); splitface operator init(); bsp operator init(); sCAD operator init(); real eps; weighted operator init(); bucket operator init(); vertex operator init(); object operator init(); vertex[][] contour3(triple[][][] v, real[][][] f, real[][][] midpoint=, projection P=); vertex[][] contour3(real[][][] f, real[][][] midpoint=, triple a, triple b, projection P=); vertex[][] contour3(real f(real, real, real), triple a, triple b, int nx=, int ny=, int nz=, projection P=); surface surface(vertex[][] g); segment case3(pair p0, pair p1, pair p2, real v0, real v1, real v2, int edge=); segment case1(pair p0, pair p1, int edge); real eps; segment case2(pair p0, pair p1, pair p2, real v0, real v1, real v2, int edge); pen[][] interior(picture pic=, guide[][] g, pen[] palette); segment checktriangle(pair p0, pair p1, pair p2, real v0, real v1, real v2, int edge=); segment operator init(); guide[][] contour(picture pic=, pair[][] z, real[][] f, real[][] midpoint=, real[] c, guide join(... guide[])=); guide[][] contour(picture pic=, real[][] f, real[][] midpoint=, pair a, pair b, real[] c, guide join(... guide[])=); guide[][] contour(picture pic=, real f(real, real), pair a, pair b, real[] c, int nx=, int ny=, guide join(... guide[])=); guide[][] contour(picture pic=, real f(pair), pair a, pair b, real[] c, int nx=, int ny=, guide join(... guide[])=); guide[][] contour(picture pic=, pair[] z, real[] f, real[] c, guide join(... guide[])=); void addseg(pair[][] gds, segment seg); void collect(pair[][][] points, real[] c); void draw(picture pic=, Label[] L=, guide[][] g, pen[] p); void draw(picture pic=, Label[] L=, guide[][] g, pen p=); guide[][] connect(picture pic, pair[][][] points, real[] c, guide join(... guide[])); void fill(picture pic=, guide[][] g, pen[][] palette); pen[] extend(pen[] palette, pen below, pen above); void drawAll(TreeNode node, frame f); real layout(int level, TreeNode node); real treeMinNodeWidth; real treeLevelStep; TreeNode makeNode(TreeNode parent=, frame f); TreeNode makeNode(TreeNode parent=, Label label); void add(TreeNode child, TreeNode parent); void draw(TreeNode root, pair pos); TreeNode operator init(); real treeNodeStep; string embed(string name, string text=, string options=, real width=, real height=); string link(string label, string text=); string embedplayer(string name, string text=, string options=, real width=, real height=); string hyperlink(string url, string text); string embed(string name, string text=, string options=, real width=, real height=, string image=); string link(string label, string text=); void texshipout(string stem, picture pic=, bool xalign=); void fmdefaults(); void drawMomArrow(picture pic=, path p, align align, position pos=, real offset=, real length=, pen fgpen=, bool arrow(picture, path, pen, marginT(path, pen))=, bool erasebg=, pen bgpen=, real margin=); void drawVertexOX(picture pic=, pair xy, real r=, pen fgpen=, bool erasebg=, pen bgpen=); void drawVertexX(picture pic=, pair xy, real r=, pen fgpen=); bool XYAlign; void drawVertexBoxO(picture pic=, pair xy, real r=, pen fgpen=, bool erasebg=, pen bgpen=); void drawVertexBox(picture pic=, pair xy, real r=, pen fgpen=); void drawVertexTriangleO(picture pic=, pair xy, real r=, pen fgpen=, bool erasebg=, pen bgpen=); void drawVertexTriangle(picture pic=, pair xy, real r=, pen fgpen=); void drawVertexO(picture pic=, pair xy, real r=, pen fgpen=, bool erasebg=, pen bgpen=); void drawVertex(picture pic=, pair xy, real r=, pen fgpen=); void drawGhost(picture pic=, path p, pen fgpen=, bool arrow(picture, path, pen, marginT(path, pen))=, bool erasebg=, pen bgpen=, real vertexangle=, real margin=); void drawFermion(picture pic=, path p, pen fgpen=, bool arrow(picture, path, pen, marginT(path, pen))=, bool erasebg=, pen bgpen=, real vertexangle=, real margin=); void drawPhoton(picture pic=, path p, real amp=, real width=, pen fgpen=, bool erasebg=, pen bgpen=, real vertexangle=, real margin=); void drawGluon(picture pic=, path p, real amp=, real width=, pen fgpen=, bool erasebg=, pen bgpen=, real vertexangle=, real margin=); path momArrowPath(path p, align align, position pos, real offset=, real length=); path photon(path p, real amp=, real width=); void drawVertexBoxX(picture pic=, pair xy, real r=, pen fgpen=, bool erasebg=, pen bgpen=); path gluon(path p, real amp=, real width=); string includegraphicscommand; real momarrowoffset; pen doublelinepen; real momarrowsize(pen p=); void drawDoubleLine(picture pic=, path p, pen fgpen=, real dlspacing=, bool arrow(picture, path, pen, marginT(path, pen))=, bool erasebg=, pen bgpen=, real vertexangle=, real margin=); pen photonpen; bool overpaint; real gluonratio; pen vertexpen; bool currentmomarrow(picture, path, pen, marginT(path, pen)); real linemargin; real bigvertexsize; void do_overpaint(picture pic, path p, pen bgpen, real halfwidth, real vertexangle); bool currentarrow(picture, path, pen, marginT(path, pen)); real vertexsize; bool YAlign; pen momarrowpen; pen bigvertexpen; real gluonamplitude; real photonratio; real photonamplitude; pen backgroundpen; void drawScalar(picture pic=, path p, pen fgpen=, bool arrow(picture, path, pen, marginT(path, pen))=, bool erasebg=, pen bgpen=, real vertexangle=, real margin=); pen gluonpen; pen fermionpen; pen scalarpen; pen ghostpen; real doublelinespacing; real minvertexangle; real momarrowlength; real momarrowmargin; real momarrowfactor; bool appendsuffix; Dir Down; Dir Up; Dir Left; Dir Right; block blockconnector(block, block)(picture pic, transform t, pen p=, marginT margin(path, pen)=); path path(pair[] point ... flowdir[] dir); block bevel(object body, pair center=, pen fillpen=, pen drawpen=, real dh=, real dw=, real minwidth=, real minheight=); block roundrectangle(object body, pair center=, pen fillpen=, pen drawpen=, real ds=, real dw=, real minwidth=, real minheight=); block parallelogram(object body, pair center=, pen fillpen=, pen drawpen=, real dx=, real slope=, real minwidth=, real minheight=); real defaultexcursion; real minblockheight; real minblockwidth; flowdir Horizontal; block operator --(block b1, Label label); block operator --(block b1, Dir dir); block operator --(block b, bool arrowbar(picture, path, pen, marginT(path, pen))); void draw(picture pic=, block block, pen p=); real mincirclediameter; flowdir Vertical; block circle(object body, pair center=, pen fillpen=, pen drawpen=, real dr=, real mindiameter=); flowdir operator init(); block operator init(); Dir operator init(); block diamond(object body, pair center=, pen fillpen=, pen drawpen=, real ds=, real dw=, real height=, real minwidth=, real minheight=); block rectangle(object header, object body, pair center=, pen headerpen=, pen bodypen=, pen drawpen=, real dx=, real minheaderwidth=, real minheaderheight=, real minbodywidth=, real minbodyheight=); block rectangle(object body, pair center=, pen fillpen=, pen drawpen=, real dx=, real minwidth=, real minheight=); line tangent(circle c, abscissa x); line tangent(circle c, point M); line tangent(circle c, explicit vector v); line tangent(ellipse el, abscissa x); line tangent(parabola p, abscissa x); line tangent(hyperbola h, abscissa x); line tangent(explicit arc a, abscissa x); line tangent(explicit arc a, point M); point radicalcenter(circle c1, circle c2); point radicalcenter(circle c1, circle c2, circle c3); inversion inversion(circle c1, circle c2, real sgn=); inversion inversion(circle c1, circle c2, circle c3); inversion inversion(circle c); triangle anticomplementary(triangle t); triangle symmedial(triangle t); triangle orthic(triangle t); line median(vertex V); line median(side side); point intouch(side side); triangle intouch(triangle t); triangle incentral(triangle t); triangle antipedal(triangle t, point M); point isogonal(side side, point M); line isogonal(vertex V, point M); triangle isogonal(triangle t, point M); point isogonalconjugate(triangle t, point M); point[] fermat(triangle t); point gergonne(triangle t); triangle cevian(triangle t, point P); point cevian(side side, point P); line cevian(vertex V, point P); point symmedian(triangle t); point symmedian(side side); line symmedian(vertex V); trilinear trilinear(triangle t, real a, real b, real c); trilinear trilinear(triangle t, point M); trilinear trilinear(triangle t, real f(real, real, real), real a=, real b=, real c=); point foot(vertex V); point foot(side side); triangle triangleabc(real a, real b, real c, real angle=, point A=); circle excircle(point A, point B, point C); circle excircle(side side); real exradius(point A, point B, point C); real exradius(side side); point excenter(point A, point B, point C); point excenter(side side); circle incircle(point A, point B, point C); circle incircle(triangle t); real inradius(point A, point B, point C); real inradius(triangle t); point orthocenter(point A, point B, point C); point orthocenter(triangle t); mass masscenter(... mass[] M); int arcnodesnumber(explicit arc a); point curpoint(line l, real x); point curpoint(explicit circle c, real x); point curpoint(explicit ellipse el, real x); point curpoint(explicit parabola p, real x); point curpoint(conic co, real x); point curpoint(arc a, real x); abscissa nodabscissa(real x); abscissa nodabscissa(int x); abscissa nodabscissa(line l, point M); abscissa nodabscissa(circle c, point M); abscissa nodabscissa(ellipse el, point M); abscissa nodabscissa(parabola p, point M); abscissa nodabscissa(conic co, point M); abscissa nodabscissa(arc a, point M); abscissa angabscissa(real x, path polarconicroutine(conic co, real angle1, real angle2, int n, bool direction)=); abscissa angabscissa(int x, path polarconicroutine(conic co, real angle1, real angle2, int n, bool direction)=); abscissa angabscissa(circle c, point M); abscissa angabscissa(ellipse el, point M, path polarconicroutine(conic co, real angle1, real angle2, int n, bool direction)=); abscissa angabscissa(hyperbola h, point M, path polarconicroutine(conic co, real angle1, real angle2, int n, bool direction)=); abscissa angabscissa(parabola p, point M); abscissa angabscissa(explicit conic co, point M); abscissa angabscissa(arc a, point M); abscissa curabscissa(real x); abscissa curabscissa(int x); abscissa curabscissa(line l, point M); abscissa curabscissa(circle c, point M); abscissa curabscissa(ellipse el, point M); abscissa curabscissa(parabola p, point M); abscissa curabscissa(conic co, point M); abscissa curabscissa(arc a, point M); abscissa relabscissa(real x); abscissa relabscissa(int x); abscissa relabscissa(line l, point M); abscissa relabscissa(circle c, point M); abscissa relabscissa(ellipse el, point M); abscissa relabscissa(conic co, point M); abscissa relabscissa(arc a, point M); int relativesystem; bqe canonical(bqe bqe); path fromFocus(conic co, real angle1, real angle2, int n, bool direction); real operator ^(point M, explicit circle c); point circumcenter(point A, point B, point C); point circumcenter(triangle t); parabola parabola(point F, line l); parabola parabola(point F, point vertex); parabola parabola(point F, real a, real angle); parabola parabola(bqe bqe); parabola parabola(point M1, point M2, point M3, line l); parabola parabola(point M1, point M2, point M3, point M4, point M5); real focusToCenter(ellipse el, real a); path arcfromcenter(ellipse el, real angle1, real angle2, bool direction=, int n=); path arcfromcenter(hyperbola h, real angle1, real angle2, int n=, bool direction=); path arcfromcenter(explicit conic co, real angle1, real angle2, int n, bool direction=); hyperbola hyperbola(point P1, point P2, real ae, bool byfoci=); hyperbola hyperbola(point F1, point F2, point M); hyperbola hyperbola(point C, real a, real b, real angle=); hyperbola hyperbola(bqe bqe); hyperbola hyperbola(point M1, point M2, point M3, point M4, point M5); coordsys canonicalcartesiansystem(ellipse el); coordsys canonicalcartesiansystem(parabola p); coordsys canonicalcartesiansystem(hyperbola h); coordsys canonicalcartesiansystem(explicit conic co); point angpoint(conic co, real angle); point angpoint(explicit circle c, real x); point angpoint(explicit ellipse el, real x, path polarconicroutine(conic co, real angle1, real angle2, int n, bool direction)=); point angpoint(explicit parabola p, real x); point angpoint(explicit hyperbola h, real x, path polarconicroutine(conic co, real angle1, real angle2, int n, bool direction)=); point angpoint(arc a, real angle); path currentpolarconicroutine(conic co, real angle1, real angle2, int n, bool direction); int hyperbolanodesnumber(hyperbola h, real angle1, real angle2); int parabolanodesnumber(parabola p, real angle1, real angle2); int parabolanodesnumberfactor; real centerToFocus(ellipse el, real a); int ellipsenodesnumberfactor; int circlenodesnumberfactor; line sector(int n=, int p=, line l1, line l2, real angle=, bool sharp=); real[] bangles(picture pic=, parabola p); real[][] bangles(picture pic=, hyperbola h); real sharpangle(line l1, line l2); line perpendicular(point M, line l); line perpendicular(point M, explicit vector normal); line perpendicular(point M, explicit pair normal); bool perpendicular(line l1, line l2); void perpendicular(picture pic=, pair z, pair align, pair dir=, real size=, pen p=, marginT margin(path, pen)=, filltype filltype=); void perpendicular(picture pic=, pair z, pair align, path g, real size=, pen p=, marginT margin(path, pen)=, filltype filltype=); transform hprojection(line l, bool safe=); line parallel(point M, line l); line parallel(point M, explicit vector dir); line parallel(point M, explicit pair dir); bool parallel(line l1, line l2, bool strictly=); transform reflect(line l); transform reflect(line l1, line l2, bool safe=); line hline(coordsys R=); line hline; line vline(coordsys R=); line vline; line Oy(coordsys R=); line Oy; line Ox(coordsys R=); line Ox; line extend(line l); coordsys coordsys(line l); coordsys coordsys(conic co); coordsys coordsys(ellipse el); bool operator @(point m, line l); bool operator @(point M, conic co); bool operator @(point M, explicit circle c); bool operator @(point M, arc a); line line(point A, bool extendA=, point B, bool extendB=); line line(segment s); line line(real a, point A=); line line(point A=, real a); line line(int a, point A=); line line(coordsys R=, real slope, real origin); line line(coordsys R=, real a, real b, real c); line line(circle c); line line(explicit side side); void distance(picture pic=, Label L=, point A, point B, bool rotated=, real offset=, pen p=, pen joinpen=, bool arrow(picture, path, pen, marginT(path, pen))=); real distance(point M, line l); real distance(line l, point M); void clipdraw(picture pic=, Label L=, path g, align align=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, bool bar(picture, path, pen, marginT(path, pen))=, real xmargin=, real ymargin=, Label legend=, marker marker=); void Drawline(picture pic=, Label L=, pair P, bool dirP=, pair Q, bool dirQ=, align align=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, Label legend=, marker marker=, path pathModifier(path)=); bool between(point M, point O, point N); bool defined(point P); pen addpenarc; pen addpenarc(pen p); point origin; point origin(coordsys R=); vector unit(point M); vector unit(vector u); real perpfactor; bool collinear(vector u, vector v); vector vector(coordsys R=, pair v); vector vector(point M); transform scaleO(real x); transform yscale(real k, point M); transform rotateO(real a); bool Finite(explicit point z); point conj(explicit point M); vector conj(explicit vector u); hyperbola conj(hyperbola h); real abs(coordsys R, pair m); real abs(explicit point M); point operator -(explicit point P); point operator -(explicit point P1, explicit point P2); point operator -(explicit point P1, explicit pair p2); point operator -(explicit pair p1, explicit point P2); point operator -(point M, explicit vector v); vector operator -(explicit vector v); point operator -(explicit pair m, explicit vector v); vector operator -(explicit vector v1, explicit vector v2); line operator -(line l, vector u); conic operator -(conic c, explicit point M); conic operator -(conic c, explicit pair m); conic operator -(conic c, vector v); circle operator -(explicit circle c, explicit point M); circle operator -(explicit circle c, pair m); circle operator -(explicit circle c, vector m); abscissa operator -(explicit abscissa a); abscissa operator -(real x, explicit abscissa a); abscissa operator -(explicit abscissa a, real x); abscissa operator -(int x, explicit abscissa a); arc operator -(explicit arc a, point M); arc operator -(explicit arc a, vector v); mass operator -(mass M1, mass M2); mass operator -(explicit mass M, real x); mass operator -(explicit mass M, int x); pair locate(point P); point locate(pair p); pair locate(explicit vector v); point[] standardizecoordsys(coordsys R=, bool warn= ... point[] M); coordsys currentcoordsys; coordsys defaultcoordsys; real EPS; real binomial(real n, real k); real Infinity; void markangle(picture pic=, Label L=, int n=, real radius=, real space=, explicit line l1, explicit line l2, explicit pair align=, bool arrow(picture, path, pen, marginT(path, pen))=, pen p=, filltype filltype=, marginT margin(path, pen)=, marker marker=); void markangle(picture pic=, Label L=, int n=, real radius=, real space=, explicit line l1, explicit line l2, explicit vector align, bool arrow(picture, path, pen, marginT(path, pen))=, pen p=, filltype filltype=, marginT margin(path, pen)=, marker marker=); pair coordinates(point M); line isotomic(vertex V, point M); point isotomic(side side, point M); triangle isotomic(triangle t, point M); int hyperbolanodesnumberfactor; int ellipsenodesnumber(real a, real b); int ellipsenodesnumber(real a, real b, real angle1, real angle2, bool dir); point point(coordsys R, pair p, real m=); point point(explicit pair p, real m); point point(coordsys R, explicit point M, real m=); point point(explicit vector u); point point(circle c, abscissa l); point point(ellipse el, abscissa l); point point(parabola p, abscissa l); point point(hyperbola h, abscissa l); point point(explicit conic co, abscissa l); point point(line l, abscissa x); point point(line l, explicit real x); point point(line l, explicit int x); point point(explicit circle c, explicit real x); point point(explicit circle c, explicit int x); point point(explicit ellipse el, explicit real x); point point(explicit ellipse el, explicit int x); point point(explicit parabola p, explicit real x); point point(explicit parabola p, explicit int x); point point(explicit hyperbola h, explicit real x); point point(explicit hyperbola h, explicit int x); point point(explicit conic co, explicit real x); point point(explicit conic co, explicit int x); point point(arc a, abscissa l); point point(arc a, real x); pair point(explicit arc a, int x); point point(explicit mass m); point point(explicit vertex V); point point(trilinear tri); point point(circle c, point M); point point(circle c, explicit vector v); int angularsystem; point changecoordsys(coordsys R, point M); vector changecoordsys(coordsys R, vector v); line changecoordsys(coordsys R, line l); bqe changecoordsys(coordsys R, bqe bqe); conic changecoordsys(coordsys R, conic co); int conicnodesfactor; point isotomicconjugate(triangle t, point M); point operator +(explicit point P1, explicit point P2); point operator +(explicit point P1, explicit pair p2); point operator +(explicit pair p1, explicit point p2); point operator +(point M, explicit vector v); point operator +(explicit pair m, explicit vector v); vector operator +(explicit vector v1, explicit vector v2); line operator +(line l, vector u); conic operator +(conic c, explicit point M); conic operator +(conic c, explicit pair m); conic operator +(conic c, vector v); circle operator +(explicit circle c, explicit point M); circle operator +(explicit circle c, pair m); circle operator +(explicit circle c, vector m); abscissa operator +(real x, explicit abscissa a); abscissa operator +(explicit abscissa a, real x); abscissa operator +(int x, explicit abscissa a); arc operator +(explicit arc a, point M); arc operator +(explicit arc a, vector v); mass operator +(mass M1, mass M2); mass operator +(explicit mass M, real x); mass operator +(explicit mass M, int x); triangle tangential(triangle t); point arcsubtendedcenter(point A, point B, real angle); real rd(real x, real y, real z); vector dir(vertex V); coordsys cartesiansystem(pair O=, pair i, pair j); string conictype(bqe bqe); void fill(picture pic=, circle c, pen p=); void fill(picture pic=, ellipse el, pen p=); void fill(picture pic=, triangle t, pen p=); void fill(picture pic=, triangle[] ts, pen p=); segment segment(point A, point B); segment segment(line l); segment segment(explicit side side); line bisector(line l1, line l2, real angle=, bool sharp=); line bisector(point A, point B, point C, point D, real angle=, bool sharp=); line bisector(segment s, real angle=); line bisector(point A, point B, real angle=); line bisector(vertex V, real angle=); line bisector(side side); void drawline(picture pic=, triangle t, pen p=); transform scale(real k, point M); transform scale(real k, point A, point B, point C, point D, bool safe=); transform scale(real k, line l1, line l2, bool safe=); string massformat(string format=, string s, mass M); conic conic(point F, line l, real e); conic conic(point M1, point M2, point M3, point M4, point M5); conic conic(bqe bqe); arc arc(ellipse el, real angle1, real angle2, path polarconicroutine(conic co, real angle1, real angle2, int n, bool direction)=, bool direction=); arc arc(ellipse el, explicit abscissa x1, explicit abscissa x2, bool direction=); arc arc(ellipse el, point M, point N, bool direction=); arc arc(explicit arc a, abscissa x1, abscissa x2); arc arc(explicit arc a, point M, point N); path arc(explicit pair B, explicit pair A, explicit pair C, real r); point inverse(inversion i, point P); circle inverse(inversion i, line l); circle inverse(inversion i, circle c); arc inverse(inversion i, segment s); pair[] intersectionpoints(pair A, pair B, real a, real b, real c, real d, real f, real g); pair[] intersectionpoints(pair A, pair B, real[] equation); point[] intersectionpoints(line l, path g); point[] intersectionpoints(triangle t, line l, bool extended=); point[] intersectionpoints(line l, triangle t, bool extended=); point[] intersectionpoints(line l, circle c); point[] intersectionpoints(circle c, line l); point[] intersectionpoints(line l, ellipse el); point[] intersectionpoints(ellipse el, line l); point[] intersectionpoints(line l, parabola p); point[] intersectionpoints(parabola p, line l); point[] intersectionpoints(line l, hyperbola h); point[] intersectionpoints(hyperbola h, line l); point[] intersectionpoints(line l, conic co); point[] intersectionpoints(conic co, line l); point[] intersectionpoints(bqe bqe1, bqe bqe2); point[] intersectionpoints(conic co1, conic co2); point[] intersectionpoints(triangle t, conic co, bool extended=); point[] intersectionpoints(conic co, triangle t, bool extended=); point[] intersectionpoints(ellipse a, ellipse b); point[] intersectionpoints(ellipse a, circle b); point[] intersectionpoints(circle a, ellipse b); point[] intersectionpoints(ellipse a, parabola b); point[] intersectionpoints(parabola a, ellipse b); point[] intersectionpoints(ellipse a, hyperbola b); point[] intersectionpoints(hyperbola a, ellipse b); point[] intersectionpoints(circle a, parabola b); point[] intersectionpoints(parabola a, circle b); point[] intersectionpoints(circle a, hyperbola b); point[] intersectionpoints(hyperbola a, circle b); point[] intersectionpoints(parabola a, parabola b); point[] intersectionpoints(parabola a, hyperbola b); point[] intersectionpoints(hyperbola a, parabola b); point[] intersectionpoints(hyperbola a, hyperbola b); point[] intersectionpoints(circle c1, circle c2); point[] intersectionpoints(conic co, arc a); point[] intersectionpoints(arc a, conic co); point[] intersectionpoints(arc a1, arc a2); point[] intersectionpoints(line l, arc a); point[] intersectionpoints(arc a, line l); point midpoint(segment s); point midpoint(side side); pair attract(pair m, path g, real fuzz=); point attract(point M, path g, real fuzz=); triangle pedal(triangle t, point M); line pedal(side side, point M); real length(explicit point M); real length(segment s); triangle medial(triangle t); int[] numarray; triangle triangleAbc(real alpha, real b, real c, real angle=, point A=); path arctopath(arc a, int n); bool byfoci; real[] realquarticroots(real a, real b, real c, real d, real e); line reverse(line l); arc reverse(arc a); bool simeq(point A, point B, real fuzz=); bool simeq(point a, real b, real fuzz=); void write(explicit line l); void write(explicit segment s); void write(trilinear tri); point relpoint(line l, real x); point relpoint(explicit circle c, real x); point relpoint(explicit ellipse el, real x); point relpoint(explicit parabola p, real x); point relpoint(explicit hyperbola h, real x); point relpoint(explicit conic co, explicit real x); point relpoint(explicit conic co, explicit int x); point relpoint(arc a, real x); arc arcsubtended(point A, point B, real angle); line[] operator ^^(line l1, line l2); line[] operator ^^(line l1, line[] l2); line[] operator ^^(line[] l2, line l1); line[] operator ^^(line[] l1, line[] l2); triangle[] operator ^^(triangle[] t1, triangle t2); triangle[] operator ^^(... triangle[] t); line complementary(explicit line l); line[] complementary(explicit segment s); arc complementary(arc a); bqe equation(ellipse el); bqe equation(parabola p); bqe equation(hyperbola h); bqe equation(explicit conic co); void addMargins(picture pic=, real lmargin=, real bmargin=, real rmargin=, real tmargin=, bool rigid=, bool allObject=); triangle triangle(line l1, line l2, line l3); void draw(picture pic=, Label L=, line l, bool dirA=, bool dirB=, align align=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, Label legend=, marker marker=, path pathModifier(path)=); void draw(picture pic=, Label[] L=, line[] l, align align=, pen[] p=, bool arrow(picture, path, pen, marginT(path, pen))=, Label[] legend=, marker marker=, path pathModifier(path)=); void draw(picture pic=, Label[] L=, line[] l, align align=, pen p, bool arrow(picture, path, pen, marginT(path, pen))=, Label[] legend=, marker marker=, path pathModifier(path)=); void draw(picture pic=, Label L=, circle c, align align=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, bool bar(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, Label legend=, marker marker=); void draw(picture pic=, Label L=, ellipse el, align align=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, bool bar(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, Label legend=, marker marker=); void draw(picture pic=, Label L=, parabola parabola, align align=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, bool bar(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, Label legend=, marker marker=); void draw(picture pic=, Label L=, hyperbola h, align align=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, bool bar(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, Label legend=, marker marker=); void draw(picture pic=, Label L=, explicit conic co, align align=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, bool bar(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, Label legend=, marker marker=); void draw(picture pic=, Label L=, arc a, align align=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, bool bar(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, Label legend=, marker marker=); void draw(picture pic=, triangle t, pen p=, marker marker=); void draw(picture pic=, triangle[] ts, pen p=, marker marker=); path square(pair z1, pair z2); real epsgeo; bool degenerate(conic c); bool degenerate(circle c); bool degenerate(ellipse el); bool sameside(point M, point N, point O); bool sameside(point M, point P, line l); point[] sameside(point M, line l1, line l2); pair operator cast(point P); pair[] operator cast(point[] P); point operator cast(pair p); point[] operator cast(pair[] p); guide operator cast(point p); path operator cast(point p); point operator cast(vector v); vector operator cast(pair v); vector operator cast(explicit point v); pair operator cast(explicit vector v); align operator cast(vector v); line operator cast(segment s); segment operator cast(line l); ellipse operator cast(circle c); conic operator cast(parabola p); conic operator cast(hyperbola h); conic operator cast(ellipse el); conic operator cast(circle c); path operator cast(ellipse el); path operator cast(circle c); path operator cast(parabola p); path operator cast(hyperbola h); path operator cast(conic co); abscissa operator cast(explicit position position); abscissa operator cast(real x); abscissa operator cast(int x); path operator cast(explicit arc a); guide operator cast(explicit arc a); point operator cast(mass m); mass operator cast(point M); point[] operator cast(mass[] m); mass[] operator cast(point[] P); mass operator cast(pair m); path operator cast(mass M); guide operator cast(mass M); path operator cast(triangle t); line operator cast(side side); point operator cast(vertex V); point operator cast(trilinear tri); circle operator cast(inversion i); inversion operator cast(circle c); int circlenodesnumber(real r); int circlenodesnumber(real r, real angle1, real angle2); void perpendicularmark(picture pic=, point z, explicit pair align, explicit pair dir=, real size=, pen p=, marginT margin(path, pen)=, filltype filltype=); void perpendicularmark(picture pic=, point z, vector align, vector dir=, real size=, pen p=, marginT margin(path, pen)=, filltype filltype=); void perpendicularmark(picture pic=, point z, explicit pair align, path g, real size=, pen p=, marginT margin(path, pen)=, filltype filltype=); void perpendicularmark(picture pic=, point z, vector align, path g, real size=, pen p=, marginT margin(path, pen)=, filltype filltype=); void perpendicularmark(picture pic=, line l1, line l2, real size=, pen p=, int quarter=, marginT margin(path, pen)=, filltype filltype=); string defaultmassformat; path arcfromfocus(conic co, real angle1, real angle2, int n=, bool direction=); void label(picture pic=, Label L, explicit mass M, align align=, string format=, pen p=, filltype filltype=); void label(picture pic=, Label L, vertex V, pair align=, real alignFactor=, pen p=, filltype filltype=); void label(picture pic=, Label LA=, Label LB=, Label LC=, triangle t, real alignAngle=, real alignFactor=, pen p=, filltype filltype=); bqe bqe(coordsys R=, real a, real b, real c, real d, real e, real f); bqe bqe(point M1, point M2, point M3, point M4, point M5); real arclength(circle c); real arclength(ellipse el); real arclength(ellipse el, real angle1, real angle2, bool direction=, path polarconicroutine(conic co, real angle1, real angle2, int n, bool direction)=); real arclength(parabola p, real angle); real arclength(parabola p, real angle1, real angle2); real arclength(parabola p); real arclength(arc a); void show(picture pic=, Label lo=, Label li=, Label lj=, coordsys R, pen dotpen=, pen xpen=, pen ypen=, pen ipen=, pen jpen=, bool arrow(picture, path, pen, marginT(path, pen))=); void show(Label L, vector v, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=); void show(picture pic=, line l, pen p=); void show(picture pic=, Label LA=, Label LB=, Label LC=, Label La=, Label Lb=, Label Lc=, triangle t, pen p=, filltype filltype=); int sgnd(real x); int sgnd(int x); pair operator *(coordsys R, pair p); path operator *(coordsys R, path g); coordsys operator *(transform t, coordsys R); point operator *(real x, explicit point P); point operator *(transform t, explicit point P); point operator *(explicit point P1, explicit point P2); point operator *(explicit point P1, explicit pair p2); point operator *(explicit pair p1, explicit point p2); vector operator *(real x, explicit vector v); vector operator *(transform t, explicit vector v); vector operator *(explicit point M, explicit vector v); line operator *(transform t, line l); line operator *(real x, line l); line operator *(int x, line l); line operator *(point M, line l); circle operator *(real x, explicit circle c); circle operator *(int x, explicit circle c); ellipse operator *(transform t, ellipse el); parabola operator *(transform t, parabola p); ellipse operator *(transform t, circle c); hyperbola operator *(transform t, hyperbola h); conic operator *(transform t, conic co); ellipse operator *(real x, ellipse el); abscissa operator *(real x, explicit abscissa a); abscissa operator *(explicit abscissa a, real x); arc operator *(transform t, explicit arc a); arc operator *(real x, explicit arc a); arc operator *(int x, explicit arc a); mass operator *(real x, explicit mass M); mass operator *(int x, explicit mass M); mass operator *(transform t, mass M); triangle operator *(transform T, triangle t); point operator *(inversion i, point P); circle operator *(inversion i, line l); circle operator *(inversion i, circle c); arc operator *(inversion i, segment s); path operator *(inversion i, triangle t); void dot(picture pic=, Label L, explicit point Z, align align=, string format=, pen p=); real dot(point A, point B); real dot(point A, explicit pair B); real dot(explicit pair A, point B); void dot(picture pic=, Label L, explicit mass M, align align=, string format=, pen p=); void dot(picture pic=, triangle t, pen p=); bool isparabola(bqe bqe); real sharpdegrees(line l1, line l2); bool samecoordsys(bool warn= ... point[] M); bool samecoordsys(bool warn= ... bqe[] bqes); point intersectionpoint(line l1, line l2); int curvilinearsystem; bool finite(explicit point p); transform vprojection(line l, bool safe=); pair operator /(pair p, coordsys R); point operator /(explicit point P, real x); point operator /(real x, explicit point P); vector operator /(explicit vector v, real x); line operator /(line l, real x); line operator /(line l, int x); circle operator /(explicit circle c, real x); circle operator /(explicit circle c, int x); ellipse operator /(ellipse el, real x); abscissa operator /(real x, explicit abscissa a); abscissa operator /(explicit abscissa a, real x); abscissa operator /(int x, explicit abscissa a); arc operator /(explicit arc a, real x); mass operator /(explicit mass M, real x); mass operator /(explicit mass M, int x); real elle(real phi, real k); bool onpath(picture pic=, path g, point M, pen p=); path operator ecast(segment s); circle operator ecast(ellipse el); ellipse operator ecast(conic co); parabola operator ecast(conic co); hyperbola operator ecast(conic co); circle operator ecast(conic c); real approximate(real t); real[] approximate(real[] T); void markrightangle(picture pic=, point A, point O, point B, real size=, pen p=, marginT margin(path, pen)=, filltype filltype=); arc arccircle(point A, point M, point B); arc arccircle(point A, point B, real angle, bool direction=); int nodesystem; transform rotate(explicit pair dir); transform rotate(explicit vector dir); transform rotate(explicit point dir); path compassmark(pair O, pair A, real position, real angle=); transform xscaleO(real x); real degrees(explicit point M, coordsys R=, bool warn=); real degrees(vector v, coordsys R=, bool warn=); real degrees(line l, coordsys R=); real degrees(line l1, line l2); real degrees(arc a); point orthocentercenter(point A, point B, point C); point orthocentercenter(triangle t); transform projection(point A, point B); transform projection(point A, point B, point C, point D, bool safe=); transform projection(line l); transform projection(line l1, line l2, bool safe=); transform yscaleO(real x); line[] tangents(circle c, point M); line[] tangents(ellipse el, point M); line[] tangents(parabola p, point M); line[] tangents(hyperbola h, point M); circle circumcircle(point A, point B, point C); circle circumcircle(triangle t); real linemargin; real linemargin(); point centroid(point A, point B, point C); point centroid(triangle t); void markarc(picture pic=, Label L=, int n=, real radius=, real space=, arc a, pen sectorpen=, pen markpen=, marginT margin(path, pen)=, bool arrow(picture, path, pen, marginT(path, pen))=, marker marker=); path NoModifier(path); side opposite(vertex V); vertex opposite(side side); coordsys operator init(); point operator init(); vector operator init(); line operator init(); segment operator init(); bqe operator init(); conic operator init(); circle operator init(); ellipse operator init(); parabola operator init(); hyperbola operator init(); abscissa operator init(); arc operator init(); mass operator init(); triangle operator init(); trilinear operator init(); inversion operator init(); void filldraw(picture pic=, circle c, pen fillpen=, pen drawpen=); void filldraw(picture pic=, ellipse el, pen fillpen=, pen drawpen=); void filldraw(picture pic=, triangle t, pen fillpen=, pen drawpen=); void filldraw(picture pic=, triangle[] ts, pen fillpen=, pen drawpen=); transform xscale(real k, point M); real rf(real x, real y, real z); mass mass(point M, real m); mass mass(explicit point P); mass mass(coordsys R, explicit pair p, real m); void lineinversion(); bool inside(ellipse el, point M); bool inside(parabola p, point M); pen addpenline; pen addpenline(pen p); bool concurrent(... line[] l); int conicnodesnumber(conic co, real angle1, real angle2, bool dir=); path polarconicroutine(conic co, real angle1, real angle2, int n, bool direction)(conic co); ellipse ellipse(point F1, point F2, real a); ellipse ellipse(point F1, point F2, point M); ellipse ellipse(point C, real a, real b, real angle=); ellipse ellipse(bqe bqe); ellipse ellipse(point M1, point M2, point M3, point M4, point M5); circle circle(explicit point C, real r); circle circle(point A, point B); circle circle(segment s); circle circle(point A, point B, point C); circle circle(triangle t); circle circle(inversion i); line radicalline(circle c1, circle c2); point incenter(point A, point B, point C); point incenter(triangle t); line altitude(vertex V); line altitude(side side); point ppoint(arc a, real x); path fromCenter(conic co, real angle1, real angle2, int n, bool direction); point bisectorpoint(side side); bool byvertices; int[] tricoef(side side); real angle(explicit point M, coordsys R=, bool warn=); real angle(explicit vector v, coordsys R=, bool warn=); real angle(line l, coordsys R=); real angle(line l1, line l2); real angle(arc a); real[] intersect(path g, explicit pair p, real fuzz=); real[] intersect(path g, explicit point P, real fuzz=); bool operator !=(explicit point M, explicit point N); bool operator !=(line l1, line l2); triangle extouch(triangle t); triangle extouch(side side); bool operator ==(coordsys c1, coordsys c2); bool operator ==(explicit point M, explicit point N); bool operator ==(explicit vector u, explicit vector v); bool operator ==(line l1, line l2); surface bispline(real[][] z, real[][] p, real[][] q, real[][] r, real[] x, real[] y, bool[][] cond=); real[][][] bispline(real[][] f, real[] x, real[] y, real[] xsplinetype(real[], real[])=, real[] ysplinetype(real[], real[])=, bool[][] cond=); bool vperiodic(real[][] a); bool vperiodic(triple[][] a); bool uperiodic(real[][] a); bool uperiodic(triple[][] a); void labelz3(picture pic=, Label L=, real z, align align=, string format=, pen p=); void labelz(picture pic=, Label L=, triple v, align align=, string format=, pen p=); void ztick3(picture pic=, real z, triple dir=, real size=, pen p=); void ztick3(picture pic=, Label L, real z, triple dir=, string format=, real size=, pen p=); real ScaleZ(picture pic=, real z); real[][] ScaleZ(picture pic=, real[][] P); void axes3(picture pic=, Label xlabel=, Label ylabel=, Label zlabel=, bool extend=, triple min=, triple max=, pen p=, bool arrow(picture, path3, material, marginT3(path3, pen), light, light)=, marginT3 margin(path3, pen)=, projection P=); void zlimits(picture pic=, real min=, real max=, bool crop=); void yaxis3(picture pic=, Label L=, void axis(picture, axisT)=, real ymin=, real ymax=, pen p=, void ticks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)=, bool arrow(picture, path3, material, marginT3(path3, pen), light, light)=, marginT3 margin(path3, pen)=, bool above=, projection P=); void xaxis3(picture pic=, Label L=, void axis(picture, axisT)=, real xmin=, real xmax=, pen p=, void ticks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)=, bool arrow(picture, path3, material, marginT3(path3, pen), light, light)=, marginT3 margin(path3, pen)=, bool above=, projection P=); void xaxis3At(picture pic=, Label L=, void axis(picture, axisT), real xmin=, real xmax=, pen p=, void ticks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)=, bool arrow(picture, path3, material, marginT3(path3, pen), light, light)=, marginT3 margin(path3, pen)=, bool above=, bool opposite=, bool opposite2=, bool primary=, projection P=); triple defaultdir(triple X, triple Y, triple Z, bool opposite=, projection P); real ztrans(real[][] t, real z); void XYZero(picture, axisT)(triple align=, bool extend=); void XYZero(picture, axisT); real[][][] bispline0(real[][] z, real[][] p, real[][] q, real[][] r, real[] x, real[] y, bool[][] cond=); void XYEquals(picture, axisT)(real x, real y, triple align=, bool extend=); void XZEquals(picture, axisT)(real x, real z, triple align=, bool extend=); void YZEquals(picture, axisT)(real y, real z, triple align=, bool extend=); void OutTicks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, int N=, int n=, real Step=, real step=, bool begin=, bool end=, tickvalues modify(tickvalues)=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void OutTicks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, real[] Ticks, real[] ticks=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void OutTicks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P); void NoTicks3(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)(); void NoTicks3(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P); void Ticks3(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)(int sign, Label F=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, real[] Ticks=, real[] ticks=, int N=, bool begin=, bool end=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void Ticks3(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)(int sign, Label F=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, int N, int n=, real Step=, real step=, bool begin=, bool end=, tickvalues modify(tickvalues)=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); triple Dir(real)(triple dir); void XZZero(picture, axisT)(triple align=, bool extend=); void XZZero(picture, axisT); void InOutTicks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, int N=, int n=, real Step=, real step=, bool begin=, bool end=, tickvalues modify(tickvalues)=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void InOutTicks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, real[] Ticks, real[] ticks=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void InOutTicks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P); void Bounds(picture, axisT)(int type=, int type2=, triple align=, bool extend=); void Bounds(picture, axisT); void limits(picture pic=, triple min, triple max); real ScaleX(picture pic=, real x); ticklocate ticklocate(real a, real b, autoscaleT S=, real tickmin=, real tickmax=, real time(real)=, triple dir(real)); void autoscale3(picture pic=, void axis(picture, axisT)); real maxlength(triple f(pair z), pair a, pair b, int nu, int nv); void InTicks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, int N=, int n=, real Step=, real step=, bool begin=, bool end=, tickvalues modify(tickvalues)=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void InTicks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, real[] Ticks, real[] ticks=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void InTicks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P); path3 Circle(triple c, real r, triple normal=, int n=); real ytrans(real[][] t, real y); real xtrans(real[][] t, real x); void labeltick(picture pic, real[][] T, path3 g, ticklocate locate, real val, int sign, real Size, string ticklabel(real), Label F, real norm=); void Straight(flatguide3)(... void(flatguide3)[]); void polargraph(flatguide3)(real r(real, real), real theta(real), real phi(real), int n=, void join(flatguide3)(... void(flatguide3)[])=); void labely(picture pic=, Label L=, triple v, align align=, string format=, pen p=); void Spline(flatguide3)(... void(flatguide3)[]); void drawtick(picture pic, real[][] T, path3 g, path3 g2, ticklocate locate, real val, real Size, int sign, pen p, bool extend); void axis(picture pic=, Label L=, path3 g, path3 g2=, pen p=, void ticks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P), ticklocate locate, bool arrow(picture, path3, material, marginT3(path3, pen), light, light)=, marginT3 margin(path3, pen)=, int[] divisor=, bool above=, bool opposite=); void xtick(picture pic=, triple v, triple dir=, real size=, pen p=); void xtick(picture pic=, Label L, triple v, triple dir=, string format=, real size=, pen p=); void labelx(picture pic=, Label L=, triple v, align align=, string format=, pen p=); void labelaxis(picture pic, real[][] T, Label L, path3 g, ticklocate locate=, int sign=, bool ticklabels=); void ytick(picture pic=, triple v, triple dir=, real size=, pen p=); void ytick(picture pic=, Label L, triple v, triple dir=, string format=, real size=, pen p=); path3 Arc(triple c, triple v1, triple v2, triple normal=, bool direction=, int n=); path3 Arc(triple c, real r, real theta1, real phi1, real theta2, real phi2, triple normal=, bool direction, int n=); path3 Arc(triple c, real r, real theta1, real phi1, real theta2, real phi2, triple normal=, int n=); triple polar(real r, real theta, real phi); void graph(flatguide3)(triple F(real), real, real, int)(void join(flatguide3)(... void(flatguide3)[])); void(flatguide3)[] graph(triple F(real), real, real, int)(void join(flatguide3)(... void(flatguide3)[]), bool3 cond(real)); void graph(flatguide3)(picture pic=, real x(real), real y(real), real z(real), real a, real b, int n=, void join(flatguide3)(... void(flatguide3)[])=); void(flatguide3)[] graph(picture pic=, real x(real), real y(real), real z(real), real a, real b, int n=, bool3 cond(real), void join(flatguide3)(... void(flatguide3)[])=); void graph(flatguide3)(picture pic=, triple v(real), real a, real b, int n=, void join(flatguide3)(... void(flatguide3)[])=); void(flatguide3)[] graph(picture pic=, triple v(real), real a, real b, int n=, bool3 cond(real), void join(flatguide3)(... void(flatguide3)[])=); void graph(flatguide3)(picture pic=, triple[] v, void join(flatguide3)(... void(flatguide3)[])=); void(flatguide3)[] graph(picture pic=, triple[] v, bool3[] cond, void join(flatguide3)(... void(flatguide3)[])=); void graph(flatguide3)(picture pic=, real[] x, real[] y, real[] z, void join(flatguide3)(... void(flatguide3)[])=); void(flatguide3)[] graph(picture pic=, real[] x, real[] y, real[] z, bool3[] cond, void join(flatguide3)(... void(flatguide3)[])=); void graph(flatguide3)(triple F(path, real), path p, int n=, void join(flatguide3)(... void(flatguide3)[])=); void graph(flatguide3)(triple F(pair), path p, int n=, void join(flatguide3)(... void(flatguide3)[])=); void graph(flatguide3)(picture pic=, real f(pair), path p, int n=, void join(flatguide3)(... void(flatguide3)[])=); void graph(flatguide3)(real f(pair), path p, int n=, real T(pair), void join(flatguide3)(... void(flatguide3)[])=); path3[] segment(triple[] v, bool[] cond, void join(flatguide3)(... void(flatguide3)[])=); void labelx3(picture pic=, Label L=, real x, align align=, string format=, pen p=); void tick(picture pic=, triple v, triple dir, real size=, pen p=); void tick(picture pic=, Label L, real value, triple v, triple dir, string format=, real size=, pen p=); void label(picture pic, Label L, triple v, real x, align align, string format, pen p); void zaxis3(picture pic=, Label L=, void axis(picture, axisT)=, real zmin=, real zmax=, pen p=, void ticks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)=, bool arrow(picture, path3, material, marginT3(path3, pen), light, light)=, marginT3 margin(path3, pen)=, bool above=, projection P=); void draw(picture pic=, Label[] L=, void(flatguide3)[][] g, pen[] p, light light=, string name=, render render=, interaction interaction=); void draw(picture pic=, Label[] L=, void(flatguide3)[][] g, pen p=, light light=, string name=, render render=, interaction interaction=); picture vectorfield(path3 vector(pair v), triple f(pair z), pair a, pair b, int nu=, int nv=, bool truesize=, real maxlength=, bool cond(pair z)=, pen p=, bool arrow(picture, path3, material, marginT3(path3, pen), light, light)=, marginT3 margin(path3, pen)=, string name=, render render=); triple Scale(picture pic=, triple v); triple[][] Scale(picture pic=, triple[][] P); void xtick3(picture pic=, real x, triple dir=, real size=, pen p=); void xtick3(picture pic=, Label L, real x, triple dir=, string format=, real size=, pen p=); locateT operator init(); void ztick(picture pic=, triple v, triple dir=, real size=, pen p=); void ztick(picture pic=, Label L, triple v, triple dir=, string format=, real size=, pen p=); void zaxis3At(picture pic=, Label L=, void axis(picture, axisT), real zmin=, real zmax=, pen p=, void ticks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)=, bool arrow(picture, path3, material, marginT3(path3, pen), light, light)=, marginT3 margin(path3, pen)=, bool above=, bool opposite=, bool opposite2=, bool primary=, projection P=); void yaxis3At(picture pic=, Label L=, void axis(picture, axisT), real ymin=, real ymax=, pen p=, void ticks(picture, real[][], Label, path3, path3, pen, bool(picture, path3, material, marginT3(path3, pen), light, light), marginT3(path3, pen), ticklocate, int[], bool opposite=, bool primary=, projection P)=, bool arrow(picture, path3, material, marginT3(path3, pen), light, light)=, marginT3 margin(path3, pen)=, bool above=, bool opposite=, bool opposite2=, bool primary=, projection P=); real[] uniform(real T(real x), real Tinv(real x), real a, real b, int n); void(flatguide3)[][] lift(real f(real x, real y), guide[][] g, void join(flatguide3)(... void(flatguide3)[])=); void(flatguide3)[][] lift(real f(pair z), guide[][] g, void join(flatguide3)(... void(flatguide3)[])=); void YZZero(picture, axisT)(triple align=, bool extend=); void YZZero(picture, axisT); void labely3(picture pic=, Label L=, real y, align align=, string format=, pen p=); real ScaleY(picture pic=, real y); void ytick3(picture pic=, real y, triple dir=, real size=, pen p=); void ytick3(picture pic=, Label L, real y, triple dir=, string format=, real size=, pen p=); triple ticklabelshift(triple align, pen p=); triple tickMax3(picture pic); triple tickMin3(picture pic); surface surface(picture pic=, triple[][] f, bool[][] cond=); surface surface(picture pic=, real[][] f, real[] x, real[] y, real[] xsplinetype(real[], real[])=, real[] ysplinetype(real[], real[])=, bool[][] cond=); surface surface(picture pic=, real[][] f, pair a, pair b, real[] xsplinetype(real[], real[]), real[] ysplinetype(real[], real[])=, bool[][] cond=); surface surface(picture pic=, real[][] f, pair a, pair b, bool[][] cond=); surface surface(picture pic=, triple f(pair z), pair a, pair b, int nu=, int nv=, bool cond(pair z)=); surface surface(picture pic=, triple f(pair z), real[] u, real[] v, real[](real[], real[])[] usplinetype, real[](real[], real[])[] vsplinetype=, bool cond(pair z)=); surface surface(picture pic=, triple f(pair z), pair a, pair b, int nu=, int nv=, real[](real[], real[])[] usplinetype, real[](real[], real[])[] vsplinetype=, bool cond(pair z)=); surface surface(picture pic=, real f(pair z), pair a, pair b, int nx=, int ny=, bool cond(pair z)=); surface surface(picture pic=, real f(pair z), pair a, pair b, int nx=, int ny=, real[] xsplinetype(real[], real[]), real[] ysplinetype(real[], real[])=, bool cond(pair z)=); path Circle(pair c, real r, int n=); path Arc(pair c, real r, real angle1, real angle2, bool direction, int n=); path Arc(pair c, real r, real angle1, real angle2, int n=); path Arc(pair c, explicit pair z1, explicit pair z2, bool direction=, int n=); guide polargraph(picture pic=, real r(real), real a, real b, int n=, guide join(... guide[])=); guide polargraph(picture pic=, real[] r, real[] theta, guide join(... guide[])=); void checkconditionlength(int x, int y); guide Hermite(... guide[])(real[] splinetype(real[], real[])); guide Hermite(... guide[]); guide Straight(... guide[]); picture secondaryY(picture primary=, void f(picture)); picture secondaryX(picture primary=, void f(picture)); string noprimary; void labely(picture pic=, Label L=, explicit pair z, align align=, string format=, pen p=); void labely(picture pic=, Label L=, real y, align align=, string format=, pen p=); void labely(picture pic=, Label L, string format=, explicit pen p=); void labelx(picture pic=, Label L=, explicit pair z, align align=, string format=, pen p=); void labelx(picture pic=, Label L=, real x, align align=, string format=, pen p=); void labelx(picture pic=, Label L, string format=, explicit pen p=); void ytick(picture pic=, explicit pair z, pair dir=, real size=, pen p=); void ytick(picture pic=, real y, pair dir=, real size=, pen p=); void ytick(picture pic=, Label L, explicit pair z, pair dir=, string format=, real size=, pen p=); void ytick(picture pic=, Label L, real y, pair dir=, string format=, real size=, pen p=); void xtick(picture pic=, explicit pair z, pair dir=, real size=, pen p=); void xtick(picture pic=, real x, pair dir=, real size=, pen p=); void xtick(picture pic=, Label L, explicit pair z, pair dir=, string format=, real size=, pen p=); void xtick(picture pic=, Label L, real x, pair dir=, string format=, real size=, pen p=); real ScaleX(picture pic=, real x); void yaxis(picture pic=, Label L=, void axis(picture, axisT)=, real ymin=, real ymax=, pen p=, void ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)=, bool arrow(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, bool above=, bool autorotate=); void xaxis(picture pic=, Label L=, void axis(picture, axisT)=, real xmin=, real xmax=, pen p=, void ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)=, bool arrow(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, bool above=); void limits(picture pic=, pair min, pair max, bool crop=); void crop(picture pic=); void ylimits(picture pic=, real min=, real max=, bool crop=); void xaxisAt(picture pic=, Label L=, void axis(picture, axisT), real xmin=, real xmax=, pen p=, void ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)=, bool arrow(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, bool above=, bool opposite=); real ytrans(transform t, real y); real xtrans(transform t, real x); void YEquals(picture, axisT)(real y, bool extend=); void LeftRight(picture, axisT)(bool extend=); void LeftRight(picture, axisT); void Right(picture, axisT)(bool extend=); void Right(picture, axisT); void Left(picture, axisT)(bool extend=); void Left(picture, axisT); axisT axis; void axis(picture pic=, Label L=, path g, path g2=, pen p=, void ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=), ticklocate locate, bool arrow(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, int[] divisor=, bool above=, bool opposite=); int Max; int Min; guide graphwithderiv(pair f(real), pair fprime(real), real a, real b, int n=); pair tickMax(picture pic); void RightTicks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, int N=, int n=, real Step=, real step=, bool begin=, bool end=, tickvalues modify(tickvalues)=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void RightTicks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, real[] Ticks, real[] ticks=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void RightTicks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=); tickvalues NoZero(tickvalues); tickvalues OmitTickInterval(tickvalues)(real a, real b); void Ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(int sign, Label F=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, real[] Ticks=, real[] ticks=, int N=, bool begin=, bool end=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void Ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(int sign, Label F=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, int N, int n=, real Step=, real step=, bool begin=, bool end=, tickvalues modify(tickvalues)=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void Ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, int N=, int n=, real Step=, real step=, bool begin=, bool end=, tickvalues modify(tickvalues)=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void Ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, real[] Ticks, real[] ticks=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void Ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=); tickvalues generateticks(int sign, Label F=, string ticklabel(real)=, int N, int n=, real Step=, real step=, real Size=, real size=, transform T, pair side, path g, real limit, pen p, ticklocate locate, int[] divisor, bool opposite); string autoformat(string format=, real norm ... real[] a); void labelaxis(frame f, transform T, Label L, path g, ticklocate locate=, int sign=, bool ticklabels=); void axes(picture pic=, Label xlabel=, Label ylabel=, bool extend=, pair min=, pair max=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, bool above=); pair labeltick(frame d, transform T, path g, ticklocate locate, real val, pair side, int sign, real Size, string ticklabel(real), Label F, real norm=); void drawtick(frame f, transform T, path g, path g2, ticklocate locate, real val, real Size, int sign, pen p, bool extend); ticklocate ticklocate(real a, real b, autoscaleT S=, real tickmin=, real tickmax=, real time(real)=, pair dir(real)=); autoscaleT defaultS; string LogFormat(real)(int base); string LogFormat(real); string DefaultLogFormat(real)(int base); string DefaultLogFormat(real); string NoZeroFormat(real); string DefaultFormat(real); string signedtrailingzero; string Format(real)(string s=); bounds autoscale(real Min, real Max, scaleT scale=); void autoscale(picture pic=, void axis(picture, axisT)); real upscale(real b, real a); int[] divisors(int a, int b); scaleT BrokenLog(real a, real b, bool automin=, bool automax=); scaleT Broken(real a, real b, bool automin=, bool automax=); string baselinetemplate; scaleT Logarithmic; scaleT Log; scaleT Log(bool automin=, bool automax=); guide Spline(... guide[]); void errorbar(picture pic, pair z, pair dp, pair dm, pen p=, real size=); tickvalues None(tickvalues v); string conditionlength; pair polar(real r, real theta); void scale(picture pic=, scaleT x, scaleT y=, scaleT z=); void scale(picture pic=, bool xautoscale=, bool yautoscale=, bool zautoscale=); guide graph(pair f(real), real, real, int)(guide join(... guide[])); guide[] graph(pair f(real), real, real, int)(guide join(... guide[]), bool3 cond(real)); guide graph(picture pic=, real f(real), real a, real b, int n=, real T(real)=, guide join(... guide[])=); guide[] graph(picture pic=, real f(real), real a, real b, int n=, real T(real)=, bool3 cond(real), guide join(... guide[])=); guide graph(picture pic=, real x(real), real y(real), real a, real b, int n=, real T(real)=, guide join(... guide[])=); guide[] graph(picture pic=, real x(real), real y(real), real a, real b, int n=, real T(real)=, bool3 cond(real), guide join(... guide[])=); guide graph(picture pic=, pair z(real), real a, real b, int n=, real T(real)=, guide join(... guide[])=); guide[] graph(picture pic=, pair z(real), real a, real b, int n=, real T(real)=, bool3 cond(real), guide join(... guide[])=); guide graph(picture pic=, pair[] z, guide join(... guide[])=); guide[] graph(picture pic=, pair[] z, bool3[] cond, guide join(... guide[])=); guide graph(picture pic=, real[] x, real[] y, guide join(... guide[])=); guide[] graph(picture pic=, real[] x, real[] y, bool3[] cond, guide join(... guide[])=); void XZero(picture, axisT)(bool extend=); void XZero(picture, axisT); pair zero(real); path[] segment(pair[] z, bool[] cond, guide join(... guide[])=); string trailingzero; void yaxisAt(picture pic=, Label L=, void axis(picture, axisT), real ymin=, real ymax=, pen p=, void ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)=, bool arrow(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, bool above=, bool opposite=); void xlimits(picture pic=, real min=, real max=, bool crop=); int Both; void NoTicks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(); void NoTicks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=); void Bottom(picture, axisT)(bool extend=); void Bottom(picture, axisT); tickvalues OmitTick(tickvalues)(... real[] x); pair Scale(picture pic=, pair z); scaleT Linear; scaleT Linear(bool automin=, bool automax=, real s=, real intercept=); bool logaxiscoverage(int N, transform T, path g, ticklocate locate, pair side, int sign, real Size, Label F, string ticklabel(real), real limit, int first, int last); void XEquals(picture, axisT)(real x, bool extend=); string OmitFormat(real)(string s= ... real[] x); real linear(real)(real S(real x)=, real Min, real Max); void tick(picture pic=, pair z, pair dir, real size=, pen p=); void tick(picture pic=, Label L, real value, explicit pair z, pair dir, string format=, real size=, pen p=); void YZero(picture, axisT)(bool extend=); void YZero(picture, axisT); int Value; void xequals(picture pic=, Label L=, real x, bool extend=, real ymin=, real ymax=, pen p=, void ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)=, bool arrow(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, bool above=); tickvalues OmitTickIntervals(tickvalues)(real[] a, real[] b); void yequals(picture pic=, Label L=, real y, bool extend=, real xmin=, real xmax=, pen p=, void ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)=, bool arrow(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=, bool above=); scientific operator init(); bounds operator init(); ticklocate operator init(); locateT operator init(); tickvalues operator init(); axisT operator init(); void Top(picture, axisT)(bool extend=); void Top(picture, axisT); void label(picture pic, Label L, pair z, real x, align align, string format, pen p); picture vectorfield(path vector(real), path g, int n, bool truesize=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=); picture vectorfield(path vector(pair), pair a, pair b, int nx=, int ny=, bool truesize=, bool cond(pair z)=, pen p=, bool arrow(picture, path, pen, marginT(path, pen))=, marginT margin(path, pen)=); void BottomTop(picture, axisT)(bool extend=); void BottomTop(picture, axisT); pair tickMin(picture pic); scientific scientific(real x); void LeftTicks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, int N=, int n=, real Step=, real step=, bool begin=, bool end=, tickvalues modify(tickvalues)=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void LeftTicks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, real[] Ticks, real[] ticks=, real Size=, real size=, bool extend=, pen pTick=, pen ptick=); void LeftTicks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=); Label Break; tickvalues Break(tickvalues)(real, real); real zerotickfuzz; real ScaleY(picture pic=, real y); bool axiscoverage(int N, transform T, path g, ticklocate locate, real Step, pair side, int sign, real Size, Label F, string ticklabel(real), real norm, real limit); pair ticklabelshift(pair align, pen p=); void errorbars(picture pic=, pair[] z, pair[] dp, pair[] dm=, bool[] cond=, pen p=, real size=); void errorbars(picture pic=, real[] x, real[] y, real[] dpx, real[] dpy, real[] dmx=, real[] dmy=, bool[] cond=, pen p=, real size=); void errorbars(picture pic=, real[] x, real[] y, real[] dpy, bool[] cond=, pen p=, real size=); real axiscoverage; int nmesh; bool Crop; real Ticksize; real axislabelfactor; bool NoCrop; real ticksize; int ngraph; int nCircle; real ylabelwidth; real epsilon; guide hermite(real[] x, real[] y, real[] splinetype(real[], real[])=); real[] monotonic(real[] x, real[] y); real[] clamped(real[], real[])(real slopea, real slopeb); real[] natural(real[] x, real[] y); real[] periodic(real[] x, real[] y); real[] notaknot(real[] x, real[] y); void checkincreasing(real[] x); void checklengths(int x, int y, string text=); string differentlengths; string morepoints; real[] Spline(real[] x, real[] y); real[](real[], real[])[] Spline; real[] linear(real[] x, real[] y); void grid3(picture pic=, grid3(picture pic)[][] gridroutine=, int N=, int n=, real Step=, real step=, bool begin=, bool end=, pen pGrid=, pen pgrid=, bool above=); void grid3(picture pic=, grid3(picture pic)[][] gridroutine, int N=, int n=, real Step=, real step=, bool begin=, bool end=, pen[] pGrid, pen[] pgrid, bool above=); grid3(picture pic)[][] XYZgrid(position pos=); grid3(picture pic)[][] XYZgrid; grid3(picture pic)[] ZX_ZYgrid(position posa=, position posb=); grid3(picture pic)[] ZX_ZYgrid; grid3(picture pic)[] XY_XZgrid(position posa=, position posb=); grid3(picture pic)[] XY_XZgrid; grid3(picture pic)[] YZYgrid(position pos=); grid3(picture pic)[] YZYgrid; grid3(picture pic)[] ZYZgrid(position pos=); grid3(picture pic)[] ZYZgrid; grid3(picture pic)[] XZXgrid(position pos=); grid3(picture pic)[] XZXgrid; grid3 ZYgrid(picture pic)(position pos=); grid3 ZYgrid(picture pic); grid3 ZXgrid(picture pic)(position pos=); grid3 ZXgrid(picture pic); grid3 XZgrid(picture pic)(position pos=); grid3 XZgrid(picture pic); grid3 XYgrid(picture pic)(position pos=); grid3 XYgrid(picture pic); grid3(picture pic)[] XYXgrid(position pos=); grid3(picture pic)[] XYXgrid; position bottom; grid3(picture pic)[] YXYgrid(position pos=); grid3(picture pic)[] YXYgrid; triple X(picture pic); grid3(picture pic)[] YX_YZgrid(position posa=, position posb=); grid3(picture pic)[] YX_YZgrid; triple XY(picture pic); triple Z(picture pic); void yaxis3(picture pic=, Label L=, void axis(picture, axisT)=, pen p=, ticksgridT ticks(), bool arrow(picture, path3, material, marginT3(path3, pen), light, light)=, bool above=); void xaxis3(picture pic=, Label L=, void axis(picture, axisT)=, pen p=, ticksgridT ticks(), bool arrow(picture, path3, material, marginT3(path3, pen), light, light)=, bool above=); ticksgridT InTicks()(Label F=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, int N=, int n=, real Step=, real step=, bool begin=, bool end=, real Size=, real size=, pen pTick=, pen ptick=, grid3(picture pic)[][] gridroutine, pen pGrid=, pen pgrid=); ticksgridT InOutTicks()(Label F=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, int N=, int n=, real Step=, real step=, bool begin=, bool end=, real Size=, real size=, pen pTick=, pen ptick=, grid3(picture pic)[][] gridroutine, pen pGrid=, pen pgrid=); ticksgridT OutTicks()(Label F=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, int N=, int n=, real Step=, real step=, bool begin=, bool end=, real Size=, real size=, pen pTick=, pen ptick=, grid3(picture pic)[][] gridroutine, pen pGrid=, pen pgrid=); grid3(picture pic)[] ZXZgrid(position pos=); grid3(picture pic)[] ZXZgrid; triple YZ(picture pic); triple Y(picture pic); grid3 YXgrid(picture pic)(position pos=); grid3 YXgrid(picture pic); position top; void zaxis3(picture pic=, Label L=, void axis(picture, axisT)=, pen p=, ticksgridT ticks(), bool arrow(picture, path3, material, marginT3(path3, pen), light, light)=, bool above=); triple ZX(picture pic); position middle; grid3(picture pic)[] operator cast(grid3 gridroutine(picture pic)); grid3(picture pic)[][] operator cast(grid3(picture pic)[] gridroutine); grid3(picture pic)[][] operator cast(grid3 gridroutine(picture pic)); grid3 YZgrid(picture pic)(position pos=); grid3 YZgrid(picture pic); grid3 operator init(); ticksgridT operator init(); real fspline(real)(real[] x, real[] y, real[] splinetype(real[], real[])=); real pwhermite(real)(real[] x, real[] y, real[] dy); horner diffdiv(real[] x, real[] y); real fhorner(real)(horner sh); horner operator init(); horner hdiffdiv(real[] x, real[] y, real[] dy); surface labelpath(string s, path3 p, real angle=, triple optional=); triple nextnormal(triple p, triple q); real eps; triple[] nextframe(path3 p, real reltimestart, triple[] start, real reltimeend, int subdiv=); triple[] firstframe(path3 p, triple optional=); string LeftJustified; string RightJustified; string Centered; void labelpath(frame f, Label L, path g, string justify=, pen p=); void labelpath(picture pic=, Label L, path g, string justify=, pen p=); void lm_minimize(int m_dat, int n_par, real[] par, void evaluate(real[] par, int m_dat, real[] fvec, lm_data_type data, lm_int_type info), void printout(int n_par, real[] par, int m_dat, real[] fvec, lm_data_type data, int iflag, int iter, int nfev), lm_data_type data, lm_control_type control); void lm_lmdif(int m, int n, real[] x, real[] fvec, real ftol, real xtol, real gtol, int maxfev, real epsfcn, real[] diag, int mode, real factor, lm_int_type info, lm_int_type nfev, real[] fjac, int[] ipvt, real[] qtf, real[] wa1, real[] wa2, real[] wa3, real[] wa4, void evaluate(real[] par, int m_dat, real[] fvec, lm_data_type data, lm_int_type info), void printout(int n_par, real[] par, int m_dat, real[] fvec, lm_data_type data, int iflag, int iter, int nfev), lm_data_type data); void lm_print_quiet(int n_par, real[] par, int m_dat, real[] fvec, lm_data_type data, int iflag, int iter, int nfev); void lm_evaluate_default(real[] par, int m_dat, real[] fvec, lm_data_type data, lm_int_type info); string[] lm_infmsg; real LM_SQRT_DWARF; real LM_DWARF; FitResult fit(real[] xdata, real[] ydata, real[] errors, real function(real[], real), real[] parameters, FitControl control=); FitResult fit(real[] xdata, real[] ydata, real function(real[], real), real[] parameters, FitControl control=); void lm_qrsolv(int n, real[] r, int ldr, int[] ipvt, real[] diag, real[] qtb, real[] x, real[] sdiag, real[] wa); real LM_MACHEP; real LM_USERTOL; real LM_SQRT_GIANT; string pad(string str, int count, string pad=); string pad(int num, int digits, string pad=); string pad(real num, int digits, string pad=); real lm_enorm(int n, real[] x, int offset=); string[] lm_shortmsg; void lm_lmpar(int n, real[] r, int ldr, int[] ipvt, real[] diag, real[] qtb, real delta, lm_real_type par, real[] x, real[] sdiag, real[] wa1, real[] wa2); real SQR(real x); void lm_print_default(int n_par, real[] par, int m_dat, real[] fvec, lm_data_type data, int iflag, int iter, int nfev); FitControl defaultControl; lm_data_type operator init(); lm_int_type operator init(); lm_real_type operator init(); lm_control_type operator init(); FitControl operator init(); FitResult operator init(); void lm_qrfac(int m, int n, real[] a, bool pivot, int[] ipvt, real[] rdiag, real[] acnorm, real[] wa); marker TildeIntervalMarker(int i=, int n=, real size=, real space=, real angle=, pair offset=, bool rotated=, pen p=, frame uniform=, bool above=); marker CrossIntervalMarker(int i=, int n=, real size=, real space=, real angle=, pair offset=, bool rotated=, pen p=, frame uniform=, bool above=); real markanglespace(pen p=); real markanglespace; real barmarksizefactor; real stickmarksizefactor; frame tildeframe(int n=, real size=, pair space=, real angle=, pair offset=, pen p=); frame tildeframe; real tildemarksize(pen p=); real tildemarksizefactor; real stickmarkspace(pen p=); frame stickframe(int n=, real size=, pair space=, real angle=, pair offset=, pen p=); frame stickframe; frame circlebarframe(int n=, real barsize=, real radius=, real angle=, pair offset=, pen p=, filltype filltype=, bool above=); real barmarksize(pen p=); real markangleradiusfactor; real markanglespacefactor; marker StickIntervalMarker(int i=, int n=, real size=, real space=, real angle=, pair offset=, bool rotated=, pen p=, frame uniform=, bool above=); void markangle(picture pic=, Label L=, int n=, real radius=, real space=, pair A, pair O, pair B, bool arrow(picture, path, pen, marginT(path, pen))=, pen p=, filltype filltype=, marginT margin(path, pen)=, marker marker=); real circlemarkradiusfactor; marker operator *(transform T, marker m); real stickmarkspacefactor; real markangleradius(pen p=); real markangleradius; frame duplicate(path g, int n=, pair space=, pen p=); marker CircleBarIntervalMarker(int i=, int n=, real barsize=, real radius=, real angle=, pair offset=, bool rotated=, pen p=, filltype filltype=, bool circleabove=, frame uniform=, bool above=); real crossmarksize(pen p=); real circlemarkradius(pen p=); real stickmarksize(pen p=); frame crossframe(int n=, real size=, pair space=, real angle=, pair offset=, pen p=); real crossmarksizefactor; void markinterval(picture pic=, frame f, path g)(int n=, frame f, bool rotated=); real findroot(real f(real), real a, real b, real tolerance=, real fa=, real fb=); real[] leastsquares(real[][] A, real[] b, bool warn=); void drawline(picture pic=, pair P, pair Q, pen p=); real[] zero(int n); real[][] zero(int n, int m); int[][] segment(bool[] b); triple intersectionpoint(triple n0, triple P0, triple n1, triple P1); pair[][] fft(pair[][] a, int sign=); rootfinder_settings operator init(); real interpolate(real[] x, real[] y, real x0, int i); real interpolate(real[] x, real[] y, real x0); bool increasing(real[] a, bool strict=); bool lexorder(pair a, pair b); bool lexorder(triple a, triple b); real asec(real x); bool polygon(path p); real csc(real x); real slope(path g, real x, int n=, real fuzz=); real slope(path g, explicit pair z, int n=, real fuzz=); bool rectangular(real[][] m); bool rectangular(pair[][] m); bool rectangular(triple[][] m); int unique(real[] a, real x); int unique(string[] a, string x); real intersect(pair p, pair q, pair z); real intersect(triple P, triple Q, triple n, triple Z); real acot(real x); int quadrant(real degrees); pair unityroot(int n, int k=); real sec(real x); real cot(real x); real acsc(real x); real frac(real x); pair log(explicit pair z); pair exp(explicit pair z); picture grid(int Nx, int Ny, pen p=); real[] partialsum(real[] a); real[] partialsum(real[] a, real[] dx); int[] partialsum(int[] a); int[] partialsum(int[] a, int[] dx); int[][] segmentlimits(bool[] b); bool square(real[][] m); string nopoint; real time(path g, real x, int n=, real fuzz=); real time(path g, explicit pair z, int n=, real fuzz=); real value(path g, real x, int n=, real fuzz=); real value(path g, explicit pair z, int n=, real fuzz=); pair[] quarticroots(real a, real b, real c, real d, real e); path cuttings; path cutbefore(path p, path q); path cutafter(path p, path q); obj operator init(); void draw(picture pic=, obj o, light light=); obj operator *(real[][] T, obj o); real[] solveBVP(real[] f(real, real[]), real a, real b=, real h=, int n=, bool dynamic=, real tolmin=, real tolmax=, real dtmin=, real dtmax=, RKTableau tableau, bool verbose=, real[] initial(real[]), real[] discrepancy(real[]), real[] guess, int iterations=); real error(real error, real initial, real lowOrder, real norm, real diff); RKTableau RK5DP; RKTableau RK5F; RKTableau RK4; RKTableau E_PC; RKTableau PC; RKTableau E_RK2; RKTableau RK2; RKTableau RK3BS; real stepfactor; RKTableau RK3; real phi4(real x); RKTableau Euler; real[] Coeff; void expfactors(real x, coefficients a); real phi3(real x); solution integrate(real y, real c=, real f(real t, real y), real a, real b=, real h=, int n=, bool dynamic=, real tolmin=, real tolmax=, real dtmin=, real dtmax=, RKTableau tableau, bool verbose=); Solution integrate(real[] y, real[] f(real t, real[] y), real a, real b=, real h=, int n=, bool dynamic=, real tolmin=, real tolmax=, real dtmin=, real dtmax=, RKTableau tableau, bool verbose=); void report(real old, real h, real t); real adjust(real h, real error, real tolmin, real tolmax, RKTableau tableau); RKTableau E_RK3BS; RKTableau E_Euler; void write(solution S); void write(Solution S); coefficients operator init(); RKTableau operator init(); solution operator init(); Solution operator init(); RKTableau RK5; real phi2(real x); real phi1(real x); real[][] finiteDifferenceJacobian(real[] f(real[]), real[] t, real[] h=); real[] newton(int iterations=, real[] f(real[]), real[][] jacobian(real[]), real[] t); pen[] BWRainbow2(int NColors=); pen[] quantize(pen[] Palette, int n); pen[] BWRainbow(int NColors, bool two); pen[] BWRainbow(int NColors=); pen[] Wheel(int NColors=); void PaletteTicks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(int sign=)(Label format=, string ticklabel(real)=, bool beginlabel=, bool endlabel=, int N=, int n=, real Step=, real step=, pen pTick=, pen ptick=); void PaletteTicks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(int sign=); pen[] palette(real[] f, pen[] palette); pen[][] palette(real[][] f, pen[] palette); void palette(picture pic=, Label L=, bounds bounds, pair initial, pair final, void axis(picture, axisT)=, pen[] palette, pen p=, void ticks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(int sign=)=, bool copy=, bool antialias=); bounds Automatic(picture pic, real min, real max); bounds Range(picture pic, real min, real max)(bool automin=, real min=, bool automax=, real max=); bounds Full(picture pic, real min, real max); pen[] Rainbow(int NColors=); pen[] Grayscale(int NColors=); void image(frame f, real[][] data, pair initial, pair final, pen[] palette, bool transpose=, transform t=, bool copy=, bool antialias=); void image(frame f, pen[][] data, pair initial, pair final, bool transpose=, transform t=, bool copy=, bool antialias=); bounds image(picture pic=, real[][] f, bounds range(picture pic, real min, real max)=, pair initial, pair final, pen[] palette, int divs=, bool transpose=, bool copy=, bool antialias=); bounds image(picture pic=, real f(real, real), bounds range(picture pic, real min, real max)=, pair initial, pair final, int nx=, int ny=, pen[] palette, int divs=, bool antialias=); void image(picture pic=, pen[][] data, pair initial, pair final, bool transpose=, bool copy=, bool antialias=); void image(picture pic=, pen f(int, int), int width, int height, pair initial, pair final, bool transpose=, bool antialias=); bounds image(picture pic=, pair[] z, real[] f, bounds range(picture pic, real min, real max)=, pen[] palette); bounds image(picture pic=, real[] x, real[] y, real[] f, bounds range(picture pic, real min, real max)=, pen[] palette); pen[] adjust(picture pic, real min, real max, real rmin, real rmax, pen[] palette); pen[] cmyk(pen[] Palette); void NoTicks(frame, transform, Label, pair, path, path, pen, bool(picture, path, pen, marginT(path, pen)), marginT(path, pen), ticklocate, int[], bool opposite=)(int sign=); transform swap; real[] sequencereal; pen[] Gradient(int NColors= ... pen[] p); picture tile(real Hx=, real Hy=, pen p=, filltype filltype=); frame tiling(string name, picture pic, pair lb=, pair rt=); picture crosshatch(real H=, pen p=); real hatchepsilon; picture brick(real Hx=, real Hy=, pen p=); void add(string name, picture pic, pair lb=, pair rt=); picture hatch(real H=, pair dir=, pen p=); picture checker(real Hx=, real Hy=, pen p=); void gsave(picture pic=); pen textpen; void grestore(picture pic=); pair align; rational sum(rational[] a); string texstring(rational r); string string(rational r); rational operator -(rational r); rational operator -(rational r, rational s); rational[] operator -(rational[] r); int lcm(int m, int n); int maxDenominator; bool operator <(rational r, rational s); bool[] operator <(rational[] r, rational s); bool operator >(rational r, rational s); bool[] operator >(rational[] r, rational s); rational abs(rational r); bool rectangular(rational[][] m); bool operator >=(rational r, rational s); bool[] operator >=(rational[] r, rational s); bool operator <=(rational r, rational s); bool[] operator <=(rational[] r, rational s); real operator ecast(rational r); rational operator ecast(real x); rational operator init(); rational[][] rationalidentity(int n); rational operator cast(int p); rational[] operator cast(int[] a); rational[][] operator cast(int[][] a); rational max(rational a, rational b); rational max(rational[] a); rational operator *(rational r, rational s); bool operator ==(rational r, rational s); bool[] operator ==(rational[] r, rational s); bool operator ==(rational[] r, rational[] s); bool operator ==(rational[][] r, rational[][] s); rational operator /(rational r, rational s); void write(file fout, string s=, rational r, void suffix(file)=); void write(string s=, rational r, void suffix(file)=); void write(file fout=, string s=, rational[] a, void suffix(file)=); void write(file fout=, string s=, rational[][] a, void suffix(file)=); rational min(rational a, rational b); int gcd(int m, int n); bool operator !=(rational r, rational s); rational operator +(rational r, rational s); void simplexPhase2(); void simplexPhase1(rational[] c, rational[][] A, rational[] b, int[] Bindices); void simplexTableau(rational[][] E, int[] Bindices, int I=, int J=, int n=); bool optimizeTableau; int[] artificialColumn; simplex operator init(); void simplexInit(rational[] c, rational[][] A, int[] s=, rational[] b, int count); void simplexWrite(rational[][] E, int[] Bindices, int, int); path roundedpath(path A, real R, real S=); problem operator init(); simplex operator init(); void currentexitfunction(); void bibliographystyle(string name); void subitem(string s, pen p=); string asywrite(string s, string preamble=); void code(bool center=, string s, pen p=, real indent=, real skip=, filltype filltype=); void asyinclude(string s, real xsize=, real ysize=); void indexedfigure(string prefix, int first, int last, string options=, string caption=, pair align=, pen p=, pen figuremattpen=, bool step=); void multifigure(string[] slist, string options=, string caption=, pair align=, pen p=, pen figuremattpen=, bool step=); void display(frame[] f, real margin=, pair align=, pen p=, pen figuremattpen=, bool final=); void display(frame f, real margin=, pair align=, pen p=, pen figuremattpen=, bool final=); void display(string[] s, real margin=, string[] captions=, string caption=, pair align=, pen p=, pen figuremattpen=, bool final=); void display(string s, string caption=, pair align=, pen p=, pen figuremattpen=, bool final=); void skip(real n=); void vbox(string s, pen p=); void center(string s, pen p=); void outline(string s=, pair position=, pair align=, pen p=); void title(string s, pair position=, pair align=, pen p=, bool newslide=); void incrementposition(pair z); bool checkposition(); void numberpage(pen p=); void normalvideo(); string texcolor(pen p); bool empty(); bool havepagenumber; int[] lastnode; int[] firstnode; pen backgroundcolor; pen steppagenumberpen; real figureborder; pen pagenumberpen; string[] codefile; pair startposition; void filecode(bool center=, string s, pen p=, real indent=, real skip=, filltype filltype=); void figure(string[] s, string options=, real margin=, string[] captions=, string caption=, string[] url=, pair align=, pen p=, pen figuremattpen=, bool final=); void figure(string s, string options=, string caption=, string url=, pair align=, pen p=, pen figuremattpen=, bool final=); pen foregroundcolor; string bulletcolor(string color); bool landscape; void erasestep(int erasenode); bool reverse; void remark(bool center=, string s, pair align=, pen p=, real indent=, bool minipage=, real skip=, filltype filltype=, bool step=); void exitfunction(); pen itempen; pen institutionpen; transform tinv; void color(string name, string color); void item(string s, pen p=, bool step=); void usersetting(); void setpens(pen red=, pen blue=, pen steppen=); string cropcode(string s); bool allowstepping; int preamblenodes; pair titlealign; pair dateskip; int page; void titlepage(string title, string author, string institution=, string date=, string url=, bool newslide=); void asycode(bool center=, string s, string options=, string caption=, string preamble=, pair align=, pen p=, pen figuremattpen=, real indent=, real skip=, filltype filltype=, bool newslide=); real pagemargin; void asyfigure(string s, string options=, string caption=, pair align=, pen p=, pen figuremattpen=, filltype filltype=, bool newslide=); string oldbulletcolor; bool firststep; void step(); void equation(string s, pen p=); void reversevideo(); void nextpage(pen p=); void bibliography(string name); pair titlepageposition; void equations(string s, pen p=); pen figuremattpen; pen urlpen; void asyfilecode(bool center=, string s, string options=, string caption=, pair align=, pen p=, pen figuremattpen=, real indent=, real skip=, filltype filltype=, bool newslide=); real titleskip; pen codepen; void newslide(bool stepping=); pair currentposition; pair pagenumberalign; pair pagenumberposition; pen authorpen; real minipagemargin; bool stepping; bool itemstep; real pagewidth; real pageheight; picture background; void background(); real minipagewidth; pen titlepagepen; pen datepen; real itemskip; real codeskip; real aboveequationskip; pair urlskip; pen titlepen; string newbulletcolor; string bullet; path curve(pair c, real f(real, real), pair a, pair b); path curve(pair c, real f(real), pair a, pair b); real stepfraction; picture slopefield(real f(real, real), pair a, pair b, int nx=, int ny=, real tickfactor=, pen p=); picture slopefield(real f(real), pair a, pair b, int nx=, int ny=, pen p=); surface implicitsurface(real f(triple)=, real ff(real, real, real)=, triple a, triple b, int n=, bool keyword overlapedges=, int keyword nx=, int keyword ny=, int keyword nz=, int keyword maxdepth=, bool keyword usetriangles=); evaluatedpoint[][][] make3dgrid(triple a, triple b, int nx, int ny, int nz, real f(triple), bool allowzero=); bool checkptincube(triple pt, triple a, triple b); bool check_fpt_zero(triple testpoint, real f(triple), triple grad(triple)); patch[] maketriangle(path3 external, real f(triple), triple grad(triple), bool allowsubdivide=); triple normalout(int face); path3 pathinface(positionedvector v1, positionedvector v2, triple facenorm, triple edge1normout, triple edge2normout); path3 pathinface(positionedvector v1, positionedvector v2, int face, int edge1face, int edge2face); triple projecttospan(triple toproject, triple v1, triple v2, real mincoeff=); real[] projecttospan_findcoeffs(triple toproject, triple v1, triple v2, bool warn=); path3 pathbetween(positionedvector v1, positionedvector v2); path3 pathbetween(path3 edgecycle, int vertex1, int vertex2); int[] makecircle(edge[] edges); int YLOW; int YHIGH; int XLOW; patch trianglewithnormals(path3 external, triple n1, triple n2, triple n3); patch patchwithnormals(path3 external, triple[] u0normals, triple[] u1normals, triple[] v0normals, triple[] v1normals); patch patchwithnormals(path3 external, triple normalat(triple)); patch[] triangletoquads(path3 external, real f(triple), triple grad(triple), triple a, triple b); real B23(real t); real B03(real t); bool checkpt(triple testpt, real f(triple), triple grad(triple), triple a, triple b); int NULL_VERTEX; evaluatedpoint[][] slice(evaluatedpoint[][] a, int start1, int end1, int start2, int end2); evaluatedpoint[][][] slice(evaluatedpoint[][][] a, int start1, int end1, int start2, int end2, int start3, int end3); positionedvector[][] slice(positionedvector[][] a, int start1, int end1, int start2, int end2); positionedvector[][][] slice(positionedvector[][][] a, int start1, int end1, int start2, int end2, int start3, int end3); triple nGrad(triple)(real f(triple)); real angledegrees(triple a, triple b); path3 bisector(path3 edgecycle, int[] savevertices); int ZHIGH; int XHIGH; real(real)[] bernstein; pathwithnormals_settings operator init(); intset operator init(); int_to_intset operator init(); edge operator init(); positionedvector operator init(); evaluatedpoint operator init(); gridwithzeros operator init(); string operator cast(edge e); string operator cast(edge[] edges); string operator cast(positionedvector vv); triple operator cast(evaluatedpoint p); patch[] quadpatches(path3 edgecycle, positionedvector[] corners, real f(triple), triple grad(triple), triple a, triple b, bool usetriangles); real B33(real t); real B13(real t); int ZLOW; bool operator ==(edge a, edge b); revolution sphere(triple c=, real r, int n=); pen defaultbackpen; path line(path p, path q, real[] t); real[] tangent(path p, path q, bool side); void draw(picture pic=, revolution r, int m=, int n=, pen frontpen=, pen backpen=, pen longitudinalpen=, pen longitudinalbackpen=, light light=, string name=, render render=, projection P=); revolution operator *(real[][] t, revolution r); surface surface(revolution r, int n=, pen color(int i, real j)=); skeleton operator init(); revolution operator init(); path[] cylinder(path3 base, real h, triple axis=, projection P); revolution cylinder(triple c=, real r, real h, triple axis=); revolution cone(triple c=, real r, real h, triple axis=, int n=); linefit leastsquares(real[] x, real[] y); linefit leastsquares(real[] x, real[] y, real[] w); real Gaussrand(); int bins(real[] data, int max=); void histogram(picture pic=, real[] bins, real[] count, real low=, pen fillpen=, pen drawpen=, bool bars=, Label legend=, real markersize=); void histogram(picture pic=, real[] data, real a, real b, int n, bool normalize=, real low=, pen fillpen=, pen drawpen=, bool bars=, Label legend=, real markersize=); path topbox(pair a, pair b); path halfbox(pair a, pair b); int[] frequency(real[] data, real[] bins); int[] frequency(real[] data, real a, real b, int n); int[][] frequency(real[] x, real[] y, real[] xbins, real[] ybins); int[][] frequency(real[] x, real[] y, pair a, pair b, int nx, int ny=); int[][] frequency(pair[] z, pair a, pair b, int nx, int ny=); real kurtosisexcess(real[] A); real kurtosis(real[] A); real skewness(real[] A); real rms(real[] A); real stdev(real[] A); real variance(real[] A); real variancebiased(real[] A); real legendmarkersize; real mean(real[] A); pair Gaussrandpair(); real Gaussian(real x, real sigma); real Gaussian(real x); linefit operator init(); Braid apply(Relation r, Braid b, int step, int place); Relation operator -(Relation r); Component wye; Component bm; Component bp; pair[] endpoints(guide[] a); real gapfactor; Relation r4b; Component operator init(); Braid operator init(); Relation operator init(); Syzygy operator init(); Relation r4a; picture tableau(frame[] cards, bool number=); pair min(pair[] z); pair max(pair[] z); real hwratio; Relation r3; Component phi; pen Brown; pen OliveGreen; pen SpringGreen; pen LimeGreen; pen PineGreen; pen Green; pen JungleGreen; pen SkyBlue; pen ProcessBlue; pen Blue; pen NavyBlue; pen MidnightBlue; pen Periwinkle; pen BlueViolet; pen RoyalPurple; pen Violet; pen Plum; pen Sepia; pen Black; pen BlueGreen; pen Aquamarine; pen Cerulean; pen Apricot; pen RawSienna; pen Orange; pen Rhodamine; pen Red; pen ForestGreen; pen BurntOrange; pen YellowOrange; pen Cyan; pen Bittersweet; pen Gray; pen GreenYellow; pen DarkOrchid; pen RedOrange; pen CadetBlue; pen Turquoise; pen Dandelion; pen Melon; pen RoyalBlue; pen Orchid; pen BrickRed; pen CornflowerBlue; pen Yellow; pen YellowGreen; pen Tan; pen TealBlue; pen Magenta; pen Lavender; pen Mulberry; pen Goldenrod; pen WildStrawberry; pen SeaGreen; pen White; pen CarnationPink; pen Peach; pen Mahogany; pen Maroon; pen OrangeRed; pen RubineRed; pen Emerald; pen Salmon; pen VioletRed; pen RedViolet; pen Fuchsia; pen Thistle; pen Purple; int lookup(tree t, int key); bool contains(tree t, int key); tree newtree(); tree operator init(); tree add(tree t, int key, int value); void write(file out=, tree t); real trembleFrequency; real trembleRandom; real trembleAngle; real magneticRadius; tremble operator init(); real trembleFuzz(); int coloredNodes; path3 roundedpath(path3 A, real r); surface tube(path3 g, coloredpath section, transform T(real)=, real corner=, real relstep=); real tubegranularity; coloredpath operator cast(path p); coloredpath operator cast(guide p); real degrees(rmf a, rmf b); int coloredSegments; real[] sample(path3 g, real r, real relstep=); coloredpath operator init(); void render(path3 s, real r, void f(path3, real)); surface surface(rmf[] R, real[] t, coloredpath cp, transform T(real), bool cyclic); triangleGroup operator init(); pixel operator init(); CameraInformation operator init(); v3dfile operator init(); void importv3d(string name); real[][] Align(real polar, real azimuth); v3dheadertypes v3dheadertypes; v3dheadertypes operator init(); v3dtypes v3dtypes; v3dtypes operator init(); string VERSION; pen WhiteSmoke; pen Wheat; pen Violet; pen Tomato; pen SteelBlue; pen SpringGreen; pen Snow; pen SkyBlue; pen Silver; pen SandyBrown; pen SaddleBrown; pen RosyBrown; pen Purple; pen PowderBlue; pen Plum; pen Pink; pen PeachPuff; pen PapayaWhip; pen PaleVioletRed; pen PaleTurquoise; pen PaleGoldenrod; pen OrangeRed; pen Orange; pen Olive; pen OldLace; pen Navy; pen NavajoWhite; pen Moccasin; pen MintCream; pen MidnightBlue; pen MediumTurquoise; pen MediumSpringGreen; pen MediumSlateBlue; pen MediumPurple; pen Linen; pen LimeGreen; pen Lime; pen LightYellow; pen LightSteelBlue; pen LightSkyBlue; pen LightGrey; pen LightGreen; pen LightCyan; pen LightCoral; pen LightBlue; pen LawnGreen; pen LavenderBlush; pen Khaki; pen IndianRed; pen HotPink; pen GreenYellow; pen Green; pen Goldenrod; pen Gold; pen GhostWhite; pen Gainsboro; pen Fuchsia; pen FloralWhite; pen DodgerBlue; pen DeepSkyBlue; pen DarkViolet; pen DarkSlateGray; pen DarkSlateBlue; pen DarkSeaGreen; pen DarkSalmon; pen DarkOrchid; pen FireBrick; pen Black; pen RoyalBlue; pen LightPink; pen DeepPink; pen LightSeaGreen; pen Maroon; pen LightSlateGray; pen Brown; pen BlueViolet; pen LightSalmon; pen Cyan; pen DimGray; pen Sienna; pen AntiqueWhite; pen ForestGreen; pen SlateBlue; pen Teal; pen DarkCyan; pen Peru; pen AliceBlue; pen Thistle; pen CadetBlue; pen Ivory; pen Gray; pen SlateGray; pen DarkOliveGreen; pen Turquoise; pen MediumAquamarine; pen Aqua; pen Red; pen Azure; pen DarkGray; pen LightGoldenrodYellow; pen MediumBlue; pen White; pen Salmon; pen Coral; pen MediumOrchid; pen Blue; pen MediumSeaGreen; pen Orchid; pen PaleGreen; pen CornflowerBlue; pen DarkOrange; pen Yellow; pen Chocolate; pen DarkRed; pen Crimson; pen YellowGreen; pen Indigo; pen Tan; pen MediumVioletRed; pen DarkBlue; pen OliveDrab; pen Magenta; pen MistyRose; pen Honeydew; pen LemonChiffon; pen Chartreuse; pen Seashell; pen Lavender; pen SeaGreen; pen DarkTurquoise; pen Cornsilk; pen rgbint(int r, int g, int b); pen Aquamarine; pen Beige; pen Bisque; pen BlanchedAlmond; pen BurlyWood; pen DarkGoldenrod; pen DarkGreen; pen DarkKhaki; pen DarkMagenta;