| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192919391949195919691979198919992009201920292039204920592069207920892099210921192129213921492159216921792189219922092219222922392249225922692279228922992309231923292339234923592369237923892399240924192429243924492459246924792489249925092519252925392549255925692579258925992609261926292639264926592669267926892699270927192729273927492759276927792789279928092819282928392849285928692879288928992909291929292939294929592969297929892999300930193029303930493059306930793089309931093119312931393149315931693179318931993209321932293239324932593269327932893299330933193329333933493359336933793389339934093419342934393449345934693479348934993509351935293539354935593569357935893599360936193629363936493659366936793689369937093719372937393749375937693779378937993809381938293839384938593869387938893899390939193929393939493959396939793989399940094019402940394049405940694079408940994109411941294139414941594169417941894199420942194229423942494259426942794289429943094319432943394349435943694379438943994409441944294439444944594469447944894499450945194529453945494559456945794589459946094619462946394649465946694679468946994709471947294739474947594769477947894799480948194829483948494859486948794889489949094919492949394949495949694979498949995009501950295039504950595069507950895099510951195129513951495159516951795189519952095219522952395249525952695279528952995309531953295339534953595369537953895399540954195429543954495459546954795489549955095519552955395549555955695579558955995609561956295639564956595669567956895699570957195729573957495759576957795789579958095819582958395849585958695879588958995909591959295939594959595969597959895999600960196029603960496059606960796089609961096119612961396149615961696179618961996209621962296239624962596269627962896299630963196329633963496359636963796389639964096419642964396449645964696479648964996509651965296539654965596569657965896599660966196629663966496659666966796689669967096719672967396749675967696779678967996809681968296839684968596869687968896899690969196929693969496959696969796989699970097019702970397049705970697079708970997109711971297139714971597169717971897199720972197229723972497259726972797289729973097319732973397349735973697379738973997409741974297439744974597469747974897499750975197529753975497559756975797589759976097619762976397649765976697679768976997709771977297739774977597769777977897799780978197829783978497859786978797889789979097919792979397949795979697979798979998009801980298039804980598069807980898099810981198129813981498159816981798189819982098219822982398249825982698279828982998309831983298339834983598369837983898399840984198429843984498459846984798489849985098519852985398549855985698579858985998609861986298639864986598669867986898699870987198729873987498759876987798789879988098819882988398849885988698879888988998909891989298939894989598969897989898999900990199029903990499059906990799089909991099119912991399149915991699179918991999209921992299239924992599269927992899299930993199329933993499359936993799389939994099419942994399449945994699479948994999509951995299539954995599569957995899599960996199629963996499659966996799689969997099719972997399749975997699779978997999809981998299839984998599869987998899899990999199929993999499959996999799989999100001000110002100031000410005100061000710008100091001010011100121001310014100151001610017100181001910020100211002210023100241002510026100271002810029100301003110032100331003410035100361003710038100391004010041100421004310044100451004610047100481004910050100511005210053100541005510056100571005810059100601006110062100631006410065100661006710068100691007010071100721007310074100751007610077100781007910080100811008210083100841008510086100871008810089100901009110092100931009410095100961009710098100991010010101101021010310104101051010610107101081010910110101111011210113101141011510116101171011810119101201012110122101231012410125101261012710128101291013010131101321013310134101351013610137101381013910140101411014210143101441014510146101471014810149101501015110152101531015410155101561015710158101591016010161101621016310164101651016610167101681016910170101711017210173101741017510176101771017810179101801018110182101831018410185101861018710188101891019010191101921019310194101951019610197101981019910200102011020210203102041020510206102071020810209102101021110212102131021410215102161021710218102191022010221102221022310224102251022610227102281022910230102311023210233102341023510236102371023810239102401024110242102431024410245102461024710248102491025010251102521025310254102551025610257102581025910260102611026210263102641026510266102671026810269102701027110272102731027410275102761027710278102791028010281102821028310284102851028610287102881028910290102911029210293102941029510296102971029810299103001030110302103031030410305103061030710308103091031010311103121031310314103151031610317103181031910320103211032210323103241032510326103271032810329103301033110332103331033410335103361033710338103391034010341103421034310344103451034610347103481034910350103511035210353103541035510356103571035810359103601036110362103631036410365103661036710368103691037010371103721037310374103751037610377103781037910380103811038210383103841038510386103871038810389103901039110392103931039410395103961039710398103991040010401104021040310404104051040610407104081040910410104111041210413104141041510416104171041810419104201042110422104231042410425104261042710428104291043010431104321043310434104351043610437104381043910440104411044210443104441044510446104471044810449104501045110452104531045410455104561045710458104591046010461104621046310464104651046610467104681046910470104711047210473104741047510476104771047810479104801048110482104831048410485104861048710488104891049010491104921049310494104951049610497104981049910500105011050210503105041050510506105071050810509105101051110512105131051410515105161051710518105191052010521105221052310524105251052610527105281052910530105311053210533105341053510536105371053810539105401054110542105431054410545105461054710548105491055010551105521055310554105551055610557105581055910560105611056210563105641056510566105671056810569105701057110572105731057410575105761057710578105791058010581105821058310584105851058610587105881058910590105911059210593105941059510596105971059810599106001060110602106031060410605106061060710608106091061010611106121061310614106151061610617106181061910620106211062210623106241062510626106271062810629106301063110632106331063410635106361063710638106391064010641106421064310644106451064610647106481064910650106511065210653106541065510656106571065810659106601066110662106631066410665106661066710668106691067010671106721067310674106751067610677106781067910680106811068210683106841068510686106871068810689106901069110692106931069410695106961069710698106991070010701107021070310704107051070610707107081070910710107111071210713107141071510716107171071810719107201072110722107231072410725107261072710728107291073010731107321073310734107351073610737107381073910740107411074210743107441074510746107471074810749107501075110752107531075410755107561075710758107591076010761107621076310764107651076610767107681076910770107711077210773107741077510776107771077810779107801078110782107831078410785107861078710788107891079010791107921079310794107951079610797107981079910800108011080210803108041080510806108071080810809108101081110812108131081410815108161081710818108191082010821108221082310824108251082610827108281082910830108311083210833108341083510836108371083810839108401084110842108431084410845108461084710848108491085010851108521085310854108551085610857108581085910860108611086210863108641086510866108671086810869108701087110872108731087410875108761087710878108791088010881108821088310884108851088610887108881088910890108911089210893108941089510896108971089810899109001090110902109031090410905109061090710908109091091010911109121091310914109151091610917109181091910920109211092210923109241092510926109271092810929109301093110932109331093410935109361093710938109391094010941109421094310944109451094610947109481094910950109511095210953109541095510956109571095810959109601096110962109631096410965109661096710968109691097010971109721097310974109751097610977109781097910980109811098210983109841098510986109871098810989109901099110992109931099410995109961099710998109991100011001110021100311004110051100611007110081100911010110111101211013110141101511016110171101811019110201102111022110231102411025110261102711028110291103011031110321103311034110351103611037110381103911040110411104211043110441104511046110471104811049110501105111052110531105411055110561105711058110591106011061110621106311064110651106611067110681106911070110711107211073110741107511076110771107811079110801108111082110831108411085110861108711088110891109011091110921109311094110951109611097110981109911100111011110211103111041110511106111071110811109111101111111112111131111411115111161111711118111191112011121111221112311124111251112611127111281112911130111311113211133111341113511136111371113811139111401114111142111431114411145111461114711148111491115011151111521115311154111551115611157111581115911160111611116211163111641116511166111671116811169111701117111172111731117411175111761117711178111791118011181111821118311184111851118611187111881118911190111911119211193111941119511196111971119811199112001120111202112031120411205112061120711208112091121011211112121121311214112151121611217112181121911220112211122211223112241122511226112271122811229112301123111232112331123411235112361123711238112391124011241112421124311244112451124611247112481124911250112511125211253112541125511256112571125811259112601126111262112631126411265112661126711268112691127011271112721127311274112751127611277112781127911280112811128211283112841128511286112871128811289112901129111292112931129411295112961129711298112991130011301113021130311304113051130611307113081130911310113111131211313113141131511316113171131811319113201132111322113231132411325113261132711328113291133011331113321133311334113351133611337113381133911340113411134211343113441134511346113471134811349113501135111352113531135411355113561135711358113591136011361113621136311364113651136611367113681136911370113711137211373113741137511376113771137811379113801138111382113831138411385113861138711388113891139011391113921139311394113951139611397113981139911400114011140211403114041140511406114071140811409114101141111412114131141411415114161141711418114191142011421114221142311424114251142611427114281142911430114311143211433114341143511436114371143811439114401144111442114431144411445114461144711448114491145011451114521145311454114551145611457114581145911460114611146211463114641146511466114671146811469114701147111472114731147411475114761147711478114791148011481114821148311484114851148611487114881148911490114911149211493114941149511496114971149811499115001150111502115031150411505115061150711508115091151011511115121151311514115151151611517115181151911520115211152211523115241152511526115271152811529115301153111532115331153411535115361153711538115391154011541115421154311544115451154611547115481154911550115511155211553115541155511556115571155811559115601156111562115631156411565115661156711568115691157011571115721157311574115751157611577115781157911580115811158211583115841158511586115871158811589115901159111592115931159411595115961159711598115991160011601116021160311604116051160611607116081160911610116111161211613116141161511616116171161811619116201162111622116231162411625116261162711628116291163011631116321163311634116351163611637116381163911640116411164211643116441164511646116471164811649116501165111652116531165411655116561165711658116591166011661116621166311664116651166611667116681166911670116711167211673116741167511676116771167811679116801168111682116831168411685116861168711688116891169011691116921169311694116951169611697116981169911700117011170211703117041170511706117071170811709117101171111712117131171411715117161171711718117191172011721117221172311724117251172611727117281172911730117311173211733117341173511736117371173811739117401174111742117431174411745117461174711748117491175011751117521175311754117551175611757117581175911760117611176211763117641176511766117671176811769117701177111772117731177411775117761177711778117791178011781117821178311784117851178611787117881178911790117911179211793117941179511796117971179811799118001180111802118031180411805118061180711808118091181011811118121181311814118151181611817118181181911820118211182211823118241182511826118271182811829118301183111832118331183411835118361183711838118391184011841118421184311844118451184611847118481184911850118511185211853118541185511856118571185811859118601186111862118631186411865118661186711868118691187011871118721187311874118751187611877118781187911880118811188211883118841188511886118871188811889118901189111892118931189411895118961189711898118991190011901119021190311904119051190611907119081190911910119111191211913119141191511916119171191811919119201192111922119231192411925119261192711928119291193011931119321193311934119351193611937119381193911940119411194211943119441194511946119471194811949119501195111952119531195411955119561195711958119591196011961119621196311964119651196611967119681196911970119711197211973119741197511976119771197811979119801198111982119831198411985119861198711988119891199011991119921199311994119951199611997119981199912000120011200212003120041200512006120071200812009120101201112012120131201412015120161201712018120191202012021120221202312024120251202612027120281202912030120311203212033120341203512036120371203812039120401204112042120431204412045120461204712048120491205012051120521205312054120551205612057120581205912060120611206212063120641206512066120671206812069120701207112072120731207412075120761207712078120791208012081120821208312084120851208612087120881208912090120911209212093120941209512096120971209812099121001210112102121031210412105121061210712108121091211012111121121211312114121151211612117121181211912120121211212212123121241212512126121271212812129121301213112132121331213412135121361213712138121391214012141121421214312144121451214612147121481214912150121511215212153121541215512156121571215812159121601216112162121631216412165121661216712168121691217012171121721217312174121751217612177121781217912180121811218212183121841218512186121871218812189121901219112192121931219412195121961219712198121991220012201122021220312204122051220612207122081220912210122111221212213122141221512216122171221812219122201222112222122231222412225122261222712228122291223012231122321223312234122351223612237122381223912240122411224212243122441224512246122471224812249122501225112252122531225412255122561225712258122591226012261122621226312264122651226612267122681226912270122711227212273122741227512276122771227812279122801228112282122831228412285122861228712288122891229012291122921229312294122951229612297122981229912300123011230212303123041230512306123071230812309123101231112312123131231412315123161231712318123191232012321123221232312324123251232612327123281232912330123311233212333123341233512336123371233812339123401234112342123431234412345123461234712348123491235012351123521235312354123551235612357123581235912360123611236212363123641236512366123671236812369123701237112372123731237412375123761237712378123791238012381123821238312384123851238612387123881238912390123911239212393123941239512396123971239812399124001240112402124031240412405124061240712408124091241012411124121241312414124151241612417124181241912420124211242212423124241242512426124271242812429124301243112432124331243412435124361243712438124391244012441124421244312444124451244612447124481244912450124511245212453124541245512456124571245812459124601246112462124631246412465124661246712468124691247012471124721247312474124751247612477124781247912480124811248212483124841248512486124871248812489124901249112492124931249412495124961249712498124991250012501125021250312504125051250612507125081250912510125111251212513125141251512516 | \input texinfo @c -*-texinfo-*-@c %**start of header@setfilename avram.info@settitle avram - a virtual machine code interpreter@finalout@setchapternewpage odd@c %**end of header@set VERSION 0.13.0@ifinfoThis file documents the @code{avram} command which is a virtual machine code interpreterCopyright (C) 2000, 2003, 2006-2010, 2012 Dennis FureyPermission is granted to make and distribute verbatim copies ofthis manual provided the copyright notice and this permission noticeare preserved on all copies.@ignorePermission is granted to process this file through TeX and print theresults, provided the printed document carries copying permissionnotice identical to this one except for the removal of this paragraph(this paragraph not being relevant to the printed manual).@end ignorePermission is granted to copy and distribute modified versions of thismanual under the conditions for verbatim copying, provided that the entireresulting derived work is distributed under the terms of a permissionnotice identical to this one.Permission is granted to copy and distribute translations of this manualinto another language, under the above conditions for modified versions,except that this permission notice may be stated in a translation approvedby the Free Software Foundation.@end ifinfo@titlepage@title Avram@subtitle a virtual machine code interpreter@subtitle for avram Version @value{VERSION}@author by Dennis Furey@page@vskip 0pt plus 1filllCopyright @copyright{} 2000, 2003, 2006-2010, 2012 Dennis FureyPermission is granted to make and distribute verbatim copies ofthis manual provided the copyright notice and this permission noticeare preserved on all copies.Permission is granted to copy and distribute modified versions of thismanual under the conditions for verbatim copying, provided that the entireresulting derived work is distributed under the terms of a permissionnotice identical to this one.Permission is granted to copy and distribute translations of this manualinto another language, under the above conditions for modified versions,except that this permission notice may be stated in a translation approvedby the Free Software Foundation.@end titlepage@shortcontents@contents@c All the nodes can be updated using the EMACS command@c texinfo-every-node-update, which is normally bound to C-c C-u C-e.@node Top, Preface, (dir), (dir)@ifinfoThis file documents @code{avram} version @value{VERSION}, which is a virtualmachine code interpreter.@end ifinfo@c All the menus can be updated with the EMACS command@c texinfo-all-menus-update, which is normally bound to C-c C-u C-a.@menu* Preface::                        project aims and scope* User Manual::                    command line options and usage* Virtual Machine Specification::  a guide for compiler writers* Library Reference::              how to reuse or enhance @code{avram}* Character Table::                representations for ASCII characters* Reference Implementations::      constructive computability proofs* Changes::                        recent updates to the manual* External Libraries::             specifications and calling conventions* Copying::                        license terms* Function Index::                 for the shared library API* Concept Index::@end menu@node Preface, User Manual, Top, Top@unnumbered Preface@code{avram} is a virtual machine code interpreter.  It reads an inputfile containing a user-supplied application expressed in virtual machinecode, and executes it on the host machine. The name is a quasi-acronymfor ``Applicative ViRtuAl Machine''.  Notable features are@cindex functional programming@cindex environment@cindex Unix@itemize @bullet@item strongsupport for functional programming operations (e.g., list processing)@iteminterfaces to selected functions from mathematical libraries, such as@itemize @bullet@item@code{gsl}      (numerical integration, differentiation, and series acceleration) @url{http://www.gnu.org/software/gsl/}@item@code{mpfr}     (arbitrary precision arithmetic)@url{http://www.mpfr.org}@item@code{minpack}  (non-linear optimization)@url{http://www.netlib.org/minpack}@item@code{lapack}   (linear algebra)@url{http://www.netlib.org/lapack}@item@code{fftw}     (fast fourier transforms)@url{http://www.fftw.org}@item@code{Rmath}    (statistical and transcendental functions)@url{http://www.r-project.org}@item@code{ufsparse} (sparse matrices)@url{http://www.cise.ufl.edu/research/sparse/SuiteSparse/current/SuiteSparse/}@item@code{glpk}     (linear programming by the simplex method)@url{http://www.gnu.org/software/glpk}@item@code{lpsolve}      (mixed integer linear programming)@url{http://sourceforge.net/projects/lpsolve/}@item@code{kinsol}   (constrained non-linear optimization)@url{http://www.llnl.gov/CASC/sundials/}@end itemize@item interoperability of virtual code applications with other consoleapplications or shells through the @code{expect} library@item a simple high-levelinterface to files, environment variables and command line parameters@item support for various styles of stateless or persistent streamprocessors (a.k.a. Unix filters)@end itemizeThe reason for writing @code{avram} was that I wanted to do some workusing a functional programming language, didn't like any functionalprogramming languages that already existed, and felt that it would beless trouble to write a virtual machine emulator than the back end ofa compiler. As of version 0.1.0, the first public release of@code{avram} as such in 2000, most of the code base had been in heavyuse by me for about four years, running very reliably. At this writingsome six years later, it has seen even more use with rarely anyreliability issues, in some cases attacking large combinatorialproblems for weeks or months at a time. These problems have involvedboth long running continuous execution, and batches of thousands ofshorter jobs.Although the virtual machine is biased toward functional programming,it is officially language agnostic, so @code{avram} may be useful toanyone involved in the development of compilers for other programming,scripting, or special purpose languages. The crucial advantage ofusing it in your own project is that rather than troubling overaddress modes, register allocation, and other hassles inherent ingenerating native code, your compiler can just dump a fairly highlevel intermediate code representation of the source text to a file,and let the virtual machine emulator deal with the details. Thetradeoff for using a presumably higher level interpreted language is that theperformance is unlikely to be competitive with native code, but thisissue is mitigated in the case of numerical applications whose heavylifting is done by the external libraries mentioned above.Portability is an added bonus. The virtual code is binary compatibleacross all platforms. Versions of @code{avram} as of 0.1.0 and later arepackaged using GNU autotools and should be possible to build on anyplatform supporting them. In particular, the package is known to havebuilt successfully on MacOS, FreeBSD, Solaris (thanks to the compilefarm at Sourceforge.net) Digital Unix, and Debian GNU/Linux for i386 andAlpha platforms, although it has not been extensively tested on all ofthem. Earlier versions were compiled and run successfully on Irix andeven Windows-NT (with @command{gcc}).This document is divided into three main parts, with possibly threedifferent audiences, but they all depend on a basic familiarity with@cindex UnixUnix or GNU/Linux systems.@table @asis@item @ref{User Manual}essentially reproduces the information found inthe manpage that is distributed with @code{avram} with a few extraexamples and longer explanations. Properly deployed,@code{avram} should be almost entirely hidden from end users by wrapperscripts, so the ``users'' to whom this part is relevant would bethose involved in preparing these scripts (a matter of choosing the rightcommand line options). Depending on the extent to which this task isautomated by a compiler, that may include the compiler writer or thedevelopers of applications.@item @ref{Virtual Machine Specification}documents much of what one would need to know in order to write acompiler that generates code executable by @code{avram}. That includesthe complete virtual machine code semantics and file formats. It wouldalso be possible to implement a compatible replacement for @code{avram}from scratch based on the information in this chapter, in case anyonehas anything against C, my coding style, or the GPL.  (A few patches tomake it @command{lint} cleanly or a new implementation in goodpedagogical Java without pointers would both be instructiveexercises. ;-))@cindex pointers@cindex Java@item @ref{Library Reference}includes documentation on the application program interface andrecommended entry points for the C library distributed with@code{avram}. This information would be of use to those wishing todevelop applications incorporating similar features, or to reuse thecode for unrelated purposes. It might also be useful to anyone wishingto develop C or C++ applications that read or write data files in theformat used by @code{avram}.@end table@node User Manual, Virtual Machine Specification, Preface, Top@chapter User ManualThis chapter provides the basic information on how to use @code{avram}to execute virtual machine code applications.@code{avram} is invokedby typing a command at a shell prompt in one of these three forms.@display@kbd{avram} [@emph{general options}]@kbd{avram} [@emph{filter mode options}] @var{codefile}[@kbd{.avm}]@kbd{avram} [@emph{parameter mode options}] @var{codefile}[@kbd{.avm}] [@emph{parameters}]@end display@noindentIn the second case, @code{avram} reads from standard input, and mayof course appear as part of commands such as@cindex standard input@display@kbd{avram} [@emph{filter mode options}] @var{codefile}[@kbd{.avm}] < @var{inputfile}@var{anothercommand} | @kbd{avram} [@emph{filter mode options}] @var{codefile}[@kbd{.avm}]@end display@noindentWhen @code{avram} is invoked with the name of an input file (with adefault extension @kbd{.avm}), it reads virtual machine code from thefile and executes it on the host machine.@cindex functional programmingThe virtual code format used by @code{avram} is designedto support the features of functional or applicative programminglanguages. Although this chapter documents only the usage of@code{avram} and not the internals, it will be helpful to keep in mindthat the virtual machine code expresses a mathematical function ratherthan a program in the conventional sense. As such, it performs no actiondirectly, but may be applied in a choice of ways by the user of@code{avram} according to the precise operation required.The following sections provide information in greater detail aboutusage and diagnostics.@menu* General Options::             getting help and version information* Modes of Operation::          stream processing or file oriented* Filter Mode Options::         how to run a stream processor* Parameter Mode Options::      how to have an application use files* Command Line Syntax::         application-independent conventions* Diagnostics::                 explanation of error messages* Security::                    running untrusted applications* Example Script::              how to unburden the end users* Files::                       miscellaneous files used* Environment::                 environment variables* Bugs::                        hall of shame@end menu@node General Options, Modes of Operation, User Manual, User Manual@section General OptionsRegardless of whatever other command line parameters are given,@code{avram} accepts the following parameters:@cindex help@cindex emulation@cindex @code{help} command line option@cindex @code{emulation} command line option@table @code@item -h, --helpShow a summary of options and exit.@item -V,-v, --versionShow the version of program and a short copyleft message and exit.@item --emulation=@var{version}Be backward compatible with an older version of @code{avram}.  Thisoption should include a valid version number, for example@kbd{@value{VERSION}}, which is the version of @code{avram} to beemulated. It can make virtual code applications future proof, assumingthat future versions of @code{avram} correctly support backwardcompatibility. It may be used in conjunction with any other option inany mode of operation.@cindex web page@cindex home page@cindex urlThis copy of the user manual has not been updated since version @value{VERSION} of@code{avram}, so it is unable to document incompatibilities with laterversions. The latest version of the manual may be found at@url{http://www.lsbu.ac.uk/~fureyd/avram}.@item -e, --external-libraries@cindex @code{external-libraries}Show a list of libraries with which @code{avram} has been linked andwhose functions therefore could be called from virtual machineprograms. This growing list currently includes selected functions from@code{fftw}, @code{glpk}, @code{gsl}, @code{kinsol}, @code{lapack},@code{minpack}, @code{mpfr}, @code{lpsolve}, @code{Rmath} and @code{ufsparse}(see @ref{Preface}) which are documented further in @ref{External Libraries}.@item -j, --jail@cindex @code{jail}This option disables execution of shell commands by virtual codeapplications, which is normally possible by default even for nominallynon-interactive applications (see @ref{Parameter Mode Options}). Avirtual code application attempting to spawn a shell (using the@code{interact} combinator) when this option is selected willencounter an exception rather than successful completion of theoperation. This option is provided as a security feature for runninguntrusted code (see @ref{Security}), and is incompatible with@option{-i}, @option{-t}, and @option{-s}.@item -f, --force-text-input@cindex @code{force-text-input} command line optionNormally @code{avram} will try to guess by looking at a file whether itis an ordinary text file or one that has been written in the virtualcode file format, and choose a different internal representationaccordingly. An application may require one representation or theother. This option tells @code{avram} to treat all input files otherthan the virtual code file (named in the first command line parameter)as text files regardless of whether or not it would be possible tointerpret them otherwise. This option may be used in combination withany other option.@end table@node Modes of Operation, Filter Mode Options, General Options, User Manual@section Modes of OperationApart from to the capability to print brief help messages and exit,there are two main modes of operation, depending on which optionsare specified on the command line before the virtual code file name.@cindex modes@cindex modesFor the purpose of choosing the mode of operation, the virtualcode filename is taken to be the first command line argument notbeginning with a dash. Other conventions relevant to applicationspecific parameters are detailed in @ref{Command Line Syntax}.@menu* Filter Mode::                 * Parameter Mode::              @end menu@node Filter Mode, Parameter Mode, Modes of Operation, Modes of Operation@subsection Filter Mode@cindex filter mode@cindex modesIn filter mode, the argument to the function given by the virtual codeis taken from standard input, and the result is written to standardoutput, except for error messages resulting from a failure to evaluatethe function, which are written to standard error.@xref{Diagnostics}. Filter mode is indicated whenever these threeconditions are all met.@itemize @bullet@itemEither at least one of the filter mode options appears on the commandline preceding the first filename parameter, or there are no options atall. @xref{Filter Mode Options}.@itemExactly one filename parameter appears on the command line,which is the name of the virtual machine code file.@itemEither the filename comes last on the command line, or the@option{--unparameterized} option precedes it, causingeverything following it to be ignored.@end itemize @noindentExamples:@table @kbd@item avram mynewapp < inputfilename@cindex standard inputIn this example, filter mode is recognized by default because there areno options or input files on the command line to indicateotherwise. (The input file redirected into standard input is not treatedby the shell as a command line argument.)@item cat somefile | avram -r coolprog > outputfileIn this example, the @option{-r} option gives it away, being one of thefilter mode options, in addition to the fact that there are no inputfile parameters or application-specific options.@item avram -u devilmaycare.avm --bogusoption ignoredparameterIn this case, filter mode is forced by the @option{-u}option despite indications to the contrary.@end table@node Parameter Mode,  , Filter Mode, Modes of Operation@subsection Parameter Mode@cindex parameter modeIn parameter mode, the argument to the function given by the virtualcode is a data structure containing environment variables and commandline parameters including files, application specific options, andpossibly standard input. The result obtained by evaluating thefunction is either a data structure representing a set of files to bewritten, which may include standard output, or a sequence of shellcommands to be executed, or a combination of both. Parameter mode isindicated whenever either of these conditions is met.@itemize @bullet@itemAny of the parameter mode options appears on thecommand line preceding the first filename parameter.@ifinfo@*@end ifinfo@xref{Parameter Mode Options}.@itemAt least one additional filename parameter or option follows the firstfilename parameter, and the option @option{--unparameterized} does notprecede it.@end itemize @noindentExamples:@table @kbd@item avram --map-to-each-file prettyprinter.avm *.c *.h --extra-prettyIn this example, parameter mode is indicated both by the parametermode option @option{--map-to-each-file} and by the presence of inputfile names and the @option{--extra-pretty} option. The latter isspecific to the hypothetical @code{prettyprinter.avm} virtual codeapplication, as indicated by its position on the command line, and istherefore passed to it by @code{avram}.@item cat ~/specfile | avram reportgenerator -v - /var/log/syslogIn this example, a hypothetical parameter mode application@code{reportgenerator} is able to read @file{~/specfile} from standardinput because of the @code{-} used as a parameter.@item avram --parameterized grepenvIn this example, a hypothetical application that searches shellvariables is invoked in parameter mode even with no input files orapplication specific options, because of the  @option{--parameterized}option. Parameter mode invocation is required by the application to giveit access to the environment.@item avram grepenv --search-targets=PATH,MANPATHThis example shows an application specific option with both a keywordand a parameter list. They suffice to indicate parameter mode withoutan explicit @option{--parameterized} option.@end table@node Filter Mode Options, Parameter Mode Options, Modes of Operation, User Manual@section Filter Mode OptionsThe options available in filter mode are listed below. Except asotherwise noted, all options are mutually exclusive. Ordinarily agiven application will require certain fixed settings of these optionsand will not work properly if they are set inappropriately.@table @code@item -r, @code{--raw-output}@cindex raw-output command line optionNormally the result obtained by evaluating the function in the virtualcode file must be a list of character strings, which is written assuch to standard output. However, if this option is selected, the formof the result is unconstrained, and it will be written in a data fileformat that is not human readable but can be used by otherapplications. This option is incompatible with any other optionsexcept @option{-u}.@item -c, --choice-of-output@cindex @code{choice-of-output} command line optionWhen this option is used, the evaluation of the function given by thevirtual machine code will be expected to yield a data structure fromwhich @code{avram} will ascertain whether standard output should bewritten in text or raw data format.  This option should be used onlyif application is aware of it. It is incompatible with any other optionsexcept @option{-u}.@item -l, --line-map@cindex @code{line-map} command line optionNormally the entire contents of standard input up to @code{EOF} areloaded into memory and used as the argument to the function in thevirtual code file. However, this option causes standard input to be reada line at a time, with the function applied individually to each line,and its result in each case written immediately to standard output.  Agiven application either requires this option or does not, and will notwork properly in the alternative. This option implies@option{--force-text-input} and is incompatible with any other option except@option{-u}.@item -b, --byte-transducer@cindex @code{byte-transducer} command line optionThis option causes standard input to be read one character at a time,evaluating the function given by the virtual code file each time. Thefunction is used as a state transition function that takes a state andinput to a next state and output. The output is written concurrentlywith the input operations. A given application will not work properlywith an inappropriate setting of this option.  This option implies@option{--force-text-input} and is incompatible with any other optionexcept @option{-u}.@item -u, --unparameterized@cindex @code{unparameterized} command line optionNormally @code{avram} guesses whether to use filter mode or parametermode depending on whether there are any parameters. Selecting thisoption forces it to operate in filter mode regardless. Any parametersthat may appear on the command line after the virtual code file nameare ignored. This option may be used in conjunction with any otherfilter mode option.@end table@node Parameter Mode Options, Command Line Syntax, Filter Mode Options, User Manual@section Parameter Mode Options@cindex parameter modeThe parameter mode options are listed below. Except as otherwisenoted, any combination of parameter mode options may be selectedtogether, and except as noted, the settings of these options can bevaried without breaking the application.@table @code@item -q, --quiet@cindex @code{quiet} command line option@code{avram} normally informs the user when writing an output file witha short message to standard output. This option suppresses suchmessages. This option is compatible with any application and any otherparameter mode option except @option{-a}.@item -a, --ask-to-overwrite@cindex @code{ask-to-overwrite} command line optionSelecting this option will cause @code{avram} to ask permissioninteractively before overwriting an existing file, and to refrain fromoverwriting it without permission, in which case the contents thatwere to be written will be lost. This option overrides @option{-q} and iscompatible with any other parameter mode option or application.@item -.EXT@cindex @code{EXT} command line option@cindex default file extensions@cindex extensions@cindex file name extensions@cindex file name suffixesAn option beginning with a dash followed by a period specifies adefault extension for input file names. If @code{avram} doesn't find afile named on the command line, and the filename doesn't alreadycontain a period, @code{avram} will try to find a file having a similarname but with the default extension appended. The default extension givenby this option takes precedence over the hard coded default extensionsof @kbd{.fun} and @kbd{.avm}. At most one default extension can be supplied. Thisoption is compatible with any other parameter mode option andcompatible with any application.@item -d, --default-to-stdin@cindex @code{default-to-stdin} command line option@cindex standard inputIf no filename parameter appears on the command line (other than thename of the virtual code file), this option directs @code{avram} to readthe contents of standard input as if it were specified as a command lineparameter. (Standard input can also be specified explicitly as adash. See @ref{Command Line Syntax}.) This option is compatible with anyapplication and any other parameter mode option except @option{-m}.@item -m, --map-to-each-file@cindex @code{map-to-each-file} command line optionNormally @code{avram} loads the entire contents of all files named onthe command line into memory so as to evaluate the virtual machinecode application on all of them together. This option can be used tosave memory in the case of applications that operate on multiple filesindependently. It causes @code{avram} to load only one file at a timeand to perform the relevant evaluation and output before loading thenext one. Application specific options and standard input (ifspecified) are read only once and reused. This option is incompatiblewith @option{-d}, and not necessarily compatible with all applications,although some may work both with and without it.@item -i, --interactive@cindex @code{interactive} command line option@cindex interactive applicationsThis option is used in the case of applications that interact withother programs through shell commands. An application that is meant tobe invoked in this way requires this option and will not work withoutit, nor will applications that are not of this type work with it. Thisoption is implied by @option{-t} and @option{-s}, and is compatible with anyother parameter mode option.@item -s, --step@cindex @code{step} command line optionThis option is used in the case of applications that interact withother programs through shell commands, similarly to @option{-i}, andcan substitute for it (see above). The option has the additionaleffect of causing shell commands issued by @code{avram} on behalf ofthe application to be written with their results to standard output,and to cause @code{avram} to pause after displaying each shell commanduntil a key is pressed.  This capability may be useful for debuggingor auditing purposes but does not otherwise alter the effects of theapplication.  This option is compatible with any other parameter modeoption.@item -t, --trace@cindex @code{trace} command line optionThis option is used in the case of applications that interact withother programs through shell commands, but only by way of the@code{interact} combinator, for which it provides developers a meansof low level debugging, particularly deadlock detection. When thisoption is selected, a verbose trace of all characters exchangedbetween the functional transducer and the external application arewritten to standard output, along with some additional control flowdiagnostics. This option is compatible with any other parameter modeoption.@item -p, --parameterized@cindex @code{parameterized} command line optionNormally @code{avram} tries to guess whether to operate in filter modeor parameter mode based on the options used and the parameters. Ifthere are no parameters and no options, it will default to filtermode, and try to read standard input. However, if this option isselected, it will use parameter mode (and therefore not try to readstandard input unless required).@end table@node Command Line Syntax, Diagnostics, Parameter Mode Options, User Manual@section Command Line Syntax@cindex command lineThe command line parameters that follow the virtual code file namewhen @code{avram} is used in parameter mode (@ref{Parameter Mode}) are dependent on thespecific application. However, all supported applications areconstrained for implementation reasons to observe certain uniformconventions regarding their command line parameters, which aredocumented here to avoid needless duplication.@cindex shell@cindex file parameters@cindex input filesThe shell divides the command line into "arguments" separated by whitespace.  Arguments containing white space or special characters used bythe shell must be quoted or protected as usual. File names with wildcards in them are expanded by the shell before @code{avram} sees them.@code{avram} then extracts from the sequence of arguments a sequence offilenames and a sequence of options. Each option consists of a keyword and anoptional parameter list. Filenames, keywords, and parameter lists aredistinguished according to the following criteria.@enumerate@itemAn argument is treated as a keyword iff it meets these threeconditions.@enumerate a@itemIt starts with a dash.@itemIt doesn't contain an equals sign.@itemIt doesn't consist solely of a dash.@end enumerate@itemAn argument is treated as a parameter list iff it meets these fourconditions.@enumerate a@itemIt doesn't begin with a dash.@itemIt either begins with an equals sign or doesn't contain one.@itemIt immediately follows an argument beginning with a dash, notcontaining an equals sign and not consisting solely of a dash.@itemAt least one of the following is true.@enumerate@itemIt doesn't contain a period, tilde, or path separator.@cindex path separators@itemIt contains a comma.@itemIt can be interpreted as a C formatted floating point number.@end enumerate@end enumerate@itemAn argument is treated as an input file name iff it meets these fourconditions.@enumerate a@itemIt doesn't begin with a dash.@itemIt doesn't contain an equals sign.@itemIt doesn't contain a comma.@itemAt least one of the following is true.@enumerate@itemIt contains a period, tilde, or path separator.@itemIt doesn't immediately follow an argument beginning with a dash, notconsisting solely of a dash, and not containing an equals sign.@end enumerate@end enumerate@itemIf an argument contains an equals sign but doesn't begin with one,the part on the left of the first equals sign is treated as akeyword and the part on the right is treated as a parameter list.@itemAn argument consisting solely of a dash is taken to represent thestandard input file.@itemAn argument not fitting any of the above classifications is an error.@end enumerateThese conventions are needed for @code{avram} to detect input file namesin a general, position independent way, so that it can preload the fileson behalf of the application. Many standard Unix utilities follow these@cindex Unixconventions to a large extent, the exceptions being those that employnon-filename arguments without distinguishing syntax, and use positionalor other ad hoc methods of command line interpretation. A drop-inreplacement for such an application could nevertheless be implementedusing @code{avram} with an appropriate wrapper script, similar to theapproach recommended in @ref{Example Script}, but with suitable keywordsinserted prior to the ambiguous arguments.@node Diagnostics, Security, Command Line Syntax, User Manual@section Diagnostics@cindex diagnostics@cindex error messages@cindex run time errorsThe means exists for virtual code applications to have run time errormessages written to standard error on their behalf by@code{avram}. Any error messages not documented here originate with anapplication and should be documented by it.Most error messages originating from @code{avram} are prefaced by theapplication name (i.e., the name of the file containing the virtualmachine code), but will be prefaced by @code{avram:} if the error iscaused by a problem loading this file itself. Error messages originatingfrom virtual code applications are the responsibility of theirrespective authors and might not be prefaced by the application name.The run time errors not specifically raised by the application can beclassified as internal errors, i/o errors, overflow errors, fileformat errors, application programming errors, and configuration relatederrors.Some error messages include a code number. The number identifiesthe specific point in the source code where the condition wasdetected, for the benefit of the person maintaining it.@menu* Internal Errors::             * i/o Errors::                  * Overflow Errors::             * File Format Errors::          * Application Programming Errors::  * Configuration Related Errors::  * Other Diagnostics and Warnings::  @end menu@node Internal Errors, i/o Errors, Diagnostics, Diagnostics@subsection Internal Errors@cindex internal errorsInternal errors should never occur unless the@code{avram} source code has been carelessly modified, except as notedin @ref{Bugs}. There are two kinds.@table @code@item @var{application-name}: virtual machine internal error (code @var{nn})Most internal errors would be reported by a message of this formif they were to occur. It indicates that some required invariant wasnot maintained. In such cases, the program terminates immediately, andany results already produced are suspect.@item @var{application-name}: @var{nn} unreclaimed @var{struct-names}A message of this form could be printed at the end of an otherwise successfulrun. @code{avram} maintains a count of the number of units allocatedfor various data structures, and checks that they are all reclaimedeventually as a safeguard against memory leaks. This message indicatesthat some memory remains unaccounted for.@end table@cindex bug reports@cindex email@cindex authorIf a repeatable internal error is discovered, please email a bugreport and a small representative test case to@email{ursala-users@@freelists.org} or file an issue on the Avramgithub page. Include the version number of @code{avram}, which you canget by running @kbd{avram --version}.@node i/o Errors, Overflow Errors, Internal Errors, Diagnostics@subsection i/o Errors@cindex i/o errorsThese error messages are prefaced with the name of theapplication. A further explanation as to the@cindex @code{strerror}reason, obtained from the standard @code{strerror()} utility, isappended to the messages below if possible.@table @code@item @var{application-name}: can't read @var{filename}@cindex file names@cindex @code{can't read}@cindex environment@cindex @code{AVMINPUTS}A file was not able to be opened for reading, typically because it wasnot found or because the user does not have permission. The file name isdisplayed with special characters expanded but without any defaultextensions or search paths that may have been tried. If you think a fileexists and should have been found, there may be a problem with your@env{AVMINPUTS} environment variable (@ref{Environment}).@item @var{application-name}: can't write @var{filename}@cindex @code{can't write}A file was not able to be opened for writing.@item @var{application-name}: can't write to @var{filename}A file was successfully opened for writing but became impossible towrite thereafter.@item @var{application-name}: can't spawn @var{command}@cindex shell@cindex expect@cindex libexpect@cindex @code{can't spawn}@cindex @code{exp_popen}@cindex spawning processesAn attempt to execute a shell command on behalf of an interactiveapplication failed during the @code{exp_popen()} call to the@code{libexpect} library.@item @var{application-name}: can't close @var{filename}@cindex @code{can't close}A call to the standard C procedure @code{fclose()} failed due tounforeseen circumstances. The error is non-fatal but the file should bechecked for missing data.@end table@node Overflow Errors, File Format Errors, i/o Errors, Diagnostics@subsection Overflow ErrorsThese errors are reported by the application name prefacing one of thefollowing messages, except as noted below.@cindex overflow@cindex counter overflow@cindex memory overflow@table @code@item @var{application-name}: counter overflow (code @var{nn})An overflow occurred in an unsigned long integer being used as a referencecounter or something similar. This situation is very unlikely.@item @var{application-name}: memory overflow (code @var{nn})There wasn't enough memory to build an internal data structure. Themost likely cause is an attempt to operate on inputfiles that are too large. Standard remedies apply.@end tableThe memory overflow or counter overflow messages can also be reportedwithout the application name preface or a code number. In these cases,they arise in the course of evaluating the function given by theapplication, rather than by loading the input files.A counter overflow in this case is possible if the applicationattempts to compute the size of a very large, shared structure usingnative integer arithmetic.@cindex @command{ulimit}Memory overflows are possible due to insufficient memory for a validpurpose, but may also occur due to a non-terminating recursion in thevirtual machine code. To prevent thrashing or other bad effects fromrunaway code, the @command{ulimit} shell command is your friend.@node File Format Errors, Application Programming Errors, Overflow Errors, Diagnostics@subsection File Format ErrorsCertain application crashes result from an application not adheringto the required conventions about data and file formats, or because theapplication was invoked in the wrong mode (@ref{Modes of Operation}). Theseare the following.@table @code@item @var{application-name}: invalid text format (code @var{nn})@cindex @code{invalid text format}An application that was expected to return a string of characters tobe written to a text file returned data that did not correspond to anyvalid character representation.@item @var{application-name}: null character in promptAn interactive application (invoked rightly or wrongly with @option{-i},@option{-t}, or @option{-s}) is required to exchange strings of non-nullcharacters internally with @code{avram}, and used a null.@item @var{application-name}: invalid file name (code @var{nn})The data structure representing a file obtained from an applicationhas a name consisting of something other than character strings. Thiserror could be the result of a filter mode application (@ref{FilterMode}) being invoked in parameter mode.@ifinfo@*@end ifinfo(@ref{Parameter Mode})@item @var{application-name}: null character in file name@cindex @code{null character in file name}Similar to the above errors.@item @var{application-name}: bad character in file name@cindex @code{bad character in file name}Slashes, backslashes, and unprintable characters other than spaces arealso prohibited in file names.@item @var{application-name}: invalid output preamble format@cindex @code{invalid output preamble format}According the format used by @code{avram} for data files, a data filemay contain an optional text portion, known as the preamble. Thiserror occurs when a data file obtained from an application can not bewritten because the preamble is something other than a list ofcharacter strings.@item @var{application-name}: invalid file specification@cindex @code{invalid file specification}This error occurs in situations where the data structure for a fileobtained by evaluating the application is too broken to permit anymore specific diagnosis.@item avram: invalid raw file format in @var{application-name}@cindex @code{invalid raw file format}The file containing the virtual machine code was not able to beloaded, because the code was not in a recognizable format. Either thefile has become corrupted, the compiler that generated it has abug in it, or the wrong file was used as a virtual code file.@end table@node Application Programming Errors, Configuration Related Errors, File Format Errors, Diagnostics@subsection Application Programming ErrorsA further class of application crashes results from miscellaneous bugsin the application. These require the application to be debugged andhave no user level explanation or workaround, but are listed here forreference. These messages are not normally prefaced by the applicationname when reported unless the application elects to do so, except forthe @code{invalid profile identifier} message.@itemize @bullet@item @code{invalid recursion}@cindex @code{invalid recursion}@item @code{invalid comparison}@cindex @code{invalid comparison}@item @code{invalid deconstruction}@cindex @code{invalid deconstruction}@item @code{invalid transpose}@cindex @code{invalid transpose}@item @code{invalid membership}@cindex @code{invalid membership}@item @code{invalid distribution}@cindex @code{invalid distribution}@item @code{invalid concatenation}@cindex @code{invalid concatenation}@item @code{invalid assignment}@cindex @code{invalid assignment}@item @code{unrecognized combinator (code @var{nn})}@cindex @code{unrecognized combinator}@item @code{@var{application-name}: invalid profile identifier}@cindex @code{invalid profile identifier}@item @code{unsupported hook}@cindex @code{unsupported hook}@end itemize@node Configuration Related Errors, Other Diagnostics and Warnings, Application Programming Errors, Diagnostics@subsection Configuration Related ErrorsThe source code distribution of @code{avram} incorporates a flexibleconfiguration script allowing it to be installed on a variety ofplatforms. Not all platforms allow support for all features. It is alsoanticipated that new features may be added to @code{avram} from time totime. Some problems may therefore occur due to features not beingsupported at your site for either of these reasons. The following errormessages are relevant to these situations.@table @code@item unsupported hook@cindex @code{unsupported hook}If it's not simply due to an application programming error(@ref{Application Programming Errors}) this message may be the result oftrying to use an application that requires a newer version of@code{avram} than the one installed, even though applications shouldavoid this problem by checking the version number at run time. If thisis the reason, the solution would be to install the latest version.@item @var{application-name}: I need avram linked with @var{foo}, @var{bar} and @var{baz}.@cindex @code{I need avram linked with}A message of the this form indicates that a new installation may beneeded. At this writing (11/11/1), @code{avram} may report this messagewith respect to @code{libexpect5.32}, @code{tcl8.3}, and @code{libutil}if any of the @option{-i}, @option{-t}, or @option{-s} options is used on asystem where not all of these libraries were detected when @code{avram}was installed from a source distribution. (See @ref{Parameter Mode Options}.)Because @code{avram} is useful even without interactive applications,these libraries are not considered absolute prerequisites by theconfiguration script.@item avram: can't emulate version @var{version}@cindex @code{can't emulate version}@cindex @code{emulation} command line option@cindex versions@cindex backward compatibilityThe @option{--emulation=@var{version}} option obviously won't work ifthe requested version is newer than the installed version, or if it isnot a valid version number (@ref{General Options}). When that happens,this message is printed instead and @code{avram} terminates.@item avram: multiple version specifications@cindex @code{multiple version specifications}The @option{--emulation=@var{version}} option can be used at most onceon a command line. This message is printed if it is used more thanonce. If you only typed it once and got this message, check your aliasesand wrapper scripts before reporting a bug.@item avram: unrecognized option: @var{option-name}@cindex @code{unrecognized option}may mean that a command line option has been misspelled, or may be anothersign of an obsolete version of @code{avram}. This message will be followedby a usage summary similar to that of the @option{--help} option.(@ref{General Options}).@item @var{application-name}: warning: search paths not supported@cindex search paths@cindex paths@cindex environment@cindex @code{AVMINPUTS}@cindex @code{search paths not supported}@cindex @file{argz.h}If the @file{argz.h} header file was not detected during configuration,@code{avram} will not be able to support search paths in the@env{AVMINPUTS} environment variable (@ref{Environment}). This messageis a warning that the environment variable is being ignored. If thewarning is followed by an i/o error@ifinfo@*@end ifinfo(@ref{i/o Errors}), the latter may be due to a file being in a path thatwas not searched for this reason. A workaround is to specify the fullpath names of all input files outside the current working directory. Ifyou don't need search paths, you can get rid of this message byundefining @env{AVMINPUTS}.@end table@node Other Diagnostics and Warnings,  , Configuration Related Errors, Diagnostics@subsection Other Diagnostics and Warnings@table @asis@item @code{avram: multiple -.EXT options; all but last ignored}@cindex @code{multiple -.EXT options}@cindex extensions@cindex file extensions@cindex extensions@cindex file name extensions@cindex file name suffixesThis message is written when more than one default extension is given asa command line parameter.  At most one default extension is allowed. Ifmore than one is given, only the last one is used. The error isnon-fatal and @code{avram} will try to continue. If you need morethan one default extension, consider using the hard coded defaultextensions of @file{.fun} and @file{.avm}, or hacking the shell scriptin which the @code{avram} command line appears.@item @code{@var{application name}: empty operator}This message probably means that the virtual code file is corrupt orinvalid.@item usage summary@cindex @code{help} command line optionFor any errors in usage not covered by other diagnostics, such asincompatible combinations of options, @code{avram} prints a message tostandard error giving a brief summary of options, similar to the outputfrom @kbd{avram --help}. (See @ref{General Options}.)@end table@node Security, Example Script, Diagnostics, User Manual@section Security@cindex securityA few obvious security considerations are relevant to running untrustedvirtual code applications. These points are only as reliable as theassumption that the @code{avram} executable has not been modified to thecontrary.@itemize @bullet@cindex filter mode@item The applications with the best protection from malicious code arethose that run in filter mode, because they have no access to anyinformation not presented to them in standard input, nor the ability toaffect anything other than the contents of standard output (provided thatthe @code{--jail} command line option is used). The worstthey can do is use up a lot of memory, which can be prevented with the@command{ulimit} command. Unfortunately, not all applications are usablein this mode.@item Parameter mode applications that do not involve the @option{-i},@cindex parameter mode@cindex standard input@option{-t} or @option{-s} options are almost as safe (also assuming@code{--jail}). They have (read-only) access to environment variables, and to the files that areindicated explicitly on the command line. If standard input is one ofthe files (as indicated by the use of @code{-} as a parameter), thevirtual code application may infer the current date and time.  However,a parameter mode application may write any file that the user haspermission to write. The @option{--ask-to-overwrite} option should beused for better security, or at least the @option{--quiet} option shouldnot be used.  The virtual code can neither override nor detect the useof these options.@item Interactive parameter mode applications (those that use either the@cindex interactive applications@option{-i}, @option{-t} or @option{-s} options) are the least securebecause they can execute arbitrary shell commands on behalf of theuser. This statement also applies to filter mode and parameter modeapplications where the @option{--jail} option is not used.  Use of@option{--step} is preferable to @option{-i} for making an audittrail of all commands executed, but the application could probablysubvert it. The @option{--step} option may be slightly better becauseit can allow the user to inspect each command and interrupt it ifappropriate. However, in most cases a command will not be displayeduntil it is already executed. Commands executed by non-interactiveapplications normally will display no output to that effect. A@command{chroot} environment may be the only secure way of runninguntrusted interactive applications.@end itemize@node Example Script, Files, Security, User Manual@section Example Script@cindex script@cindex shell scriptIt is recommended that the application developer (or the compiler)package virtual machine code applications as shell scripts with the@code{avram} command line embedded in them. This style relieves the userof the need to remember the appropriate virtual machine options forinvoking the application, which are always the same for a givenapplication, or even to be aware of the virtual machine at all.@cindex @code{cat}@cindex @code{default-to-stdin} command line optionHere is a script that performs a similar operation to the standard@cindex UnixUnix @command{cat} utility.@example#!/bin/sh#\exec avram --force-text-input --default-to-stdin "$0" "$@@"sKYQNTP\@end example@noindentThat is, it copies the contents of a file whosename is given on the command line to standard output, or copiesstandard input to standard output if no file name is given. Thisscript can be marked executable@cindex executable files(with @command{chmod}) and run by any user@cindex @code{chmod}@cindex pathswith the directory of the @code{avram} executable in his or her@code{PATH} environment variable, even if @code{avram} had to beinstalled in a non-standard directory such as@cindex non-standard installation@file{~/bin}.The idea for this script is blatantly lifted from the @command{wish}@cindex @code{wish}manpage. The first line of the script invokes a shell to processwhat follows. The shell treats the second line as a comment andignores it.  Based on the third line, the shell invokes @code{avram}with the indicated options, the script itself as the next argument, andwhatever command line parameters were initially supplied by the useras the remaining arguments. The rest of the script afterthat line is never processed by the shell.When @code{avram} attempts to load the shell script as a virtualmachine code file, which happens as a result of it being executed bythe shell, it treats the first line as a comment and ignores it. Italso treats the second line as a comment, but takes heed of thetrailing backslash, which is interpreted as a comment continuationcharacter. It therefore also treats the third line as a comment andignores it. Starting with the fourth line, it reads the virtual code,which is in a binary data format encoded with printable characters,and evaluates it.@node Files, Environment, Example Script, User Manual@section Files@table @code@item ./profile.txt@cindex @file{profile.txt}This file is written automatically by @code{avram} on behalf ofapplications that include profile annotations. It lists the number ofinvocations for each annotated part of the application, the totalamount of time spent on it (in relative units), the average amount oftime for each invocation, and the percentage of time relative to theremainder of the application. The exact format is undocumented andsubject to change.@end table@node Environment, Bugs, Files, User Manual@section Environment@cindex environment@cindex @code{AVMINPUTS}@cindex pathsAn environment variable @env{AVMINPUTS} can be made to store a list ofdirectories (using the @command{set} or @command{export} commands) that@code{avram} will search for input files. The directories should beseparated by colons, similarly to the @env{PATH} environment variable.@cindex search pathsThe search paths in @env{AVMINPUTS} apply only to the names of inputfiles given on the command line (@ref{Command Line Syntax}) when@code{avram} is invoked in parameter mode (@ref{Parameter Mode}).  Theydo not apply to the name of the virtual code file, which is alwaysassumed to be either absolute or relative to the current workingdirectory (this assumption being preferable in the case of a script likethat of @ref{Example Script}).@cindex shell scriptStarting in the first directory in the list of @env{AVMINPUTS},@code{avram} searches for a file exactly as its name appears onthe command line (subject to the expansion of special charactersby the shell). If it is not found and the name does not contain aperiod, but a command line option of @option{-.EXT} has been used,@code{avram} will then search for a file with that name combined withthe extension @code{.EXT}. If @option{-.EXT} has not been used or if no@cindex @code{EXT} command line optionmatching file is found with it, @code{avram} tries the extensions of@kbd{.avm} and @kbd{.fun} in that order, provided the given file namecontained no periods. If no match is found for any of those cases,@code{avram} proceeds to search the next directory in the list obtainedfrom @env{AVMINPUTS}, and so on. It stops searching when the firstmatch is found. For subsequent input files, the search begins again atthe first directory.If @env{AVMINPUTS} is defined, the current working directory is notsearched for input files unless it is listed. If it is empty or not@cindex search pathsdefined, a default list of search paths is used, currently@example.:/usr/local/lib/avm:/usr/lib/avm:/lib/avm:/opt/avm:/opt/lib/avm\:/usr/local/share/avm:/usr/share/avm:/share/avm:/opt/avm:/opt/share/avm@end example@noindentThese paths are defined in @code{avram.c} and can be changedby recompiling it.@node Bugs,  , Environment, User Manual@section Bugs@cindex internal errors@cindex bugs@cindex exceptionsThere are no known bugs outstanding, except for any that may beinherent in the external library functions. However, @code{avram} hasbeen used most extensively on GNU/Linux systems, and the prospectof portability issues with new or lesser used features on othersystems can't be excluded.Though not observed in practice, it's theoretically possible to blowthe stack by passing enough functions as arguments to libraryfunctions that pass more functions to library functions (e.g., byusing nested calls to the gsl integration functions meant for a singlevariable to evaluate a very high dimensional multiple integral). Inall other cases only dynamic heap storage or a constant amount ofstack space is used.  In particular, this issue is @emph{not} relevantto virtual code applications that don't use external libraries, orthat don't pass functions to them as arguments.@code{avram} is designed to recover gracefully from memory overflowsby always checking for @code{NULL} results from @code{malloc()} orotherwise trapping functions that allocate memory. In the event of anoverflow, it conveys an appropriate error message to the virtual codeapplication to be handled by the usual exception handlingmechanisms. However, there is currently no way for a virtual codeapplication to detect in advance whether sufficient memory isavailable, nor for it to resume normal operation once an exceptionoccurs. Furthermore, it has been observed on some systems includingIrix and 2.4 series Linux kernels that the @code{avram} process iskilled automatically for attempting to allocate too much memory ratherthan given the chance to recover.Please send bug reports to @email{ursala-users@@freelists.org} or filean issue on the Avram github page.@node Virtual Machine Specification, Library Reference, User Manual, Top@chapter Virtual Machine SpecificationThis chapter contains a description of the virtual machine implementedby @code{avram}, from the point of view of a person wishing to write acompiler that generates code for it. Before reading this chapter,readers should at least skim @ref{User Manual} in order to see the bigpicture. Topics covered in this chapter include data representations,virtual code semantics, and file formats. A toy programming language isintroduced for illustrative purposes. The sections in this chapter mightnot make sense if read out of order the first time through.@ifinfoThe last section, @ref{Virtual Code Semantics}, contains many equationsthat may be difficult to read in the info or html renderings. Theprinted version is recommended for anyone who really wants to comprehendthis material.@end ifinfo@menu* Raw Material::                * Concrete Syntax::             * File Format::                 * Representation of Numeric and Textual Data::  * Filter Mode Interface::       * Parameter Mode Interface::    * Virtual Code Semantics::      @end menu@node Raw Material, Concrete Syntax, Virtual Machine Specification, Virtual Machine Specification@section Raw MaterialThe purpose of this section is to instill some basic concepts about theway information is stored or communicated by the virtual machine, whichmay be necessary for an understanding of subsequent sections.The virtual machine represents both programs and data as members of asemantic domain that is straightforward to describe. Lisp users andfunctional programmers may recognize familiar concepts of atoms and@cindex listslists in this description. However, these terms are avoided for themoment, in order to keep this presentation self contained and to preventknowledgeable readers from inferring any unintended meanings.As a rule, it is preferable to avoid overspecifying any theoreticalartifact.  In this spirit, the set of entities with which the virtualmachine is concerned can be defined purely in terms of the properties weneed it to have.@table @emph@item A distinguished elementA particular element of the set is designated, arbitrarily or otherwise,as a distinguished element. Given any element of the set, it isalways possible to decide whether or not it is the distinguishedelement. The set is non-empty and such an element exists.@item A binary operatorA map from pairs of elements of the set to elements of the set existsand meets these conditions.@itemize @bullet@item It associates a @emph{unique} element of the set with any givenordered pair of elements from the set.@item It does not associate the distinguished element with any pair of elements.@end itemize@end tableFor the sake of concreteness, an additional constraint is needed:@emph{the set has no proper subset satisfying the above conditions}. Anynumber of constructions remain within these criteria, but there is noneed to restrict them further, because they are all equivalent for ourpurposes.To see that these properties provide all the structure we need forgeneral purpose computation, we may suppose some given set @code{S} andan operator @code{cons} having them are fixed, and infer the followingpoints.@itemize @bullet@item @code{S} contains at least one element, the distinguishedelement. Call it @code{nil}.@cindex @code{nil}@item The pair @code{(nil,nil)} is a pair ofelements of @code{S}, so there must be an element of @code{S} that@code{cons} associates with it. We can denote this element@code{cons(nil,nil)}.@cindex @code{cons}@item As no pair of elements is associated with thedistinguished element, @code{cons(nil,nil)} must differ from @code{nil}, so@code{S} contains at least two distinct elements.@item The pair @code{(nil,cons(nil,nil))} therefore differs from @code{(nil,nil)},but because it is yet another pair of elements from @code{S}, theremust be an element associated with it by the operator. We can denotethis element as @code{cons(nil,cons(nil,nil))}.@item Inasmuch as the operatorassociates every pair of elements with a @emph{unique} element,@code{cons(nil,cons(nil,nil))} must differ from the element associatedwith any other pair of elements, so it must differ from@code{cons(nil,nil)}, and we conclude that @code{nil},@code{cons(nil,nil)} and @code{cons(nil,cons(nil,nil))} constitute threedistinct elements of the set @code{S}.@item By defining @code{cons(cons(nil,nil),nil)}and @code{cons(cons(nil,nil),cons(nil,nil))} analogously and following asimilar line of reasoning, one may establish the existence of two moredistinct elements of @code{S}.@end itemizeIt is not difficult to see that an argument in more general terms couldshow that the inclusion of infinitely many elements in @code{S} ismandated by the properties of the @code{cons} operator. Furthermore,every element of @code{S} other than @code{nil} owes its inclusion tobeing associated with some other pair of elements by @code{cons},because if it were not, its exclusion would permit a proper subset of@code{S} to meet all of the above conditions. We can conclude that@code{S} contains exactly @code{nil} and the countable infinitude ofelements of the form @code{cons(x,y)}, where @code{x} and @code{y} areeither @code{nil} or something of the form @code{cons(@dots{})} themselves.Some specific examples of sets and operators that have the requiredproperties are as follows.@itemize @bullet@item the set of natural numbers, with @code{0} as the distinguished element,and the @code{cons} operator defined by @code{cons(@var{x},@var{y}) =((@var{x}+@var{y})(@var{x}+@var{y}+1))/2 + @var{y} + 1}@item a set of balanced strings of parentheses, with @code{()} as thedistinguished element, and @code{cons} defined as string concatenationfollowed by enclosure in parentheses@item a set of ordered binary trees, with the empty tree as the distinguishedelement, and the @code{cons} operator as that which takes an orderedpair of trees to the tree having them as its descendents@item a set containing only its own Cartesian product and an arbitrarybut fixed element @code{nil}, with @code{cons} being the identityfunction@end itemizeEach of these models may suggest a different implementation, some of whichare more practical than others. The remainder of this document isphrased somewhat imprecisely in terms of a combination of the lattertwo. The nature of the set in question is not considered further, andelements of the set are described as ``trees'' or ``lists''. The@cindex trees@cindex listsdistinguished element is denoted by @code{nil} and the operator by@code{cons}. Where no ambiguity results, @code{cons(x,y)} may be writtensimply as @code{(x,y)}.  These terms should not be seen as constraintson the implementation.@node Concrete Syntax, File Format, Raw Material, Virtual Machine Specification@section Concrete SyntaxThe previous section has developed a basic vocabulary for statementssuch as ``the virtual machine code for the identity function is@cindex identity function@code{(nil,(nil,nil))}'', which are elaborated extensively in thesubsequent sections on code and data formats. However, a description inthis style would be inadequate without an explanation of how such anentity as @code{(nil,(nil,nil))} is communicated to @code{avram} in avirtual machine code file. The purpose of this section is to fill thegap by explaining exactly how any given tree would be transformed to itsconcrete representation.The syntax is based on a conversion of the trees to bit strings,@cindex bit stringsfollowed by grouping the bits into blocks of six, which are then encodedby printable characters. Although anyone is free to modify @code{avram},it is recommended that the concrete syntax described here be maintainedfor the sake of portability of virtual machine code applications.Building a tree by reading the data from a file requires a moredifficult algorithm than the one presented in this section, and is notconsidered because it's not strictly necessary for acompiler. Procedures for both reading and writing are available to C andC++ users as part of the @code{avram} library, and are also easilyinvoked on the virtual code level.@menu* Bit String Encoding::         * Blocking::                    @end menu@node Bit String Encoding, Blocking, Concrete Syntax, Concrete Syntax@subsection Bit String EncodingThe conversion from trees to bit strings might have been done in several@cindex treesways, perhaps the most obvious being based on a preorder traversal witheach vertex printed as it is traversed.  By this method, the entireencoding of the left descendent would precede that of the right in thebit string. This alternative is therefore rejected because it imposesunnecessary serialization on communication.It is preferable for the encodings of both descendents of a tree to beinterleaved to allow concurrent transmission. Although there ispresently no distributed implementation of the virtual machine and hence@cindex distributed implementationnone that takes advantage of this possibility, it is better to planahead than to be faced with backward compatibility problems later.The preferred algorithm for encoding a tree as a bit string employs aqueue. The queue contains trees and allows them to be processed in a@cindex queuesfirst-in first-out order. Intuitively, the algorithm works by traversing@cindex printing algorithmthe tree in level order. To print a tree @code{T} as a string of@code{1}s and @code{0}s, it performs the following steps.@displayInitialize the queue to contain only @code{T}while the queue is not empty do   if the front element of the queue is @code{nil} then      print @code{0}   else if the front element of the queue is of the form @code{cons(x,y)} then      print @code{1}      append @code{x} to the back of the queue      append @code{y} to the back of the queue   end if   remove the front element of the queueend while@end displayThis algorithm presupposes that any given tree@cindex deconstruction@code{cons(x,y)} can be ``deconstructed'' to obtain @code{x} and@code{y}. The computability of such an operation is assured in theory bythe uniqueness property of the @code{cons} operator, regardless of therepresentation chosen. If the trees are implemented with pointers in theobvious way, their deconstruction is a trivial constant time operation.As an example, running the following tree through the above algorithmresults in the bit string @code{111111101011110010001001100010100010100100100}.@examplecons(   cons(      cons(nil,cons(nil,cons(nil,nil))),      cons(nil,cons(nil,nil))),   cons(      cons(         cons(nil,cons(nil,cons(nil,cons(nil,nil)))),         cons(nil,nil)),      cons(         cons(            cons(nil,cons(nil,cons(cons(nil,cons(nil,nil)),nil))),            cons(nil,nil)),         nil)))@end example@node Blocking,  , Bit String Encoding, Concrete Syntax@subsection BlockingAfter the bit string is obtained as described above, it is grouped intoblocks of six. Continuing with the example, the string@example111111101011110010001001100010100010100100100@end example@noindentwould be grouped as@example111111 101011 110010 001001 100010 100010 100100 100@end example@noindentBecause the number of bits isn't a multiple of six, the last group has tobe padded with zeros, to give@example111111 101011 110010 001001 100010 100010 100100 100000@end example@noindentEach of these six bit substrings is then treated as a binary number,with the most significant bit on the left. The numbers expressed indecimal are@example63 43 50 9 34 34 36 32@end example@noindent@cindex character codesThe character codes for the characters to be written are obtained byadding sixty to each of these numbers, so as to ensure that they will beprintable characters. The resulting character codes are@example123 103 110 69 94 94 96 92@end example@noindentwhich implies that the tree in the example could be written to a file as@code{@{gnE^^`\}.@node File Format, Representation of Numeric and Textual Data, Concrete Syntax, Virtual Machine Specification@section File Format@cindex file formatA virtual code file consists of an optional text preamble, followed bythe concrete representation for a tree. The latter uses thesyntax described in the previous section. The purpose of this section isto specify the remaining details of the file format.The format for virtual code files may also be used for other purposesby virtual code applications, as it is automatically detected and parsedby @code{avram} when used in an input file, and can be automaticallywritten to output files at the discretion of the application.Other than virtual code files, input files not conforming to this formatare not an error as far as @code{avram} is concerned, because they are@cindex text filesassumed to be text files. Applications can detect in virtual codethe assumption that is made and report an error if appropriate.Although the data file format includes no checksums or other explicit@cindex checksumsmethods of error detection, the concrete syntax itself provides agood measure of protection against undetected errors. The probability isvanishingly small that a random alteration to any valid encoding leavesit intact, because every bit in the sequence either mandates orprohibits the occurrence of two more bits somewhere after it. Errors indifferent parts of the file would have to be consistent with one anotherto go unnoticed.@menu* Preamble Section::            * Data Section::                @end menu@node Preamble Section, Data Section, File Format, File Format@subsection Preamble Section@cindex preamble@itemize @bullet@item A file may contain at most one preamble.@item The preamble, if any, is a consecutive sequence of lines beginningwith the first line in the file.@item The first line of the preamble must begin with a hash (@code{#})character.@item Subsequent lines of the preamble must either begin with a hash, orimmediately follow a line that ends with a backslash (@code{\})character (or both).@end itemize@node Data Section,  , Preamble Section, File Format@subsection Data Section@itemize @bullet@item The data or virtual code section of the file begins on the firstline of the file that isn't part of the preamble.@item The data section may not contain any hashes, white space, or otherextraneous characters other than line breaks.@item If line breaks are ignored, the data section contains a sequenceof characters expressing a single tree in the concrete syntax describedin @ref{Concrete Syntax}.@end itemize@node Representation of Numeric and Textual Data, Filter Mode Interface, File Format, Virtual Machine Specification@section Representation of Numeric and Textual DataAs noted already, virtual code applications are specified by functionsoperating on elements of a set having the properties described in@ref{Raw Material}, which are convenient to envision as ordered binary trees or@cindex trees@cindex @code{nil}pairs of @code{nil}. However, virtual code applications normally dealwith numeric or textual data, for example when they refer to thecontents of a text file. It is therefore necessary for the applicationand the virtual machine emulator to agree on a way of describing textualor numeric data with these trees.The purpose of this section is to explain the basic data structures usedin the exchange of information between @code{avram} and a virtual codeapplication.  For example, an explanation is needed for statements like``an application invoked with the @option{--baz} option is expected toreturn a pair @code{(@var{foo},@var{bar})}, where @code{@var{foo}} is a@cindex strings@cindex character strings@cindex listslist of character strings @dots{}'', that are made subsequently in thisdocument. Such statements should be understood as referring to the treesrepresenting the pairs, lists, character strings, etc., according to theconventions explained below.@table @emph@item Characters@cindex character codesAn arbitrarily chosen set of 256 trees is used to represent thecharacter set. They are listed in @ref{Character Table}. For example,the letter @code{A} is represented by@code{(nil,(((nil,(nil,(nil,nil))),nil),(nil,nil)))}.  That means thatwhen an application wants the letter @code{A} written to a text file, itreturns something with this tree in it.@item Booleans@cindex booleansThe value of @code{false} is represented by @code{nil}, and the value of@code{true} is represented by @code{(nil,nil)}.@item Pairs@cindex pairsGiven any two items of data @var{x1} and @var{x2}, having the respectiverepresentations @var{r1} and @var{r2}, the pair @code{(@var{x1},@var{x2})} has therepresentation @code{cons(@var{r1},@var{r2})}.@item Lists@cindex listsA list of the items @var{x1}, @var{x2} @dots{} @var{xn} with respectiverepresentations @var{r1} through @var{rn} is represented by the tree@code{cons(@var{r1},cons(@var{r2}@dots{}cons(@var{rn},nil)@dots{}))}. In other words,lists are represented as pairs whose left sides are the heads and whoseright sides are the tails. The empty list is identified with@code{nil}. Lists of arbitrary finite length can be accommodated.@item Naturals@cindex naturalsA number of the form @code{@var{b0} + 2@var{b1} + 4@var{b2} + @dots{} +2^n @var{bn}}, where each @code{@var{b}i} is @code{0} or @code{1}, isrepresented by a tree of the form@code{cons(@var{t0},cons(@var{t1}@dots{}cons(@var{tn},nil)@dots{}))}where each @code{@var{t}i} is @code{nil} if the corresponding@code{@var{b}i} is @code{0}, and @code{(nil,nil)} otherwise. Note thatthe numbers @code{@var{b}i} are exactly the bits written in the binaryexpansion of the number, with @code{@var{b0}} being the least significantbit.@item Strings@cindex strings@cindex character stringsare represented as lists of characters.@end table@cindex types@code{avram} imposes no more of a ``type discipline'' than necessary toa workable interface between it and an application.  This selection oftypes and constructors should not be seen as constraining what acompiler writer may wish to have in a source language.@node Filter Mode Interface, Parameter Mode Interface, Representation of Numeric and Textual Data, Virtual Machine Specification@section Filter Mode Interface@cindex filter mode@cindex parameter mode@cindex modesFrom the point of view of the application developer or compiler writer,there are parameter mode applications, which are discussed in@ref{Parameter Mode Interface}, and filter mode applications,which are discussed in this section. Of the latter, there are mainlythree kinds: those that read one character at a time, those that read aline at a time, and those that read the whole standard input file at@cindex standard inputonce. Each of them is invoked with different options and expected tofollow different calling conventions. This section summarizes theseconventions.@menu* Loading All of Standard Input at Once::  * Line Maps::                   * Byte Transducers::            @end menu@node Loading All of Standard Input at Once, Line Maps, Filter Mode Interface, Filter Mode Interface@subsection Loading All of Standard Input at OnceUnless @option{--line-map} or @option{--byte-transducer} is used as a@cindex @code{line-map} command line option@cindex @code{byte-transducer} command line option@cindex standard inputcommand line option when the application is invoked, the contents ofstandard input are loaded entirely into memory by @code{avram} beforeevaluation of the virtual code begins.  This interface is obviously not@cindex infinite streamsappropriate for infinite streams.The virtual code application in this mode of operation is treated as asingle function taking the entire contents of standard input as its argument,and returning the entire contents of standard output as its result.Hence, this interface is one of the simplest available.@menu* Standard Input Representation::  * Standard Output Representation::  @end menu@node Standard Input Representation, Standard Output Representation, Loading All of Standard Input at Once, Loading All of Standard Input at Once@subsubsection Standard Input Representation@cindex standard inputThe representation for the standard input file used as the argument tothe function depends both on the file format and on the command lineoptions specified when the application is invoked. The@cindex @code{unparameterized} command line option@cindex @code{raw-mode} command line option@option{--unparameterized} and @option{--raw-output} options make nodifference to the input representation, and the @option{--line-map}and @option{--byte-transducer} options are not relevant to this mode ofoperation. That leaves four possible combined settings of the@cindex @code{choice-of-output} command line option@cindex @code{force-text-input} command line option@option{--choice-of-output} and @option{--force-text-input} options.  Ifstandard input conforms to the data file format specification @ref{File Format},the following effects are possible.@itemize @bullet@item If neither @option{--choice-of-output} nor@option{--force-text-input} is used, the argument to the function willbe given directly by the tree encoded in the data section of thefile. The preamble of the file will be ignored.@item If the @option{--choice-of-output} option is usedand the @option{--force-text-input} option is not used, the argument tothe function will be a pair @code{(@var{preamble},@var{contents})},where @var{preamble} is a list of character strings taken from thepreamble of the file (with leading hashes stripped), and @var{contents}is the tree represented in the data section of the file.@item If the @option{--choice-of-output} option is not usedand the @option{--force-text-input} option is used, the argument to thefunction will be the whole file as a list of character strings.  I.e.,both the preamble and the data sections are included, hashes are notstripped from the preamble, and the data section is not converted to thetree it represents.@item If the @option{--choice-of-output} option is usedand the @option{--force-text-input} option is also used, the argument to thethe function will be a pair @code{(nil,@var{contents})}, where thecontents are the list of character strings as in the previous case.@end itemize@cindex file formatIf standard input does not conform to the data file format specificationin @ref{File Format}, then it is assumed to be a text file. The@option{--force-text-input} option makes no difference, and there areonly two possible effects, depending on whether@option{--choice-of-output} is used. They correspond to the latter twocases above, where @option{--force-text-input} is used.@cindex preamble@cindex text filesThe idea of the @option{--choice-of-output} option is that it is usedonly for applications that are smart enough to be aware of the@code{(@var{preamble},@var{contents})} convention. A non-empty preambleimplies a data file whose contents could be any type, but an emptypreamble implies a text file whose contents can only be a list ofcharacter strings. (In the case of a data file with no preamble, thelist of the empty string is used for the preamble to distinguish it froma text file.)Dumb applications that never want to deal with anything but text filesshould be invoked with @option{--force-text-input}. Otherwise, they haveto be prepared for either text or data as arguments.The use of both options at once is unproductive as far as the inputformat is concerned, but may be justified when the output is to be adata file and the input is text only.@node Standard Output Representation,  , Standard Input Representation, Loading All of Standard Input at Once@subsubsection Standard Output Representation@cindex standard output@cindex @code{raw-output} command line option@cindex @code{choice-of-output} command line optionAs in the case of standard input, the representation for standard outputthat the function is expected to return depends on the command lineoptions with which the application is invoked. The only relevant optionsare @option{--raw-output} and @option{--choice-of-output}, which aremutually exclusive.@itemize @bullet@item If neither option is selected, the result returned by the function mustbe a list of character strings. @item If @option{--raw-output} is used, the result returned by thefunction is unconstrained, and it will be written as a data file with nopreamble, following the format specified in @ref{File Format}.@item If @option{--choice-of-output} is used, the result returned by thefunction must be a pair @code{(@var{preamble},@var{contents})}.@end itemize@cindex preambleIn the last case, the preamble determines how the file will be written.If it is meant to be a text file, the preamble should be @code{nil}, andthe contents should be a list of character strings. If it is meant to bea data file, the preamble should be a non-empty list of characterstrings, and the format of the contents is unconstrained. To express adata file with no preamble, the preamble should be the list containingthe empty string, rather than being empty.In the result returned by the function, the preamble lines should notinclude leading hash characters, because they are automatically added tothe output to enforce consistency with the data file format. However,they should include trailing backslashes as continuation characterswhere appropriate. The hashes that are automatically added will beautomatically stripped by @code{avram} on behalf of whatever applicationuses the file.@cindex character strings@cindex printing algorithmAny file can be written as a list of character strings, even ``text''files that are full of unprintable characters, and even ``text'' filesthat happen to conform to the format used for data files.  However, ifthe application intends to write a data file in the standard format usedby other virtual code applications, it can do so more quickly and easilyby having the virtual machine do the formatting automatically with the@option{--choice-of-output} option than by implementing the algorithm in@ref{Concrete Syntax}, from scratch in virtual code.@node Line Maps, Byte Transducers, Loading All of Standard Input at Once, Filter Mode Interface@subsection Line Maps@cindex @code{line-map} command line optionVirtual code applications invoked with the @option{--line-map} option(with or without the @option{--unparameterized} option) adhere to a verysimple interface. @itemize @bullet@item The argument to the function is a character string, and the resultmust also be a character string.@item The function is applied to each line of the standard input file@cindex standard inputand the result in each case is written to standard output followed by a@cindex standard outputline break.@end itemize@cindex infinite streamsThis kind of application may be used on finite or infinite streams,provided that the lengths of the lines are finite, but preserves no stateinformation from one line to the next.@node Byte Transducers,  , Line Maps, Filter Mode Interface@subsection Byte TransducersThe interface used when the @code{--byte-transducer} option is selected@cindex @code{byte-transducer} command line optionallows an application to serve as a persistent stream processor suitable@cindex infinite streamsfor finite or infinite streams. The interface can be summarized by thefollowing points.@itemize @bullet@item When it is first invoked, the function in the virtual code file isapplied to an argument of @code{nil}, and is expected to return a pair@code{(@var{state},@var{output})}. The @var{state} format isunconstrained. The @var{output} must be a character string that willbe written to standard output, but it may be the empty string.@item For each byte read from standard input, @code{avram} applies the functionto the pair @code{(@var{state},@var{character})}, using the stateobtained from previous evaluation, and the character whose code is thebyte. The purpose of the @var{state} field is therefore to provide away for the application to remember something from one invocation tothe next.@item The function is usually expected to return a pair@code{(@var{state},@var{output})} for each input byte, so that the statecan be used on the next iteration, and the output can be written to standardoutput as a character string.@item If the function ever returns a value of @code{nil}, the computationterminates.@item If standard input comes to an end before the computation terminates,the function will be applied to a pair of the form@code{(@var{state},nil)} thereafter, but may continue to return@code{(@var{state},@var{output})} pairs for arbitrarily many more iterations.The @code{EOF} character is not explicitly passed to the function, butthe end is detectable insofar as @code{nil} is not a representation forany character.@end itemizeUnlike the situation with line maps, the output character stringsdo not have line breaks automatically appended, and the application mustinclude them explicitly if required. The convention for@cindex Unixline breaks is system dependent. On Unix and GNU/Linux systems, charactercode 10 indicates a line break, but other systems may use character code13 followed by character code 10. See @ref{Character Table} for the@cindex character codesrepresentations of characters having these codes.@node Parameter Mode Interface, Virtual Code Semantics, Filter Mode Interface, Virtual Machine Specification@section Parameter Mode Interface@cindex parameter modeThe virtual code file for a parameter mode application contains a treerepresenting a single function, which takes as its argument a datastructure in the format described below. The format of the resultreturned by the function depends on the virtual machine options used onthe command line, and the various alternatives are explainedsubsequently.@menu* Input Data Structure::        * Input for Mapped Applications::  * Output From Non-interactive Applications::  * Output From Interactive Applications::  @end menu@node Input Data Structure, Input for Mapped Applications, Parameter Mode Interface, Parameter Mode Interface@subsection Input Data StructureThe data structure that is used as the argument to the parameter modeapplication incorporates all the information about the command line and@cindex environment@cindex command linethe environment variables. It is in the form of a triple@code{((@var{files},@var{options}),@var{environs})}. The fields havethese interpretations.@table @var@item filesis a list of quadruples@code{((@var{date},@var{path}),(@var{preamble},@var{contents}))}, withone quadruple for each input file named on the command line (but not thevirtual code file or the @code{avram} executable).  The list will be inthe same order as the filenames on the command line, and is not affectedby options interspersed with them. The fields in each item have thefollowing interpretations.@table @var@item dateis the time stamp of the file in as a character string in the usual@cindex time stamp@cindex date@cindex system time@cindex current time@cindex UnixUnix format, for example, @code{Fri Jan 19 14:34:44 GMT 2001}. If thefile corresponds to standard input, the current system time and date areused.@item pathis the full path of the file, expressed as a list of strings. If the@cindex file names@cindex paths@cindex absolute path@cindex relative pathfile corresponds to standard input, the list is empty. Otherwise, thefirst string in the list is the file name. The next is the name of thefile's parent directory, if any. The next is the parent of the parent,and so on. The root directory is indicated by the empty string, so thatany path ending with the empty string is an absolute path, while any pathending with a non-empty string is relative to the current workingdirectory.  Path separators (i.e., slashes) are omitted.@item preambleIn the case of a text file, or any file not conforming to the format in@cindex preamble@ref{File Format}, this field is @code{nil}. Otherwise, this field containsthe preamble of the file expressed as a list of strings, or containsjust the empty string if the file has no preamble. Any leading hashes inthe preamble of the file are stripped.@item contentsIn the case of a text file (as indicated by the @var{preamble} field), this@cindex text filesfield will contain a list of character strings, with each line of the filecontained in a character string. Otherwise, it can contain data in anyformat, which are obtained by converting the data section of the fileto a tree.@end table@item optionsis a list of quadruples of the form@code{((@var{position},@var{longform}),(@var{keyword},@var{params}))}with one quadruple for each option appearing on the command line afterthe name of the virtual code file.@table @var@item positionis a natural number indicating the position of the option on the command@cindex naturals@cindex command lineline. The position numbers of all the options will form an ascendingsequence, but not necessarily consecutive nor starting with zero.  Themissing numbers in the sequence will correspond to the positions of thefile names on the command line, allowing their positions to be inferred byapplications for which the position matters.@item longformis a boolean value which is true if the option starts with two or more@cindex booleansdashes but false otherwise.@item keywordis the key word of the option expressed as a character string. For examplein the case of a command line option @kbd{--foo=bar,baz}, the keyword is@code{foo}. Leading dashes are stripped.@item paramsis a list of character strings identifying the parameters for thecommand line option in question. In the case of an option of the form@kbd{--foo=bar,baz}, the first character string in the list will be@code{bar} and the next will be @code{baz}. The same applies if theoption is written @kbd{--foo bar,baz} or @kbd{--foo =bar,baz}. If thereare no parameters associated with the option, the list is empty.@end table@item environsis a list of pairs of character strings, with one pair in the list for@cindex environmenteach environment variable. The identifier is the left string in thepair, and the value is the right.  For example, if the environmentcontains the definition @code{OSTYPE=linux-gnu}, there will be a pair inthe list whose left side is the string @code{OSTYPE} and whoseright side is the string @code{linux-gnu}.@end table@node Input for Mapped Applications, Output From Non-interactive Applications, Input Data Structure, Parameter Mode Interface@subsection Input for Mapped ApplicationsApplications invoked using the @option{--map-to-each-file} option@cindex @code{map-to-each-file} command line optionbenefit from a slightly different interface than the one describedabove. As the purpose of this option is to save memory by loading onlyone file at a time, the application does not have access to all inputfiles named on the command line simultaneously within the same datastructure. Although the data structure is of the type already described,the @var{files} field is not a list of arbitrary length. Instead, it isa list containing exactly one item for an input file. If @kbd{-}is used as a command line parameter, indicating standard input, then@var{files} will have another item pertaining to standardinput. In no event will it have other than one or two items.The mapped application is expected to work by being applied individuallyto each of any number of separately constructed data structures, doingthe same in each case as it would if that case were the only one. To makethat possible, copies of the environment variables, the contents of standardinput, and the list of application specific options are contained in thedata structure used for every invocation. @cindex command lineThe position numbers in the options are adjusted for each invocation toreflect the position of the particular input file associated with it.For example, in the following command@display@kbd{avram --map-to-each-file mapster.avm fa.txt --data fb.dat --code fc.o}@end display@noindentthe function in the virtual code file @file{mapster.avm} would beapplied to each of three data structures, corresponding to the commands@display@kbd{avram mapster.avm fa.txt --data --code}@kbd{avram mapster.avm --data fb.dat --code}@kbd{avram mapster.avm --data --code fc.o}@end display@noindentIf the relative positions of the options and filenames were important tothe application, they could be reliably inferred from the positionnumbers. In the first case, they would be 1 and 2, implying that thefile is in position 0. In the second case they would be 0 and 2,implying that the file is in position 1, and in the third case theywould be 0 and 1, implying that the file is in position 2. (Of course,nothing compels an application to concern itself with the positions ofits parameters, and the alternative might be preferable.)For the most part, any application that can operate on one file at atime without needing information from any others can be executed moreeconomically with the @option{--map-to-each-file} option and few if anychanges to the code. The effect will normally be analogous to the aboveexample, subject to a few possible differences.@itemize @bullet@item If an application is supposed to do something by default whenthere are no file parameters or only standard input, it won't work as amapped application, because if there are no file parameters it won't beexecuted at all.@item If a mapped application causes any output files to be generated, theymay be written before other input files are read, possibly causing theinput files to be overwritten if they have the same names, and causingsubsequent invocations to use the overwritten versions. This behaviordiffers from that of loading all input files at the outset, whichensures the application seeing all of the original versions. The latter may bemore convenient for maintaining a group of files in some sort ofconsistent state.@item If an application causes standard output to be written along withoutput files, normally standard output is written last as a securitymeasure against malicious code altering the @option{--ask-to-overwrite}prompts by subtly clobbering the console. In a mapped application,standard output isn't always last because there may be more invocationsto come.@end itemize@node Output From Non-interactive Applications, Output From Interactive Applications, Input for Mapped Applications, Parameter Mode Interface@subsection Output From Non-interactive Applications@cindex @code{interactive} command line option@cindex @code{step} command line optionIf a parameter mode application is not invoked with either of the@option{--interactive} or @option{--step} options,then it is deemed to be non-interactive, and therefore does not concernitself with executing shell commands. Instead, it simply specifies alist of output files to be created or updated on its behalf by @code{avram}.The files are described by a list of quadruples@code{((@var{overwrite},@var{path}),(@var{preamble},@var{contents}))},with one quadruple for each file.@cindex preamble@cindex paths@cindex standard input@cindex standard outputIn each quadruple, the @var{path}, @var{preamble}, and @var{contents}fields have the same interpretations as in the list of files in theinput data structure described in @ref{Input Data Structure}, except that a@code{nil} path refers to standard output rather than to standard input.The @var{overwrite} field in each quadruple tells whether the file@cindex appending to filesshould be overwritten or appended. If the @var{overwrite} field is@code{nil} (i.e., the representation for the Boolean value of@code{false}) and a file already exists at the given path, the newcontents will be appended to it.  If the @var{overwrite} field isanything other than @code{nil} and/or no file exists with the givenpath, a new file is written or the extant one is overwritten. Note thatthe data file format specified in @ref{File Format} precludes appendinganything to it, but the format of existing output files is not checkedand nothing prevents data or text from being appended to one.@node Output From Interactive Applications,  , Output From Non-interactive Applications, Parameter Mode Interface@subsection Output From Interactive Applications@cindex @code{interactive} command line option@cindex @code{step} command line optionParameter mode applications invoked with either of the@option{--interactive} or @option{--step} options arerequired to take the data structure described in @ref{Input Data Structure} as anargument but to return the virtual code for a function that will observe@cindex shella certain protocol allowing shell commands to be executed on itsbehalf. The intent is that the virtual code file doesn't contain thereal application @emph{per se}, but only something that builds the realone on the fly using configuration information from the input files andcommand line options.The format of the result returned by an interactive application, being avirtual code application itself, requires a full exposition of thevirtual machine code semantics. This subject is deferred to @ref{Virtual Code Semantics}.The remainder of this section describes the protocol followed by thefunction returned by the interactive application rather than theapplication itself.Similarly to the case of a byte transducer described in @ref{Byte Transducers},the basic pattern of interaction between @code{avram} and the functionis a cycle of invocations. In general terms, the function is applied toa @code{nil} argument initially, and expected to return an initial stateand initial output. Thereafter, the function is applied to a pair of thestate returned on the previous iteration, and the next installment ofinput. The function returns further output and a new state, and thecycle continues until the function returns a value of @code{nil}, atwhich time the computation terminates.@menu* Line Oriented Interaction::   * Character Oriented Interaction::  * Mixed Modes of Interaction::  @end menu@node Line Oriented Interaction, Character Oriented Interaction, Output From Interactive Applications, Output From Interactive Applications@subsubsection Line Oriented InteractionWithin this general pattern, more specific styles of interaction arepossible. In the simplest one to explain first, the result returned bythe function is always a data structure of the form@cindex command line@code{(@var{state},(@var{command lines},@var{prompts}))}, wherein thefields have these interpretations.@table @var@item stateis a tree incorporating any data in any format that the applicationneeds to remember from one invocation to the next.@item command linesis a list of character strings that are piped to the standard inputstream of a separately spawned process. The process may persist from oneinvocation of the function to the next, or may be spawned each time.@item promptsis a non-empty list of character strings containing a suffix of the textexpected from the standard output stream of the process as a result ofsending the command lines to it.@end tableOn each iteration, @code{avram} sends the command line character strings@cindex spawning processesto a separately spawned process, with line breaks between them if thereare more than one command. If a process remains from the previous iteration thathas not terminated itself, the list of command lines is sent to the sameprocess. If no such process already exists, the first string in the listof command lines is treated as a shell command and used to spawn the@cindex @code{exp_popen}process (using the @code{exp_popen} library function), and the remainingstrings are sent to the newly spawned process.Normally processes spawned with commands that invoke interactive commandline interpreters of their own, such as @command{bash}, @command{ftp} or@command{bc}, will persist indefinitely unless the command causing themto exit is issued or some other event kills them. Processes spawned withnon-interactive commands, such as @command{ls} or @command{pwd}, willterminate when the last of their initial output has been received.In the case of processes that persist after being spawned, @code{avram}needs some way of knowing when to stop waiting for more output from themso that it doesn't get stuck waiting forever. This purpose is served bythe @var{prompts} field. This field could contain a single stringholding the last thing the process will send before becoming quiescent,such as the strings @code{bash$ } or @code{ftp> } in the aboveexamples. Alternatively, a sequence of more than one prompt string canbe used to indicate that the corresponding sequence of lines must bedetected. An empty string followed by @code{ftp> } would indicate thatthe @code{ftp> } prompt is expected to be immediately preceded by a line@cindex promptsbreak. There is also the option of using prompt strings to indicate apattern that does not necessarily imply quiescence, but is a moreconvenient point at which to stop reading the output from the process.For processes spawned with commands that do not start their owninteractive command line interpreters, such as @command{ls} or@command{pwd}, it may be preferable to read all the output from themuntil they terminate. To achieve this effect, the list of prompt stringsshould contain only the single string containing only the single@code{EOF} character (usually code 4) or any other character that iscertain not to occur in the output of the process. This technique isbased on the assumption that the process was spawned originally with thecommand in question, not that such a command is sent to an existingshell process.In any case, when enough output has been received from the process, itis collected into a list of received strings including the promptstrings at the end (if they were received), and the function is appliedto the pair @code{(@var{state},@var{received strings})}. If the cycle isto continue, the result returned by the function will include a newstate, a new list of command lines, and a new list of prompt strings. Aresult of @code{nil} will cause the computation to terminate.There are some unusual situations that could occur in the course of lineoriented interaction, and are summarized as follows.@itemize @bullet@item If the process terminates before any pattern matching the promptstrings is received from it, all of the output from the process up tothe point where it terminated is collected into the @var{receivedstrings} list and passed to the function. This situation includes caseswhere the process terminates immediately upon being spawned, but notabnormal completion of the @code{exp_popen} library function, which isa fatal error. This feature of the interface is what allows @code{EOF}to be used for collecting all the output at once from a non-interactivecommand.@item If the list of @var{command lines} is empty, and no processcurrently exists due to a previous iteration, the effect is the same asif the process terminates unexpectedly before outputting anything. I.e.,the function is applied to a pair containing an empty list of receivedstrings. There is no good reason for an application to get into thissituation.@item If the list of @var{command lines} is empty but a process persistsfrom a previous iteration, no output is sent to it, but receiving fromit proceeds normally. This feature of the interface could be usedeffectively by applications intended to process the received data in@cindex deadlockparts, but will cause deadlock if the process is already quiescent.@item All character strings have to consist of lists of validrepresentations of non-null characters according to @ref{CharacterTable}, or else there will be some fatal error messages.@item If the list of @var{prompt strings} contains only the emptystring, @code{avram} will not wait to receive anything from the process,but will proceed with the next iteration immediately. If this effect isintended, care must be taken not to confuse the empty listof @var{prompt strings} with the list containing the empty string. The formerindicates character oriented interaction, which is explained next.@end itemize@node Character Oriented Interaction, Mixed Modes of Interaction, Line Oriented Interaction, Output From Interactive Applications@subsubsection Character Oriented InteractionA character oriented style of interaction involves the function alwaysreturning a data structure of the form @code{(@var{state},(@var{commandlines},nil))}. The @var{state} and @var{command lines} fields serve@cindex command lineexactly the same purposes respectively as they do in the case of lineoriented interaction. The field that would be occupied by the@var{prompt strings} list in the case of line oriented interaction isidentically @code{nil} in this style.When this style is used, @code{avram} spawns a process and/or sends@cindex spawning processescommand lines to it as in the case of line oriented interaction, butattempts to read only a single character from it per iteration. When thecharacter is received, @code{avram} applies the function to the pair@code{(@var{state},@var{character})} in order to obtain the next stateand the next list of command lines. If the process has terminated, a@code{nil} value is used in place of the character. If the process isquiescent, deadlock ensues.The character oriented style is a lower level protocol that shifts moreof the burden of analyzing the process's output to the virtual codeapplication. It can do anything line oriented interaction can do exceptproceeding immediately without waiting to receive any output from theprocess. It may also allow more general criteria (in effect) than thematching of a fixed prompt string to delimit the received data, forthose pathological processes that may require such things.Applications using character oriented interaction need to deal with line@cindex line breaksbreaks explicitly among the received characters, unlike the case withline oriented interaction, where the line breaks are implicit in the@cindex Unixlist of received strings. Contrary to the convention for Unix textfiles, line breaks in the output of a process are indicated by charactercode 13 followed by character code 10.@node Mixed Modes of Interaction,  , Character Oriented Interaction, Output From Interactive Applications@subsubsection Mixed Modes of InteractionAn application is not confined exclusively to line oriented or characteroriented interaction, but may switch from one style to the other betweeniterations, and signal its choice simply by the format of the datastructure it returns. If the @var{prompt strings} field is non-empty,the interaction is line oriented, and if the field is empty, theinteraction is character oriented. A function using both styles has tobe prepared for whichever type of data it indicates, either a character ora list of character strings as the case may be.Another alternative is possible if the function returns a data structurein the form @code{(@var{files},nil)}. This structure includes neither alist of command lines nor a list of prompt strings, empty or otherwise,but does include a list of quadruples in the @var{files} field. Thequadruples are of the form@code{((@var{overwrite},@var{path}),(@var{preamble},@var{contents}))}.The fields have the same interpretations as in the output from anon-interactive parameter mode application, as described in@ref{Output From Non-interactive Applications}, and will cause a list of files to be written in the same way.As an interactive application is able cause the execution of arbitraryshell commands, it doesn't need @code{avram} to write files for it theway a non-interactive application does, so this feature does not provideany additional capabilities. However, it may be helpful as a matter ofconvenience.After the files are written, the function will be applied to the sameresult it returned, @code{(@var{files},nil)}. There is no direct meansof preserving unconstrained state information from previous iterationsin this style of interaction. A likely scenario might therefore be thatthe function returns a file list after finishing its other business, andthen returns @code{nil} on the next iteration to terminate.@node Virtual Code Semantics,  , Parameter Mode Interface, Virtual Machine Specification@section Virtual Code SemanticsAs the previous sections explain, virtual code applications are definedin terms of mathematical functions. Up until this point, the discussionhas focused on the interface between the function and the virtualmachine interpreter, by detailing the arguments passed to the functions undervarious circumstances and the results they are expected to return inorder to achieve various effects.The purpose of this section is to complete the picture by explaining howa given computable function can be expressed in virtual code,considering only functions operating on the trees described in @ref{Raw Material}.Functions manipulating trees of @code{nil} are undoubtedly a frivolousand abstract subject in themselves. One is obliged to refer back to theprevious sections if in need of motivation.@menu* A New Operator::              * On Equality::                 * A Minimal Set of Properties::  * A Simple Lisp Like Language::  * How @code{avram} Thinks::     * Variable Freedom::            * Metrics and Maintenance::     * Deconstruction::              * Recursion::                   * Assignment::                  * Predicates::                  * Iteration::                   * List Combinators::            * List Functions::              * Exception Handling::          * Interfaces to External Code:: * Vacant Address Space::        @end menu@node A New Operator, On Equality, Virtual Code Semantics, Virtual Code Semantics@subsection A New OperatorWith regard to a set of trees as described in @ref{Raw Material}, we can definea new binary operator. Unlike the @code{cons} operator, this one is notrequired to associate an element of the set with every possible pairof elements. For very many pairs of operands we will have nothing tosay about its result. In fact, we require nothing of it beyonda few simple properties to be described presently.Because this is the only other operator than @code{cons}, there is no@cindex @code{cons}need to have a special notation for it, so it will be denoted by emptyspace. The tree associated by the operator with a pair of trees @code{@var{x}}and @code{@var{y}}, if any, will be expressed in the infix notation@code{@var{x} @var{y}}. For convenience, the operator is regarded asbeing right associative, so that @code{@var{a} @var{b} @var{c}} can bewritten for @code{@var{a} (@var{b} @var{c})}.@node On Equality, A Minimal Set of Properties, A New Operator, Virtual Code Semantics@subsection On Equality@cindex equalityOne example of a property this operator should have, for reasons thatwill not be immediately clear, is that for any trees @code{@var{x}} and@code{@var{k}}, the equality @code{cons(cons(nil,@code{@var{k}),nil) @var{x}} =@code{@var{k}}} always holds.Even though the present exposition opts for readability over formality,statements like these demand clarification of the notion ofequality. Some of the more pedantic points in @ref{Raw Material} may be neededfor the following ideas to hold water.@itemize @bullet@item As originally stipulated, it is always possible to distinguish@code{nil} from any member of the set. We can therefore decide on thisbasis whether @code{@var{a} = @var{b}} whenever at least one of them is @code{nil}.@item Where neither @code{@var{a}} nor @code{@var{b}} is @code{nil} in an expression@code{@var{a} = @var{b}}, but rather something of the form@code{cons(@var{x},@var{y})}, the equality holds if and onlyif both pairs of corresponding subexpressions are equal. If at least onemember of each pair of corresponding subexpressions is @code{nil}, thequestion is settled, but otherwise there is recourse to their respectivesubexpressions, and so on. This condition follows from the uniqueness propertyof the @code{cons} operator.@item If one side of an equality is of the form@code{@var{x} @var{y}}, or is defined in terms of such an expression,but @code{(@var{x},@var{y})} is one of those pairs with which the operatorassociates no result, then the equality holds if and only if the otherside is similarly ill defined.@item Statements involving universal quantification (i.e.,@cindex universal quantification@cindex undefined expressionsbeginning with words similar to ``for any tree @code{@var{x}} @dots{}'')obviously do not apply to instances of a variable (@code{@var{x}}) outsidethe indicated set (trees). Hence, they are not refuted by anyconsequence of identifying a variable with an undefined expression.@end itemizeReaders who are aware of such issues as pointer equality or intensional@cindex pointer equality@cindex pointersversus extensional equality of functions are urged to forget all aboutthem in the context of this document, and abide only by what isstated. Other readers should ignore this paragraph.@node A Minimal Set of Properties, A Simple Lisp Like Language, On Equality, Virtual Code Semantics@subsection A Minimal Set of PropertiesFor any trees @code{@var{x}}, @code{@var{y}}, and @code{@var{k}}, and any non-@code{nil}trees @code{@var{p}}, @code{@var{f}}, and @code{@var{g}}, the new invisible operator satisfies theseconditions. In these expressions and hereafter, increasing abuse ofnotation is perpetrated by not writing the @code{cons} in expressions of the form@code{cons(@var{x},@var{y})}.@table @emph@item P0@code{(nil,(nil,nil)) @var{x}} = @code{@var{x}}@item P1@code{(nil,((nil,nil),nil)) (@var{x},@var{y})} = @code{@var{x}}@item P2@code{(nil,(nil,(nil,nil))) (@var{x},@var{y})} = @code{@var{y}}@item P3@code{((nil,@var{k}),nil) @var{x}} = @code{@var{k}}@item P4@code{(((nil,(nil,nil)),nil),nil) (@var{f},@var{x})} = @code{@var{f} (@var{f},@var{x})}@item P5@code{((@var{f},@var{g}),nil) @var{x}} = @code{@var{f} @var{g} @var{x}}@item P6@code{((@var{f},nil),@var{g}) @var{x}} = @code{(@var{f} @var{x},@var{g} @var{x})}@item P7@code{((@var{p},@var{f}),@var{g}) @var{x}} = @code{@var{f} @var{x}} if@code{@var{p} @var{x}}  is a non-@code{nil} tree,but @code{@var{g} @var{x}} if @code{@var{p} @var{x}} = @code{nil}@end table@cindex properties@cindex operator propertiesAlthough other properties remain to be described, it is worth pausing atthis point because there is ample food for thought in the ones alreadygiven. An obvious question would be that of their origin. The shortanswer is that they have been chosen arbitrarily to be true bydefinition of the operator. At best, the completion of the constructionmay lead to a more satisfactory answer based on aesthetic or engineeringgrounds.A more important question would be that of the relevance of the mysteryoperator and its properties to the stated purpose of this section, whichis to specify the virtual machine code semantics. The answer lies inthat the operator induces a function for any given tree @code{@var{t}},such that the value returned by the function when given an argument@var{x} is @code{@var{t} @var{x}}. This function is the one that isimplemented by the virtual code @var{t}, which is to say the way anapplication will behave if we put @var{t} in its virtual code file. Anequivalent way of looking at the situation is that the virtual machinedoes nothing but compute the result of this operator, taking the tree inthe virtual code file as its left operand and the input data as theright operand. By knowing what the operator will do with a given pair ofoperands, we know what to put into the virtual code file to get thefunction we want.@cindex universality@cindex Turing equivalence@cindex exceptions@cindex listsIt is worthwhile to note that properties @emph{P0} to @emph{P7} aresufficient for universality in the sense of Turing equivalence. Thatmeans that any computable function could be implemented by the suitablechoice of a tree @var{t} without recourse to any other properties of theoperator. A compiler writer who finds this material boring couldtherefore stop reading at this point and carry out the task of targetingany general purpose programming language to the virtual machine based onthe specifications already given. However, such an implementation wouldnot take advantage of the features for list processing, exceptionhandling, or profiling that are also built into the virtualmachine and have yet to be described.@node A Simple Lisp Like Language, How @code{avram} Thinks, A Minimal Set of Properties, Virtual Code Semantics@subsection A Simple Lisp Like Language@cindex @code{silly}With a universal computational model already at our disposal, it will beeasier to use the virtual machine to specify itself than to define allof it from scratch. For this purpose, we use the @code{silly}programming language, whose name is an acronym for SImple Lisp-likeLanguage (Yeah right). The language serves essentially as a thin layerof symbolic names on top of the virtual machine code. Due to its poorsupport for modularity and abstraction, @code{silly} is not recommendedfor serious application development, but at least it has a shallowlearning curve.@footnote{Previous releases of @code{avram} included aworking @code{silly} compiler, but this has now been supersededby the Ursala programming language. Ursala includes @code{silly} as a subsetfor the most part, and the examples in this manual should compile andexecute with very little modification.}@menu* Syntax::                      * Semantics::                   * Standard Library::            @end menu@node Syntax, Semantics, A Simple Lisp Like Language, A Simple Lisp Like Language@subsubsection Syntax@code{silly} has no reserved words, but it has equals signs, commas andparentheses built in. A concise but ambiguous grammar for it can be givenas follows.@cindex syntax@cindex grammar@display@var{program} ::= @var{declaration}*@var{declaration} ::= @var{identifier} @code{=} @var{expression}@iftex@var{expression} ::= @code{()} | @var{identifier} | @code{(@var{expression})} | @code{(@var{expression},@var{expression})}                    | @var{expression} @var{expression} | @var{expression}@code{(}@var{expression}@code{)}                    | @var{expression}@code{(}@var{expression}@code{,}@var{expression}@code{)}@end iftex@ifinfo@var{expression} ::= () | @var{identifier}                    | (@var{expression})                    | (@var{expression},@var{expression})                    | @var{expression} @var{expression}                    | @var{expression}(@var{expression})                    | @var{expression}(@var{expression},@var{expression})@end ifinfo@end display@noindent@cindex precedence@cindex operator precedenceThe real grammar is consistent with this one but enforces rightassociativity for binary operations and higher precedence for juxtapositionwithout intervening white space.The declaration of any identifier must be unique and must precede itsoccurrence in any expression. Hence, cyclic dependences betweendeclarations and ``recursive'' declarations are not allowed.@node Semantics, Standard Library, Syntax, A Simple Lisp Like Language@subsubsection SemanticsDeclarations in @code{silly} should be understood in the obvious way aspreprocessor directives to perform parenthetic textual substitutions (similar to@code{#define id (exp)} in C). All identifiers in expressions are therebyeliminated during the preprocessing phase.@cindex semantic functionThe overall meaning of the program is the meaning of the expression inthe last declaration.  A denotational semantics for expressions is givenby the following equations, where [[@code{@var{x}}]] should be read as``the meaning of @code{@var{x}}'', and @code{@var{x}}, @code{@var{y}} and @code{@var{z}}are metavariables. (That is, they stand for any source code fragmentthat could fit there subject to the constraint, informally speaking,that it has to correspond to a connected subtree of the parse tree as enforcedby the unambiguous grammar in the context of the rest of the program.)@display[[@code{()}]] = @code{nil}[[@code{(@var{x})}]] = [[@code{@var{x}}]][[@code{(@var{x},@var{y})}]] = @code{cons(}[[@code{@var{x}}]]@code{,}[[@code{@var{y}}]]@code{)}[[@code{@var{x} @var{y}}]] = [[@code{@var{x}(@var{y})}]] = [[@code{@var{x}}]] [[@code{@var{y}}]][[@code{@var{x} (@var{y},@var{z})}]] = [[@code{@var{x}(@var{y},@var{z})}]] = [[@code{@var{x}}]] [[@code{(@var{y},@var{z})}]]@end display@noindentToy languages like this are among the few situations a@cindex denotational semanticsdenotational semantics stands a chance of clarifying more than itobfuscates, so the reader is invited to take a moment to savor it.@node Standard Library,  , Semantics, A Simple Lisp Like Language@subsubsection Standard Library@code{silly} programs may be linked with library modules, which consistof @code{silly} source text to be concatenated with the user@cindex library modules@cindex standard preludeprogram prior to the preprocessing phase. Most @code{silly} programs arelinked with the standard @code{silly} prelude, which contains thefollowing declarations among others.@cindex @code{nil}@cindex @code{identity}@cindex @code{left}@cindex @code{right}@cindex @code{meta}@cindex @code{constant}@cindex @code{couple}@cindex @code{compose}@cindex @code{conditional}@examplenil           = ()identity      = (nil,(nil,nil))left          = (nil,((nil,nil),nil))right         = (nil,(nil,(nil,nil)))meta          = (((nil,(nil,nil)),nil),nil)constant_nil  = ((nil,nil),nil)couple        = ((((left,nil),constant_nil),nil),right)compose       = couple(identity,constant_nil)constant      = couple(couple(constant_nil,identity),constant_nil)conditional   =   couple(couple(left,compose(left,right)),compose(right,right))@end exampleThere is a close correspondence between these declarations and theproperties described in @ref{A Minimal Set of Properties}. A fitting analogy would be thatthe properties of the operator specify the virtual machine instructionset in a language independent way, and the @code{silly} library definesthe instruction mnemonics for a virtual assembly language. The@cindex mnemonicsrelationship of some mnemonics to their corresponding instructions maybe less clear than that of others, so they are all discussed next.@node How @code{avram} Thinks, Variable Freedom, A Simple Lisp Like Language, Virtual Code Semantics@subsection How @code{avram} ThinksThe definitions in the standard @code{silly} library pertaining to thebasic properties of the operator can provide a good intuitiveillustration of how computations are performed by @code{avram}.  Thistask is approached in the guise of a few trivial correctness proofsabout them. Conveniently, as an infeasibly small language, @code{silly}is an ideal candidate for analysis by formal methods.Technically the semantic function [[@dots{}]] has not been defined onidentifiers, but we can easily extend it to them by stipulating that themeaning of an identifier @code{@var{x}} is the meaning of the program@cindex identifiers@code{@var{main} = @var{x}} when linked with a library containing thedeclaration of @code{@var{x}}, where @code{@var{main}} is an identifiernot appearing elsewhere in the library.With this idea in mind, the following ``theorems'' can be stated,all of which have a similar proof. The variables @var{x} and @var{y}stand for any tree, and the variable @var{f} stands for any tree otherthan @code{nil}.@table @emph@item T0[[@code{identity}]] @code{@var{x}} = @code{@var{x}}@item T1[[@code{left}]] @code{(@var{x},@var{y})} = @code{@var{x}}@item T2[[@code{right}]] @code{(@var{x},@var{y})} = @code{@var{y}}@item T4[[@code{meta}]] @code{(@var{f},@var{x})} = @code{@var{f} (@var{f},@var{x})}@item T5[[@code{constant_nil}]] @code{@var{x}} = @code{nil}@end table@noindentReplacing each identifier with its defining expression directlydemonstrates a logical equivalence between the relevant theorem and oneof the basic operator properties postulated in @ref{A Minimal Set of Properties}.For more of a challenge, it is possible to prove the next theorem.@table @emph@item T6For non-@code{nil} @code{@var{f}} and @code{@var{g}},([[@code{couple}]] @code{(@var{f},@var{g})}) @code{@var{x}} =@code{(@var{f} @var{x},@var{g} @var{x})}@end table@noindentThe proof is a routine calculation. Beware of the distinction betweenthe mathematical @code{nil} and the @code{silly} identifier @code{nil}.@ifnotinfo@format   ([[@code{couple}]] @code{(@var{f},@var{g})}) @code{@var{x}} =  ([[@code{((((left,nil),constant_nil),nil),right)}]] @code{(@var{f},@var{g})}) @code{@var{x}}by substitution of @code{couple} with its definition in the standard library   = (@code{((((}[[@code{left}]]@code{,}[[@code{nil}]]@code{),}[[@code{constant_nil}]]@code{),}[[@code{nil}]])@code{,}[[@code{right}]]@code{)} @code{(@var{f},@var{g})}) @code{@var{x}}by definition of the semantic function [[@dots{}]] regarding pairs   = (@code{((((}[[@code{left}]]@code{,}[[@code{()}]]@code{),}[[@code{constant_nil}]]@code{),}[[@code{()}]])@code{,}[[@code{right}]]@code{)} @code{(@var{f},@var{g})}) @code{@var{x}}by substitution of @code{nil} from its definition in the standard library   = (@code{((((}[[@code{left}]]@code{,}@code{nil}@code{),}[[@code{constant_nil}]]@code{),}@code{nil})@code{,}[[@code{right}]]@code{)} @code{(@var{f},@var{g})}) @code{@var{x}}by definition of the semantic function in the case of [[@code{()}]]   = (@code{(}[[@code{left}]] @code{(@var{f},@var{g}),}[[@code{constant_nil}]] @code{(@var{f},@var{g})),}[[@code{right}]] @code{(@var{f},@var{g})}) @code{@var{x}}by property @emph{P6} (twice)   = @code{((@var{f},nil),@var{g}) @var{x}}by theorems @emph{T1}, @emph{T2}, and @emph{T5}   = @code{(@var{f} @var{x},@var{g} @var{x})}by property @emph{P6} again.@end format@end ifnotinfo@ifinfo@ifnothtml@format   ([[@code{couple}]] @code{(@var{f},@var{g})}) @code{@var{x}}      = ([[@code{((((left,nil),constant_nil),nil),right)}]] @code{(@var{f},@var{g})}) @code{@var{x}}by substitution of @code{couple} with its definition in the standard library   = (        @code{(           (((}[[@code{left}]]@code{,}[[@code{nil}]]@code{),}[[@code{constant_nil}]]@code{),}[[@code{nil}]])@code{,}           [[@code{right}]]@code{)}        @code{(@var{f},@var{g})})     @code{@var{x}}by definition of the semantic function [[@dots{}]] regarding pairs   = (        @code{(           (((}[[@code{left}]]@code{,}[[@code{()}]]@code{),}[[@code{constant_nil}]]@code{),}[[@code{()}]])@code{,}           [[@code{right}]]@code{)}        @code{(@var{f},@var{g})})     @code{@var{x}}by substitution of @code{nil} from its definition in the standard library   = (        @code{(           (((}[[@code{left}]]@code{,}[[@code{nil}]]@code{),}[[@code{constant_nil}]]@code{),}[[@code{nil}]])@code{,}           [[@code{right}]]@code{)}        @code{(@var{f},@var{g})})     @code{@var{x}}by definition of the semantic function in the case of [[@code{()}]]   = (        @code{(}           [[@code{left}]] @code{(@var{f},@var{g}),}[[@code{constant_nil}]] @code{(@var{f},@var{g})),}           [[@code{right}]] @code{(@var{f},@var{g})})     @code{@var{x}}by property @emph{P6} (twice)   = @code{((@var{f},nil),@var{g}) @var{x}}by theorems @emph{T1}, @emph{T2}, and @emph{T5}   = @code{(@var{f} @var{x},@var{g} @var{x})}by property @emph{P6} again.@end format@end ifnothtml@end ifinfoSomething to observe about this proof is that it might just as well havebeen done automatically. Every step is either the substitution of anidentifier or a pattern match against existing theorems and propertiesof the operator. Another thing to note is that the use of identifiersand previously established theorems helps to make the proof humanreadable, but is not a logical necessity. An equivalent proof could havebeen expressed entirely in terms of the properties of the operator. Ifone envisions a proof like this being performed blindly andmechanically, without the running commentary or other amenities, thatwould not be a bad way of thinking about what takes place when@code{avram} executes virtual code.Three more theorems have similar proofs. For non-@code{nil}trees @code{@var{p}}, @code{@var{f}} and @code{@var{g}}, and any trees@code{@var{x}} and @code{@var{k}}:@cindex @code{compose}@cindex @code{constant}@cindex @code{conditional}@table @emph@item T7([[@code{compose}]] @code{(@var{f},@var{g})}) @var{x} = @var{f} @var{g} @var{x}@item T8([[@code{constant}]] @code{@var{k}}) @var{x} = @var{k}@item T9([[@code{conditional}]] @code{(@var{p},(@var{f},@var{g})}) @var{x} =@code{@var{f} @var{x}} if@code{@var{p} @var{x}}  is non-@code{nil},but @code{@var{g} @var{x}} if @code{@var{p} @var{x}} = @code{nil}@end table@noindentThe proofs of these theorems are routine calculations analogous to theproof of @emph{T6}. Here is a proof of theorem @emph{T7} for goodmeasure.@ifnotinfo@format   ([[@code{compose}]] @code{(@var{f},@var{g})}) @code{@var{x}} = ([[@code{couple(identity,constant_nil)}]] @code{(@var{f},@var{g})}) @code{@var{x}}@end format@end ifnotinfo@ifinfo@ifnothtml@format   ([[@code{compose}]] @code{(@var{f},@var{g})}) @code{@var{x}}      = ([[@code{couple(identity,constant_nil)}]] @code{(@var{f},@var{g})}) @code{@var{x}}@end format@end ifnothtml@end ifinfo@iftex@display@end display@noindent@end iftexby substitution of @code{compose} with its definition in the standard library@format   = (@code{(}[[@code{couple}]] @code{(}[[@code{identity}]]@code{,}[[@code{constant_nil}]]@code{))(@var{f},@var{g})}) @code{@var{x}}by definition of the semantic function   = @code{(}[[@code{identity}]] @code{(@var{f},@var{g}),}[[@code{constant_nil}]]@code{ (@var{f},@var{g})) @var{x}}by theorem @emph{T6}   = @code{((@var{f},@var{g}),nil) @var{x}}by theorems @emph{T0} and @emph{T5}   = @code{@var{f} @var{g} @var{x}}by property @emph{P5} of the operator.@end format@node Variable Freedom, Metrics and Maintenance, How @code{avram} Thinks, Virtual Code Semantics@subsection Variable FreedomThe virtual code semantics is easier to specify using the@code{silly} language than it would be without it, but still awkward insome cases. An example is the following declaration from the standardlibrary,@cindex @code{hired}@examplehired = compose(   compose,   couple(      constant compose,      compose(couple,couple(constant,constant couple))))@end example@noindentwhich is constructed in such a way as to imply the following theorem,provable by routine computation.@table @emph@item T9@code{(}[[@code{hired}]] @code{@var{h}) (@var{f},@var{g})} = [[@code{compose}]]@code{(@var{h},}[[@code{couple}]]@code{(@var{f},@var{g}))}@end table@noindentIntuitively, @code{hired} represents a function that takes a givenfunction to a higher order function. For example, if @code{f} were afunction that adds two real numbers, @code{hired f} would be a function thattakes two real valued functions to their pointwise sum.Apart from its cleverness, such an opaque way of defining a function haslittle to recommend it. The statement of the theorem about the functionis more readable than the function definition itself, probably becausethe theorem liberally employs mathematical variables, whereas the@code{silly} language is variable free. On the other hand, it is notworthwhile to linger over further enhancements to the language, such asadding variables to it. The solution will be to indicate informally ageneral method of inferring a variable free function definition from anexpression containing variables, and hereafter omit the morecumbersome definitions.@cindex @code{isolate}@cindex variablesAn algorithm called @code{isolate} does the job.The input to @code{isolate} is a pair @code{(@var{e},@var{x})}, where@code{@var{e}} is a syntactically correct @code{silly} expression inwhich the identifier @code{@var{x}} may occur, but no other identifiersdependent on @code{@var{x}} may occur (or else it'sgarbage-in/garbage-out).  Output is a syntactically correct @code{silly}expression @code{@var{f}} in which the identifier @code{@var{x}} doesnot occur, such that [[@code{@var{e}}]] = [[@code{@var{f} @var{x}}]].The algorithm is as follows,@displayif @code{@var{e}} = @code{@var{x}} then   return @code{identity}else if @code{@var{e}} is of the form @code{(@var{u},@var{v})}   return @code{couple(isolate(@var{u},@var{x}),isolate(@var{v},@var{x}))}else if @code{@var{e}} is of the form @code{@var{u} @var{v}}   return @code{(hired apply)(isolate(@var{u},@var{x}),isolate(@var{v},@var{x}))}else   return @code{constant @var{e}}@end display@noindent@cindex equalitywhere equality is by literal comparison of expressions, and thedefinition of @code{apply} is@cindex @code{apply}@exampleapply = (hired meta)((hired compose)(left,constant right),right)@end example@noindentwhich represents a function that does the same thing as the invisibleoperator.@table @emph@item T10[[@code{apply}]] @code{(@var{f},@var{x})} = @code{@var{f} @var{x}}@end tableThe @code{isolate} algorithm can be generalized to functions ofarbitrarily many variables, but in this document we will needonly a unary and a binary version. The latter takes an expression@code{@var{e}} and a pair of identifiers @code{(@var{x},@var{y})} asinput, and returns an expression @code{@var{f}} such that[[@code{@var{e}}]] = [[@code{@var{f} (@var{x},@var{y})}]].@displayif @code{@var{e}} = @code{@var{x}} then   return @code{left}else if @code{@var{e}} = @code{@var{y}} then   return @code{right}else if @code{@var{e}} is of the form @code{(@var{u},@var{v})}   return @code{couple(isolate(@var{u},(@var{x},@var{y})),isolate(@var{v},(@var{x},@var{y})))}else if @code{@var{e}} is of the form @code{@var{u} @var{v}}   return @code{(hired apply)(isolate(@var{u},(@var{x},@var{y})),isolate(@var{v},(@var{x},@var{y})))}else   return @code{constant @var{e}}@end displayIt might be noted in passing that something similar to these algorithmswould be needed in a compiler targeted to @code{avram} if the sourcewere a functional language with variables.@node Metrics and Maintenance, Deconstruction, Variable Freedom, Virtual Code Semantics@subsection Metrics and MaintenanceCertain features of the virtual machine pertain to software developmentand maintenance more than to implementing any particular function. Theoperations with the mnemonics @code{version}, @code{note},@code{profile}, and @code{weight} are in this category.@menu* Version::                     * Note::                        * Profile::                     * Weight::                      @end menu@node Version, Note, Metrics and Maintenance, Metrics and Maintenance@subsubsection VersionA virtual code application with exactly the following definitionimplements a function that returns a constant character stringregardless of its argument.@cindex @code{version}@exampleversion = ((nil,nil),((nil,nil),(nil,((nil,nil),nil))))@end example@noindentThe character string encodes the version number of the installed@code{avram} executable, for example @code{@value{VERSION}}, using the standardrepresentation for characters.Although such an application is useless by itself, the intended use forthis feature is to cope with the possibility that future versions of@code{avram} may include enhancements. Ideally, the maintainer of@code{avram} will update the version number when new enhancements areadded. Applications can then detect whether they are available in theinstalled version by using this feature. If a needed enhancement is notavailable, the application can either make allowances or at leastterminate gracefully.@node Note, Profile, Version, Metrics and Maintenance@subsubsection NoteThis operation allows arbitrary information or comments to be embeddedin a virtual code application in such a way that it will be ignored by@code{avram} when executing it. For the @code{silly} language, a@code{note} function is defined in the standard prelude so as to implythe following theorem.@cindex @code{note}@cindex annotations@table @emph@item T11[[@code{note}]] @code{(@var{f},@var{c})} = @code{((nil,nil),((nil,nil),(nil,(nil,(@var{f},@var{c})))))}@end table@noindentIntuitively, the argument @code{@var{f}} represents a function, and theargument @code{c} represents the comment, annotation, or whatever, thatwill be embedded but ignored in the virtual code.Semantically, a function with a note attached is the same as thefunction by itself, as the following property stipulates forany non-@code{nil} @code{@var{f}}.@table @emph@item P8([[@code{note}]] @code{(@var{f},@var{c})}) @code{@var{x}} = @code{@var{f} @var{x}}@end tableA possible reason for using this feature might be to support a languagethat performs run-time type checking by hanging type tags on@cindex type tagseverything. Another possible use would be to include symbolicinformation needed by a debugger.@node Profile, Weight, Note, Metrics and Maintenance@subsubsection ProfileThe virtual machine supports a profiling capability by way of this@cindex @file{profile.txt}feature. Profiling an application causes run time statistics about it tobe written to a file @file{./profile.txt}. Profiled applications are ofthe form indicated in the following theorem@table @emph@item T12[[@code{profile}]] @code{(@var{f},@var{s})} = @code{((nil,nil),((nil,nil),(nil,((@var{f},@var{s}),nil))))}@end table@noindentwhere @code{@var{f}} stands for the virtual code of the application, and@code{@var{s}} stands for the name of it to be written to the file.The semantics of a profiled function is identical to the unprofiledform for any non-@code{nil} @code{@var{f}}.@table @emph@item P9([[@code{profile}]] @code{(@var{f},@var{s})}) @code{@var{x}} = @code{@var{f} @var{x}}@end tableUnlike the situation with @code{note}, the annotation @code{@var{s}} of@cindex @code{note}used in profiled code is not in an unrestricted format but must be acharacter string in the standard representation (as in@ref{Representation of Numeric and Textual Data}),because this string needs to be written by @code{avram} to the file@file{./profile.txt}. Ordinarily this string will be the source codeidentifier of the function being profiled.When profiles are used in many parts of an application, an informativetable is generated showing the time spent in each part.@node Weight,  , Profile, Metrics and Maintenance@subsubsection WeightThe following virtual code implements a function that returns the weightof its argument in the standard representation for natural numbers.@cindex @code{weight}@exampleweight = ((nil,nil),((nil,nil),(nil,(nil,nil))))@end example@noindentThe weight of a tree is zero if the tree is @code{nil}, and otherwisethe sum of the weights of the two subtrees plus one.An algorithm to compute the weight of a tree would be trivial toimplement without being built in to the virtual machine. The built incapability could also be used for purposes unrelated to codemaintenance. Nevertheless, it is built in for the following reasons.@itemize @bullet@item Computing weights happened to be a bottleneck for a particularaspect of code generation that was of interest to the author,@cindex compressionnamely the compression of generated code.@item A built in implementation in C runs at least an order of magnitudefaster than the equivalent implementation in virtual code.@item It runs even faster when repeated on the same data, by retrievingpreviously calculated weights rather than recalculating them.@end itemizeThe only disadvantage of using this feature instead of implementing afunction in virtual code to compute weights is that it relies on native@cindex native integer arithmetic@cindex overflowinteger arithmetic and could overflow, causing a fatal error. It hasnever occurred in practice, but is possible due to sharing, whereby thenominal weight of a tree could be exponentially larger than the actualamount of memory occupied by it.@node Deconstruction, Recursion, Metrics and Maintenance, Virtual Code Semantics@subsection DeconstructionMuch of the time required for evaluating a function is devoted to@cindex deconstructionperforming deconstruction operations, e.g., taking the left side of apair, the tail of a list, the right side of the head of the tail, etc..Because these operations are so frequent, there are some features of thevirtual machine to make them as efficient as possible.@menu* Field::                       * Fan::                         @end menu@node Field, Fan, Deconstruction, Deconstruction@subsubsection FieldThe virtual machine supports a generalization of the @code{left} and@cindex @code{left}@cindex @code{right}@code{right} deconstruction operations that is applicable to deeply nestedstructures. Use of this feature is conducive to code that is faster andmore compact than is possible by relying on the primitive deconstructorsalone. It may also be easier for a code optimizer to recognize andtransform.The general form of a virtual code application to perform deconstructionis that it is a pair with a @code{nil} left side, and a non-@code{nil}right side. The right side indicates the nature of the deconstruction tobe performed when the function is evaluated on an argument.To make the expression of deconstruction functions more readable in@code{silly}, the standard library contains the declaration@examplefield = couple(constant nil,identity)@end example@noindentwhich implies the following theorem.@table @emph@item T13[[@code{field}]] @code{@var{w}} = @code{(nil,@var{w})}@end table@cindex @code{field}The virtual machine recognizes an application in this form and evaluatesit according to the following properties, where @code{@var{u}} and@code{@var{v}} are other than @code{nil}, but @code{@var{x}},@code{@var{y}}, and @code{@var{z}} are unrestricted.@table @emph@item P10([[@code{field}]] @code{(@var{u},nil)}) @code{(@var{x},@var{y})} = ([[@code{field}]] @code{@var{u}}) @code{@var{x}}@item P11([[@code{field}]] @code{(nil,@var{v})}) @code{(@var{x},@var{y})} = ([[@code{field}]] @code{@var{v}}) @code{@var{y}}@item P12([[@code{field}]] @code{(@var{u},@code{v})}) @code{@var{z}} = @code{((}[[@code{field}]] @code{@var{u}) @var{z},(}[[@code{field}]] @code{@var{v}) @var{z})}@end table@noindentOne might also add that ([[@code{field}]] @code{(nil,nil)})@code{@var{z}} = @code{@var{z}}, but this statement would be equivalent to@emph{P0}.A suitable choice of the @code{field} operand permits the implementationof any deconstruction function expressible in terms of @code{compose},@code{couple}, @code{identity}, @code{left} and @code{right}. Forexample, the application @code{couple(compose(right,right),left)} has anequivalent representation in@code{field((nil,(nil,(nil,nil))),((nil,nil),nil))}. The latter lookslonger in @code{silly} but is smaller and faster in virtual code.@node Fan,  , Field, Deconstruction@subsubsection Fan@cindex @code{fan}In cases where a deconstructions would be needed to apply the samefunction to both sides of a pair, the overhead can be avoided by meansof a property of the virtual machine intended for that purpose.A @code{silly} definition of @code{fan} implying the following theorem ishelpful in expressing such an application.@table @emph@item T14[[@code{fan}]] @code{@var{f}} = @code{((nil,nil),((nil,@var{f}),(nil,nil)))}@end table@noindentThe virtual machine recognizes when an application has the form shownabove, and uses @code{@var{f}} as a function to be applied to both sidesof the argument.@table @emph@item P13([[@code{fan}]] @code{@var{f}}) @code{(@var{x},@var{y})} = @code{(@var{f} @var{x},@var{f} @var{y})}@end table@node Recursion, Assignment, Deconstruction, Virtual Code Semantics@subsection Recursion@cindex recursionDefining functions or programs self referentially is sometimesinformally known as recursion. In functional languages, the clever use@cindex combinators@cindex functional programmingof ``combinators'' is often preferred to this practice, and is in fact wellsupported by the virtual machine. However, some computations may beinexpressible without an explicitly ``recursive'' formulation, so thereis some support for that as well.@menu* Recur::                       * Refer::                       @end menu@node Recur, Refer, Recursion, Recursion@subsubsection Recur@cindex @code{meta}@cindex @code{recur}A generalization of the form denoted by @code{meta} in @code{silly} isrecognized by the virtual machine and allows a slightly more efficientencoding of recursive applications. An expression @code{recur @var{p}}has the representation indicated by this theorem,@table @emph@item T15[[@code{recur}]] @code{@var{p}} = @code{(((nil,@var{p}),nil),nil)}@end table@noindentwhich implies that [[@code{meta}]] = [[@code{recur}]] @code{(nil,nil)}.If @code{@var{p}} is non-@code{nil}, a tree of the form [[@code{recur}]]@code{@var{p}} is interpreted as follows. Note that @emph{P4} isequivalent to the special case of this property for which @code{@var{p}}is @code{(nil,nil)}.@table @emph@item P14([[@code{recur}]] @code{@var{p}}) @code{@var{x}} = [[@code{meta}]] ([[@code{field}]] @code{@var{p}}) @code{@var{x}}@end tableThe rationale is that @code{meta} would very frequently be composed witha deconstruction @code{field @var{p}}, so the virtual machine saves sometime and space by allowing the two of them to be encoded in a smallertree with the combined meaning.@node Refer,  , Recur, Recursion@subsubsection Refer@cindex @code{refer}In the style of recursive programming compelled by the available@code{meta} primitive, a function effectively requires a copy of its ownmachine code as its left argument. Bringing about that state ofaffairs is an interesting party trick.@cindex @code{bu}If we had a definition of @code{bu} in the standard library implying@table @emph@item T16([[@code{bu}]] @code{(@var{f},@var{k})}) @code{@var{x}} = @code{@var{f}(@var{k},@var{x})}@end table@noindentwhich for the sake of concreteness can be done like this,@examplebu = (hired compose)(        left,        (hired couple)(compose(constant,right),constant identity))@end example@noindentthen a definition of @code{refer} as@examplerefer = (hired bu)(identity,identity)@end example@noindentwould be consistent with the following property of the operator.@table @emph@item P15([[@code{refer}]] @code{@var{f}}) @code{@var{x}} = @code{@var{f} (@var{f},@var{x})}@end table@noindentThe proof, as always, is a matter of routine calculation in the mannerof the section on how @code{avram} thinks.However, this pattern would occur so frequently in recursively definedfunctions as to be a significant waste of space and time. Therefore,rather than requiring it to be defined in terms of other operations, thevirtual machine specification recognizes a pattern of the form below withrespect to property @emph{P15},@table @emph@item T17[[@code{refer}]] @code{@var{f}} = @code{(((@var{f},nil),nil),nil)}@end table@noindentand takes the property to be true by definition of the operator. Adefinition of @code{refer} consistent with @emph{T17} is therefore to@cindex standard librarybe found in the standard library, not the definition proposed above.@node Assignment, Predicates, Recursion, Virtual Code Semantics@subsection Assignment@cindex assignment@cindex imperative programmingIn an imperative programming paradigm, a machine consists partly of anensemble of addressable storage locations, whose contents are changedover time by assignment statements. An assignment statement includessome computable function of the global machine state, and the address ofthe location whose contents will be overwritten with the value computedfrom the function when it is evaluated.Compiling a language containing assignment statements into virtualmachine code suitable for @code{avram} might be facilitated byexploiting the following property.@table @emph@item P16([[@code{assign}]] @code{(@var{p},@var{f})}) @code{@var{x}} = [[@code{replace}]] @code{((@var{p},@var{f} @var{x}),@var{x})}@end table@noindentThe identifier @code{assign} is used in @code{silly} to express avirtual code fragment having the form shown below, and @code{replace}corresponds to a further operation to be explained presently.@cindex @code{assign}@table @emph@item T18[[@code{assign}]] @code{(@var{p},@var{f})} = @code{(((@var{p},@var{f}),nil),nil)}@end tableThis feature simulates assignment statements in the following way.  Thevariable @code{@var{x}} in @emph{P16} corresponds intuitively to the setof addressable locations in the machine. The variable @code{@var{f}}corresponds to the function whose value will be stored in the locationaddressed by @code{@var{p}}. The result of a function expressed using@code{assign} is a new store similar to the argument @code{@var{x}}, butwith the part of it in location @code{@var{p}} replaced by @code{@var{f}@var{x}}. A source text with a sequence of assignment statements couldtherefore be translated directly into a functional composition of treesin this form.@cindex storage locationsThe way storage locations are modeled in virtual code using this featurewould be as nested pairs, and the address @code{@var{p}} of a locationis a tree interpreted similarly to the trees used as operands to the@code{field} operator described in @ref{Field}, to specifydeconstructions. In fact, @code{replace} can be defined as a minimalsolution to the following equation.@cindex @code{replace}@table @emph@item E0([[@code{field}]] @code{@var{p}}) [[@code{replace}]] @code{((@var{p},@var{y}),@var{x})} = @code{@var{y}}@end tableThis equation regrettably doesnot lend itself to inferring the @code{silly} source for @code{replace}@cindex @code{isolate}using the @code{isolate} algorithm in @ref{Variable Freedom}, so an explicitconstruction is given in @ref{Replace}. This construction need not concern areader who considers the equation a sufficiently precise specificationin itself.In view of the way addresses for deconstruction are represented astrees, it would be entirely correct to infer from this equation that atuple of values computed together can be assigned to a tuple oflocations. The locations don't even have to be ``contiguous'', but couldbe anywhere in the tree representing the store, and the function iscomputed from the contents of all of them prior to the update. Hence,this simulation of assignment fails to capture the full inconvenience ofimperative programming except in the special case of a single valueassigned to a single location, but fortunately this case is the only onemost languages allow.There is another benefit to this feature besides running languages withassignment statements in them, which is the support of abstract oropaque data structures. A function that takes an abstract data structureas an argument and returns something of the same type can be coded in away that is independent of the fields it doesn't use. For example, adata structure with three fields having the field identifiers@code{foo}, @code{bar}, and @code{baz} in some source language might berepresented as a tuple @code{((@var{foo contents},@var{barcontents}),@var{baz contents})} on the virtual code level. Compile timeconstants like @code{bar = ((nil,(nil,nil)),nil)} could be defined in aneffort to hide the details of the representation, so that the virtualcode @code{field bar} is used instead of @code{compose(right,left)}.Using field identifiers appropriately, a function that transforms such astructure by operating on the @code{bar} field could have the virtual@cindex @code{field}code @code{couple(couple(field foo,compose(f,field bar)),fieldbaz)}. However, this code does not avoid depending on the representationof the data structure, because it relies on the assumption of the @code{foo}field being on the left of the left, and the @code{baz} field being onthe right. On the other hand, the code @code{assign(bar,compose(f,fieldbar))} does the same job without depending on anything but the positionof the @code{bar} field. Furthermore, if this position were to changerelative to the others, the code maintenance would be limited to arecompilation.@node Predicates, Iteration, Assignment, Virtual Code Semantics@subsection Predicates@cindex predicatesA couple of operations are built into the virtual machine for performingtests efficiently. These functions return either @code{nil} for false or@code{(nil,nil)} for true, and are useful for example as a predicate@code{@var{p}} in programs of the form@code{conditional(@var{p},(@var{f},@var{g}))} among other things. Inthis example, the predicate is applied to the argument, a result of@code{(nil,nil)} causes @code{@var{f}} to be applied to it, and a resultof @code{nil} causes @code{@var{g}} to be applied to it.@menu* Compare::                     * Member::                      @end menu@node Compare, Member, Predicates, Predicates@subsubsection Compare@cindex @code{compare}A function that performs comparison has a the following very simplevirtual code representation.@table @emph@item T19[[@code{compare}]] = @code{(nil,nil)}@end table@noindentThe proof of theorem @emph{T19} is that the standard @code{silly} preludecontains the declaration @code{compare = (nil,nil)}.  Code in this formhas the following semantics.@table @emph@item P17For distinct trees @code{@var{x}} and @code{@var{y}}, [[@code{compare}]] @code{(@var{x},@var{y})} = @code{nil}@item P18[[@code{compare}]] @code{(@var{x},@var{x})} = @code{(nil,nil)}@end table@noindent@cindex equalityIn other words, the virtual code @code{(nil,nil)} implements a functionthat takes a pair of trees and returns true if and only if they areequal.It would be fairly simple to write an equivalent virtual codeapplication that implements this function if it were not realizable inthis form by definition of the operator. However, this method ispreferable because it saves space in virtual code and has a highlyoptimized implementation in C.@node Member,  , Compare, Predicates@subsubsection MemberAnother built in predicate function has the virtual code shown below.@cindex @code{member}@table @emph@item T20[[@code{member}]] = @code{((nil,nil),((nil,nil),nil))}@end table@noindentAs the mnemonic suggests, the function implemented by this code detectswhether a given item is a member of a list. The left side of itsargument is the item to be detected, and the right side is the list thatmay or may not contain it. Lists are represented as explained in@ref{Representation of Numeric and Textual Data}.The virtual code semantics can be specified by these three properties ofthe operator.@table @emph@item P19[[@code{member}]] @code{(@var{x},nil)} = @code{nil}@item P20[[@code{member}]] @code{(@var{x},(@var{x},@var{y}))} = @code{(nil,nil)}@item P21For distinct trees @code{@var{x}} and @code{@var{y}}, [[@code{member}]] @code{(@var{x},(@var{y},@var{z}))} =[[@code{member}]] @code{(@var{x},@code{z})}@end tableAs in the case of @code{compare}, the implementation of @code{member} iswell optimized in C, so this form is to be preferred over an ad hocconstruction of a membership testing function in virtual code.@node Iteration, List Combinators, Predicates, Virtual Code Semantics@subsection Iteration@cindex recursion@cindex @code{iterate}One of many alternatives to recursion provided by the virtual machine isiteration, which allows an operation to be repeated until a condition ismet. If the source language is imperative, this feature provides an easymeans of translating loop statements to virtual code. In languages that allowfunctions to be treated as data, iteration can be regarded as a functionthat takes a predicate and a function as arguments, and returns afunction that applies the given function repeatedly to its argumentuntil the predicate is refuted.Iterative applications are expressed in virtual code by the pattern shown below.@table @emph@item T21[[@code{iterate}]] @code{(@var{p},@var{f})} = @code{((nil,nil),(nil,(@var{p},@var{f})))}@end table@noindentIn the @code{silly} language, the @code{iterate} mnemonic plays the roleof the function that takes the virtual code for a predicate@code{@var{p}} and a function @code{@var{f}} as arguments, and returnsthe virtual code for an iterating function.The code for an iterating function is recognized as such by the virtualmachine emulator only if the subtrees @code{@var{f}} and @code{@var{p}} are otherthan @code{nil}. The resulting function tests the argument@code{@var{x}} with @code{@var{p}} and returns @code{@var{x}} if thepredicate is false.@table @emph@item P22([[@code{iterate}]] @code{(@var{p},@var{f})}) @code{@var{x}} = @code{@var{x}} if @code{@var{p} @var{x}} = @code{nil}@end table@noindentIf the predicate turns out to be true, @code{@var{f}} is applied to@code{@var{x}}, and then another iteration is performed.@table @emph@item P23([[@code{iterate}]] @code{(@var{p},@var{f})}) @code{@var{x}} =([[@code{iterate}]] @code{(@var{p},@var{f})}) @code{@var{f} @var{x}} if @code{@var{p} @var{x}} is a non-@code{nil} tree@end table@node List Combinators, List Functions, Iteration, Virtual Code Semantics@subsection List Combinators@cindex lists@cindex imperative programming@cindex functional programmingThere is extensive support for operations on lists in the virtual codeformat. Use of these features is encouraged because they are conduciveto tight code with explicit concurrency. Within an imperativeprogramming paradigm, these features might perhaps have to be understoodas design patterns or algorithmic skeletons. The present expositiontakes a functional view, describing them in terms of operators that takefunctions as their arguments and return functions as their result.@menu* Map::                         * Filter::                      * Reduce::                      * Sort::                        * Transfer::                    * Mapcur::                      @end menu@node Map, Filter, List Combinators, List Combinators@subsubsection MapA virtual code application in the following form causes a function withnon-@code{nil} virtual code @code{@var{f}} to be applied to every itemin a list.@table @emph@item T22[[@code{map}]] @code{@var{f}} = @code{((nil,nil),((nil,@var{f}),nil))}@end table@noindent@cindex @code{map}The @code{map} mnemonic is used in @code{silly} to express applicationsin this form as @code{map @var{f}}.  This operation is also well known tolisp users and functional programmers.  The semantics is determined bythese two operator properties (for non-@code{nil} @code{@var{f}}).@table @emph@item P24([[@code{map}]] @code{@var{f}}) @code{nil} = @code{nil}@item P25([[@code{map}]] @code{@var{f}}) @code{(@var{x},@var{y})} = @code{(@var{f} @var{x},(}[[@code{map}]] @code{@var{f}) @var{y})}@end table@noindentNote that the representation of lists described in @ref{Representation of Numeric and Textual Data}, is assumed.@node Filter, Reduce, Map, List Combinators@subsubsection Filter@cindex @code{filter}Another well known list operation is that which applies a predicate toevery item of a list, and deletes those for which the predicate isfalse. For a predicate with virtual code @code{@var{p}}, such anapplication can be coded conveniently in this form,@table @emph@item T23[[@code{filter}]] @code{@var{p}} = @code{((nil,nil),(nil,(@var{p},nil)))}@end table@noindentwhich is to say that writing @code{((nil,nil),(nil,(@var{p},nil)))} in@code{silly} is the same as writing @code{filter @var{p}}.The virtual machine detects code of this form provided that@code{@var{p}} is other than @code{nil}, and evaluates it consistentlywith the following properties, causing it to have the meaning that itdoes.@table @emph@item P26([[@code{filter}]] @code{@var{p}}) @code{nil} = @code{nil}@item P27([[@code{filter}]] @code{@var{p}}) @code{(@var{x},@var{y})} =([[@code{filter}]] @code{@var{p}}) @code{@var{y}} if @code{@var{p} @code{@var{x}}} = @code{nil}@item P28([[@code{filter}]] @code{@var{p}}) @code{(@var{x},@var{y})} =@code{(@var{x},}([[@code{filter}]] @code{@var{p}}) @code{@var{y})} if @code{@var{p} @var{x}} is a non-@code{nil} tree@end table@node Reduce, Sort, Filter, List Combinators@subsubsection Reduce@cindex @code{reduce}In the virtual code fragment shown below, @code{@var{f}} should beregarded as the virtual code for a binary operator, and @code{@var{k}}is a constant.@table @emph@item T24[[@code{reduce}]] @code{(@var{f},@var{k})} = @code{((nil,nil),((@var{f},@var{k}),nil))}@end table@noindentBy constructing a tree in the form shown, the @code{silly}mnemonic @code{reduce} effectively constructs the code for a functionoperating on lists in a particular way.The effect of evaluating an application in this form with an argumentrepresenting a list can be broken down into several cases.@itemize @bullet@item If the list is empty, then the value of @code{@var{k}} is theresult.@item If the list has only one item, then that item is the result.@item if the list has exactly two items, the first being @code{@var{x}} and thesecond being @code{@var{y}}, then  the result is  @code{@var{f}(@var{x},@var{y})}.@item If the list has more than two items and an even number of them, theresult is that of evaluating the application with the list of valuesobtained by partitioning the list into pairs of adjacent items, andevaluating @code{@var{f}} with each pair.@item If the list has more than two items and an odd number of them, theresult is that of evaluating the application with the list of valuesobtained by partitioning the list into pairs of adjacent items excludingthe last one, evaluating @code{@var{f}} with each pair, and thenappending the last item to the list of values.@end itemize@noindentIn the last two cases, evaluation of the application is not necessarilyfinished after just one traversal of the list, because it has to carryon until the list is reduced to a single item.Some care has been taken to describe this operation in detail because itdiffers from comparable operations common to functional programming@cindex foldlanguages, variously known as fold or reduce. All of these operationscould be used, for example, to compute the summation of a list ofnumbers. The crucial differences are as follows.@itemize @bullet@item Whereas a fold or a reduce is conventionally either of the left orright variety, this @code{reduce} is neither.@item The vacuous case result @code{@var{k}} is never used at all unlessthe argument is the empty list.@item This @code{reduce} is not very useful if the operator@code{@var{f}} is not associative.@end itemizeThe reason for defining the semantics of @code{reduce} in this wayinstead of the normal way is that a distributed implementation of this@cindex distributed implementationone could work in logarithmic time, so it's worth making it easy for alanguage processor to detect the pattern in case the virtual code isever going to be targeted to such an implementation. Of course, nothingprevents the conventional left or right reduction semantics from beingtranslated to virtual code by explicit recursion.@cindex recursionThe precise semantics of this operation are as follows, where@code{@var{f}} is not @code{nil}, @code{@var{k}} is unconstrained, and@code{pairwise} represents a function to be explained presently.@cindex @code{iterate}@cindex @code{pairwise}@cindex @code{bu}@cindex @code{right}@table @emph@item P29([[@code{reduce}]] @code{(@var{f},@var{k})}) @code{nil} = @code{@var{k}}@item P30([[@code{reduce}]] @code{(@var{f},@var{k})}) @code{(@var{x},@var{y})} = @*@w{ }@w{ }@w{ }[[@code{left}]] ([[@code{bu(iterate,right)}]] [[@code{pairwise}]] @code{@var{f}}) @code{(@var{x},@var{y})} @end table@noindentThe latter property leverages off some virtual machine features and@code{silly} code that has been defined already. The functionimplemented by [[@code{pairwise}]] @code{@var{f}} is the one thatpartitions its argument into pairs and evaluates @code{@var{f}} witheach pair as described above. The combination of that with@code{bu(iterate,right)} results in an application that repeatedlyperforms [[@code{pairwise}]] @code{@var{f}} while the resulting liststill has a tail (i.e., a @code{right} side), and stops when the listhas only a single item (i.e., when @code{right} is false). The@code{left} operation then extracts the item.For the sake of completeness, it is tedious but straightforward togive an exact definition for @code{pairwise}. The short version is thatit can be anything that satisfies these three equations.@table @emph@item E1([[@code{pairwise}]] @code{@var{f}}) @code{nil} = @code{nil}@item E2([[@code{pairwise}]] @code{@var{f}}) @code{(@var{x},nil)} = @code{(@var{x},nil)}@item E3([[@code{pairwise}]] @code{@var{f}}) @code{(@var{x},(@var{y},@var{z}))} =@code{(@var{f} (@var{x},@var{y}),}([[@code{pairwise}]] @code{@var{f}}) @code{@var{z})}@end table@noindentFor the long version, see @ref{Pairwise}.@node Sort, Transfer, Reduce, List Combinators@subsubsection Sort@cindex @code{sort}Sorting is a frequently used operation that has the following standardrepresentation in virtual code.@table @emph@item T25[[@code{sort}]] @code{@var{p}} = @code{((nil,nil),((@var{p},nil),(nil,nil)))}@end table@noindentWhen an application in this form is evaluated with an operandrepresenting a list, the result is a sorted version of the list.The way a list is sorted depends on what order is of interest. Forexample, numbers could be sorted in ascending or descending order,character strings could be sorted lexically or by length, etc.. Thevalue of @code{@var{p}} is therefore needed in sorting applications tospecify the order. It contains the virtual code for a partial orderrelational operator. This operator can be evaluated with any pair ofitems selected from a list, and should have a value of true if the leftone should precede the right under the ordering. For example, if numberswere to be sorted in ascending order, then @code{@var{p}} would computethe ``less or equal'' relation, returning true if its operand were apair of numbers in which the left is less or equal to the right.The virtual code semantics for sorting applications is given by thesetwo properties, wherein @code{@var{p}} is a non-@code{nil} tree, and@code{insert} is a @code{silly} mnemonic to be defined next.@cindex @code{insert}@table @emph@item P31([[@code{sort}]] @code{@var{p}}) @code{nil} = @code{nil}@item P32([[@code{sort}]] @code{@var{p}}) @code{(@var{x},@var{y})} = ([[@code{insert}]] @code{@var{p}})@code{(@var{x},}([[@code{sort}]] @code{@var{p}}) @code{@var{y})}@end table@noindentThese properties say that the empty list is already sorted, anda non-empty list is sorted if its tail is sorted and the head is theninserted in the proper place. This specification of sorting has nothingto do with the sorting algorithm that @code{avram} really uses.The meaning of insertion is convenient to specify in virtual codeitself. It should satisfy these three equations.@table @emph@item E4([[@code{insert}]] @code{@var{p}}) @code{(@var{x},nil)} = @code{(@var{x},nil)}@item E5([[@code{insert}]] @code{@var{p}}) @code{(@var{x},(@var{y},@var{z}))} =@code{(@var{y},}([[@code{insert}]] @code{@var{p}}) @code{(@var{x},@var{z}))}if @code{@var{p}(@var{x},@var{y})} = @code{nil}@item E6([[@code{insert}]] @code{@var{p}}) @code{(@var{x},(@var{y},@var{z})}) =@code{(@var{x},(@var{y},@var{z}))} if @code{@var{p}(@var{x},@var{y})} is a non-@code{nil} tree@end table@noindentIntuitively, the right argument, whether @code{nil} or@code{(@var{y},@var{z})}, represents a list that is already sorted. Theleft argument @code{@var{x}} therefore only needs to be compared to thehead element, @code{@var{y}} to ascertain whether or not it belongs atthe beginning. If not, it should be inserted into the tail.A possible implementation of @code{insert} in @code{silly} is given in@ref{Insert}.@node Transfer, Mapcur, Sort, List Combinators@subsubsection Transfer@cindex @code{transfer}A particular interpretation is given to virtual code in the following form.@table @emph@item T26[[@code{transfer}]] @code{@var{f}} = @code{((nil,nil),(nil,(nil,@var{f})))}@end table@noindentWhen code in this form is evaluated with an argument, the tree@cindex state transition function@code{@var{f}} is used as a state transition function, and the argumentis used as a list to be traversed. The traversal begins with@code{@var{f}} being evaluated on @code{nil} to get the initial stateand the initial output. Thereafter, each item of the list is paired withthe current state to be evaluated with @code{@var{f}}, resulting in alist of output and the next state. The output resulting from the entireapplication is the cumulative concatenation of all outputs obtained inthe course of evaluating @code{@var{f}}. The computationterminates when @code{@var{f}} yields a @code{nil} result. If the listof inputs runs out before the computation terminates, @code{nil} valuesare used as inputs.This behavior is specified more precisely in the following propertyof the operator, which applies in the case of non-@code{nil} @code{@var{f}}.@cindex @code{transition}@table @emph@item P33([[@code{transfer}]] @code{@var{f}}) @code{@var{x}} =([[@code{transition}]] @code{@var{f}}) @code{(nil,(@var{f} nil,@var{x}))}@end tableMuch of the @code{transfer} semantics is implicit in the meaning of@code{transition}. For any given application @code{@var{f}},[[@code{transition}]] @code{@var{f}} is the virtual code for a functionthat takes the list traversal from one configuration to the next.A configuration is represented as a tuple, usually in the form@code{(@var{previous outputs},((@var{state},@var{output}),(@var{next input},@var{subsequentinputs})))}. A terminal configuration has the form@code{(@var{previous outputs},(nil,(@var{next input},@var{subsequentinputs})))}. A configuration may also have @code{nil} in place of thepair @code{(@var{next input},@var{subsequent inputs})} if no more inputremains.In the non-degenerate case, the meaning of [[@code{transition}]]@code{@var{f}} is consistent with the following equation.@table @emph@item E7([[@code{transition}]] @code{@var{f}}) @code{(@var{y},((@var{s},@var{o}),(@var{i},@var{x})))} =@*@w{ }@w{ }@w{ }@w{ }([[@code{transition}]] @code{@var{f}}) @code{((@var{o},@var{y}),(@var{f} (@var{s},@var{i}),@var{x}))}@end table@noindentThat is, the current output @code{@var{o}} is stored with previous outputs @code{@var{y}}, the nextinput @code{@var{i}} is removed from the configuration, and the next state and outputare obtained from the evaluation of @code{@var{f}} with the state @code{@var{s}} andthe next input @code{@var{i}}.In the case where no input remains, the transition function isconsistent with the following equation.@table @emph@item E8([[@code{transition}]] @code{@var{f}}) @code{(@var{y},((@var{s},@var{o}),nil))} = @*@w{ }@w{ }@w{ }@w{ }([[@code{transition}]] @code{@var{f}}) @code{((@var{o},@var{y}),(@var{f} (@var{s},nil),nil))}@end table@noindentThis case is similar to the previous one except that the @code{nil}value is used in place of the next input. Note that in either case,nothing about @code{@var{f}} depends on the particular wayconfigurations are represented, except that it should have a state asits left argument and an input as its right argument.Finally, in the case of a terminal configuration, the transitionfunction returns the cumulative output.@table @emph@item E9([[@code{transition}]] @code{@var{f}}) @code{(@var{y},(nil,@var{x}))} =[[@code{reduce(cat,nil)}]] [[@code{reverse}]] @code{@var{y}}@end table@noindentThe @code{silly} code @code{reduce(cat,nil)} has the effect of@cindex @code{cat}@cindex concatenationflattening a list of lists into one long list, which is necessaryinsofar as the transition function will have generated not necessarily asingle output but a list of outputs on each iteration. The @code{cat}mnemonic stands for list concatenation and is explained in @ref{Cat}.The reversal is necessary to cause the first generated output to be atthe head of the list. List reversal is a built in operation of thevirtual machine and is described in @ref{Reverse}.If such a function as @code{transition} seems implausible, itsimplementation in @code{silly} can be found in @ref{Transition}.It is usually more awkward to express a function in terms ofa @code{transfer} than to code it directly using recursion or other listoperations. However, this feature is provided by the virtual machine forseveral reasons.@itemize @bullet@item Functions in this form may be an easier translation target if thesource is an imperative language.@item Translating from virtual code to asynchronous circuits or process@cindex asynchronous circuitsnetworks has been a research interest of the author, and code in this@cindex authorform lends itself to easy recognition and mapping onto discrete components.@item The @option{--byte-transducer} and @option{--interactive} commandline options to @code{avram} cause an application to be invoked in a@cindex state transition functionsimilar manner to the transition function in a @code{transfer}function, so this feature allows for easy simulation and troubleshootingof these applications without actually deploying them.@end itemize@node Mapcur,  , Transfer, List Combinators@subsubsection MapcurAn alternative form of recursive definition is the following.@cindex @code{mapcur}@table @emph@item T27[[@code{mapcur}]] @code{@var{p}} = @code{((nil,nil),((nil,nil),(@var{p},nil)))}@end table@noindentThis form is convenient for applications that cause themselves to be@cindex recursionapplied recursively to a list of arguments. It has this semantics.@table @emph@item P34([[@code{mapcur}]] @code{@var{p}}) @code{@var{x}} =[[@code{map meta}]] [[@code{distribute}]] ([[@code{field}]] @code{@var{p}}) @code{@var{x}}@end table@node List Functions, Exception Handling, List Combinators, Virtual Code Semantics@subsection List FunctionsIn addition to the foregoing list operations, the virtual machine@cindex listsprovides a number of canned functions operating on lists, namelyconcatenation, reversal, distribution, and transposition. Thesefunctions could be coded by other means if they were not built in, butthe built in versions are faster and smaller.@menu* Cat::                         * Reverse::                     * Distribute::                  * Transpose::                   @end menu@node Cat, Reverse, List Functions, List Functions@subsubsection CatThe list concatenation operation has this representation in virtual code.@cindex @code{cat}@cindex concatenation@table @emph@item T28[[@code{cat}]] = @code{((nil,nil),(nil,nil))}@end table@noindentThis function takes a pair of lists as an argument, an returns the listobtained by appending the right one to the left. The semantics ofconcatenation is what one would expect.@table @emph@item P35[[@code{cat}]] @code{(nil,@var{z})} = @code{@var{z}}@item P36[[@code{cat}]] @code{((@var{x},@var{y}),@var{z})} = @code{(@var{x},}[[@code{cat}]] @code{(@var{y},@code{z}))}@end table@node Reverse, Distribute, Cat, List Functions@subsubsection Reverse@cindex @code{reverse}The function that reverses a list has the following representation invirtual code.@table @emph@item T29[[@code{reverse}]] = @code{((nil,nil),(nil,(nil,nil)))}@end table@noindentThis function takes a list as an argument, and returns a the listconsisting of the same items in the reverse order. The semantics isgiven by the following properties.@table @emph@item P37[[@code{reverse}]] @code{nil} = @code{nil}@item P38[[@code{reverse}]] @code{(@var{x},@var{y})} = [[@code{cat}]] ([[@code{reverse}]] @code{@var{y},(@var{x},nil)})@end table@node Distribute, Transpose, Reverse, List Functions@subsubsection DistributeThe function with the following virtual code representation isfrequently useful for manipulating lists.@cindex @code{distribute}@table @emph@item T30@code{distribute} = @code{(((nil,nil),nil),nil)}@end table@noindentThis function takes a pair whose right side represents a list, andreturns a list of pairs, with one pair for each item in the list. Theleft side of each pair is the left side of the original argument, andthe right side is the corresponding item of the list. A semantics forthis operation is specified by the following properties.@table @emph@item P39[[@code{distribute}]] @code{(@var{x},nil)} = @code{nil}@item P40[[@code{distribute}]] @code{(@var{x},(@var{y},@var{z}))} =@code{((@var{x},@var{y}),}[[@code{distribute}]] @code{(@var{x},@var{z}))}@end table@node Transpose,  , Distribute, List Functions@subsubsection TransposeThe @code{transpose} operation has the following representation invirtual code.@table @emph@item T31[[@code{transpose}]] = @code{((nil,nil),((nil,nil),(nil,nil)))}@end table@noindent@cindex @code{transpose}This function takes a list of equal length lists as an argument, andreturns a list of lists as a result. In the resulting list, the firstitem is the list of all first items of lists in the argument. The nextitem is the list of all second items, and so on.In the specification of the semantics, the @code{silly} mnemonic@cindex @code{flat}@code{flat} is defined by @code{flat = reduce(cat,nil)} in the standard@code{silly} prelude, which means that it flattens a list of lists intoone long list.@table @emph@item P41[[@code{transpose}]] @code{@var{x}} = @code{nil} if [[@code{flat}]] @code{@var{x}} = @code{nil}@item P42[[@code{transpose}]] @code{@var{x}} =@code{(}[[@code{map left}]] @code{@var{x},}[[@code{transpose}]] [[@code{map right}]] @code{@var{x})}@*@w{ }@w{ }@w{ } if [[@code{flat}]] @code{@var{x}} is a non-@code{nil} tree@end table@node Exception Handling, Interfaces to External Code, List Functions, Virtual Code Semantics@subsection Exception Handling@cindex exceptionsIn quite a few cases, the properties given for the operator up to thispoint do not imply any particular result. A good example would be anexpression such as [[@code{left}]] @code{nil}, which appears torepresent the left side of an empty pair. It can be argued thatexpressions like this have no sensible interpretation and should neverbe used, so it would be appropriate to leave them undefined.  On theother hand, attempts to evaluate such expressions occur frequently bymistake, and in any case, the virtual machine emulator should bedesigned to do something reasonable about them if only for the sake ofreporting the error.  The chosen remedy for this situation addresses theneed for error reporting, and also turns out to be useful in other ways.@menu* A Hierarchy of Sets::         * Operator Generalization::     * Error Messages::              * Expedient Error Messages::    * Computable Error Messages::   * Exception Handler Usage::     @end menu@node A Hierarchy of Sets, Operator Generalization, Exception Handling, Exception Handling@subsubsection A Hierarchy of SetsAs indicated already, the virtual machine represents all functions anddata as members of a set satisfying the properties in @ref{Raw Material},namely a @code{nil} element and a @code{cons} operator for constructingtrees or nested pairs of @code{nil}. However, it will be necessary todistinguish the results of computations that go wrong for exceptionalreasons from normal results. Because any tree in the set could conceivablyrepresent a normal result, we need to go outside the set to find anunambiguous representation of exceptional results.Because there may be many possible exceptional conditions, it will be helpfulto have a large set of possible ways to encode them, and in fact thereis no need to refrain from choosing a countably infiniteset. Furthermore, it will be useful to distinguish between differentlevels of severity among exceptional conditions, so for this purpose acountably infinite hierarchy of mutually disjoint sets is used.In order to build on the theory already developed, the set that has beenused up to this point will form the bottom level of the hierarchy, andits members will represent normal computational results. The members ofsets on the higher levels in the hierarchy represent exceptionalresults. To avoid ambiguity, the term ``trees'' is reserved for members@cindex treesof the bottom set, as in ``for any tree @code{@var{x}} @dots{}''.Unless otherwise stated, variables like @code{@var{x}} and@code{@var{y}} are universally quantified over the bottom set only.@cindex universal quantificationBecause each set in the hierarchy is countably infinite, it isisomorphic to the bottom set. With respect to an arbitrary but fixedbijection between them, let @code{@var{x}_@var{n}} denote the image inthe @code{@var{n}}th level set of a tree @code{@var{x}} in the bottomset. The level numbers in this notation start with zero, and we take@code{@var{x}_0} to be synonymous with @code{@var{x}}. For good measure,let @code{(@var{x}_@var{n})_@var{m}} = @code{@var{x}_(@var{n}+@var{m})}.@node Operator Generalization, Error Messages, A Hierarchy of Sets, Exception Handling@subsubsection Operator GeneralizationEach set in the hierarchy induces a structure preserving @code{cons}@cindex @code{cons}operator, denoted @code{cons_@var{n}} for the @code{@var{n}}th levelset, and satisfying this equation.@table @emph@item E10@code{cons_@var{n}(@var{x}_@var{n},@var{y}_@var{n})} =@code{(cons(@var{x},@var{y}))_@var{n}}@end table@noindentIt will be convenient to generalize all of these @code{cons} operators to bedefined on members of other sets than their own.@table @emph@item E11For @code{@var{m}} greater than @code{@var{n}},@w{ } @w{ } @w{ } @code{cons_@var{n}(@var{x}_@var{m},@var{y}_@var{p})} =@code{@var{x}_@var{m}}@end table@noindentIn this equation, @code{@var{p}} is unrestricted. The intuition is thatif the left operand of a @code{cons} is the result of a computation thatwent wrong due to an exceptional condition (more exceptional than@code{@var{n}}, the level already in effect), then the exceptionalresult becomes the whole result.It is tempting to hazard a slightly stronger statement, which is thatthis equation holds even if @code{@var{y}_@var{p}} is equal to someexpression @code{@var{f} @var{x}} that is undefined according to theoperator semantics. This stipulation would correspond to animplementation in which the right operand isn't evaluated after an erroris detected in the left, but there are two problems with it.@itemize @bullet@item This semantics might unreasonably complicate a concurrentimplementation of the virtual machine. If evaluation leads tonon-termination in some cases where the result is undefined (as it certainlywould in any possible implementation consistent with cases where it'sdefined), then the mechanism that evaluates the right side of a pairmust be interruptible in case an exception is detected in the left.@item It is beyond the expressive power of the present mathematicalframework to make such a statement, because it entails universalquantification over non-members of the constructed sets, which includes@cindex universal quantificationalmost everything.@end itemize@noindentNevertheless, the implementation in @code{avram} is sequential and doesindeed behave as proposed, with no practical difficulty. As for anydeficiency in the theory, it could be banished by recasting thesemantics in terms of a calculus of expressions with formal rules ofmanipulation. An operand to the @code{cons} operator would be identifiednot with a member of a semantic domain, but with the expression used towrite it down, and then even ``undefinedness'' could be@cindex undefined expressionsdefined. However, the present author's preference in computing as in@cindex authorlife is to let some things remain a mystery rather than to abandon thequest for meaning entirely.A comparable condition applies in cases where the right side of a pairrepresents an exceptional result.@table @emph@item E12For @code{@var{m}} greater than @code{@var{n}},@w{ } @w{ } @code{cons_@var{n}(@var{x}_@var{n},@var{y}_@var{m})} =@code{@var{y}_@var{m}}@end tableWhereas an infinitude of @code{cons} operators has been needed, it will@cindex @code{cons}be possible to get by with only one invisible operator, as before, bygeneralizing it in the following way to operands on any level of thehierarchy.@table @emph@item P43@code{@var{f}_@var{n} @var{x}_@var{n}} = @code{(@var{f} @var{x})_@var{n}}@item P44For distinct @code{@var{n}} and @code{@var{m}}, @w{ }@code{@var{f}_@var{n} @var{x}_@var{m}} = @code{@var{x}_@var{m}}@end table@noindentThat is, the result of evaluating two operands on the same level is theimage relative to that level of the result of their respective images onthe bottom level, but the result of evaluating two operands on differentlevels is the same as the right operand.@node Error Messages, Expedient Error Messages, Operator Generalization, Exception Handling@subsubsection Error MessagesThe basic strategy for representing the results of exceptionalconditions arising from the evaluation of operands on a given level ofthe hierarchy will be to use an error message corresponding to the imageof a list of character strings on the level above.Unfortunately, the official @code{silly} standard does notdefine character constants, but they are available as a vendor specificextension in @code{silly-me} (millennium edition), where character strings@cindex @code{silly-me}@cindex strings@cindex character stringsmay be enclosed in single quotes. The value of the semantic@cindex semantic functionfunction [[@dots{}]] in the case of a character string is the listof representations of the characters, based on @ref{Character Table}and @ref{Representation of Numeric and Textual Data}.For the sake of consistency, each standard error message is a list ofcharacter strings, even though the list has only one string in it. Ifany exceptional condition is the result of a computation, it is writtento standard error by @code{avram} as the list of character strings itrepresents.@table @emph@item P45([[@code{compare}]] @code{nil})@code{_@var{n}} = [[@code{('invalid comparison',nil)}]]@code{_(@var{n}+1)}@item P46([[@code{left}]] @code{nil})@code{_@var{n}}  = [[@code{('invalid deconstruction',nil)}]]@code{_(@var{n}+1)}@item P47([[@code{right}]] @code{nil})@code{_@var{n}} = [[@code{('invalid deconstruction',nil)}]]@code{_(@var{n}+1)}@item P48(([[@code{fan}]] @code{@var{f}})@code{nil})@code{_@var{n}} = [[@code{('invalid deconstruction',nil)}]]@code{_(@var{n}+1)}@item P49([[@code{member}]] @code{nil})@code{_@var{n}}  = [[@code{('invalid membership',nil)}]]@code{_(@var{n}+1)}@item P50([[@code{distribute}]] @code{nil})@code{_@var{n}} = [[@code{('invalid distribution',nil)}]]@code{_(@var{n}+1)}@item P51([[@code{cat}]] @code{nil})@code{_@var{n}}  = [[@code{('invalid concatenation',nil)}]]@code{_(@var{n}+1)}@item P52([[@code{meta}]] @code{nil})@code{_@var{n}} = [[@code{('invalid recursion',nil)}]]@code{_(@var{n}+1)}@end tableNote that by virtue of property @emph{P44}, there is no need for anapplication to make explicit checks for exceptional results at anypoint, because the exceptional result propagates through to the outputof any function composed with the one that incurred it. For example, anapplication of the form @code{h = compose(f,right)}, which will cause aninvalid deconstruction error if applied in filter mode to an empty file,imposes no requirement that @code{f} be written to accommodate thatpossibility (i.e., by checking for it) in order for the error to bereported properly. The following proof demonstrates that the meaning of @code{f}is irrelevant to the result.@format[[@code{compose(f,right)}]]@code{_0} @code{nil_0}   = [[@code{f}]]@code{_0} [[@code{right}]]@code{_0} @code{nil}@code{_0}   = [[@code{f}]]@code{_0} [[@code{('invalid deconstruction',nil)}]]@code{_1}   = [[@code{('invalid deconstruction',nil)}]]@code{_1}@end format@noindentIn an application @code{h = compose(f,g)}, the inputvalidation therefore may be confined to the ``front @w{end'', @code{g}.}It will be recalled from the discussions of @code{recur} (@ref{Recur})@cindex @code{recur}@cindex @code{transpose}and @code{transpose} (@ref{Transpose}) that the semantics ofvirtual code involving these forms is defined in terms of the@code{field} format for deconstruction functions (@ref{Field}),@cindex @code{field}which depends implicitly on the semantics of @code{left} and@code{right}, being a generalization of them. An invalid deconstruction@cindex @code{left}@cindex @code{right}message could therefore result from applications incorporating any ofthe forms of @code{recur}, @code{transpose}, or @code{field}. Invaliddeconstructions could also arise from the @code{replace} operation@cindex @code{replace}@cindex assignment(@ref{Replace}), which is used for assignment (@ref{Assignment}), because@code{replace} is defined by virtual code, except as noted next.@node Expedient Error Messages, Computable Error Messages, Error Messages, Exception Handling@subsubsection Expedient Error Messages@cindex error messagesBecause there are so many ways to cause an invalid deconstruction, thismessage is the most common in practice and therefore the leastinformative. As a matter of convenience, @code{avram} takes the libertyof a slight departure from the virtual machine specification as writtenhitherto, and employs the following messages when invaliddeconstructions occur respectively in the cases of recursion,transposition, and assignment.@itemize @bullet@item @code{invalid recursion}@item @code{invalid transpose}@item @code{invalid assignment}@end itemize@noindentThat is, this section contradicts and supersedes what is stated at theend of @ref{Error Messages} and implied by the operator properties@emph{P14}, @emph{P16}, and @emph{P42}. It is also possible that userapplications may modify the error messages by methods described in@ref{Computable Error Messages}.Whereas these three cases constitute an expedient variation on thesemantics, there is another sense in which no possible implementationcould conform faithfully to the specification. When an evaluation cannot be carried out because of insufficient space on the host machine,one of the following error messages may be the result.@itemize @bullet@item @code{memory overflow}@item @code{counter overflow}@end itemize@noindentThese messages are treated in the same way as those that are caused byprogramming errors, and propagate to the final result written tostandard error without any specific consideration by the applicationdeveloper. The latter occurs only in connection with the built in weightfunction (@ref{Weight}). Other messages listed in@ref{Application Programming Errors} are also of this ilk.@node Computable Error Messages, Exception Handler Usage, Expedient Error Messages, Exception Handling@subsubsection Computable Error MessagesThe automatic generation and reporting of error messages provides areasonable default behavior for applications that do not considerexceptional conditions. All applications and their input data areordinarily members of the bottom level set in the hierarchy (@ref{A Hierarchy of Sets}).  The error messages caused by invalidoperations on this level are on the first level above the bottom, whichare recognized as such and written to standard error withoutintervention from the application. However, there are two drawbacks tothis style of dealing with exceptions.@cindex exceptions@itemize @bullet@item An application developer may wish to translate error messagesinto terms that are meaningful to the user, not only by literallytranslating them from English to the local vernacular, but perhaps byrelating the particular exceptional condition to application specificcauses. While it is convenient for the ``back end'' code not to berequired to intervene in the error reporting, it would be mostinconvenient for it not to be able to do so.@item Some application specific errors might not correspond directly to any ofthe particular conditions detected automatically due to invalidoperations, for example a semantic error in a syntactically correctinput file. It might be convenient in such cases for an application tobe able to define its own error messages but still have them reportedautomatically like the built in messages.@end itemizeThese situations suggest a need for some ability on the part of anapplication to operate on error messages themselves. Based on theoperator semantics given so far, such an application is inexpressible,because for any application @code{@var{f}_0} and error message@w{@code{@var{x}_1}}, property @emph{P44} stipulates @code{@var{f}_0 @var{x}_1} =@code{@var{x}_1}, meaning that the resulting error message isunchanged. Therefore, we need to define another basic property of theoperator.The following form of virtual code is used in applications that may needto operate on error messages.@cindex @code{guard}@table @emph@item T32[[@code{guard}]] @code{(@var{f},@var{g})} = @code{((nil,@var{f}),@var{g})}@end table@noindentCode in this form has the following semantics.@table @emph@item P53([[@code{guard}]] @code{(@var{f},@var{g})})@code{_@var{n}}@code{@var{x}_@var{p}} =@code{@var{g}_(@var{n}+1) @var{f}_@var{n} @var{x}_@var{p}}@end table@noindentThe intuitive explanation is that @code{@var{f}} is the main part of theapplication, and @code{@var{g}} is the part of the application thatoperates on the error message that comes from @code{@var{f}} if anexception occurs while it is being evaluated (i.e., the ``exceptionhandler''). Typically the exception handler code implements a functionthat takes an error message as an argument and returns an error messageas a result.Where there is no exception, the exception handler@code{@var{g}_(@var{n}+1)} is never used, because its argument will beon level @code{@var{n}}, and therefore unaffected by an application onlevel @code{@var{n}+1}.Exception handlers may have their own exception handlers, which will beinvoked if the evaluation of the exception handler causes a furtherexception. Such an exception corresponds semantically to a value on thenext level of the hierarchy of sets.@node Exception Handler Usage,  , Computable Error Messages, Exception Handling@subsubsection Exception Handler UsageOne way for this feature of the virtual machine to be used is tointercept and translate error messages to a more meaningful form. Anapplication guarded as shown below causes messages of invalid deconstructionto be changed to @code{'syntax error'}.@display@code{main = guard(   application,   conditional(      bu(compare,('invalid deconstruction',nil)),      (constant ('syntax error',nil),identity)))}@end display@noindentThe conditional compares its argument to the error message for an@cindex deconstructioninvalid deconstruction, and if it matches, the syntax error message isreturned, but otherwise the original message is returned. Note that anerror message must be in the form of a list of character strings, sothat it can be printed.  Although the message of @code{'syntax error'}might not be very informative, at least it looks less like a crash.A real application should of course strive to do better than that.Exception handling features of the virtual machine can also be adaptedby applications to raise their own exceptions with customized messages.@exampleerror_messenger =   guard(compose(compare,constant nil),constant ('syntax error',nil))@end example@noindentThis code fragment implements a function that causes a message of@code{'syntax error'} to be reported for any possible input.  This codeworks by first causing an invalid comparison and then substituting itsown error message. A function that always causes an error is not usefulin itself, but might be used as part of an application in the followingform.@examplemain = conditional(validation,(application,error_messenger))@end example@noindentIn this case, the application checks the validity of the input with apredicate, and invokes the error messenger if it is invalid.Although the previous examples return a fixed error message for eachpossible kind of error, it is also possible to have error messagesthat depend on the input data, as the next example shows.@cindex @code{bu}@cindex @code{guard}@cindex @code{identity}@cindex @code{apply}@cindex @code{hired}@examplemain = (hired apply)(   compose(      bu(guard,some_application),      (hired constant)(constant 'invalid input was:',identity)),   identity)@end example   @noindentIf the application causes an exception for any reason, the error messagereturned will include a complete listing of the input, prefaced by thewords @code{'invalid input was:'}. This particular example works only ifthe input is a list of character strings, but could be adapted for othertypes of data by substituting an appropriate formatting function for thefirst identity. The formatting function would take the relevant datatype to a list of character strings. Another possible variation would be toconcatenate the invalid input listing with the error message that wasgenerated, rather than just replacing it.As the last example may suggest, exception handlers turn out to be an@cindex debugging@cindex functional programming@cindex imperative programmingessential debugging tool for functional programs, making them as easy todebug as imperative programs if not more so. This example forms thebasis for a higher order function that wraps any given function with anexception handler that prints the argument causing it to crash. Forarguments not causing a crash, the behavior is unchanged. Alternatively,code implementing a function that unconditionally reports its argumentin an error message can be inserted at a strategic point in theapplication code similarly to a print statement. Finally, inspired useof exception handlers that concatenate their messages with previouslygenerated messages can show something like a parameter stack dump when arecursively defined function crashes. These are all matters for a languagedesigner and are not pursued further in this document.@node Interfaces to External Code, Vacant Address Space, Exception Handling, Virtual Code Semantics@subsection Interfaces to External CodeA few other combinators have been incorporated into the virtualmachine as alternatives to the style of interactive applicationsdescribed in @ref{Output From Interactive Applications}. These make itpossible to interface with external libraries and applications eitherby a simple function call, or by executing a run-time generatedtransducer as described previously. In either case, there is no needfor any particular command line options to specify interactiveinvocation, nor for the application to be designed that way from theoutset. Existing virtual code applications may therefore be enhancedto make use of these features without radical changes.To account for these additional capabilities, it is not entirelyadequate to continue defining the virtual machine semantics in termsof a mathematical function, but it is done nevertheless due to thelack of any appealing alternative. Although most library functions arein fact functions in the sense that their outputs are determined bytheir arguments, they defy a concise specification within the presentmathematical framework, especially insofar as they may involve finiteprecision floating point numbers. More problematically, the effect ofinteraction with a shell is neither well defined nor deterministic.The descriptions that follow presuppose a computational procedureassociated with the following definitions but leave its exact natureunspecified.@menu* Library combinator::                    * Have combinator::                      * Interaction combinator::                      @end menu@node Library combinator, Have combinator, Interfaces to External Code, Interfaces to External Code@subsubsection Library combinatorThe simplest and fastest method of interfacing to an external libraryis by way of a virtual machine combinator called @code{library}. Ittakes two non-empty character strings as arguments to a virtual codeprogram of the form implied by the following property.@table @emph@item T33[[@code{library}]] (@code{@var{x}},@code{@var{y}}) = @code{((nil,nil),((@var{x},@var{y}),(nil,nil)))}@end table@noindentIntuitively, @var{x} is the name of a library and @var{y} is the nameof a function within the library. For example, if @var{x} is@code{'math'} and @var{y} is @code{'sqrt'}, then@code{library}(@var{x},@var{y}) represents the function that computesthe square root of a floating point number as defined by the hostmachine's native C implementation, normally in IEEE double precisionformat.  Different functions and libraries may involve other argumentand result types, such as complex numbers, arrays, sparse matrices, orarbitrary precision numbers. A list of currently supported externallibrary names with their functions and calling conventions is given in@ref{External Libraries}.On the virtual code side, all function arguments and resultsregardless of their types are encoded as nested pairs of @code{nil},as always, and may be manipulated or stored as any other data,including storage and retrieval from files in @file{.avm} virtualcode format (@ref{File Format}). However, on the C side,various memory management and caching techniques are employed tomaintain this facade while allowing the libraries to operate on datain their native format. The details are given more fully in the APIdocumentation, particularly in @ref{Type Conversions} and@ref{External Library Maintenance}.While this style is fast and convenient, it is limited either tolibraries that have already been built into the virtual machine, or tothose for which the user is prepared to implement a new interfacemodule in C as described in @ref{Implementing new libraryfunctions}.@node Have combinator, Interaction combinator, Library combinator, Interfaces to External Code@subsubsection Have combinatorAs virtual machine interfaces to external libraries accumulate fasterthan they can be documented and may vary from one installation toanother, it is helpful to have a way of interrogating the virtualmachine for an up to date list of the installed libraries andfunctions. A combinator called @code{have} can be used to test for theavailability of a library function. It takes the form@table @emph@item T34[[@code{have}]] (@code{@var{x}},@code{@var{y}}) = @code{((nil,nil),((nil,@var{x}),(nil,@var{y})))}@end table@noindentwhere @var{x} is the name of a library and @var{y} is the name of afunction within the library encoded as character strings. For example,if @var{x} is @code{'mtwist'} and @var{y} is @code{'u_disc'} (for thenatural random number generator function in the Mersenne twistorlibrary) then @code{have(@var{x},@var{y})} is a function that returnsa non-empty value if an only if that library is installed and thatfunction is available within it. The actual argument to the functionis ignored as the result depends only on the installed virtual machineconfiguration. In this sense, it acts like a @code{constant} combinator.One way for this combinator to be used is in code of the form@example   portable_rng =   conditional(      have('mtwist','u_disc'),      library('mtwist','u_disc'),      some_replacement_function)@end example@noindentwhich will use the library function if available but otherwise use areplacement function. Code in this form makes the decision at runtime, but it is also possible to express the function such that thecheck for library presence is made at compile time, as the followingexample shows, which will imply a slight improvement in performance.@example   non_portable_rng =   apply(      conditional(         have('mtwist','u_disc'),         constant library('mtwist','u_disc'),         constant some_replacement_function),      0)@end example@noindentThis program would be non-portable in the sense that it would need tobe recompiled for each installation if there were a chance that someof them might have the @code{mtwist} library and some might not,whereas the previous example would be binary compatible across all ofthem. @footnote{In practice both examples are equally portable becausethe @code{mtwist} source is distributed with @code{avram} so allinstallations will have it. Most libraries are distributedseparately.}The actual value returned by a function @code{have(foo,bar)} is thelist of pairs of strings @code{<(foo,bar)>} if the function isavailable, or the empty list otherwise. A non-empty list isrepresented as a pair @code{(head,tail)}, and an empty list as@code{nil}. The angle bracket notation @code{<a,b,c...>} used here isan abbreviation for @code{(a,(b,(c...nil)))}.Either or both arguments to the @code{have} combinator can be awildcard, which is the string containing a single asterisk,@cindex wild cards@code{'*'}. In that case, the list of all available matching librarynames and function names will be returned. This feature can be used tofind out what library functions are available without already knowingtheir names.If a library had a function named @code{'*'}, which clashes withthe wild card string, the interpretation as a wild card would takeprecedence.@node Interaction combinator,  , Have combinator, Interfaces to External Code@subsubsection Interaction combinatorA further combinator allows virtual code applications to interactdirectly with any interactive console application using the@code{expect} library.  The mechanism is similar to that ofinteractive applications documented in the @ref{Output FromInteractive Applications}, but attempts to be more convenient.Instead of being designed as an interactive application, any virtualcode application may use this combinator to spawn a shell and interactwith it in order to compute some desired result.The advantage of this combinator over the @code{library} combinator isthat it requires no modification of the virtual machine to support newapplications. It can also interact with applications that may resideon remote servers, that are implemented languages other than C, or@cindex GNU Rwhose source code is unavailable. For example, the GNU R statisticalpackage provides an interactive command to evaluate multivariate@cindex multivariate normal distrubutionnormal distribution functions with an arbitrary covariance matrix, but@cindex covariance matrixthe corresponding function is not provided by the @code{Rmath} Clibrary (or any other free library, to the author's knowledge) becauseit is implemented in interpreted code. This combinator makes itcallable by an @code{avram} virtual code application nevertheless. Thedisadvantage compared to the @code{library} combinator is that thereis more overhead in spawning a process than simply making a call to abuilt in function, and the programming interface is more complicated.The combinator takes the form@table @emph@item T35[[@code{interact}]] @var{f} = @code{((nil,nil),(((nil,nil),nil),((nil,@var{f}),nil)))}@end table@noindentwhere @var{f} is the virtual code for a function thatfollows the same protocol described in @ref{Output From Interactive Applications},except that it does not allow file output as described in@ref{Mixed Modes of Interaction}. The argument @code{x} is ignored when theexpression @code{(interact f) x} is evaluated, similarly to the way the argumentis ignored in an expression like @code{(constant k) x}. The result returnedis a transcript of the dialogue that took place between @code{f} and theexternally spawned shell, represented as a list of lists of strings forline oriented interaction, or a list of characters alternating with lists ofstrings in the case of character oriented interaction.The following example demonstrates a trivial use of the @code{interact}combinator to spawn an @code{ftp} client, do an @code{ls} command, and then@cindex ftpterminate the session.@exampleeof = <(nil,(nil,(((nil,nil),nil),(nil,nil))))>demo =interact conditional(   conditional(identity,constant false,constant true),   constant(0,<'ftp'>,<'ftp> '>),   conditional(      conditional(left,constant false,constant true),      constant(1,<'ls',''>,<'','ftp> '>),      conditional(         compose(compare,couple(left,constant 1)),         constant(2,<'bye',''>,<eof>),         constant nil)))@end example@noindentSome liberties are taken with @code{silly} syntax in this example, inthe way of using angle brackets to denote lists, and numbers torepresent states.@itemize @bullet@itemThe interacting transducer works by checking whether its argument isempty (via the @code{identity} function used as a predicate in the@code{conditional}, which is then negated). In that case it returnsthe triple containing the initial state of 0, the @code{ftp} shellcommand to spawn the client, and the @code{'ftp> '} prompt expectedwhen the client has been spawned, both of the latter being lists ofstrings.@itemIf the argument is non-empty, then next it checks whether it is in theinitial state of 0, (via the @code{left} function used as a predicate,referring to the state variable expected on the left of any given@code{(state,input)} pair, also negated). If so, it returns the triplecontaining the next state of 1, the @code{ls} command followed by anempty string to indicate a line break, and the expected promptpreceded by an empty string to match it only at the beginning of aline.@itemFinally, it checks for state 1, in which case it issues the@code{bye} command to close the session, @code{eof} rather than a@cindex eofprompt to wait for termination of the client, and a state of 2.@itemIn the remaining state of 2, which needn't be explicitly testedbecause it is the only remaining possibility, the program returns a@code{nil} value to indicate that the computation hasterminated.@end itemizeDeadlock would be possible at any point if either party did not follow@cindex deadlockthis protocol, but for this example it is not an issue. If anexpression of the form @code{demo x} were to be evaluated, thenregardless of the value of @code{x}, the value of the result would beas shown below.@example<   <'ftp'>,   <'ftp> '>,   <'ls',''>,   <'ls','Not connected.','ftp> '>,   <'bye',''>,   <'bye',''>>@end example@noindentThat is, it would be a list of lists of strings, alternating between theoutput of the interactor and the output of the @code{ftp} client.  Ifthe spawned application had been something non-trivial such as acomputer algebra system or a command line web search utility,then it is easy to see how functions using this combinator can leverageoff a wealth of available resources.@node Vacant Address Space,  , Interfaces to External Code, Virtual Code Semantics@subsection Vacant Address SpaceNot every possible pattern has been used by the virtual machine as a wayof encoding a function. The following patterns, where @code{@var{a}},@code{@var{b}}, and @code{@var{c}} are non-@code{nil} trees, do notrepresent anything useful.@table @asis@item unary forms@code{((nil,nil),((nil,nil),(nil,((nil,@var{a}),nil))))}@*@code{((nil,nil),((nil,nil),(nil,(nil,(nil,@var{a})))))}@item binary forms@code{((nil,nil),((nil,nil),(@var{a},@var{b})))}@*@code{((nil,nil),((@var{a},nil),(@var{b},nil)))}@*@code{((nil,nil),((@var{a},nil),(nil,@var{b})))}@item ternary forms@code{((nil,nil),((@var{a},@var{b}),(@var{c},nil)))}@*@code{((nil,nil),((@var{a},@var{b}),(nil,@var{c})))}@*@code{((nil,nil),((@var{a},nil),(@var{b},@var{c})))}@*@code{((nil,nil),((nil,@var{a}),(@var{b},@var{c})))}@end table@noindentThese patterns are detected by the virtual machine simply to avoid blowingit up, but they always cause an error message to be reported.@cindex @code{unsupported hook}@cindex @code{unrecognized combinator}@table @emph@item P55For @code{@var{f}} matching any of the first three trees in the above list,@*@w{ }@w{ }@w{ }@code{@var{f}_@var{n} @var{x}_@var{n}} =[[@code{('unsupported hook',nil)}]]@code{_(@var{n}+1)}@item P56For the remaining trees @code{@var{f}} in the above list,@*@w{ }@w{ }@w{ }@code{@var{f}_@var{n} @var{x}_@var{n}} =[[@code{('unrecognized combinator (code @var{m})',nil)}]]@code{_(@var{n}+1)}@end table@noindentHere, @code{@var{m}} is a numeric constant dependent on which tree@code{@var{f}} was used. The unsupported hook message is meant to bemore informative than the unrecognized combinator message, suggestingthat a feature intended for future use is not yet available.This list has been assembled for the benefit of readers considering theaddition of backward compatible extensions to the virtual codesemantics, who are undeterred by the facts that @itemize @bullet@item the computational model@cindex universalityis already universal@itemvirtual code applications are alreadyinteroperable with all kinds of high performance software having a textbased or console interface by way of the @code{interact} combinator@iteman unlimited number of built in library functions can be addedby way of the @code{library} combinator as described in@ref{Implementing new library functions}@itemthe C code in @code{avram} makes fairly@cindex pointersintricate use of pointers with a careful policy of reference countingand storage reclamation@itemthere is also a performance penalty incurred by@cindex reference countfurther extensions to the semantics, even for applications that don'tuse them, because a pattern recognition algorithm in the interpreter hasmore cases to consider.@end itemizeNevertheless, a new functional form combining a pair of functions to beinterpreted in a new way by the virtual machine could be defined usingany of the binary forms above, for example, with @code{@var{a}} as thevirtual code for one of the functions and @code{@var{b}} as that of theother. Such a form would not conflict with any existing applications,provided that both @code{@var{a}} and @code{@var{b}} are not @code{nil},which is true of any valid representation for a function.Virtual machine architects, take note. There are infinitely many trees@cindex treesfitting these patterns, but it would be possible to use them up byassigning them without adequate foresight. For example, ifinterpretations were assigned to the four ternary forms, the three binaryforms, and one of the remaining unary forms, then the onlyunassigned pattern could be of the form@display@code{((nil,nil),((nil,nil),(nil,(nil,(nil,@var{a})))))}@end display@noindentAssigning an interpretation to it would leave no further room forbackward compatible expansion. On the other hand, any tree of thefollowing form also fits the above pattern,@display@code{((nil,nil),((nil,nil),(nil,(nil,(nil,(@var{b},@var{c}))))))}@end display@noindentwith any values for @code{@var{b}} and @code{@var{c}}. Differentmeanings could be chosen for the case where both are @code{nil}, bothare non-@code{nil}, or one is @code{nil} and the other non-@code{nil},allowing two unary forms, one binary, and one constant. If at least oneof these patterns is reserved for future enhancements, then apotentially inexhaustible supply of address space remains and there willbe no need for incompatible changes later.@node Library Reference, Character Table, Virtual Machine Specification, Top@chapter Library ReferenceMuch of the code developed for @code{avram} may be reusable in otherprojects, so it has been packaged into a library and documented in thischapter. For ease of reference, this chapter is organized with aseparate section for each source file. For the most part, each sourcefile encapsulates an abstract type and a number of related functions,except for a few cases where C makes such a design awkward. An attempthas been made to present the sections in a readable order as far aspossible.The documentation in this chapter is confined to the application programinterface (API), and does not delve unnecessarily into any details of the@cindex APIimplementation. A reader wishing to extend, modify, or troubleshoot thelibrary itself can find additional information in the source codecomments. These are more likely to be in sync with the code than thisdocument may be, and are more readily accessible to someone working withthe code.Some general points pertaining to the library are the following.@itemize @bullet@item Unlike the previous chapter, this chapter uses the word``function'' in the C sense rather than the mathematical sense of the word.@item Internal errors are internal from the user's point of view, notthe developer's (@ref{Internal Errors}). Invoking these functions inways that are contrary to their specifications can certainly causeinternal errors (not to mention segfaults).@item The library is definitely not thread safe, and thread safety is@cindex threadsnot a planned enhancement. The amount of locking required to make itthread safe would probably incur an objectionable performance penaltydue to the complexity of the shared data structures involved, inaddition to being very difficult to get right. If you need thesefacilities in a concurrent application, consider spawning a process for@cindex spawning processeseach client of the library so as to keep their address spaces separate.@item The library files are built from the standard sourcedistribution using GNU @command{libtool}. In the default directoryhierarchy, they will be foundeither in @file{/usr/lib/libavram.*} or in @file{/usr/local/lib/libavram.*}.These directories will differ in a non-standard installation.@item The header files will probably belocated in either @file{/usr/include/avm/*.h} or@file{/usr/local/include/avm/*.h} for a standard installation.@item All exported functions, macros and constants arepreceded with @code{avm_}, so as to reduce the chance of name clasheswith other libraries. Not all type declarations or field identifiersfollow this convention, because that would be far too tedious.@item The library header files are designed to be compatible with C++@cindex C++but have been tested only with C. Please refer to platform specificdocumentation for further information on how to link library moduleswith your own code.@end itemize@menu* Lists::                       * Characters and Strings::      * File Manipulation::           * Invocation::                  * Version Management::          * Error Reporting::             * Profiling::                   * Emulation Primitives::        * External Library Maintenance::        @end menu@node Lists, Characters and Strings, Library Reference, Library Reference@section ListsThe basic data structure used for representing virtual code and data inthe @code{avram} library is declared as a @code{list}.@cindex lists@cindex @code{head} field@cindex @code{tail} fieldThe @code{list} type is a pointer to a structure having a @code{head}field and a @code{tail} field, which are also lists. The empty tree,@code{nil}, is represented by the C constant @code{NULL}. A tree of theform @code{cons(@var{a},@var{b})} is represented in C as a list whose@code{head} is the representation of @code{@var{a}} and whose@code{tail} is the representation of @code{@var{b}}.A number of other fields in the structure are maintained automaticallyand should not be touched. For that matter, even the @code{head} and@code{tail} fields should be considered read-only. Because of sharing,it is almost never valid to modify a list ``in place'', except for casesthat are already covered by library functions.@menu* Simple Operations::           * Recoverable Operations::      * List Transformations::        * Type Conversions::            * Comparison::      * Deconstruction Functions::    * Indirection::                 * The Universal Function::      @end menu@node Simple Operations, Recoverable Operations, Lists, Lists@subsection Simple OperationsThese functions are declared in the header file @code{lists.h}, whichshould be included in any C source file that uses them with a directivesuch as @code{@w{#include <avm/lists.h>}}. All of these functions exceptthe first three have the potential cause a memory overflow. In that@cindex overflowevent, a brief message is written to standard error and the process iskilled rather than returning to the caller. It is possible for clientprograms requiring more robust behavior to do their own error handlingby using the alternative versions of these operations described in thenext section.@deftypefun void avm_initialize_lists ()The function @code{avm_initialize_lists} should be called before any ofthe other ones in this section is called, because it sets up someinternal data structures. Otherwise, the behavior of the other functionsis undefined.@end deftypefun@deftypefun void avm_dispose (list @var{front})This function deallocates the memory associated with a given list,either by consigning it to a cache maintained internally by the library,or by the standard @code{free} function if the cache is full. Sharedlists are taken into account and handled properly according to areference counting scheme. Lists should be freed only by this function,not by using @code{free} directly.@end deftypefun@deftypefun void avm_count_lists ()If a client program aims to do its own storage reclamation, thisfunction can be called optionally at the end of a run when it isbelieved that all lists have been freed. If any allocated lists remainat large, a warning will be printed to standard error. This functiontherefore provides a useful check for memory leaks. Overhead is smallenough that it is not infeasible to leave this check in the productioncode.@end deftypefun@deftypefun list avm_copied (list @var{operand})A copy of the argument list is returned by this function. The copyremains intact after the original is reclaimed. A typical use might befor retaining part of a list after the rest of it is no longerneeded. In this example, a list @code{x} is traversed by a hypothetical@code{visit} function to each item, which is then immediately reclaimed.@examplewhile(x)@{   visit(x->head);   old_x = x;   x = avm_copied(x->tail);       /* the right way */   avm_dispose(old_x);@}@end exampleThis example allows each item in the list to be visited even aspreviously visited items are reclaimed, because @code{x} is copied ateach iteration. This example contrasts with the next one, which willprobably cause a segmentation fault.@cindex segmentation fault@examplewhile(x)@{   visit(x->head);   old_x = x;   x = x->tail;                   /* the wrong way */   avm_dispose(old_x);@}@end exampleIn the second example, a reference is made to a part of a list which nolonger exists because it has been deallocated.In fact, the @code{avm_copied} function does nothing but increment areference count, so it is a fast, constant time operation that requires@cindex reference countno additional memory allocation. Semantically this action is equivalentto creating a fresh copy of the list, because all list operations in thelibrary deal with reference counts properly.@end deftypefun@deftypefun list avm_join (list @var{left}, list @var{right})This function takes a pair of lists to a list in which the left is thehead and the right is the tail. It may need to use @code{malloc} toallocate additional memory. If there is insufficient memory, an errormessage is written to standard error and the program exits.When the list returned by @code{avm_join} is eventually deallocated, thelists from which it was built are taken with it and must not bereferenced again. For example, the following code is an error.@examplez = avm_join(x,y);@dots{}avm_dispose(z);avm_print_list(x);         /* error here */@end exampleTo accomplish something similar to this without an error, a copy of@code{x} should be made, as in the next example.@examplez = avm_join(avm_copied(x),y);@dots{}avm_dispose(z);avm_print_list(x);         /* original x still intact */@end example@end deftypefun@deftypefun void avm_enqueue (list *@var{front}, list *@var{back}, list @var{operand})@cindex queuesA fast simple way of building a list head first is provided by the@code{enqueue} function. The @code{front} is a pointer to the beginningof the list being built, and the @code{back} is a pointer to the lastitem. The recommended way to use it would be something like this.@examplefront = back = NULL;avm_enqueue(&front,&back,item);avm_enqueue(&front,&back,next_item);avm_enqueue(&front,&back,another_item);@dots{}@end exampleIt might be more typical for the calls to @code{avm_enqueue} to appearwithin a loop. In any case, after the above code is executed, thefollowing postconditions will hold.@examplefront->head == itemfront->tail->head == next_itemfront->tail->tail->head == another_itemback->head == another_itemback->tail == NULL@end exampleThe @code{avm_enqueue} function must never be used on a shared list, becauseit modifies its arguments in place. The only practical way to guaranteethat a list is not shared is to initialize the @code{front} and @code{back} to@code{NULL} as shown before the first call to @code{avm_enqueue}, and tomake no copies of @code{front} or @code{back} until after the last callto @code{avm_enqueue}.Because a list built with @code{avm_enqueue} is not shared, it is one of thefew instances of a list that can have something harmlessly appended toit in place. For example, if the next line of code were@exampleback->tail = rest_of_list;@end examplethat would be acceptable assuming @code{rest_of_list} is not shared anddoes not conceal a dangling or cyclic reference, and if nothing furtherwere enqueued.The items that are enqueued into a list are not copied and will bedeallocated when the list is deallocated, so they must not be referencedthereafter. A non-obvious violation of this convention is implicit inthe following code.@example@dots{}avm_enqueue(&front,&back,x->head);@dots{}avm_dispose(front);avm_print_list(x);      /* error here  */@end exampleThis code might cause a segmentation fault because of the reference to@cindex segmentation fault@code{x} after its head has been deallocated. The following code issubject to the same problem,@example@dots{}avm_enqueue(&front,&back,x->head);@dots{}avm_dispose(x);avm_print_list(front);       /* error here */@end exampleas is the following.@example@dots{}avm_enqueue(&front,&back,x->head);@dots{}avm_dispose(x);       /* front is now impossible to reclaim */avm_dispose(front);@end exampleThe problem with the last example is that it is not valid even todispose of the same list more than once, albeit indirectly.If part of a list is intended to be enqueued temporarily orindependently of its parent, the list should be copied explicitly, asthe following code demonstrates.@example@dots{}avm_enqueue(&front,&back,avm_copied(x->head));   /* correct */@dots{}avm_dispose(front);avm_print_list(x);@end example@end deftypefun@deftypefun counter avm_length (list @var{operand})A @code{counter} is meant to be the longest unsigned integer available@cindex @code{counter}on the host machine, and is defined in @code{common.h}, which isautomatically included whenever @code{lists.h} is included. The@code{avm_length} function returns the number of items in a list. If alist is @code{NULL}, a value of zero is returned. There is a possibilityof a counter overflow error from this function (@ref{Overflow Errors}),but only on a platform where the @code{counter} type is shorter than theaddress length.@end deftypefun@deftypefun counter avm_area (list @var{operand})This function is similar to @code{avm_length}, but it treats itsargument as a list of lists and returns the summation of their lengths.@end deftypefun@deftypefun list avm_natural (counter @var{number})@cindex naturalsThis function takes a @code{counter} to its representation as a list, asdescribed in @ref{Representation of Numeric and Textual Data}. That is,the number is represented as a list of bits, least significant bitfirst, with each zero bit represented by @code{NULL} and each one bitrepresented by a list whose @code{head} and @code{tail} are @code{NULL}.@end deftypefun@deftypefun void avm_print_list (list @var{operand})The @code{avm_print_list} function is not used in any production codebut retained in the library for debugging purposes. It prints a list to@cindex standard outputstandard output using an expression involving only commas and parentheses,as per the @code{silly} syntax (@ref{A Simple Lisp Like Language}). Theresults quickly become unintelligible for lists of any significant size.The function is recursively defined and will crash in the event of astack overflow, which will occur in the case of very large or cycliclists.@end deftypefun@deftypefun list avm_position (list @var{key}, list @var{table}, int *@var{fault})This function searches for a @var{key} in a short @var{table} whereeach item is a possible key.If it's not found, a @code{NULL} value is returned. If it'sfound, a list representing a character encoding according to@ref{Character Table} is returned. The ascii code of the character corresponding to the returned list isthe position of the @var{key} in the @var{table}, assuming positionnumbers start with 1. The table should have a length of 255 or less. If it's longer and the@var{key} is found beyond that range, the higher order bits of theposition number are ignored.The integer referenced by @var{fault} is set to a non-zero value inthe event of a memory overflow, which could happen in the course ofthe list comparisons necessary for the search.@end deftypefun@node Recoverable Operations, List Transformations, Simple Operations, Lists@subsection Recoverable OperationsThe functions in this section are similar to the ones in the previoussection except with regard to error handling. Whereas the other onescause an error message to be printed and the process to exit in theevent of an overflow, these return to the caller, whose responsibilityit is to take appropriate action. The functions in both sections aredeclared in @file{lists.h}, and should be preceded by a call to@code{avm_initialize_lists}.@deftypefun list avm_recoverable_join (list @var{left}, list @var{right})This function is similar to @code{avm_join}, but will return a@code{NULL} pointer if memory that was needed can not be allocated. A@code{NULL} pointer would never be the result of a join under normalcircumstances, so the overflow can be detected by the caller. Regardlessof whether overflow occurs, the arguments are deallocated by this functionand should not be referenced thereafter.@end deftypefun@deftypefun void avm_recoverable_enqueue (list *@var{front}, list *@var{back}, list @var{operand}, int *@var{fault})This version of the enqueue function will dispose of the @code{@var{operand}} if thereisn't room to append another item and set @code{*@var{fault}} to a non-zerovalue. Other than that, it does the same as @code{avm_enqueue}.@end deftypefun@deftypefun counter avm_recoverable_length (list @var{operand})This function checks for arithmetic overflow when calculating the lengthof a list, and returns a zero value if overflow occurs. The caller candetect the error by noting that zero is not the length of any list otherthan @code{NULL}. This kind of overflow is impossible unless the hostdoes not have long enough integers for its address space.@end deftypefun@deftypefun counter avm_recoverable_area (list @var{operand}, int *@var{fault})This function is similar to @code{avm_area}, except that it reactsdifferently to arithmetic overflow. The @code{fault} parameter should bethe address of an integer known to the caller, which will be set to anon-zero value if overflow occurs. In that event, the value of zero willalso be returned for the area. Note that it is possible for non-emptylists to have an area of zero, so this condition alone is not indicativeof an error.@end deftypefun@deftypefun list avm_recoverable_natural (counter @var{number})This function returns the @code{list} representation of a nativeunsigned long integer, provided that there is enough memory, similarly to the@code{avm_natural} function. Unlike that function, this one will returna value of @code{NULL} rather than exiting the program in the event of amemory overflow. The overflow can be detected by the caller insofar as a@code{NULL} @code{list} does not represent any number other than zero.@end deftypefun@node List Transformations, Type Conversions, Recoverable Operations, Lists@subsection List TransformationsSome functions declared in @file{listfuns.h} are used to implement theoperations described in @ref{List Functions}. These functions are ableto report error messages in the event of overflow or other exceptional@cindex overflow@cindex exceptions@cindex error messagesconditions, as described in @ref{Error Messages}. The error messages arerepresented as lists and returned to the caller. The occurrence of anerror can be detected by the @code{*@var{fault}} flag being set to anon-zero value. None of these functions ever causes a program exit exceptin the event of an internal error.@deftypefun void avm_initialize_listfuns ()This has to be called before any of the other functions in this sectionis called. It initializes the error message lists, among other things.@end deftypefun@deftypefun void avm_count_listfuns ()At the end of a run, a call to this function can verify that nounreclaimed storage attributable to these functions persists. If itdoes, a warning is printed to standard error. If @code{avm_count_lists}is also used, it must be called after this function.@end deftypefun@deftypefun list avm_reversal (list @var{operand}, int *@var{fault})The reversal of the list is returned by this function if no overflowoccurs. A non-zero @code{*@var{fault}} and an error message are returnedotherwise. The original @code{@var{operand}} still exists in its originalorder after this function is called. The amount of additional storageallocated is proportional only to the length of the list, not the sizeof its contents.@end deftypefun@deftypefun list avm_distribution (list @var{operand}, int *@var{fault})This function performs the operation described in @ref{Distribute}. Theinvalid distribution message is returned in the event of a @code{NULL}operand. Otherwise, the returned value is the distributed list. In any event,the @code{@var{operand}} is unaffected.@end deftypefun@deftypefun list avm_concatenation (list @var{operand}, int *@var{fault})@cindex concatenationThe @code{@var{operand}} is treated as a pair of lists to be concatenated, with theleft one in the @code{head} field and the right one in the @code{tail}field. The invalid concatenation message is returned in the event of a@code{NULL} @code{@var{operand}}. The result returned otherwise is the concatenationof the lists, but the given @code{@var{operand}} still exists unchanged.@end deftypefun@deftypefun list avm_transposition (list @var{operand}, int *@var{fault})The operation performed by this function corresponds to that of@ref{Transpose}. Unlike other functions in this section, the operandpassed to this function is deallocated, and must not be referenced@cindex @code{transpose}thereafter. The transposed list is accessible as the returned value ofthis function. If the original @code{@var{operand}} is still neededafter a call to @code{avm_transposition}, only a copy of it should bepassed to it, obtained from @code{avm_copied}. The invalid transposeerror message is the result if the operand does not represent a list of equallength lists.@end deftypefun@deftypefun list avm_membership (list @var{operand}, int *@var{fault})This function computes the membership predicate described in@cindex @code{member}@ref{Member}. The operand is a list in which the @code{tail} field isa list that will be searched for the item in the @code{head}. If theitem is not found, a @code{NULL} list is returned, but otherwise a listwith @code{NULL} @code{head} and @code{tail} fields is returned. If theoperand is @code{NULL}, an error message of invalid membership isreturned and @code{*@var{fault}} is set to a non-zero value.The @code{avm_membership} function calls @code{avm_binary_comparison}in order to compare lists, so the same efficiency and side-effectconsiderations are relevant to both (@ref{Comparison}). It is notnecessary to @code{#include} the header file @code{compare.h} or tocall @code{avm_initialize_compare} in order to use@code{avm_membership}, because they will be done automatically.@end deftypefun@deftypefun list avm_binary_membership (list @var{operand}, list @var{members}, int *@var{fault});This function is the same as @code{avm_membership} except that itallows the element and the set of members to be passed as separatelists instead of being the head and the tail of the same list.@end deftypefun@deftypefun list avm_measurement (list @var{operand}, int *@var{fault})This function implements the operation described in @ref{Weight}, whichpertains to the weight of a tree. The returned value of this function isa list encoding the weight as a binary number, unless a counter overflowoccurs, in which case it's an error message. As noted previously, theweight of a tree can easily be exponentially larger than the amount of@cindex native integer arithmeticmemory it occupies, but this function uses native integer arithmetic forperformance reasons. Hence, a counter overflow is a realpossibility.@end deftypefun@node Type Conversions, Comparison, List Transformations, Lists@subsection Type ConversionsExternal library functions accessed by the @code{library} combinatoras explained in @ref{Library combinator} may operate on data otherthan the @code{list} type usually used by @code{avram}, such asfloating point numbers and arrays, but a virtual code application mustbe able to represent the arguments and results of these functions inorder to use them. As a matter of convention, a data structureoccupying @var{size} bytes of contiguous storage on the host machineappears as a list of length @var{size} to a virtual code application,in which each item corresponds to a byte, and is represented accordingto @ref{Character Table}.In principle, a virtual code application invoking a library functionto operate on a contiguous block of data, such as an IEEE doubleprecision number, for example, would construct a list of eightcharacter representations (one for each byte in a double precisionnumber), and pass this list as an argument to the libraryfunction. The virtual machine would transparently convert thisrepresentation to the native floating point format, evaluate thefunction, and convert the result back to a list.  In practice, highlevel language features beyond the scope of this document wouldinsulate the programmer from some of the details on the applicationside as well.To save the time of repeatedly converting between the listrepresentation and the contiguous native binary representation, thestructure referenced by a @code{list} pointer contains a @code{value}@cindex value fieldfield which is a @code{void} pointer to a block of memory ofunspecified type, and serves as a persistent cache of the valuerepresented by the list. This field normally should be managed by theAPI rather than being accessed directly by client modules, but see thecode in @file{mpfr.c} for an example of a situation in which it'sappropriate to break this rule. (Generally these situations involvelibrary functions operating on non-contiguous data.)@menu* Primitive types::* One dimensional arrays::* Two dimensional arrays::* Related utility functions::@end menu@node Primitive types, One dimensional arrays, Type Conversions, Type Conversions@subsubsection Primitive typesA pair of functions in support of this abstraction is prototyped in@file{listfuns.h}.  These functions will be of interest mainly todevelopers wishing to implement an interface to a new library moduleand make it accessible on the virtual side by way of the@code{library} combinator (@ref{Library combinator}).@deftypefun void *avm_value_of_list (list @var{operand}, list *@var{message}, int *@var{fault})This function takes an @var{operand} representing a value used by alibrary function in the format described above (@ref{TypeConversions}) and returns a pointer to the value.The @code{value} field in the @var{operand} normally will point to theblock of memory holding the value, and the @var{operand} itself willbe a list of character representations whose binary encodings spellout the value as explained above.The @code{value} field need not be initialized on entry but it will beinitialized as a side effect of being computed by this function. If ithas been initialized due to a previous call with the same@var{operand}, this function is a fast constant time operation.The caller should not free the pointer returned by this functionbecause a reference to its value will remain in the@var{operand}. When the @var{operand} itself is freed by@code{avm_dispose} (@ref{Simple Operations}), the value will go with it.If an error occurs during the evaluation of this function, the integerreferenced by @var{fault} will be set to a non-zero value, and thelist referenced by @var{message} will be assigned a representation ofa list of strings describing the error. The @var{message} is freshlycreated and should be freed by the caller with @code{avm_dispose}when no longer needed.Possible error messages are @code{<'missing value'>}, in the case of@cindex missing valuean empty @var{operand}, @code{<'invalid value'>} in the case of an@cindex invalid value@var{operand} that is not a list of character representations, and@code{<'memory overflow'>} if there was insufficient space to allocatethe result.@end deftypefun @deftypefun list avm_list_of_value (void *@var{contents}, size_t @var{size}, int *@var{fault})This function performs the inverse operation of@code{avm_value_of_list}, taking the address of an area ofcontiguously stored data and its @var{size} in bytes to a listrepresentation. The length of the list returned is equal to the numberof bytes of data, @var{size}, and each item of the list is a characterrepresentation for the corresponding byte as given by @ref{CharacterTable}.A copy of the memory area is made so that the original is no longerneeded and may be freed by the caller. A pointer to this copy isreturned by subsequent calls to @code{avm_value_of_list} when theresult returned by this function is used as the @var{operand}parameter.If there is insufficient memory to allocate the result, the integerreferenced by @var{fault} is set to a non-zero value, and a copy ofthe message @code{<'memory overflow'>} represented as a list isreturned. This function could also cause a segmentation fault if it is@cindex segmentation faultpassed an invalid pointer or a @var{size} that overruns the storagearea.  However, it is acceptable to specify a @var{size} that is lessthan the actual size of the given memory area to construct a listrepresenting only the first part of it. The @var{size} must always begreater than zero.@end deftypefun @node One dimensional arrays, Two dimensional arrays, Primitive types, Type Conversions@subsubsection One dimensional arraysA couple of functions declared in @file{matcon.h} are concerned mainlywith one dimensional arrays or vectors. They have been used for@cindex arraysvectors of double precision and complex numbers, but are applicable to@cindex vectorsany base type that is contiguous and of a fixed size.The motivation for these functions is to enable a developer to presentan API to virtual code applications wherein external library functionsoperating natively on one dimensional arrays of numbers are seen fromthe virtual side to operate on lists of numbers. Lists are thepreferred container for interoperability with virtual codeapplications.@deftypefun void *avm_vector_of_list (list @var{operand}, size_t @var{item_size}, list *@var{message}, int *@var{fault})This function calls @code{avm_value_of_list} (@ref{Primitive types})for each item of the @var{operand} and puts all the values togetherinto one contiguous block, whose address is returned.The given @var{item_size} is required to be the lengths of the items,all necessarily equal, and is required only for validation. Forexample, @var{item_size} is 8 for a list of double precision numbers,because they occupy 8 bytes each and are represented as lists of length 8.The total number of bytes allocated is the product of @var{item_size}and the length of the @var{operand}. Unlike the case of@code{avm_value_of_list} (@ref{Primitive types}), the result returnedby this function should be explicitly freed by the caller when nolonger needed.Any errors such as insufficient memory cause the integer referenced by@var{fault} to be assigned a non-zero value and the @var{message} tobe assigned an error message represented as a list of strings. Anerror message of @code{<'bad vector specification'>} is possible inthe case of an empty @var{operand} or one whose item lengths don'tmatch the given @var{item_size}. Error messages caused by@code{avm_value_of_list} can also be generated by this function. Anynon-empty error message should be reclaimed by the caller using@code{avm_dispose} (@ref{Simple Operations}). If an error occurs, a@code{NULL} pointer is returned.@end deftypefun @deftypefun list avm_list_of_vector (void *@var{vector}, int @var{num_items}, size_t @var{item_size}, int *@var{fault})This function takes it on faith that an array of dimension@var{num_items} in which each item occupies @var{item_size} bytesbegins at the address given by @var{vector}. A list representation ofeach item in the array is constructed by the function@code{avm_list_of_value} (@ref{Primitive types}), and a list of all ofthe lists thus obtained in order of their position in the array isreturned.In the event of any errors caused by @code{avm_list_of_value} orerrors due to insufficient memory, the error message is returned asthe function result, and the integer referenced by @var{fault} isassigned a non-zero value. The error message is in the form of a listof character string representations. A segmentation fault is possible@cindex segmentation faultif @var{vector} is not a valid pointer or if the array size implied bymisspecified values of @var{num_items} and @var{item_size}exceeds its actual size.@end deftypefun@node Two dimensional arrays, Related utility functions, One dimensional arrays, Type Conversions@subsubsection Two dimensional arraysSeveral other functions in @file{matcon.h} are meant to supportconversions between matrices represented as lists of lists and arraysin a variety of representations. Dense matrices either square or@cindex matricesrectangular are accommodated, and symmetric square matrices can bestored with redundant entries omitted in either upper trangular orlower triangular format.Similarly to the vector operations (@ref{One dimensional arrays})these functions are intended to allow a developer to present aninterface to external libraries based on lists rather than arrays.The preferred convention for virtual code applications is to representa matrix as a list of lists of entities (typically numbers), withone list for each row of the matrix. For example, a 3 by 3 matrixcontaining a value of @code{aij} in the @code{i}-th row and the@code{j}-th column would be represented by this list of three lists.@example<   <a11,a12,a13>,   <a21,a22,a23>,   <a31,a32,a33>>@end example@noindentSuch a representation is convenient for manipulation byvirtual machine combinators, for example @code{transpose}(@ref{Transpose}), and is readily identified with the matrixit represents.If a matrix is symmetric (that is, with @code{aij} equal to@code{aji} for all values of @code{i} and @code{j}), only the lowertriangular portion needs to be stored because the other entries are@cindex triangular matrixredundant.  The list representatation would be something like this.@example<   <a11>,   <a21,a22>,   <a31,a32,a33>>@end exampleAnother alternative for representing a symmetric matrix is to store only theupper triangular portion. In this case, a list such as the following would be used.@example<   <a11,a12,a13>,   <a22,a23>,   <a33>>@end example@noindentThe upper and lower triangular representations are distinguishable bywhether or not the row lengths form an increasing sequence.In addition to representing symmetric matrices, these upper and lower@cindex symmetric matrixtriangular forms are also appropriate for representing matrices whoseremaining entries are zero, such as the factors in an LUdecomposition.@cindex LU decomposition@deftypefun void *avm_matrix_of_list (int @var{square}, int @var{upper_triangular}, int @var{lower_triangular}, int @var{column_major}, list @var{operand}, size_t @var{item_size}, list *@var{message}, int *@var{fault})This function converts a matrix in one of the list representationsabove to a contiguous array according to the given specifications.The array can contain elements of any fixed sized type of size@var{item_size}. The memory for it is allocated by this function andit should be freed by the caller when no longer needed.The input matrix is given by the list parameter, @var{operand}, andits format is described by the integer parameters @var{square},@var{upper_triangular}, and @var{lower_triangular}. The number ofbytes occupied by each entry is given by @var{item_size}. To the extent these specifications are redundant, they are used forvalidation. If any of the following conditions is not met, the integerreferenced by @var{fault} is assigned a non-zero value and a copyof the message @code{<'bad matrix specification'>} represented asa list is assigned to the list referenced by @var{message}. Errorsare also possible due to insufficient memory.@itemize @bullet@itemThe @var{operand} must be a list of lists of lists such that each item of each item is has a length of @var{item_size},and its items consist of character representations asrequired by @code{avm_value_of_list} (@ref{Primitive types}).@itemIf the lengths of the top level lists in the @var{operand} form anincreasing sequence, the lower triangular representation is assumedand the @var{lower_triangular} parameter must have a non-zero value.@item If the lengths of the top level lists in the @var{operand} form adecreasing sequence, the upper triangular representation is assumedand the @var{upper_triangular} parameter must have a non-zero value.@itemAt least one of @var{upper_triangular} or @var{lower_triangular} mustbe zero.@itemIf @var{square} has a non-zero value, then either all items of the@var{operand} must have the same length as the operand, or if it'striangular, then the longest one must have the same length as theoperand.@itemIf the @var{operand} is neither square nor a triangular form, allitems of it are required to have the same length.@end itemizeThe parameters @var{upper_triangular} or @var{lower_triangular} may beset to non-zero values even if the @var{operand} is not in one of theupper or lower triangular forms discussed above. In this case, the@var{operand} must be square or rectangular (i.e., with all items thesame length), and the following interpretations apply.@itemize @bullet@itemIf @var{upper_triangular} is non-zero, the diagonal elements and theupper triangular portion of the input matrix are copied to the output.The lower triangle of the input is ignored and the lower triangle ofthe output is left uninitialized.@itemIf @var{lower_triangular} is non-zero, the diagonal elements and thelower triangular portion of the input matrix are copied to the output.The upper triangle of the input is ignored and the upper triangle ofthe output is left uninitialized.@end itemizeThe @var{column_major} parameter affects the form of the output array.If it is zero, then each row of the input matrix is stored in acontiguous block of memory in the output array, and if it is non-zero,each column is stored contiguously. @cindex FortranThe latter representation is alsoknown as Fortran order and may be required by library functionswritten in Fortran.In all cases when a triangular form is specified, part of the outputmatrix is left uninitialized. The redundant entries may be assigned ifrequired by the @code{avm_reflect_matrix} function (@ref{Relatedutility functions}).@end deftypefun@deftypefun list avm_list_of_matrix (void *@var{matrix}, int @var{rows}, int @var{cols}, size_t @var{item_size}, int *@var{fault})This function performs an inverse operation to@code{avm_matrix_of_list} by taking the address of a matrix stored asa contiguous array in the parameter @var{matrix} and constructing thelist representation as discussed above. Only square and rectangularmatrices in row major order are supported, but see@code{avm_matrix_transposition} for a way to convert between row major@cindex column major orderand column major order (@ref{Related utility functions}).The parameters @var{rows}, @var{cols}, and @var{item_size} describethe form of the matrix. The list returned as a result will have alength of @var{rows}, and each item will be a list of length@var{cols}. Each item of the result corresponds to a row of thematrix, and each item of the items represents the an entry of thematrix as a list of length @var{item_size}. These items could bepassed to @code{avm_value_of_list}, for example, to obtain theirvalues (@ref{Primitive types}).Memory is allocated by this function to create the list, which can bereclaimed by @code{avm_dispose} (@ref{Simple Operations}). If there isinsufficient memory, the integer referenced by @var{fault} is assigneda non-zero value and the result returned is a list representation ofthe message @code{<'memory overflow'>}. The error message be reclaimedby the caller as well using @code{avm_dispose}.@end deftypefun A packed storage representation for symmetric square matrices and@cindex packed arraystriangular matrices is of interest because it is used by some libraryfunctions, notably those in @code{LAPACK}, to save memory and therebyaccommodate larger problems. In this representation, column major@cindex column major orderorder is assumed, and either the lower or the upper triangle of thematrix is not explicitly stored. For example, a lower triangular@cindex triangular matrixmatrix whose list representation corresponds to@example<   <a11>,   <a21,a22>,   <a31,a32,a33>,   <a41,a42,a43,a44>>@end example@noindentwould be stored according to the memory map@cindex matrix memory map@example[a11 a21 a31 a41 a22 a32 a42 a33 a43 a44]@end example@noindentwith @code{a11} at the beginning address. An upper triangular matrix@example<   <a11,a12,a13,a14>,   <a22,a23,a24>,   <a33,a34>,   <a44>>@end example@noindentwould be stored according to the memory map@example[a11 a12 a22 a13 a23 a33 a14 a24 a34 a44].@end exampleA couple of functions converting between list representations andpacked array format are provided as described below.@deftypefun void *avm_packed_matrix_of_list (int @var{upper_triangular}, list @var{operand}, int @var{n}, size_t @var{item_size}, list *@var{message}, int *@var{fault})If the @var{operand} is a list in one of the triangular formsexplained above, then the @var{upper_triangular} parameter must beconsisitent with it, being non-zero if the @var{operand} is uppertriangular and zero otherwise.If the @var{operand} is not in a triangular form, then each item ofthe operand must be a list of length @var{n}. In this case, the@var{upper_triangular} parameter indicates which triangle of theoperand should be copied to the result, and the other triangle isignored.In either case, the operand must have a length of @var{n}, and theitems of its items must be lists of length @var{item_size} containingcharacter representations as required by @code{avm_value_of_list}(@ref{Primitive types}).If the input parameters are inconsistent or if there is insufficientmemory to allocate the result, the integer referenced by @var{fault}is assigned a non-zero value, and the list referenced by @var{message}is assigned a copy of the list representation of @code{<'bad matrixspecification'>} or @code{<'memory overflow'>}, respectively. Anon-empty message must be reclaimed by the caller using@code{avm_dispose} (@ref{Simple Operations}).If there are no errors, the result is a pointer to a packed arrayrepresentation of the @var{operand} as explained above. The memory forthis result is allocated by this function and should be freed by thecaller when no longer required. The number of bytes allocated will be@var{item_size} * (@var{n} * (@var{n} + 1))/2.@end deftypefun@deftypefun list avm_list_of_packed_matrix (int @var{upper_trianguler},void *@var{operand}, int @var{n}, size_t @var{item_size}, int *@var{fault})This function performs an inverse operation to that of@code{avm_packed_matrix_of_list} given the address of a packed matrixstored according to one of the memory maps discussed above. The@var{operand} parameter holds the address, the parameter @var{n} givesthe number of rows, and the @var{upper_triangular} parameter specifieswhich of the two possible memory maps to assume.If there is sufficient memory, the result returned is a list in one ofthe triangular forms described above, being upper triangular if the@var{upper_triangular} parameter is non-zero, with values of length@var{item_size} taken from the array.In the event of a memory overflow, the integer referenced by@var{fault} is assigned a non-zero value and the result is a copy ofthe message @code{<'memory overflow'>} represented as a list. A@cindex segmentation faultsegmentation fault is possible if this function is passed an invalidpointer or dimension.@end deftypefun @node Related utility functions, , Two dimensional arrays, Type Conversions@subsubsection Related utility functionsA small selection of additional functions that are likely to be of useto developers concerned with matrix operations has been incorporatedinto the API to save the trouble of reinventing them, although doingso would be straightforward. They are described in this sectionwithout further motivation.@deftypefun void *avm_matrix_transposition  (void *@var{matrix}, int @var{rows}, int @var{cols}, size_t @var{item_size})This function takes the address of an arbitrary rectangular@var{matrix} represented as a contiguous array (not a list) andtransposes it in place. That is, this function transformsan @var{m} by @var{n} matrix to an @var{n} by @var{m} matrixby exchanging the @var{i},@var{j}th element with the@var{j},@var{i}th element for all values of @var{i} and @var{j}.The numbers of rows and columns in the @var{matrix} are given by theparameters @var{rows} and @var{cols}, respectively, and the size ofthe entries in bytes is given by @var{item_size}.The @var{matrix} is assumed to be in row major order, but thisfunction is applicable to matrices in column major order if the caller@cindex column major orderpasses the number of columns in @var{rows} and the number of rows in@var{cols}.Alternatively, this function can be seen as a conversion between therow major and the column major representation of a matrix. An @var{m}by @var{n} matrix in row major order will be transformed to the same@var{m} by @var{n} matrix in column order, or from column order to roworder.A notable feature of this function is that it allocates no memory sothere is no possibility of a memory overflow even for very largematrices, unlike a naive implementation which would involve making atemporary copy of the matrix. There is a possibility of a segmentation@cindex segmentation faultfault if invalid pointers or dimensions are given.@end deftypefun @deftypefun void *avm_matrix_reflection (int @var{upper_triangular}, void *@var{matrix}, int @var{n}, size_t @var{item_size})This function takes a symmetric square @var{matrix} of dimension@var{n} containing entries of @var{item_size} bytes each and fills inthe redundant entries.If @var{upper_triangular} is non-zero, theupper triangle of the @var{matrix} is copied to the lower triangle. If@var{upper_triangular} is zero, the lower triangular entries arecopied to the upper triangle.These conventions assume row major order. If the @var{matrix} is in@cindex row major ordercolumn major order, then the caller can either transpose it in place@cindex column major orderbefore and after this function by @code{avm_matrix_transposition}, orcan complement the value of @var{upper_triangular}.Note that this function may be unnecessary for @code{LAPACK} libraryfunctions that ignore the redundant entries in a symmetric matrix,because they can be left uninitialized, but it is included for thesake of completeness.@end deftypefun @deftypefun list *avm_row_number_array (counter @var{m}, int *@var{fault})A fast, memory efficient finite map from natural numbers to their listrepresentations can be obtained by using this function as analternative to @code{avm_natural} or @code{avm_recoverable_natural}when repeated evaluations of numbers within a known range arerequired (@ref{Simple Operations} and @ref{Recoverable Operations}).Given a positive integer @var{m}, this function allocates and returnsan array of @var{m} lists whose @var{i}th entry is the listrepresentation of the number @var{i} as explained in@ref{Representation of Numeric and Textual Data}.An amount of memory proportional to @var{m} is used for the array andits contents. If there is insufficient memory, a @code{NULL} value isreturned and the integer referenced by @var{fault} is set to anon-zero value.@end deftypefun @deftypefun void avm_dispose_rows (counter @var{m}, list *@var{row_number})This function reclaims an array @var{row_number} of size @var{m}returned by @code{avm_row_number_array}, and its contents if any. A@code{NULL} pointer is allowed as the @var{row_number} parameter andwill have no effect, but an uninitialized pointer will cause a@cindex segmentation faultsegmentation fault.@end deftypefun @deftypefun void avm_initialize_matcon ();This function initializes some static variables used by the functionsdeclared in @file{matcon.h} and should be called before any of them iscalled or they might not perform according to specifications.@end deftypefun @deftypefun void avm_count_matcon ();This function frees the static variables allocated by@code{avm_initialize_matcon} and is used to verify the absence ofmemory leaks. It should be called after the last call to any functionsin @file{matcon.h} but before @code{avm_count_lists} if the latteris being used (@ref{Simple Operations}).@end deftypefun @node Comparison, Deconstruction Functions, Type Conversions, Lists@subsection ComparisonThe file @file{compare.h} contains a few function declarationspertaining to the computation of the comparison predicate described in@ref{Compare}. Some of the work is done by static functions in@file{compare.c} that are not recommended entry points to the library.@deftypefun void avm_initialize_compare ()@cindex @code{compare}This function should be called once before the first call to@code{avm_comparison}, as it initializes some necessary internal datastructures.@end deftypefun@deftypefun void avm_count_compare ()This function can be used to check for memory leaks, by detectingunreclaimed storage at the end of a run. The data structures relevant tocomparison that could be reported as unreclaimed are known as ``decision''nodes, but these should always be handled properly by the librarywithout intervention. If @code{avm_count_lists} is also being used, thecall to this function must precede it.@end deftypefun@deftypefun list avm_comparison (list @var{operand}, int *@var{fault})This function takes a list operand representing a pair of trees andreturns a list representing the logical value of their equality. If theoperand is @code{NULL}, a message of invalid comparison is returned andthe @code{*@var{fault}} is set to a non-zero value. If the @code{head} of theoperand is unequal to the @code{tail}, a @code{NULL} value isreturned. If they are equal, a list is returned whose @code{head} and@code{tail} are both @code{NULL}. The equality in question is structural@cindex pointer equalityrather than pointer equality.The list operand to this function may be modified by this function, butnot in a way that should make any difference to a client program. If twolists are found to be equal, or if even two sublists are found to beequal in the course of the comparison, one of them is deallocated andmade to point to the other. This action saves memory and may makesubsequent comparisons faster. However, it could disrupt client programs@cindex pointersthat happen to be holding stale list pointers.@cindex discontiguous fieldAs of @code{avram} version 0.6.0, a logical field called@code{discontiguous} has been added to the @code{node} record typedeclared in @code{lists.h}, which is checked by the comparisonfunction. If a list node has its @code{discontiguous} field set to anon-zero value, and if it also has a non-null @code{value} field, thenit won't be deallocated in the course of comparison even if it isfound to be equal to something else. This feature can be used byclient modules to create lists in which value fields refer to datastructures that are meant to exist independently of them. See@file{mpfr.c} for an example.This function is likely to have better performance and memory usage thana naive implementation of comparison, for the above reasons and alsobecause of optimizations pertaining to comparison of lists representingcharacters. Moreover, it is not subject to stack overflow exceptions@cindex recursionbecause it is not written in a recursive style.@end deftypefun@deftypefun list avm_binary_comparison (list @var{left_operand}, list @var{right_operand}, int *@var{fault});This function is the same as @code{avm_comparison} except that itallows the left and right operands to be passed as separate listsrather than taking them from the @code{head} and the @code{tail} of asingle list.@end deftypefun@node Deconstruction Functions, Indirection, Comparison, Lists@subsection Deconstruction FunctionsA fast native implementation of the deconstruction operation is provided@cindex deconstructionby the functions declared in @file{decons.h}.@deftypefun void avm_initialize_decons ()This should be called prior to the first call to@code{avm_deconstruction}, so as to initialize some necessary internaldata structures. Results will be undefined if it is not.@end deftypefun@deftypefun void avm_count_decons ()For ecologically sound memory management, this function should be calledat the end of a run to verify that there have been no leaks due to thedeconstruction functions, which there won't be unless the code in@file{decons.c} has been ineptly modified. An error message to theeffect of unreclaimed ``points'' could be the result otherwise.@end deftypefun@deftypefun list avm_deconstruction (list @var{pointer}, list @var{operand}, int *@var{fault})Deconstructions are performed by this function, as described in@ref{Field}. In the @code{silly} program notation (@ref{A Simple LispLike Language}), this function computes the valueof ([[@code{field}]] @code{@var{pointer}}) @code{@var{operand}}.For example, using the fixed list @code{avm_join(NULL,NULL)} as the@code{@var{pointer}} parameter will cause a copy of the operand itselfto be returned as the result. A @code{@var{pointer}} equal to@code{avm_join(NULL,avm_join(NULL,NULL))} will cause a copy of@code{operand->tail} to be returned, and so on. A @code{NULL}@code{@var{pointer}} causes an internal error.If the deconstruction is invalid, as in the case of the tail of an emptylist, the invalid deconstruction error message is returned as theresult, and the @code{*@var{fault}} parameter is set to a non-zero value.The @code{*@var{fault}} parameter is also set to a non-zero value in the eventof a memory overflow, and the memory overflow message is returned.@end deftypefun@node Indirection, The Universal Function, Deconstruction Functions, Lists@subsection IndirectionIn some cases it is necessary to build a tree from the top down rather@cindex pointersthan from the bottom up, when it is not known in advance what's on thebottom. Although the @code{list} type is a pointer itself, thesesituations call for a type of pointers to lists, which are declared asthe @code{branch} type in @file{branches.h}. For example, if @code{b} isdeclared as a @code{branch} and @code{l} is declared as a @code{list},it would be possible to write @code{b = &l}.Facilities are also provided for maintaining queues of branches, which@cindex queuesare declared as the @code{branch_queue} type. This type is a pointer toa structure with two fields, @code{above} and @code{following}, where@code{above} is a @code{branch} and @code{following} is a@code{branch_queue}.These functions are used internally elsewhere in the library and mightnot be necessary for most client programs to use directly.@deftypefun void avm_initialize_branches ()This must be done once before any of the other branch related functions isused, and creates some internal data structures. Results of the otherfunctions are undefined if this one isn't called first.@end deftypefun@deftypefun void avm_count_branches ()This function can be used at the end of a run to detect unreclaimedstorage used for branches or branch queues. If any storage remainsunreclaimed, a message about unreclaimed branches is written to standarderror.@end deftypefun@deftypefun void avm_anticipate (branch_queue *@var{front}, branch_queue *@var{back}, branch @var{operand})This function provides a simple queueing facility forbranches. Similarly to the case with @code{avm_enqueue}, @code{front}and @code{back} should be initialized to @code{NULL} before the firstcall. Each call to this function will enqueue one item to the back,assuming enough memory is available, as the following example shows.@examplefront = NULL;back = NULL;l = avm_join(NULL,NULL);anticipate(&front,&back,&(l->head));anticipate(&front,&back,&(l->tail));@end exampleAfter the above code is executed, these postconditions will hold.@examplefront->above == &(l->head)front->following->above == &(l->tail)front->following == backback->following == NULL@end exampleThe name ``anticipate'' is used because ordinarily the queue containspositions in a tree to be filled in later. As usual, only unshared trees should bemodified in place.@end deftypefun@deftypefun void avm_recoverable_anticipate (branch_queue *@var{front}, branch_queue *@var{back}, branch @var{operand}, int *@var{fault})This function is similar to @code{avm_anticipate}, except that it willnot exit with an error message in the event of an overflow error, butwill simply set @code{*@var{fault}} to a non-zero value and return to thecaller. If an overflow occurs, nothing about the queue is changed.@end deftypefun@deftypefun void avm_enqueue_branch (branch_queue *@var{front}, branch_queue *@var{back}, int @var{received_bit})A slightly higher level interface to the @code{avm_anticipate} functionis provided by this function, which is useful for building a tree from@cindex treesa string of input bits in a format similar to the one described in@ref{Concrete Syntax}.This function should be called the first time with @code{front} and@code{back} having been initialized to represent a queue containing a@cindex queuessingle branch pointing to a list known to the caller. The list itselfneed not be allocated or initialized. An easy way of doing so would bethe following.@examplefront = NULL;back = NULL;avm_anticipate(&front,&back,&my_list);@end exampleOn each call to @code{avm_enqueue_branch}, the @code{@var{received_bit}}parameter is examined. If it is zero, nothing will be added to thequeue, the list referenced by the front branch will be assigned@code{NULL}, and the front branch will be removed from the queue. If@code{@var{received_bit}} is a non-zero value, the list referenced bythe front branch will be assigned to point to a newly created unsharedlist node, and two more branches will be appended to the queue. Thefirst branch to be appended will point to the head of the newly createdlist node, and the second branch to be appended will point to the tail.If the sequence of bits conforms to the required concrete syntax, thisfunction can be called for each of them in turn, and at the end of thesequence, the queue will be empty and the list referenced by the initialbranch (i.e., @code{my_list}) will be the one specified by the bitstring. If the sequence of bits does not conform to the requiredconcrete syntax, the error can be detected insofar as the emptying ofthe queue will not coincide exactly with the last bit.The caller should check for the queue becoming prematurely empty due tosyntax errors, because no message is reported by@code{avm_enqueue_branch} in that event, and subsequent attempts toenqueue anything are ignored. However, in the event of a memory overflow, an error message is reported and the process is terminated.@end deftypefun@deftypefun void avm_recoverable_enqueue_branch (branch_queue *@var{front}, branch_queue *@var{back}, int @var{received_bit}, int *@var{fault})This function is similar to @code{avm_enqueue_branch} but will leaveerror handling to the caller in the event of insufficient memory toenqueue another branch. Instead of printing an error message andexiting, it will dispose of the queue, set the @code{@var{fault}} flagto a non-zero value, and return. Although the queue will be reclaimed,the lists referenced by the branches in it will persist. The list nodesthemselves can be reclaimed by disposing of the list whose address wasstored originally in the front branch.@end deftypefun@deftypefun void avm_dispose_branch_queue (branch_queue @var{front})This function deallocates a branch queue by chasing the @code{following}fields in each one. It does nothing to the lists referenced by thebranches in the queue.Rather than using @code{free} directly, client programs should use thisfunction for deallocating branch queues, because it allows betterperformance by interacting with a local internal cache of free memory,and because it performs necessary bookkeeping for@code{avm_count_branches}.@end deftypefun@deftypefun void avm_dispose_branch (branch_queue @var{old})This disposes of a single branch queue node rather than a whole queue.Otherwise, the same comments as those above apply.@end deftypefun@node The Universal Function, , Indirection, Lists@subsection The Universal Function@cindex universal functionA function computing the result of the invisible operator used tospecify the virtual code semantics in @ref{Virtual Code Semantics}, iseasily available by way of a declaration in @file{apply.h}.@deftypefun void avm_initialize_apply ()This function should be called by the client program at least once priorto the first call to @code{avm_apply} or@code{avm_recoverable_apply}. It causes certain internal data structuresand error message texts to be initialized.@end deftypefun@deftypefun void avm_count_apply ()This function should be used at the end of a run for the purpose ofdetecting and reporting any unreclaimed storage associated withfunctions in this section. If the function @code{avm_count_lists()} isalso being used, it should be called after this one.@end deftypefun@deftypefun list avm_apply (list @var{operator}, list @var{operand})This is the function that evaluates the operator used to describe thevirtual code semantics. For example, the value of @code{@var{f} @var{x}}can be obtained as the result returned by@code{avm_apply(@var{f},@var{x})}. Both parameters to this function are deallocated unconditionally andshould not be referenced again by the caller. If the parameters areneeded subsequently, then only copies of them should be passed to@code{avm_apply} using @code{avm_copied}.This function is not guaranteed to terminate, and may cause a memoryoverflow error. In the event of an exceptional condition, the errormessage is written to standard error and the program is halted. There isno externally visible distinction between different levels of errorconditions.@end deftypefun@deftypefun list avm_recoverable_apply (list @var{operator}, list @var{operand}, int *@var{fault})This function is similar to @code{avm_apply} but leaves theresponsibility of error handling with the caller. If anyoverflow or exceptional condition occurs, the result returned is a listrepresenting the error message, and the @code{@var{fault}} flag is set toa non-zero value. This behavior contrasts with that of @code{avm_apply},which will display the message to standard error and kill the process.@end deftypefun@node Characters and Strings, File Manipulation, Lists, Library Reference@section Characters and Strings@cindex character stringsIf a C program is to interact with a virtual code application byexchanging text, it uses the representation for characters described in@ref{Character Table}.  This convention would be inconvenient without asuitable API, so the functions in this section address the need. Thesefunctions are declared in the header file @file{chrcodes.h}.Some of these functions have two forms, with one of them having theword @code{standard} as part of its name. The reason is to cope withmultiple character encodings. Versions of @code{avram} prior to 0.1.0@cindex character encodings@cindex multiple character encodingsused a different character encoding than the one documented in@ref{Character Table}. The functions described in @ref{VersionManagement} can be used to select backward compatible operation withthe older character encoding. The normal forms of the functions inthis section will use the older character set if a backwardcompatibility mode is indicated, whereas the standard forms will usethe character encoding documented in @ref{Character Table} regardless.Standard encodings should always be assumed for library and function@cindex standard character encodingnames associated with the @code{library} combinator (@ref{Callingexisting library functions}), and for values of lists defined by@code{avm_list_of_value} (@ref{Primitive types}), but versiondependent encodings should be used for all other purposes such aserror messages. Alternatively, the normal version dependent forms ofthe functions below can be used safely in any case if backward@cindex backward compatabilitycompatibility is not an issue. This distinction is viewed as atransitional feature of the API that will be discontinued eventuallywhen support for the old character set is withdrawn and the@code{standard} forms are be removed.@deftypefun list avm_character_representation (int @var{character})@end deftypefun@deftypefun list avm_standard_character_representation (int @var{character})This function takes an integer character code and returns a copy ofthe list representing it, as per the table in @ref{CharacterTable}. Because the copy is shared, no memory is allocated by thisfunction so there is no possibility of overflow. Nevertheless, it isthe responsibility of the caller dispose of the list when it is nolonger needed by @code{avm_dispose}, just as if the copy were notshared (@ref{Simple Operations}). For performance reasons, thisfunction is implemented as a macro. If the argument is outside therange of zero to 255, it is masked into that range.@end deftypefun@deftypefun int avm_character_code (list @var{operand})@end deftypefun@deftypefun int avm_standard_character_code (list @var{operand})This function takes a list as an argument and returns the correspondingcharacter code, as per @ref{Character Table}. If the argument does notrepresent any character, a value of @code{-1} is returned.@end deftypefun@deftypefun list avm_strung (char *@var{string})@end deftypefun@deftypefun list avm_standard_strung (char *@var{string})This function takes a pointer to a null terminated character string andreturns the list obtained by translating each character into its listrepresentation and enqueuing them together. Memory needs to be allocatedfor the result, and if there isn't enough available, an error message iswritten to standard error and the process is terminated. This functionis useful to initialize lists from hard coded strings at the beginningof a run, as in this example.@examplehello_string = avm_strung("hello");@end exampleThis form initializes a single string, but to initialize a one linemessage suitable for writing to a file, it would have to be a list ofstrings, as in this example.@examplehello_message = avm_join(avm_strung("hello"),NULL);@end exampleThe latter form is used internally by the library for initializingmost of the various error messages that can be returned by other functions.@end deftypefun@deftypefun list avm_recoverable_strung (char *@var{string}, int *@var{fault});@end deftypefun@deftypefun list avm_recoverable_standard_strung (char *@var{string}, int *@var{fault});This function is like @code{avm_strung} except that if it runs out of memoryit sets the integer referenced by @var{fault} to a non-zero value and returnsinstead of terminating the process.@end deftypefun@deftypefun char *avm_unstrung (list @var{string}, list *@var{message}, int *@var{fault})@end deftypefun@deftypefun char *avm_standard_unstrung (list @var{string}, list *@var{message}, int *@var{fault})This function performs an inverse operation to@code{avm_recoverable_strung}, taking a list representing a characterstring to the character string in ASCII null terminated form as perthe standard C representation. Memory is allocated for the result bythis function which should be freed by the caller.In the event of an exception, the integer referenced by @code{fault}is assigned a non-zero value and an error message represented as alist is assigned to the list referenced by @code{message}. The errormessage should be reclaimed by the caller with @code{avm_dispose}(@ref{Simple Operations} if it is non-empty. Possible error messagesare @code{<'memory overflow'>}, @code{<'counter overflow'>}, and@code{<'invalid text format'>}.@end deftypefun@deftypefun list avm_scanned_list (char *@var{string})An application that makes use of virtual code snippets or data that areknown at compile time can use this function to initialize them. Theargument is a string in the format described in @ref{Concrete Syntax},and the result is the list representing it. For example, the programdiscussed in @ref{Example Script} could be hard coded into a C programby pasting the data from its virtual code file into an expression ofthis form.@examplecat_program = avm_scanned_list("sKYQNTP\\");@end exampleNote that the backslash character in the original data has to bepreceded by an extra backslash in the C source, because backslashesusually mean something in C character constants.The @code{avm_scanned_list} function needs to allocate memory. If thereisn't enough memory available, it writes a message to standard error andcauses the process to exit.@end deftypefun@deftypefun list avm_multiscanned (char **@var{strings})Sometimes it may be useful to initialize very large lists fromstrings, but some C compilers impose limitations on the maximum lengthof a string constant, and the ISO standard for C requires only 512bytes.  This function serves a similar purpose to@code{avm_scanned_list}, but allows the argument to be a pointer to anull terminated array of strings instead of one long string, therebycircumventing this limitation in the compiler.@examplechar *code[] = @{"sKYQ","NTP\\",NULL@};...cat_program = avm_multiscanned(code);@end exampleIf there is insufficient memory to allocate the list this function needsto create, it causes an error message to be written to standard error,and then kills the process.@end deftypefun@deftypefun char* avm_prompt (list @var{prompt_strings})This function takes a list representing a list of character strings, andreturns its translation to a character string with the sequence 13 10used as a separator. For example, given a tree of this form@examplesome_message = avm_join(   avm_strung("hay"),   avm_join(      avm_strung("you"),      NULL));@end examplethe result returned by @code{prompt_strings(some_message)} would be apointer to a null terminated character string equivalent to the C constant@code{"hay\13\10you"}.Error messages are printed and the process terminated in the event ofeither a memory overflow or an invalid character representation.This function is used by @code{avram} in the evaluation of interactive@cindex interactive applicationsvirtual code applications, whose output has to be compared to the outputfrom a shell command in this format. The separator is chosen to becompatible with the @code{expect} library.@end deftypefun@deftypefun char* avm_recoverable_prompt (list @var{prompt_strings}, list *@var{message}, int *@var{fault})This function performs the same operation as @code{avm_prompt} butallows the caller to handle exceptional conditions. If an exceptionsuch as a memory overflow occurs, the integer referenced by@code{fault} is assigned a non-zero value and a representation of theerror message as a list of strings is assigned to the list referencedby @code{message}.This function is used to by @code{avram} to evaluate the@code{interact} combinator (@ref{Interaction combinator}), whenterminating in the event of an error would be inappropriate.@end deftypefun@deftypefun void avm_initialize_chrcodes ()This function has to be called before any of the other characterconversion functions in this section, or else their results areundefined. It performs the initialization of various internal datastructures.@end deftypefun@deftypefun void avm_count_chrcodes ()This function can be called at the end of a run, after the last call toany of the other functions in this section, but before@code{avm_count_lists} if that function is also being used. The purposeof this function is to detect and report memory leaks. If any memoryassociated with any of these functions has not been reclaimed by theclient program, a message giving the number of unreclaimed lists will bewritten to standard error.@end deftypefun@node File Manipulation, Invocation, Characters and Strings, Library Reference@section File ManipulationThe functions described in this section provide an interface betweenvirtual code applications and the host file system by convertingbetween files or file names and their representations as lists. Theseconversions are necessary when passing a file to a virtual codeapplication, or when writing a file received in the result of one.@menu* File Names::                  * Raw Files::                   * Formatted Input::             * Formatted Output::            @end menu@node File Names, Raw Files, File Manipulation, File Manipulation@subsection File NamesA standard representation is used by virtual code applications for the@cindex file namespath names of files, following the description in @ref{Input DataStructure}. The functions and constants declared in @code{fnames.h}provide an API for operating on file names in this form.@deftypefun list avm_path_representation (char *@var{path})If a C program is to invoke a virtual code application and pass a pathname to it as a parameter, this function can be used to generate theappropriate representation from a given character string.@exampleconf_path = avm_path_representation("/etc/resolve.conf");@end exampleIn this example, @code{conf_path} is a @code{list}.  For potentiallybetter portability, a C program can use the character constant@code{avm_path_separator_character} in place of the slashes in hardcoded path names.Other useful constants are @code{avm_current_directory_prefix} as a@cindex @code{avm_path_separator_character}@cindex @code{avm_path_separator}@cindex @code{avm_current_directory_prefix}@cindex @code{avm_parent_directory_prefix}@cindex @code{avm_root_directory_prefix}portable replacement for @code{"./"}, as well as@code{avm_parent_directory_prefix} instead of @code{"../"}. There isalso @code{avm_root_directory_prefix} for @code{"/"}. These threeconstants are null terminated strings, unlike@code{avm_path_separator_character}, which is a character.If a @code{NULL} pointer is passed as the @code{@var{path}}, a@code{NULL} list is returned, which is the path representation forstandard input or standard output. If the address of an empty string ispassed to this function as the @code{@var{path}}, the list of the emptystring will be returned, which is the path representation for the rootdirectory. Trailing path separators are ignored, so @code{"/"} is thesame as the empty string.Some memory needs to be allocated for the result of this function. Ifthe memory is not available, an error message is written to standarderror and the process is terminated.@end deftypefun@deftypefun list avm_date_representation (char *@var{path})This function is essentially a wrapper around the standard@code{ctime_r} function that not only gets the time stamp for a file ata given path, but transforms it to a list representation according to@ref{Character Table}. It needs to allocate memory for the result andwill cause the program to exit with an error message if there is notenough memory available.The time stamp will usually be in a format like @code{Sun Mar 4 10:56:40GMT 2001}. If for some reason the time stamp can not be obtained, the@cindex @code{unknown date}result will be a representation of the string @code{unknown date}.@end deftypefun@deftypefun char* avm_path_name (list @var{path})This function is the inverse of @code{avm_path_representation}, in thatit takes a list representing a path to the path name expressed as a characterstring. This function can be used in C programs that invoke virtual codeapplications returning paths as part of their results, so that the Cprogram can get the path into a character string in order to open the file.If the @code{@var{path}} parameter is @code{NULL}, a @code{NULL} pointeris returned as the result. The calling program should check for a@cindex standard input@cindex standard output@code{NULL} result and interpret it as the path to standard input orstandard output.The memory needed for the character string whose address is returned isallocated by this function if possible. The given @code{@var{path}} isnot required to be consistent with the host file system, but it isrequired to consist of representations of non-null printable charactersor spaces as lists per @ref{Character Table}.  In the event of any erroror overflow, control does not return to the caller, but an error messageis printed and the program is aborted. The possible error messages fromthis function are the following.@cindex @code{counter overflow}@cindex @code{memory overflow}@cindex @code{null character in file name}@cindex @code{bad character in file name}@cindex @code{invalid file name}@itemize @bullet@item @code{@var{program-name}: counter overflow (code @var{nn})}@item @code{@var{program-name}: memory overflow (code @var{nn})}@item @code{@var{program-name}: null character in file name}@item @code{@var{program-name}: bad character in file name}@item @code{@var{program-name}: invalid file name (code @var{nn})}@end itemize@end deftypefun@deftypefun void avm_initialize_fnames ()A few housekeeping operations relevant to internal data structures areperformed by this function, making it necessary to be called by theclient program prior to using any of the other ones.@end deftypefun@deftypefun void avm_count_fnames ()This function can be used after the the last call to any of the otherfunctions in this section during a run, and it will detect memory leaksthat may be attributable to code in these functions or misusethereof. If any unreclaimed storage remains when this function iscalled, a warning message will be written to standard error. If thefunction @code{avm_count_lists} is also being used by the client, itshould be called after this one.@end deftypefun@node Raw Files, Formatted Input, File Names, File Manipulation@subsection Raw FilesSome low level operations involving lists and data files are provided bythese functions, which are declared in the header file @file{rawio.h}.@deftypefun list avm_received_list (FILE *@var{object}, char *@var{filename})This function is a convenient way of transferring data directly from araw format file into a list in memory. It might typically be used toload the virtual code for an application that has been written to a fileby a compiler.  @table @code@item @var{object}is the address of a file which shouldalready be open for reading before this function is called, and will beread from its current position.@item @var{filename}should be set by the caller to the address of a null terminated stringcontaining the name of the file, but is not used unless it needs to beprinted as part of an error message. If it is a null pointer, standardinput is assumed.@end tableThe result returned is a list containing data read from the file.The file format is described in @ref{File Format}. The preamble sectionof the file, if any, is ignored. If the file ends prematurely orotherwise conflicts with the format, the program is aborted with amessage of @cindex @code{invalid raw file format}@display@code{@var{program-name}: invalid raw file format in @var{filename}}@end displaywritten to standard error. The program will also be aborted by thisfunction in the event of a memory overflow.The file is left open when this function returns, and could therefore beused to store other data after the end of the list. The end of a list isdetected automatically by this function, and it reads no further,leaving the file position on the next character, if any.@end deftypefun@deftypefun void avm_send_list (FILE *@var{repository}, list @var{operand}, char *@var{filename})This function can be used to transfer data from a list in memory to afile, essentially by implementing the printing algorithm described in@ref{Bit String Encoding}. @table @code@item @var{repository}is the address of a file already open for writing, to which the data arewritten starting from the current position.@item @var{operand}is the list containing the data to be written@item @var{filename} is the address of a null terminated string containing the name of thefile that will be reported in an error message if necessary.@end tableNo preamble section is written by this function, but one could be@cindex preamblewritten to the file by the caller prior to calling it.  Error messagesare possible either because of i/o errors or because of insufficientmemory. I/o errors are not fatal and will result only in a warningmessage being printed to standard error, but a memory overflow willcause the process to abort. An i/o error message reported by thisfunction would be of the form@cindex @code{can't write}@display@code{@var{program-name}: can't write to @var{filename}}@end displayfollowed by the diagnostic obtained from the standard @code{strerror}@cindex @code{strerror}function if it exists on the host platform. The file is left open whenthis function returns.@end deftypefun@deftypefun void avm_initialize_rawio ()This function initializes some necessary data structures for thefunctions in this section, and should be called prior to them at thebeginning of a run.@end deftypefun@deftypefun void avm_count_rawio ()This function does nothing in the present version of the library, butshould be called after the last call to all of the other functions inthis section in order to maintain compatibility with future versions ofthe library. Future versions may decide to use this function to do somecleaning up of local data structures.@end deftypefun@node Formatted Input, Formatted Output, Raw Files, File Manipulation@subsection Formatted InputSome functions relating to the input of text files or data files withpreambles are declared in the header file @file{formin.h}. The usage ofthese functions is as follows.@deftypefun list avm_preamble_and_contents (FILE *@var{source}, char *@var{filename})This function loads a file of either text or data format into memory.@table @code@item @var{source}should be initialized by the caller as the address of a filealready open for reading that will be read from its current position.@item @var{filename}should be set by the caller to the address of a null terminatedcharacter string giving the name of the file that will be used if an i/oerror message needs to be written about it. If it is a @code{NULL}pointer, standard input is assumed.@end tableThe result returned by the function will be a list whose @code{head}@cindex preamblerepresents the preamble of the file and whose @code{tail} represents thecontents. As a side effect, the input file will be closed, unless the@code{@var{filename}} parameter is @code{NULL}.If the file conforms to the format described in @ref{File Format}, thepreamble is a list of character strings. In the result returned by thefunction, the @code{head} field will be a list with one item for eachline in the file, and each item will be a list of characterrepresentations as in @ref{Character Table}, but with the leading hashesstripped. The @code{tail} will be the list specified by remainder of thefile according to @ref{Concrete Syntax}.  If the file has an emptypreamble but is nevertheless a data file, the @code{head} will be a listwhose @code{head} and @code{tail} are both @code{NULL}.If the file does not conform to the format in @ref{File Format}, thenthe @code{head} of the result will be @code{NULL}, and the @code{tail}will be a list of lists of character representations, with one for eachline. Whether or not the file conforms to the format is determined on the fly,so this function is useful for situations in which the format is notknown in advance. The conventions regarding the preamble and contentsmaintained by this function are the same as those used by virtual codeapplications as described in @ref{Standard Output Representation} and@ref{Input Data Structure}.The characters used for line breaks are not explicitly represented in@cindex line breaksthe result. Depending on the host system, line breaks in text files maybe represented either by the character code 10, or by the sequence 1310. However, in order for the library to deal with binary files in aportable way, a line break always corresponds to a 10 as far as thisfunction is concerned regardless of the host, and a 13 is treated likeany other character. Hence, if this function were used on binary filesthat happened to have some 10s in them, the exact contents of afile could be reconstructed easily by appending a 10 to all but the lastline and flattening the list.A considerable amount of memory may need to be allocated by thisfunction in order to store the file as a list. If not enough memory isavailable, the function prints an error message to standard error andaborts rather than returning to the caller. However, i/o errors are notfatal, and will cause the function to print a warning but attempt tocontinue.@end deftypefun@deftypefun list avm_load (FILE *@var{source}, char *@var{filename}, int @var{raw})Similarly to @code{avm_preamble_and_contents}, this function also loadsa file into memory, but the format is specified in advance.@table @code@item @var{source}should be set by the caller to the address of an already open file forreading, which will be read from its current position.@item @var{filename}should be initialized by the caller as a pointer to a null terminatedstring containing the name of the file that will be reported to the userin the event of an error reading from it. If it is a @code{NULL}pointer, standard input is assumed.@item @var{raw}is set to a non-zero value by the caller to indicate that the file isexpected to conform to the format in @ref{File Format}. If the file isan ordinary text file, then it should be set to zero.@end tableIn the case of a data file, which is when @code{@var{raw}} is non-zero,the result returned by this function will be a list representing thedata section of the file and ignoring the preamble. In the case of atext file, the result will be a list of lists of characterrepresentations as per @ref{Character Table}, with one such list foreach line in the file. Similar comments about line breaks to thosementioned under @code{avm_preamble_and_contents} are applicable.As a side effect of this function, the @code{@var{source}} file will beclosed, unless the @code{@var{filename}} is a @code{NULL} pointer.This function is useful when the type of file is known in advance. If adata file is indicated by the @code{@var{raw}} parameter but the formatis incorrect, an error message is reported and the processterminates. The error message will be of the form@display@code{@var{program-name}: invalid raw file format in @var{filename}}@end displayAlternatively, if a text file is indicated by the@cindex @code{invalid raw file format}@code{@var{raw}} parameter, then no attempt is made to test whether itcould be interpreted as data, even if it could be. This behavior differsfrom that of @code{avm_preamble_and_contents}, where a bad datafile format causes the file to be treated as text, and a valid data fileformat, even in a ``text'' file, causes it to be treated as data.Memory requirements for this function are significant and will cause theprocess to abort with an error message in the event of insufficient freememory. Messages pertaining to i/o errors are also possible and are notfatal.@end deftypefun@deftypefun void avm_initialize_formin ()This function should be called before either of the other functions inthis section is called, as it initializes some necessary static datastructures. Results of the other functions are undefined if this one isnot called first.@end deftypefun@deftypefun void avm_count_formin ()This function should be called after the last call to any of the otherfunctions in this section, as it is necessary for cleaning up andreclaiming some internal data. If any storage remains unreclaimed due tomemory leaks in these functions or to misuse of them, a warning messageis written to standard error. If the function @code{avm_count_lists} isalso being used by the client program, it should be called after thisone.@end deftypefun@node Formatted Output,  , Formatted Input, File Manipulation@subsection Formatted OutputThe following functions pertaining to the output of text files or data files with@cindex preamblepreambles are declared in the header file @file{formout.h}.@deftypefun void avm_output (FILE *@var{repository}, char *@var{filename}, list @var{preamble}, list @var{contents}, int @var{trace_mode})This function writes a either a text file or a data file in the formatdescribed in @ref{File Format}. The parameters have theseinterpretations.@table @code@item @var{repository}is the address of a file opened for writing by the caller, that will bewritten from its current position.@item @var{filename}is the address of a null terminated character string setby the caller to be the name of the file that willbe reported to the user in the event of an i/o error. @item @var{preamble}is @code{NULL} in the case of a text file, but a list of character stringrepresentations as per @ref{Character Table}, in the case of a datafile. If a data file has is to be written with an empty preamble, thenthis list should have a @code{NULL} @code{head} and a @code{NULL}@code{tail}.@item @var{contents}is either a list of character string representations in the case of atext file, or is an unconstrained list in the case of a data file.@item @var{trace_mode}may be set to a non-zero value by the caller to request that everythingwritten to a text file should be echoed to standard output. It isignored in the case of a data file.@end tableThe effect of calling this function is to write the preamble andcontents to the file in the format indicated by the preamble. The fileis left open when this function returns.Line breaks are always written as character code 10, not as 13 10,@cindex line breaksregardless of the convention on the host system, so that files writtenby this function can be reliably read by other functions in the library.Leading hashes are automatically added to the beginning of the lines inthe preamble, except where they are unnecessary due to a continuationcharacter on the previous line. This action enforces consistency with thefile format, ensuring that anything written as a data file can be readback as one. The hashes are stripped automatically when the file isread by @code{avm_preamble_and_contents}.Another feature of this function is that it will mark any output file asexecutable if it is a data format file with a prelude whose first@cindex executable filescharacter in the first line is an exclamation point. This feature makesit easier for a compiler implemented in virtual code to generateexecutable shell scripts directly.A fatal error is reported if any of the data requiredto be a character representation is not listed in the @ref{CharacterTable}. A fatal error can also be caused by a memory overflow. Possibleerror messages are the following.@cindex @code{invalid output preamble format}@cindex @code{invalid text format}@cindex @code{can't write}@itemize @bullet@item @code{@var{program-name}: invalid output preamble format}@item @code{@var{program-name}: invalid text format}@item @code{@var{program-name}: can't write to @var{filename}}@end itemize@cindex @code{strerror}In the last case, the error message will be followed by an explanationfurnished by the standard @code{strerror} function if available.@end deftypefun@deftypefun void avm_output_as_directed (list @var{data}, int @var{ask_to_overwrite_mode}, int @var{verbose_mode})This function writes an ensemble of files at specified paths in eithertext or data format, optionally interacting with the user throughstandard input and output. The parametershave these interpretations.@table @code@item @var{data}is a list in which each item specifies a file to bewritten.@item @var{ask_to_overwrite_mode}may be set to a non-zero value by the calling program in order tohave this function ask the user for permission to overwrite existing files.@item @var{verbose_mode}may be set to a non-zero value by the calling program to have thisfunction print to standard output a list of the names of the files itwrites.@end tableA high level interface between virtual code applications and the filesystem is provided by this function. The @code{@var{data}} parameterformat is compatible with the the data structure returned by anapplication complying with the conventions in @ref{Output FromNon-interactive Applications}.Each item in the @code{@var{data}} list should be a non-empty list whose@code{head} and @code{tail} are also non-empty. The fields in each item havethe following relevance to the file it specifies.@itemize @bullet@item The @code{head} of the @code{head} is @code{NULL} if the file isto be opened for appending, and non-@code{NULL} if it is to beoverwritten.@item The @code{tail} of the @code{head} represents a path as a list ofcharacter string representations, in a form suitable as an argument to@code{avm_path_name}.@item The @code{head} of the @code{tail} represents the preamble of thefile, as either @code{NULL} for a text file or a non-empty list ofcharacter string representations for a data file.@item The @code{tail} of the @code{tail} represents the contents of thefile, either as a list of character string representations for a textfile or as a list in an unconstrained format for a data file.@end itemizeFor each item in the list, the function performs the following steps.@enumerate@item It decides whether to open a filefor overwriting or appending based on the @code{head} of the@code{head}.@item It uses the @code{tail} of the @code{head} to find out thefile name from @code{avm_path_name}, in order to open it. @item If the@code{@var{ask_to_overwrite_mode}} flag is set and the file is found toexist already, the function will print one of the following messages tostandard output, depending on whether the file is to be overwritten orappended.@itemize @bullet@item @code{@var{program-name}: overwrite @var{filename}? (y/n)}@item @code{@var{program-name}: append to @var{filename}? (y/n)}@end itemizeIt will then insist on either @kbd{y} or @kbd{n} as an answer before continuing.@item If the @code{@var{ask_to_overwrite}} flag has not been set, or the file didnot previously exist, or the answer of @kbd{y} was given, the preambleand contents of the file are then written with @code{avm_output}.@item If permission to write or append was denied, one of the followingmessages is reported to standard output, and the data that were to bewritten are lost.@cindex @code{not writing} file name@cindex @code{writing} file name@itemize @bullet@item @code{@var{program-name}: not writing @var{filename}}@item @code{@var{program-name}: not appending @var{filename}}@end itemize@item If permission was granted to write or append to the file or the @code{@var{verbose_mode}} flag isset, one of the messages@itemize @bullet@item @code{@var{program-name}: writing @var{filename}}@item @code{@var{program-name}: appending @var{filename}}@end itemizeis sent to standard output.@end enumerate@cindex standard outputIf any files are to be written to standard output, which would beindicated by a @code{NULL} path, they are not written until all otherfiles in the list are written. This feature is in the interest of@cindex securitysecurity, as it makes it more difficult for malicious or inept virtualcode to alter the appearance of the console through standard output until afterthe interactive dialogue has taken place. Permission is not solicitedfor writing to standard output, and it will not be closed.Any of the fatal errors or i/o errors possible with @code{avm_output} or@code{avm_path_name} are also possible with this function, as well asthe following additional ones.@cindex @code{invalid file specification}@cindex @code{can't close}@cindex @code{can't write}@itemize @bullet@item @code{@var{program-name}: invalid file specification}@item @code{@var{program-name}: can't close @var{filename}}@item @code{@var{program-name}: can't write @var{filename}}@end itemizeThe last two are non-fatal i/o errors that will be accompanied by an@cindex @code{strerror}explanation from the @code{strerror} function if the host supportsit. The other message is the result of a badly formatted@code{@var{data}} parameter.@end deftypefun@deftypefun void avm_put_bytes (list @var{bytes})This function takes a list of character representations, converts themto characters, and sends them to standard output. There is no chance ofa memory overflow, but the following other errors are possible.@cindex @code{invalid text format}@cindex @code{can't write}@itemize @bullet@item @code{@var{program-name}: invalid text format (code @var{nn})}@item @code{@var{program-name}: can't write to standard output}@end itemizeThe latter is non-fatal, but the former causes the program to abort.It is caused when any member of the list @code{@var{bytes}} is not acharacter representation appearing in @ref{Character Table}.@end deftypefun@deftypefun void avm_initialize_formout ()This function initializes some data structures used locally by the otherfunctions in this section, and should be called at the beginning of arun before any of them is called.@end deftypefun@deftypefun void avm_count_formout ()This function doesn't do anything in the current version of the library,but should be called after the last call to any of the other functionsin this section. Future versions of the library might use this functionfor cleaning up some internal data structures, and client programs thatcall it will maintain compatibility with them.@end deftypefun@node Invocation, Version Management, File Manipulation, Library Reference@section InvocationThe functions documented in this section can be used to incorporate thecapabilities of a virtual machine emulator into other C programs witha minimal concern for the details of the required data structuresand virtual code invocation conventions.@menu* Command Line Parsing::        * Execution Modes::             @end menu@node Command Line Parsing, Execution Modes, Invocation, Invocation@subsection Command Line Parsing@cindex command lineA couple of functions declared in @file{cmdline.h} can be used to do allthe necessary parsing of command lines and environment variables neededby virtual code applications.@deftypefun list avm_default_command_line (int @var{argc}, char *@var{argv}[], int @var{index}, char *@var{extension}, char *@var{paths}, int @var{default_to_stdin_mode}, int @var{force_text_input_mode}, int *@var{file_ordinal})The purpose of this function is to build most of the data structure usedby parameter mode applications, as described in @ref{Input DataStructure}, by parsing the command line according to @ref{Command LineSyntax}. The parameters have these interpretations.@table @code@item @var{argc}is the number elements in the array referenced by @code{@var{argv}}@item @var{argv}is the address of an array of pointers to null terminated character stringsholding command line arguments@item @var{index}is the position of the first element of @code{@var{argv}} to beconsidered. Those preceding it are ignored.@item @var{extension}is the address of a string that will be appended to input file namesgiven in @code{@var{argv}} in an effort to find the associated files@item @var{paths}is the address of a null terminated character string containing a colonseparated list of directory names that will be searched for input files@item @var{default_to_stdin_mode}is set to a non-zero value by the caller if the contents of standardinput should be read in the absence of input files@item @var{force_text_input_mode}is set to a non-zero value by the caller to indicate that input filesshould be read as text, using @code{avm_load} (rather than@code{avm_preamble_and_contents}, which would allow them to be eithertext or data). The @code{@var{preamble}} field of the returned filespecifications will always be empty when this flag is set.@item @var{file_ordinal}is set to a pointer to an integer by the caller if only one file is tobe loaded during each call. The value of the integer indicates the whichone it will be.@end tableThe result returned by this function is a list whose @code{head} is a listof file specifications and whose @code{tail} is a list of command line optionsintended for input to a virtual code application.The list of file specifications returned in the @code{head} of theresult follows the same conventions as the @code{@var{data}} parameterto the function @code{avm_output_as_directed}, except that the@code{head} of the @code{head} of each item is a list representing thetime stamp of the file as given by @code{avm_date_representation}. Ifthe file is standard input, then it holds the current system date andtime.If the @code{@var{file_ordinal}} parameter is @code{NULL}, then allfiles on the command line are loaded, but if it points to an integer@var{n}, then only the @var{n}th file is loaded, and @var{n} isincremented. If there is no @var{n}th file, a @code{NULL} value isreturned as the entire result of the function. For a series of calls,the integer should be initialized to zero by the caller before the firstcall.If standard input is indicated as one of the files on the command line(by a dash), then it is also loaded regardless of the@code{@var{file_ordinal}}, but a cached copy of it is used on subsequentcalls after the first, so that the function does not actually attempt toreread it. If standard input is to be loaded, it must be finite for thisfunction to work properly.The search strategy for files is described in @ref{Environment}, andmakes use of the @code{@var{extension}} and @code{@var{paths}} parameters.In the list of command line options returned in the @code{tail} of theresult, each item is a list with a non-empty @code{head} and@code{tail}, and is interpreted as follows.@itemize @bullet@item The @code{head} of the @code{head} is a list representing anatural number, as given by @code{avm_natural}, indicating the positionof the option on the command line relative to the initial value of the@code{@var{index}} parameter.@item The @code{tail} of the @code{head} is a list which is @code{NULL}in the case of a ``short form'' option, written with a singledash on the command line, but is a list whose @code{head} and@code{tail} are @code{NULL} in the case of a ``long form'' option,written with two dashes.@item The @code{head} of the @code{tail} is a list representing acharacter string for the keyword of an option, for example @kbd{foo} inthe case of an option written @kbd{--foo=bar,baz}.@item The @code{tail} of the @code{tail} is a list of lists representingcharacter strings, with one item for each parameter associated with theoption, for example, @kbd{bar} and @kbd{baz}.@end itemizeIf multiple calls to the function are made with differing values of@code{*@var{file_ordinal}} but other parameters unchanged, the same list ofoptions will be returned each time, except insofar as the positionnumbers in the @code{head} of the @code{head} of each item are adjustedas explained in @ref{Input for Mapped Applications}.Any of the i/o errors or fatal errors associated with other fileinput operations are possible with this function as well. This non-fatalwarning message is also possible.@cindex @code{search paths not supported}@display@code{@var{program-name}: warning: search paths not supported}@end displayThis error occurs if the library has been built on a platform that@cindex @file{argz.h}doesn't have the @file{argz.h} header file and the @code{@var{paths}}parameter is non-@code{NULL}.@end deftypefun@deftypefun list avm_environment (char *@var{env}[])@cindex environmentThis function takes the address of a null terminated array of pointersto null terminated character strings of the form@code{"variable=value"}. The result returned is a list of lists, withone item for each element of the array. The @code{head} of each item isa representation of the left side of the corresponding string, and the@code{tail} is a representation of the right.This function is therefore useful along with@code{avm_default_command_line} for building the remainder of the datastructure described in @ref{Parameter Mode Interface}. For example, avirtual machine emulator for non-interactive parameter mode applicationswith no bells and whistles could have the following form.@exampleintmain(argc,argv,env)@dots{}@{  FILE *virtual_code_file;@dots{}  avm_initialize_lists();  avm_initialize_apply();  avm_initialize_rawio();  avm_initialize_formout();  avm_initialize_cmdline();  virtual_code_file = fopen(argv[1],"rb");  operator = avm_received_list(    virtual_code_file,argv[1]);  fclose(virtual_code_file);  command = avm_default_command_line(argc,    argv,2,NULL,NULL,0,0,NULL);  environs = avm_environment(env);  operand = avm_join(command,environs);  result = avm_apply(operator,operand);  avm_output_as_directed(result,0,0);  avm_dispose(result);@dots{}@}@end exampleThe @code{avm_environment} function could cause the program to abort dueto a memory overflow.  For security reasons, it will also abort with an@cindex securityerror message if any non-printing characters are detected in itsargument. (See @ref{Other Diagnostics and Warnings}.)@end deftypefun@deftypefun void avm_initialize_cmdline ()This function initializes some local variables and should be calledbefore any of the other functions in this section is called, or elsetheir results are unpredictable.@end deftypefun@deftypefun void avm_count_cmdline ()This function should be called after the last call to any of the otherfunctions in this section, as it reclaims some locally allocatedstorage. If the @code{avm_count_lists} function is used, it should becalled after this one.@end deftypefun@node Execution Modes,  , Command Line Parsing, Invocation@subsection Execution ModesSome functions declared in @file{exmodes.h} are useful for executinginteractive applications or filter mode transducers in a mannerconsistent with the specifications described in the previous chapter.@deftypefun void avm_interact (list @var{avm_interactor}, int @var{step_mode}, int @var{ask_to_overwrite_mode}, int @var{quiet_mode})This function executes an interactive virtual code application. Theparameters have these interpretations.@table @code@item @var{avm_interactor}is the virtual code for a function that performs as specified in@ref{Output From Interactive Applications}.@item @var{step_mode}will cause all shell commands to be echoed if set to a non-zerovalue, and will cause the program to pause after each shell commanduntil a key is pressed.@item @var{ask_to_overwrite_mode}can be set to a non-zero value by the caller to cause the program to askpermission of the user to overwrite any existing files in cases wherethe virtual code returns a file list as described in @ref{Mixed Modes ofInteraction}.@item @var{quiet_mode}can be set to a non-zero value to suppress console messages in the caseof file output per @ref{Mixed Modes of Interaction}.@end tableThe meaning of this function is accessible to any reader willing to slogthrough @ref{Output From Interactive Applications}. The only subtlepoint is that @code{@var{avm_interactor}} parameter in this functiondoes not correspond to the virtual code application that @code{avram}reads from a virtual code file, but to the result computed when theapplication read from the file is applied to the data structurerepresenting the command line and environment.Any of the memory overflows or i/o errors possible with other functionsin the library are possible from this one as well, and will also causeit to print an error message and halt the program. A badly designed@cindex deadlockvirtual code application could cause a deadlock, which will not bedetected or reported@end deftypefun@deftypefun void avm_trace_interaction ()This function enables diagnostic output for the @code{avm_recoverable_interact}function.@end deftypefun@deftypefun void avm_disable_interaction ()This function causes @code{avm_interact} and @code{avm_recoverable_interact}to terminate with an error instead of executing, as required by the@code{--jail} command line option.@end deftypefun@deftypefun list avm_recoverable_interact (list @var{interactor}, int @var{*fault})This function is similar to @code{avm_interact} but always closes thepipe and performs no file i/o, and will return an error message ratherthan exiting. Otherwise it returns a transcript of the intereaction asa list of lists of strings represented as lists of characterencodings.  It implements the @var{interact} combinator with thevirtual code for the transducer function given as the parameter.  Aprior call to @code{avm_trace_interaction} will cause diagnosticinformation to be written to standard output when this function isexecuted.@end deftypefun@deftypefun void avm_byte_transduce (list @var{operator})This function executes a filter mode byte transducer application, whichbehaves as described in @ref{Byte Transducers}. The argument is thevirtual code for the application, which would be found in a virtual codefile. There are limited opportunities for i/o errors, as only standardinput and standard output are involved with this function, but fatalerrors due to memory overflow are possible.@end deftypefun@deftypefun void avm_line_map (list @var{operator})This function executes line mapped filter mode applications, which areexplained in @ref{Line Maps}. The argument is the virtual code for theapplication. Similar comments to those above apply.@end deftypefun@deftypefun void avm_initialize_exmodes ()This function should be called before any of the other functions in thissection in order to initialize some local variables. Results areundefined if this function isn't called first.@end deftypefun@deftypefun void avm_count_exmodes ()This function doesn't do anything in the present version of the library,but should be called after the last call to any of the other functionsin this section in order to maintain compatibility with future versions,which may use it for cleaning up local variables.@end deftypefun@node Version Management, Error Reporting, Invocation, Library Reference@section Version ManagementThe @code{avram} library is designed to support any number of backward@cindex versionscompatibility modes with itself, by way of some functions declared in@file{vman.h}. The assumption is that the library will go through asequence of revisions during its life, each being identified by a uniquenumber. In the event of a fork in the project, each branch willattempt to maintain compatibility at least with its own ancestors.@deftypefun void avm_set_version (char *@var{number})This function can be used to delay the demise of a client program thatuses the library but is not updated very often. The argument is a nullterminated string representing a version number, such as @code{"@value{VERSION}"}.A call to this function requests that all library functions revert totheir behavior as of that version in any cases where the currentbehavior is incompatible with it. It will also cause virtual codeapplications evaluated with @code{avm_apply} to detect a version numberequal to the given one rather than the current one. (See @ref{Version}.)The program will exit with an internal error message if any function inthe library has already interrogated the version number before thisfunction is called, or if it is passed a null pointer. This problem canbe avoided by calling it prior to any of the @code{avm_initialize}functions with a valid address. The program will exit with the message@display@code{@var{program-name}: multiple version specifications}@end displayif this function is called more than once, even with the same number.If the number is not recognized as a present or past version, or is soold that it is no longer supported, the program will exit with thismessage.@display@code{avram: can't emulate version @var{number}}@end displayClient programs that are built to last should allow the version numberto be specified as an option by the user, and let virtual codeapplications that they execute take care of their own backwardcompatibility problems. This strategy will at least guard againstchanges in the virtual machine specification and other changes that donot affect the library API.@end deftypefun@deftypefun int avm_prior_to_version (char *@var{number})This function takes the address of a null terminated string representinga version number as an argument, such as @code{"@value{VERSION}"}, and returns anon-zero value if the version currently being emulated predates it.If no call has been made to @code{avm_set_version} prior to the call tothis function, the current version is assumed, and subsequent calls to@code{avm_set_version} will cause an internal error.The intended use for this function would be by a maintainer of thelibrary introducing an enhancement that will not be backward compatible,who doesn't wish to break existing client programs and virtual codeapplications. For example, if a version @code{1.0} is developed at sometime in the distant future, and it incorporates a previously unexpectedway of doing something, code similar to the following could be used tomaintain backward compatibility.@exampleif (avm_prior_to_version("1.0"))  @{    /* do it the 0.x way */  @}else  @{    /* do it the 1.0-and-later way */  @}@end example@noindentThis function will cause an internal error if the parameter does notmatch any known past or present version number, or if it is a null pointer.@end deftypefun@deftypefun char* avm_version ()This function returns the number of the version currently being emulatedas the address of a null terminated string. The string whose address isreturned should not be modified by the caller.If no call has been made to @code{avm_set_version} prior to the call tothis function, the current version is assumed, and subsequent calls to@code{avm_set_version} will cause an internal error.@end deftypefun@node Error Reporting, Profiling, Version Management, Library Reference@section Error Reporting@cindex error messagesMost of the error reporting by other functions in the library is done byway of the functions declared in @file{error.h}.  These functioncommunicate directly with the user through standard error.  Clientprograms should also use these functions where possible for the sake ofa uniform interface.@deftypefun void avm_set_program_name (char *@var{argv0})The argument to this function should be the address of a null terminatedstring holding the name of the program to be reported in error messagesthat begin with a program name. Typically this string will be the nameof the program as it was invoked on the command line, possibly with pathcomponents stripped from it. An alternative would be to set it to thename of a virtual code application being evaluated. If this function isnever called, the name @code{"avram"} is used by default. Space for acopy of the program name is allocated by this function, and a fatalmemory overflow error is possible if there is insufficient space available.@end deftypefun@deftypefun char* avm_program_name ()This function returns a pointer to a null terminated character stringholding the program name presently in use. It will be either the namemost recently set by @code{avm_set_program_name}, or the default name@code{"avram"} if none has been set. The string whose address isreturned should not be modified by the caller.@end deftypefun@deftypefun void avm_warning (char *@var{message})This function writes the null terminated string whose address is givento standard error, prefaced by the program name and followed by a linebreak.@end deftypefun@deftypefun void avm_error (char *@var{message})This function writes the null terminated string whose address is givento standard error, prefaced by the program name and followed by a linebreak, as @code{avm_warning}, but it then terminates the process with anexit code of 1.@end deftypefun@deftypefun void avm_fatal_io_error (char *@var{message}, char *@var{filename}, int @var{reason})This function is useful for reporting errors caused in the course ofreading or writing files. The message is written to standard errorprefaced by the program name, and incorporating the name of the relevantfile. The @code{@var{reason}} should be the error code obtained from thestandard @code{errno} variable, which will be translated to an@cindex @code{strerror}informative message if possible by the standard @code{strerror} functionand appended to the message. After the message is written, the processwill terminate with an exit code of 1.@end deftypefun@deftypefun void avm_non_fatal_io_error (char *@var{message}, char *@var{filename}, int @var{reason})This function does the same as @code{avm_fatal_io_error} except that itdoesn't exit the program, and allows control to return to the caller,which should take appropriate action.@end deftypefun@deftypefun void avm_internal_error (int @var{code})This function is used to report internal errors and halt theprogram. The error message is written to standard error prefaced by theprogram name and followed by a line break. The code should be a uniqueinteger constant (i.e., not one that's used for any other internalerror), that will be printed as part of the error message as an aid tothe maintainer.This function should be used by client programs only in the event ofconditions that constitute some violation of a required invariant. Itindicates to the user that something has gone wrong with the program,for which a bug report would be appropriate.@end deftypefun@deftypefun void avm_reclamation_failure (char *@var{entity}, counter @var{count})This function is used only by the @code{avm_count} functions to reportunreclaimed storage. The @code{@var{count}} is the number of units ofstorage left unreclaimed, and the @code{@var{entity}} is the address ofa null terminated string describing the type of unreclaimed entity, suchas @code{"lists"} or @code{"branches"}. The message is written tostandard error followed by a line break, but the program is not haltedand control returns to the caller.@end deftypefun@node Profiling, Emulation Primitives, Error Reporting, Library Reference@section Profiling@cindex @file{profile.h}The functions declared in @file{profile.h} can be used for constructingand writing tables of run time statistics such as those mentioned in@ref{Files}, and @ref{Profile}. These functions maintain a database ofstructures, each recording the statistics for a particular virtual codefragment.Each structure in the database is identified by a unique key, which mustbe a list representing a character string. A pointer to such a structure@cindex @code{score}is declared to be of type @code{score}. For the most part, the datastructure should be regarded as opaque by a client program, except for afield @code{reductions} of type @code{counter}, which may be modifiedarbitrarily by the client. The way these operations are used in the course of evaluating virtualcode applications containing profile annotations is to add a structureto the database each time a new profiled code fragment is encountered,using the annotation as its key, and to increment the @code{reductions}@cindex annotationsof the structure each time any constituent of the code gets a quantum ofwork done on it. Other ways of using these operations are left to thedeveloper's discretion.@deftypefun score avm_entries (list @var{team}, list *@var{message}, int *@var{fault})This function retrieves or creates a data base entry given its key. Theparameters have these interpretations.@table @code@item @var{team}is a list representing a character string that uniquely identifies thedatabase entry to be retrieved or created.@item @var{message}is the address of a list known to the caller, which will be assigned alist representing an error message if any error occurs in the course ofsearching the database or creating a new entry.@item @var{fault}is the address of an integer that will be set to a non-zero value if anyerror is caused by this function.@end tableThe pointer returned by this function is the address of the record whosekey is given by the @code{@var{team}} parameter. If such a record isalready in the database, its address is returned, but otherwise a newone is created whose address is then returned. The @code{reductions}field of a newly created entry will be zero.In the course of searching the database, the @code{avm_compare}function is used, so the associated lists may be modified as noted in@ref{Comparison}.  It is not necessary for a client to include the headerfile @file{compare.h} or to call @code{avm_initialize_compare} in orderto use the profile operations, because they are done automatically.If an error message is assigned to the list referenced by@code{@var{message}}, the integer referenced by @code{@var{fault}} willbe set to a non-zero value. The form of the error message will be a listin which each item is a list of character representations as per@ref{Character Table}. It is the responsibility of the caller to disposeof the error message. Currently the only possible error is a memoryoverflow, which in this case is non-fatal.@end deftypefun@deftypefun void avm_tally (char *@var{filename})This function makes a table of the results stored in the data base builtby the @code{avm_entries} function. The argument is the address of anull terminated character string containing the name of the file inwhich the results will be written. A file is opened and the table iswritten in a self explanatory text format, with columns labeled``reductions'' and ``invocations'' among others. The latter contains thenumber of times the associated key was accessed through@code{avm_entries}.The data written to the file should be taken with a grain of salt.  Itis computed using native integer and floating point arithmetic, with nochecks made for overflow or roundoff error, and no guarantee of cross@cindex reductionsplatform portability. The number of ``reductions'' means whatever thedeveloper of the client program wants it to mean.The following error messages are possible with this function, which willbe written to standard error. None of them is fatal.@cindex @code{can't write}@cindex @code{can't close}@cindex @code{invalid profile identifier}@itemize @bullet@item @code{@var{program-name}: can't write @var{filename}}@item @code{@var{program-name}: can't write to @var{filename}}@item @code{@var{program-name}: can't close @var{filename}}@item @code{@var{program-name}: invalid profile identifier}@end itemizeThe last message is reported if any record in the database has a keythat is not a list of valid character representations. The others are@cindex @code{strerror}accompanied by an explanation from the standard @code{strerror} functionif possible.@end deftypefun@deftypefun void avm_initialize_profile ()This function should be called before any of the other functions in thissection in order to initialize the data base. Results are undefined ifit is not called first.@end deftypefun@deftypefun void avm_count_profile ()This function can be called after the other functions in this section asa way of detecting memory leaks. If any storage remains unreclaimed thatwas created by the functions in this section, a warning message iswritten to standard error. If the @code{avm_count_lists} function isbeing used by the client program, it should be called after this one.@end deftypefun@node Emulation Primitives, External Library Maintenance, Profiling, Library Reference@section Emulation PrimitivesThe functions documented in this section can be used to take veryspecific control over the evaluation of virtual code applications. It isunlikely that a client program will have any need for them unless itaims to replace or extend the @code{avm_apply} function.The virtual machine is somewhat removed from a conventional von Neumannmodel of computation, so emulating it in C or any other imperativelanguage is less straightforward than one would prefer. An elaboratesystem of interdependent data structures is used to represent partiallyevaluated computations, which does not particularly lend itself to aconvenient, modular API. The abstraction provided by the functions inthis section is limited mainly to that of simple memory management andstack operations. Consequently, a developer wishing to build on themeffectively would need to @emph{grok} the data structures involved,which are described in some detail.@menu* Lists of Pairs of Ports::     * Ports and Packets::           * Instruction Stacks::          @end menu@node Lists of Pairs of Ports, Ports and Packets, Emulation Primitives, Emulation Primitives@subsection Lists of Pairs of Ports@cindex @code{port}A @code{port} is the name given to a type of pointer used in the libraryas the address of a place where a computational result yet to beevaluated will be sent. Ports are discussed further in @ref{Ports and Packets},but are mentioned here because it is sometimes necessary to employ alist of pairs of them. A pointer to such a list is declared as a@code{portal} type. It refers to a structure of the form@cindex @code{portal}@cindex @code{port_pair}@examplestruct port_pair@{  port left;  port right;  portal alters;@}@end exampleA small selection of functions for @code{portal} memory management isdeclared as follows in the header file @file{portals.h}. For reasons ofC-ness, the type declarations themselves are forced to be in@file{lists.h}.@deftypefun portal avm_new_portal (portal @var{alters})This function is used to create storage for a new @code{port_pair}structure, and returns a @code{portal} pointer to it if successful. Ifthe storage can't be allocated, a @code{NULL} pointer is returned.The @code{alters} field of the result is initialized as the givenparameter supplied by the caller. All other fields are filled with zeros.@end deftypefun@deftypefun void avm_seal (portal @var{fate})This function performs the reclamation of storage associated with@code{portal} pointers, either by freeing them or by consigning themtemporarily to a local cache for performance reasons. Client programsshould use only this function for disposing of @code{portal} storagerather than using @code{free} directly, so as to allow accurate recordkeeping.@end deftypefun@deftypefun void avm_initialize_portals ()This function should be called by a client program prior to callingeither of the above memory management functions in order to initializesome local variables. Anomalous results are possible otherwise.@end deftypefun@deftypefun void avm_count_portals ()This function should be called at the end of a run or after the lastcall to any of the other functions in this section as a way of detectingmemory leaks associated with @code{portal} pointers. A warning messagewill be written to standard error if any remains unreclaimed.@end deftypefun@node Ports and Packets, Instruction Stacks, Lists of Pairs of Ports, Emulation Primitives@subsection Ports and PacketsA pointer type declared as a @code{port} points to a structure in thefollowing form, where a @code{flag} is an unsigned short integer type,and a @code{counter} is an unsigned long integer.@cindex @code{counter}@cindex @code{flag}@cindex @code{avm_packet}@examplestruct avm_packet@{  port parent;  counter errors;  portal descendents;  list impetus, contents;  flag predicating;@};@end example@noindentFor reasons that make sense to C, the @code{avm_packet} and @code{port}types are declared in @code{lists.h}, but a few memory managementoperations on them are available by way of functions declared in@file{ports.h}. The intended meaning of this structure is describedpresently, but first the memory management functions are as follows.@deftypefun port avm_newport (counter @var{errors}, port @var{parent}, int @var{predicating})This function attempts to allocate storage for a new packet structureand returns its address if successful. If storage can not be allocated,a @code{NULL} pointer is returned. The @code{errors}, @code{parent}, and@code{predicating} fields are initialized with the parameters suppliedby the caller. The rest of the structure is filled with zeros. A localmemory cache is used for improved performance.@end deftypefun@deftypefun void avm_sever (port @var{appendage})This function reclaims the storage associated with a @code{port}, eitherfreeing it entirely or holding it in a local cache.  None of theentities that may be referenced by pointers within the structure areaffected.  Only this function should be used by client programs fordisposing of ports, not the @code{free} function directly, or someinternal bookkeeping will be disrupted. An internal error results if theargument is a @code{NULL} pointer.@end deftypefun@deftypefun void avm_initialize_ports ()This function must be called prior to calling either of the two above,in order to initialize some static variables.@end deftypefun@deftypefun void avm_count_ports ()This function may be called after the last call to any of the otherfunctions in this section in order to detect and report unreclaimedstorage associated with ports. A non-fatal warning will be written tostandard error if any is detected, but otherwise there is no effect.@end deftypefunThe interesting aspect of this data structure is the role it plays incapturing the state of a computation. For this purpose, it correspondsto a single node in a partially computed result to be represented by a@code{list} when it's finished. The nodes should be envisioned as adoubly-linked binary tree, except that the pair of @code{descendents}for each node is not yet known with certainty, so a list of alternativesmust be maintained.Because the computation is not completed while this data structureexists, there are always some empty fields in it. For example, the@code{descendents} and the @code{contents} fields embody the sameinformation, the latter doing so in a compact as opposed to a moreexpanded form. Hence, it would be redundant for both fields to benon-empty at the same time. The data structure is built initially with@code{descendents} and no @code{contents}, only to be transformed intoone with @code{contents} and no @code{descendents}.The significance of each field in the structure can be summarized asfollows.@table @code@item contentsIf the computational result destined for the @code{port} pointing to this packetis not complete, then this field is @code{NULL} and the@code{descendents} are being computed. Otherwise, it contains the resultof the computation.@item descendentsThis field points to a list of pairs of ports serving as thedestinations for an ensemble of concurrent computations.@footnote{Earlierversions of @code{avram} included a bottom avoiding choice combinatorthat required this feature, but which has been withdrawn. A single pairof descendent ports would now suffice.} The @code{head}and @code{tail} of the @code{contents} are to be identified respectivelywith the @code{contents} of the @code{left} and @code{right} @code{port}in the first pair to finish being computed.@item parentIf this packet is addressed by the @code{left} or the @code{right} of@code{port} in one of the @code{descendents} of some other packet, thenthis field points to that packet.@item errorsA non-zero value in this field indicates that the result destined forthe @code{contents} of this packet is expected to be an errormessage. If the exact level of error severity incurred in thecomputation of the @code{contents} matches this number, then thecontents can be assigned the result, but otherwise the result shouldpropagate to the @code{contents} of the @code{parent}.@item predicatingA non-zero value in this field implies that the result destined for the@code{contents} of this packet is being computed in order to decidewhich arm of a conditional function should be chosen. I.e., a@code{NULL} result calls for the one that is invoked when the predicateis false.@item impetusIf the result destined for the @code{contents} of this packet is beingcomputed in order to transform a virtual code fragment from its originalform to an equivalent representation capable of being evaluated moredirectly, this field points to a @code{list} node at the root of thevirtual code in its original form.@end tableOne of the hitherto undocumented fields in a @code{list} node structure@cindex @code{interpretation}@cindex @code{impetus}declared in @file{lists.h} is called the @code{interpretation}, and isof type @code{list}. A client program delving into sufficient depth ofdetail to be concerned with ports and packets may reasonably assign the@code{interpretation} field of the @code{list} referenced by the@code{impetus} field in a packet to be a copy of the @code{contents} ofthe packet when they are eventually obtained. Doing so will save sometime by eliminating the need for it to be recomputed if the same virtualcode should be executed again.If this course is taken, the @code{facilitator} field in a @code{list}@cindex @code{facilitator}node, also hitherto undocumented, should contain the address of thepacket referring to the list node as its @code{impetus}. The reason forthis additional link is so that it can be followed when the@code{impetus} of the packet is be cleared by @code{avm_dispose} in theevent that the @code{list} node is freed before the computationcompletes. This action is performed in order to preclude a danglingpointer in the @code{impetus} field.@node Instruction Stacks, , Ports and Packets, Emulation Primitives@subsection Instruction StacksA header file named @file{instruct.h} declares a number of memorymanagement and stack operations on a data structure of the followingform.@cindex @code{instruction_node}@examplestruct instruction_node@{  port client;  score sheet;  struct avm_packet actor;  struct avm_packet datum;  instruction dependents;@};@end exampleIn this structure, an @code{instruction} is a pointer to an@code{instruction_node}, a @code{score} is a pointer to a profiledatabase entry as discussed in @ref{Profiling}, and the @code{port} and@code{avm_packet} types are as described in @ref{Ports and Packets}.This data structure is appropriate for a simple virtual machine code@cindex concurrencyevaluation strategy involving no concurrency. The strategy to evaluate anexpression @code{@var{f} @var{x}} would be based on a stack of thesenodes threaded through the @code{dependents} field, and would proceedsomething like this.@enumerate@itemThe stack is initialized to contain a single node having@code{@var{f}} in its @code{actor.contents} field, and @code{@var{x}} inits @code{datum.contents} field.@itemThe @code{client} in this node would refer to a static packet to whose@code{contents} field the final result will be delivered.@itemThe evaluator examines the @code{actor.contents} field on the top of thestack, detects by its form the operation it represents, and decideswhether it corresponds to one that can be evaluated immediately by wayof a canned function available in the library. List reversal,transposition, and comparison would be examples of such operations.@itemIf the operation can be performed in this way, the result is computedand assigned to the destination indicated by the @code{client} field.@itemIf the operation is not easy enough to perform immediately but is of aform recognizable as a combination of simpler operations, it isdecomposed into the simpler operations, and each of them isstrategically positioned on the stack so as to effect the evaluation ofthe combination. For example, if @code{@var{f}} were of the form@code{compose(@var{g},@var{h})} (@code{silly} notation), the node with@code{@var{f}} and @code{@var{x}} would be popped, but a node with@code{@var{g}} as its @code{actor.contents} would be pushed, and then anode with @code{@var{h}} as its @code{actor.contents} and @code{@var{x}}as its @code{datum.contents} would be pushed. Furthermore, the@code{client} field of the latter node would point to the@code{datum.contents} of the one with @code{@var{g}}, and the@code{client} field of the one with @code{@var{g}} would pointwherever the @code{client} of the popped node used to point.@itemIf the operation indicated by the top @code{actor.contents} is neitherimplemented by a canned operation in the library nor easily decomposableinto some that are, the evaluator can either give up or use virtual codeto execute other virtual code. The latter trick is accomplished bypushing a node with @code{@var{f}} as its @code{datum.contents}, and acopy of a hard coded virtual code interpreter @code{@var{V}} as its@code{actor.contents}. The @code{client} of this node will point to the@code{@var{f}} in the original node so as to overwrite it when asimplified version is subsequently computed. The implementation of@code{@var{V}} is a straightforward exercise in @code{silly}programming.@itemIn any case, the evaluator would continue working on the stack untileverything on it has been popped, at which time the result of the entirecomputation will be found in the packet addressed by the @code{client}in the original instruction node.@end enumerateWhat makes this strategy feasible to implement is the assumption of asequential language, wherein synchronization incurs no cost and isautomatic. The availability of any operand is implied by its position atthe top of the stack. If you are reading this section with a view to@cindex threadsimplementing a concurrent or multi-threaded evaluation strategy, it willbe apparent that further provisions would need to be made, such as thatof a @code{data_ready} flag added to the @code{avm_packet} structure.The following functions support the use of stacks of instruction nodesthat would be needed in an evaluation strategy such as the one above.@deftypefun int avm_scheduled (list @var{actor_contents}, counter @var{datum_errors}, list @var{datum_contents}, port @var{client}, instruction *@var{next}, score @var{sheet})This function performs the memory allocation for instruction nodes. Itattempts to create one and to initialize the fields with the givenparameters, returning a pointer to it if successful. It returns a@code{NULL} pointer if the storage could not be allocated.Copies of the @code{list} parameters @code{actor_contents} and@code{data_contents} are made by this function using @code{avm_copied},so the originals still exist as far as the caller is concerned and willhave to be deallocated separately from this structure. The copies aremade only if the allocation succeeds.Any fields other than those indicated by the parameters to this functionare filled with zeros in the result.@end deftypefun@deftypefun void avm_retire (instruction *@var{done})This function performs the storage reclamation of instructions, takingas its argument the instruction to be reclaimed. The @code{list} fieldsin the structure corresponding to the @code{list} parameters used whenit was created are specifically reclaimed as well, using@code{avm_dispose}.The argument to this function is the address of an @code{instruction}rather than just an @code{instruction} so that the @code{instruction}whose address is given may be reassigned as the @code{dependents} fieldof the deallocated node. In this way, the instructions can form a stackthat is popped by this function.This function cooperates with @code{avm_scheduled} in the use of a localcache of instruction nodes in the interest of better performance. Clientmodules should not attempt to allocate or reclaim instructions directlywith @code{malloc} or @code{free}, but use only these functions.It causes a fatal internal error to pass a @code{NULL} pointer to thisfunction.@end deftypefun@deftypefun void avm_reschedule (instruction *@var{next})Given the address of an instruction pointer that may be regarded as thetop of a stack of instructions threaded through the @code{dependents}field, this function exchanges the positions of the top instruction andthe one below it. A fatal internal error is caused if there are fewerthan two instructions in the stack.A use for this function arises in the course of evaluating virtual codeapplications of the form @code{conditional(@var{p},(@var{f},@var{g}))}(in @code{silly} notation). The evaluation strategy would requirepushing nodes for all three constituents, but with @code{@var{p}} pushedlast (therefore evaluated first). The result of the evaluation of@code{@var{p}} would require either the top one or the one below it tobe popped without being evaluated, depending on whether the result isempty.@end deftypefun@deftypefun void avm_initialize_instruct ()This function should be called before any of the instruction memorymanagement functions is called in order to initialize some local datastructures. Results are unpredictable without it.@end deftypefun@deftypefun void avm_count_instruct ()This function should be called after the last call to any of theother functions in this section in order to detect and reportunreclaimed storage associated with them. A warning message will bewritten to standard error if any unreclaimed instructions remain. Thisfunction relies on the assumption that the memory management has beendone only by way of the above functions.@end deftypefun@node External Library Maintenance, , Emulation Primitives, Library Reference@section External Library MaintenanceExternal mathematical library functions such as those documented in@ref{External Libraries} that are invoked from virtual code by the@code{library} combinator (@ref{Library combinator}) are alsoaccessible from C by way of a uniform API implemented by the functionsdeclared in @code{libfuns.h}. This interface applies even to libraries@cindex Fortranimplemented in Fortran such as @code{minpack}. This section brieflydocuments the functions in @code{libfuns.h} and sets out somerecommeded guidelines for developers wishing to add support for otherexternal libraries.@menu* Calling existing library functions::* Implementing new library functions::* Working around library misfeatures::@end menu@node Calling existing library functions, Implementing new library functions, External Library Maintenance, External Library Maintenance@subsection Calling existing library functionsWhatever data types a library function manipulates, its argument andits result are each ultimately encoded each by a single list asexplained in @ref{Type Conversions}. This representation allows alllibrary functions to be invoked by a uniform calling convention asdetailed below.@deftypefun list avm_library_call (list @var{library_name}, @var{list function_name}, list @var{argument}, int *@var{fault})This function serves as an interpreter of external library functionsby taking a @var{library_name}, a @var{function_name}, and an@var{argument} to the result returned by the corresponding libraryfunction for the given @var{argument}.The library and function names should be encoded as lists of characterrepresentations, the same as the arguments that would be used with the@code{library} combinator if it were being invoked by virtual code@cindex backward compatability(with attention to the backward compatibility issue explained in@ref{Characters and Strings}).If an error occurs in the course of evaluating a library function, theinteger referenced by @var{fault} will be assigned a non-zero value,and the result will be a list of character string representationsexplaining the error, such as @code{<'memory overflow'>}, for example.Otherwise, the list returned will encode the result of the libraryfunction in a way that depends on the particular function being evaluated.@end deftypefun@deftypefun list avm_have_library_call (list @var{library_name}, list @var{function_name}, int *@var{fault})This function implements the @code{have} combinator described in@ref{Have combinator}, which tests for the availability of a libraryfunction. The @var{library_name} and @var{function_name} parametersare as explained above for @code{avm_library_call}, and @code{fault}could signal an error similarly for this function as well.The result returned will be an error message in the event of an error,or a list of pairs of strings otherwise. The list will be empty if thelibrary function is not available. If the library function isavailable, the list will contain a single pair, as in@example<(library_name,function_name)>@end exampleIn addition, the list representation of the character string@code{'*'} can be specified as either the library name or the functionname or both. This string is interpreted as a wild card and will causeall matching pairs of library and function names to be returned in thelist.@end deftypefun@deftypefun void avm_initialize_libfuns ()This function initializes some static data structures used by the twofunctions above. It may be called optionally before the first call toeither of them, but will be called automatically if not.@end deftypefun@deftypefun void avm_count_libfuns ()This function can be used as an aid to detecting memory leaks. Itreclaims any data structures allocated by@code{avm_initialize_libfuns} and should be called towards the end ofa run some time prior to @code{avm_count_lists} @ref{SimpleOperations}, if the latter is being used.@end deftypefun@node Implementing new library functions, Working around library misfeatures, Calling existing library functions, External Library Maintenance@subsection Implementing new library functionsAdding more external libraries to @code{avram} is currently a manualprocedure requiring the attention of a developer conversant with C.To support a new library called @code{foobar},these steps need to be followed at a minimum.@itemize @bullet@itemCreate a new file called @file{foobar.h} under the @file{avm/}directory in the main source tree whose name doesn't clash with any@cindex header file@cindex library interface header fileexisting file names and preferably doesn't induce any proper prefixesamong them. This file should contain at least these functiondeclarations.@exampleextern list avm_foobar_call (list function_name,list argument,                             int *fault);extern list avm_have_foobar_call (list function_name,int *fault);extern void avm_initialize_foobar ();extern void avm_count_foobar ();@end exampleThere should also be the usual preprocessor directives for@file{include} files. The naming convention shown should be followed inanticipation of automated support for these operations in the future.@itemAdd @file{foobar.h} to the list of other header files in@file{avm/Makefile.am}.@itemCreate a new file called @file{foobar.c} under the @file{src/}directory whose name doesn't clash with any existing file names to@cindex library interfac source filestore most of the library interface code. It can start out withstubs for the functions declared in @file{foobar.h}.@itemAdd @file{foobar.c} to the list of other source files in@file{src/Makefile.am}@itemExecute the following command in the main @file{avram-x.x.x}source directory where the file @file{configure.in} is found.@exampleaclocal \&& automake --gnu --add-missing \&& autoconf@end exampleThis command requires having @code{automake} and@cindex automake@cindex autoconf@code{autoconf} installed on your system.@itemMake the following changes to @file{libfuns.c}.@itemize @bullet@itemAdd the line @code{#include<avm/foobar.h>} after the@cindex include directivesother @code{include} directives.@itemAdd the string @code{"foobar"} to the end of the array of@code{libnames} in @code{avm_initialize_libfuns}.@item Add a call to @code{avm_initialize_foobar} to the body.@itemAdd a call to @code{avm_count_foobar} to the body of@code{avm_count_libfuns}.@itemAdd a case of the form@examplecase nn:  return avm_foobar_call(function_name,argument,fault);@end exampleafter the last case in @code{avm_library_call}, beingcareful not to change the order, and using the samename as above in the file @file{foobar.h}.@itemAdd a case of the form@examplecase nn:  looked_up = avm_have_foobar_call(function_name,fault);  break;@end exampleafter the last case in @code{avm_have_library_call}, beingcareful not to change the order, and using the same nameas above in the file @file{foobar.h}.@end itemize@itemEdit @file{foobar.c} and @file{foobar.h} to suit,periodically compiling and testing by executing @code{make}.@itemPackage and install at will.@end itemizeThe functions shown above have the obvious interpretations, namelythat @code{avm_foobar_call} evaluates a library function from the@code{foobar} library, and @code{avm_have_foobar_call} tests for afunction's availability. The latter should interpret wild cards asexplained in @ref{Calling existing library functions}, but shouldreturn only a list of strings for the matching function names ratherthan a list of pairs of strings, as the library name is redundant.The remaining functions are for static initialization and reclamation.These functions should consist mainly of boilerplate code similar tothe corresponding functions in any of the other library source files,which should be consulted as examples. The real work would be done byother functions called by them. These should be statically declaredwithin the @file{.c} source file and normally not listed in the@file{.h} header file unless there is some reason to think they may beof more general use. Any externally visible functions should havenames beginning with @code{avm_} to avoid name clashes.Some helpful hints are reported below for what they may be worth.@itemize @bullet@itemThe reason for doing this is to leverage off other people'sintelligence, so generally @code{foobar.c} should contain only gluecode for library routines developed elsewhere with great skill ratherthan reinventing them in some home grown way.@itemThe best numerical software is often written by Fortran@cindex Fortranprogrammers. Linking to a Fortran library is no problem on GNU systemsprovided that all variables are passed by reference and all arrays areconverted to column order (@ref{Type Conversions}).@itemMost C++ programmers have yet to reach a comparable standard, but C++@cindex C++libraries can also be linked by running @code{nm} on the static@cindex nm utilitylibrary file to find out the real names of the functions and@cindex c++filt utility@code{c++filt} to find out which is which. However, thereis no obvious workaround for the use of so called derived classesby C++ programmers to simulate passing functions as parameters.@itemAnything worth using can probably be found in the Debian@cindex Debianarchive.@itemNot all libraries are sensible candidates for interfaces to@code{avram}. Typical design flaws are@itemize @bullet@itemirrepressible debugging messages written to @code{stderr} or@code{stdout} that are unfit for end user consumption@itemdeliberately crashing the application if @code{malloc} fails@itemopaque data types with undocumented storage requirements@itemopaque data types that would be useful to store persistentlybut have platform specific binary representations@itemheavily state dependent@cindex state dependencesemantics@itemidentifiers with clashing names@itemrestrictive@cindex licensing restrictionslicenses@end itemizeSome of these misfeatures have workarounds as explained next in@ref{Working around library misfeatures}, at least if there'snothing else wrong with the library.@end itemizeThose who support @code{avram} are always prepared to assist in thedissemination of worthwhile contributed library modules under termscompatible with @ref{Copying}, and under separate copyrights if@cindex copyrightpreferred.  Contributed modules can be integrated into the officialsource tree provided that they meet the following additional@cindex coding standardsguidelines to those above.@itemize @bullet@itemsource code documentation and indentation according to GNU codingstandards (@url{http://www.gnu.org/prep/standards})@itemsufficient stability for a semi-annual release cycle@itemno run-time or compile-time dependence on any non-free software,although dynamic loading and client/server interaction are acceptable@itemportable or at least unbreakable configuration by appropriate use of@cindex autoconf@code{autoconf} macros and conditional defines@itemlittle or no state dependence at the level of the virtual code@cindex state dependenceinterface (i.e., pure functions or something like them, except for@cindex random number generatorsrandom number generators and related applications)@itemadequate documentation for a section in @ref{External Libraries}@end itemize@node Working around library misfeatures, , Implementing new library functions, External Library Maintenance@subsection Working around library misfeaturesAs mentioned already (@ref{Implementing new library functions}), somecommon problems with external libraries that are worthwhile in otherrespects are that they may generate unwelcome console output whilerunning, they may follow ill defined memory management policies, andthey may handle exceptions just by crashing themselves along with theclient module.An accumulation of techniques for coping with these issues (short ofmodifying the library source) has been collected into the API and madeavailable by way of the header file @file{mwrap.h}. This sectionbriefly documents how they might be put to use.@menu* Inept excess verbiage::* Memory leaks::* Suicidal exception handling::@end menu@node Inept excess verbiage, Memory leaks, Working around library misfeatures, Working around library misfeatures@subsubsection Inept excess verbiageAlthough the author of a library function may take pride in puttingits activities on display, it should be assumed that virtual codeapplications running on @code{avram} have other agendas for theconsole, so the library interface module should prevent direct outputfrom the external library.More thoughtful API's may have a verbosity setting, which should be@cindex verbosity settingused in preference to this workaround, but failing that, it is easy todispense with console output generated by calls to external libraryfunctions by using some combination of the following functions.@deftypefun void avm_turn_off_stdout ()Calling this function will suppress all output to the standard outputstream until the next time @code{avm_turn_on_stdout} is called.Additional calls to this function without intervening calls to@code{avm_turn_on_stdout} may be made safely with no effect.  Thestandard output stream is flushed as a side effect of calling thisfunction.@end deftypefun@deftypefun void avm_turn_on_stdout ()Calling this function will allow output to the standard outputstream to resume if it has been suppressed previously by a call to@code{avm_turn_off_stdout}. If @code{avm_turn_off_stdout} has not beenpreviously called, this function has no effect. Any output that wouldhave been sent to @code{stdout} during the time it was turned off willbe lost.@end deftypefun@deftypefun void avm_turn_off_stderr ()This function performs a similar service to that of@code{avm_turn_off_stdout} but pertains to the standard error stream.The standard error and the standard output streams are controlledindependently even if both of them are piped to the same console.@end deftypefun@deftypefun void avm_turn_on_stderr ()This function performs a similar service to that of@code{avm_turn_on_stdout} but pertains to the standard error stream.@end deftypefunAs an example, the following code fragment will prevent any output tostandard output taking place as a side effect of @code{blather}, butwill allow error messages to standard error. Note that ouput shouldnot be left permanently turned off.@example...#include <avm/mwrap.h>...x = y + z;avm_turn_off_stdout ();w = blather (foo, bar, baz);avm_turn_on_stdout ();return w;...@end exampleOne possible issue with these functions is that they rely on afeature of the GNU C library that might not be portable to non-GNU@cindex portabilitysystems and has not been widely tested on other platforms.Another issue is that a library function could be both careless enoughto clutter the console unconditionally and meticulous enough to checkfor I/O errors after each attempted write. Writing while the outputstream is disabled will return an I/O error to the caller (i.e., tothe verbose library function) for appropriate action, which couldinclude terminating the process.@node Memory leaks, Suicidal exception handling, Inept excess verbiage, Working around library misfeatures@subsubsection Memory leaksIncorrect memory management may undermine confidence in a library whenone wonders what else it gets wrong, but if the worst it does is leavea few bytes unreclaimed, then help is at hand.The first priority is to assess the seriousness of the situation.Similarly to the way library functions are bracketed with calls tothose listed in @ref{Inept excess verbiage}, the following functionsare meant to be placed before and after a call to a library functioneither for diagnostic purposes or production use.@deftypefun void avm_manage_memory ()After this function is called, all subsequent calls to the standard Cfunctions @code{malloc}, @code{free}, and @code{realloc} areintercepted and logged until the next time@code{avm_dont_manage_memory} is called. Furthermore, a completerecord is maintained of the addresses and sizes of all allocated areasof memory during this time in a persistent data structure managedinternally.@end deftypefun@deftypefun void avm_dont_manage_memory ()Calling this function suspends the storage monitoring activitiesinitiated by calling @code{avm_manage_memory}, but the record ofallocated memory areas is not erased.@end deftypefun@deftypefun void avm_debug_memory ()After this function is called and @code{avm_manage_memory} is alsocalled, the standard output stream will display a running account ofthe sizes and addresses of all memory allocations or deallocations asthey occur until the next call to either @code{avm_dont_debug_memory}or @code{avm_dont_manage_memory}.@end deftypefun@deftypefun void avm_dont_debug_memory ()This function stops the output being sent to @code{stdout} caused by@code{avm_debug_memory}, if any, but has no effect on the logging ofmemory management events preformed due to @code{avm_manage_memory}.@end deftypefunWhile the latter two are not useful in production code, they can helpto clarify an inadequately documented API during development byexperimentally identifying the functions that cause memory to beallocated. They can also provide the answer to questions like whetherseparate copies are made from arrays passed to functions (useful forknowing when it's appropriate to free them).Although the console output reveals everything there is to know aboutmemory management during the selected window, the question ofunreclaimed storage is more directly settled by the followingfunctions.@deftypefun void avm_initialize_mwrap ()This function has to be called before any other functions from@file{mwrap.h} in order to clean the slate and prepare the static datastructures for use. This function might not have to be calledexplicitly if the client module is part of @code{avram}, whose mainprogram would have already called it. There is no harm in calling itrepeatedly.@end deftypefun@deftypefun void avm_count_mwrap ()This function should be called after the last call to any otherfunctions in @file{mwrap.h}, when it is expected that all storage thatwas allocated while @code{avm_manage_memory} was in effect should havebeen reclaimed.If there is no unreclaimed storage allocated during an interval whenmemory was being managed, this function returns uneventfully. However,if any storage remains unreclaimed, a message stating the number ofbytes is written to @code{stderr}.If @code{avm_debug_memory} is also in effect when this functiondetects unreclaimed storage, an itemized list of the unreclaimedmemory addresses and their sizes is written to standard output.@end deftypefunOf course, in order for @code{avm_count_mwrap} to report meaningfulresults, any memory that is allocated during the interval betweencalls to @code{avm_manage_memory} and @code{avm_dont_manage_memory}must have been given an opportunity to be reclaimed also whilethis logging mechanism is in effect. However, there may be arbitrarilymany intervening intervals during which it is suspended.On the other hand, any storage that is allocated when memory is notbeing managed must not be freed at a time when it is (except forfreeing a @code{NULL} pointer, which is tolerated but notencouraged). Doing so raises an internal error, causing termination@cindex internal errorwith extreme prejudice. This behavior is a precaution against libraryfunctions freeing storage that they didn't allocate, which would meanno memory is safe and it's better for @code{avram} not to continue.If these investigations uncover no evidence of a memory leak, thenperhaps the relevant library functions are reliable enough to runwithout supervisory memory management. Alternatively, when memoryleaks are indicated, the next function provides a simple remedy.@deftypefun void avm_free_managed_memory ()This function causes all storage to be reclaimed that was allocatedat any time while logging of memory allocation was in effect (i.e.,whenever @code{avm_manage_memory} had been called more recently than@code{avm_dont_manage_memory}). When the storage is freed, no furtherrecord of it is maintained.A side effect of this function is to call @code{avm_dont_manage_memory}and therefore leave memory management turned off.@end deftypefunThis last function when used in conjunction with the others istherefore the workaround for library functions that don't clean upafter themselves. It may be important to do it for them if repeatedcalls to the library function are expected, which would otherwisecause unreclaimed storage to accumulate until it curtailed otheroperations.One small issue with this function is the assumption that unreclaimedstorage is really a leak and not internal library data that isdesigned to persist between calls. If this assumption is not valid,breakage will occur. However, libraries deliberately making use ofpersistent data are likely to have initialization and destructorfunctions as part of their API's, so this assumption is oftenjustified if they don't.An example of using these functions is given below.In this example, @code{allocated_library_object} is a hypotheticalfunction exported by an external library that causes storage to beallocated, and @code{library_reclamation_routine} is provided by thesame library ostensibly to reclaim the storage thusallocated. However, the latter is suspected of memory leaks.The variable @code{my_data} is declared and used by an @code{avram}developer who is presumably competent to reclaim it correctly, ratherthan it being part of an external library. Memory management istherefore enabled during the calls to the library routines but not atother times.The call to @code{avm_count_mwrap} is redundant immediately after acall to @code{avm_free_managed_memory}, because with all managedmemory having been freed, no memory leak will ever be detected, but itis included for illustrative purposes.@example#include <avm/mwrap.h>...@{  void *behemoth;  char *my_data;  avm_initialize_mwrap ();  avm_manage_memory ();  behemoth = allocated_library_object (foo, bar);  avm_dont_manage_memory ();  my_data = (char *) malloc (100);  ...  free (my_data);  avm_manage_memory ();  library_reclamation_routine (&behemoth);  avm_free_managed_memory ();  avm_count_mwrap ();  return;@}@end exampleIt might be a cleaner solution in some sense to omit the call to@code{library_reclamation_routine} entirely, because the storageallocated during the call to @code{allocated_library_object} will bereclaimed perfectly well by @code{avm_free_managed_memory} withoutit. Doing so may also be the only option if the library reclamationroutine is either extremely unreliable or non-existent. However, thestyle above is to be preferred for portability if possible. The memorymanagement functions rely on the availability of the system headerfile @code{malloc.h}, and GNU C library features whose portability isnot assured.  If the required features are not detected on the hostsystem at configuration time, conditional directives in the@code{avram} source will make the @code{avm_}* memory managementfunctions perform no operations, and the responsibility for memorymanagement will devolve to the possibly less robust external libraryimplementation.@node Suicidal exception handling, , Memory leaks, Working around library misfeatures@subsubsection Suicidal exception handlingAn inconvenient characteristic of some external library functions isto terminate the program rather than returning an error status to thecaller for routine events such as a failure of memory allocation.Although in many cases there is no simple workaround for thisbehavior, memory allocation failures at least can be detected andpreventive action taken by using the functions described in thissection.The general approach is to use memory management functions from@file{mwrap.h} as described previously (@ref{Memory leaks}), whileadditionally registering a return destination for a non-local jump to@cindex non-local jumpsbe taken in the event of a memory overflow. The jump is taken when anexternal library function calls @code{malloc} or @code{realloc}unsuccessfully.  The jump avoids passing control back to the libraryfunction, thereby denying it the opportunity to abort, but restoresthe context to that of the jump destination almost as if the libraryfunction and all of its intervening callers had returned normally.The interface is similar to that of the standard @code{setjmp}@cindex setjmpfunction defined in the system header file @code{setjmp.h}, and infact is built on it, but differs in that the client module does notexplicitly refer to jump buffers. Instead, the @code{mwrap} moduleinternally maintains a stack of return destinations.If a jump is taken, it always goes to the most recently registereddestination. It may revert to the previously registered destinationonly when the current one is cleared. This organization provides thenecessary flexibility for multiple clients and recursion, but itnecessitates a protocol whereby each registration of a destinationmust be explicitly cleared exactly once.The following functions implement these two features.@deftypefun int avm_setjmp ()This function specifies the point to which control will pass by anon-local jump if there is insufficient memory to complete asubsequent @code{malloc} or @code{realloc} operation. Only theoperations that take place while memory is being managed due to@code{avm_manage_memory} are affected (@ref{Memory leaks}).The function returns zero when it is called normally and successfullyregisters the return point.It returns a non-zero value when it has been entered by a non-localjump (i.e., when @code{malloc} or @code{realloc} has reportedinsufficient memory while memory management is active), or when thereturn point could not be successfully registered due to insufficientmemory. The client need not distinguish between these two cases,because both correspond to memory overflows and the destination mustbe cleared by @code{avm_clearjmp} regardless.When a non-zero value is returned due to this function being reachedby a non-local jump, it has the side effects of reclaiming all managedmemory by calling @code{avm_free_managed_memory} and disabling memorymanagement by calling @code{avm_dont_manage_memory}.@end deftypefun@deftypefun void avm_clearjmp ()This function cancels the effect of @code{avm_setjmp ()} by preventingfurther non-local jumps to its destination if the destination wassuccessfully registered, or by acknowledging unsuccessful registrationotherwise. It should be called before exiting any function that calls@code{avm_setjmp ()} or anomalous results may ensue.@end deftypefunThe memory management functions @code{avm_manage_memory} and@code{avm_dont_manage_memory} can be useful with or without@code{avm_setjmp}, depending on how much of a workaround is needed fora given library. If a library does not abort on memory overflows,there is no need to use @code{avm_setjmp}, while it may still beappropriate to use the other functions against memory leaks.Calling @code{avm_clearjmp} is particularly important if a clientmodule with memory management that doesn't use @code{avm_setjmp} isinvoked subsequently to one that does, so that memory overflows in thelatter won't cause an attempted jump to a stale destination.A further complication that arises from careful consideration of theseissues is the situation of a client module that does not intend to use@code{avm_setjmp} but is called (perhaps indirectly) by one thatdoes. The latter will have registered a return destination thatremains active and valid even if the former refrains from doing so,thereby allowing a branch to be taken that should have been prevented.Although it is an unusual situation, it can be accommodated by thefollowing function.@deftypefun void avm_setnonjump ()This function temporarily inhibits non-local jumps to destinationspreviously registered by @code{avm_setjmp} until the next time@code{avm_clearjmp} is called. Thereafter, any previously registereddestinations are reinstated.@end deftypefunA sketch of how some of these functions might be used to cope withlibrary functions that would otherwise terminate the program in theevent of a memory overflow is shown below. The GNU @code{libc}@cindex non-local jumpsreference manual contains a related discussion of non-local jumps.@example#include <avm/mwrap.h>...intfunction foobar (foo, bar)...@{char *my_data;  my_data = (char *) malloc (100);  if (avm_setjmp () != 0)    @{      avm_clearjmp ();      avm_turn_on_stdout ();       /* reaching here */      free (my_data);              /* means malloc  */      return ABNORMAL_STATUS;      /* failed below  */    @}  avm_turn_off_stdout ();  avm_manage_memory ();  ...  call_library_functions (foo, bar);    /* may jump */  ...                                   /* to above */  avm_free_managed_memory ();  avm_turn_on_stdout ();  avm_clearjmp ();  free (my_data);            /* reaching here means */  return OK_STATUS;          /* jumping wasn't done */@}@end examplePortability issues with these functions are not well known at this@cindex portabilitywriting. If the configuration script for @code{avram} fails to detectthe required features in @code{setjmp.h} on the host system,conditional compilation directives will disable the functions@code{avm_setjmp}, @code{avm_clearjmp}, and @code{avm_setnonjmp}.However, it may still be possible for the other @code{avm_}* memorymanagement functions to be configured.If @code{setjmp} is not configured, the @code{avm_setjmp} functionis still callable but will always return a value of zero, and willprovide no protection against external library functions aborting theprogram. The other two will perform no operation and return.@node Character Table, Reference Implementations, Library Reference, Top@appendix Character Table@cindex character representationsThis table lists the representations used by @code{avram} forcharacters. The left column shows the character code in decimal. Forprintable characters, the middle column shows the character. The rightcolumn shows the representation used. For example, the letter @code{A} hascharacter code 65, and the representation@code{(nil,(((nil,(nil,(nil,nil))),nil),(nil,nil)))}.These representations were generated automatically to meet varioushelpful criteria, and are not expected to change in future releases. Nocharacter representation coincides with the representations used forboolean values, natural numbers, character strings, pairs of characters,or certain other data types beyond the scope of this document. An easyalgorithm for lexical sorting is possible. Subject to these criteria,the smallest possible trees were chosen.@example  0   (nil,(nil,(nil,((nil,nil),(nil,nil)))))  1   (nil,(nil,((nil,nil),(nil,nil))))  2   (nil,(nil,((nil,nil),(nil,(nil,nil)))))  3   (nil,(nil,((nil,(nil,nil)),(nil,nil))))  4   (nil,(nil,(((nil,nil),nil),(nil,nil))))  5   (nil,(nil,(((nil,nil),(nil,nil)),nil)))  6   (nil,(nil,((((nil,nil),(nil,nil)),nil),nil)))  7   (nil,((nil,nil),(nil,nil)))  8   (nil,((nil,nil),(nil,(nil,nil))))  9   (nil,((nil,nil),(nil,(nil,(nil,nil))))) 10   (nil,((nil,nil),(nil,(nil,(nil,(nil,nil)))))) 11   (nil,((nil,nil),(nil,((nil,nil),(nil,nil))))) 12   (nil,((nil,nil),(nil,((nil,(nil,nil)),nil)))) 13   (nil,((nil,nil),(nil,(((nil,nil),nil),nil)))) 14   (nil,((nil,nil),((nil,nil),(nil,nil)))) 15   (nil,((nil,nil),((nil,nil),(nil,(nil,nil))))) 16   (nil,((nil,nil),((nil,(nil,nil)),nil))) 17   (nil,((nil,nil),((nil,(nil,nil)),(nil,nil)))) 18   (nil,((nil,nil),((nil,(nil,(nil,nil))),nil))) 19   (nil,((nil,nil),(((nil,nil),nil),(nil,nil)))) 20   (nil,((nil,nil),(((nil,nil),(nil,nil)),nil))) 21   (nil,((nil,(nil,nil)),(nil,nil))) 22   (nil,((nil,(nil,nil)),(nil,(nil,nil)))) 23   (nil,((nil,(nil,nil)),(nil,(nil,(nil,nil))))) 24   (nil,((nil,(nil,nil)),(nil,((nil,nil),nil)))) 25   (nil,((nil,(nil,nil)),((nil,nil),nil))) 26   (nil,((nil,(nil,nil)),((nil,nil),(nil,nil)))) 27   (nil,((nil,(nil,nil)),((nil,(nil,nil)),nil))) 28   (nil,((nil,(nil,nil)),(((nil,nil),nil),nil))) 29   (nil,((nil,(nil,(nil,nil))),(nil,nil))) 30   (nil,((nil,(nil,(nil,nil))),(nil,(nil,nil)))) 31   (nil,((nil,(nil,(nil,nil))),((nil,nil),nil))) 32   (nil,((nil,(nil,(nil,(nil,nil)))),(nil,nil))) 33 ! (nil,((nil,(nil,((nil,nil),nil))),(nil,nil))) 34 " (nil,((nil,(nil,((nil,nil),(nil,nil)))),nil)) 35 # (nil,((nil,((nil,nil),nil)),(nil,nil))) 36 $ (nil,((nil,((nil,nil),nil)),(nil,(nil,nil)))) 37 % (nil,((nil,((nil,nil),(nil,nil))),nil)) 38 & (nil,((nil,((nil,nil),(nil,nil))),(nil,nil))) 39 ' (nil,((nil,((nil,nil),(nil,(nil,nil)))),nil)) 40 ( (nil,((nil,((nil,(nil,nil)),nil)),(nil,nil))) 41 ) (nil,((nil,((nil,(nil,nil)),(nil,nil))),nil)) 42 * (nil,((nil,(((nil,nil),nil),nil)),(nil,nil))) 43 + (nil,((nil,(((nil,nil),nil),(nil,nil))),nil)) 44 , (nil,((nil,(((nil,nil),(nil,nil)),nil)),nil)) 45 - (nil,(((nil,nil),nil),(nil,nil))) 46 . (nil,(((nil,nil),nil),(nil,(nil,nil)))) 47 / (nil,(((nil,nil),nil),(nil,(nil,(nil,nil))))) 48 0 (nil,(((nil,nil),nil),((nil,nil),(nil,nil)))) 49 1 (nil,(((nil,nil),nil),((nil,(nil,nil)),nil))) 50 2 (nil,(((nil,nil),(nil,nil)),nil)) 51 3 (nil,(((nil,nil),(nil,nil)),(nil,nil))) 52 4 (nil,(((nil,nil),(nil,nil)),(nil,(nil,nil)))) 53 5 (nil,(((nil,nil),(nil,nil)),((nil,nil),nil))) 54 6 (nil,(((nil,nil),(nil,(nil,nil))),nil)) 55 7 (nil,(((nil,nil),(nil,(nil,nil))),(nil,nil))) 56 8 (nil,(((nil,nil),(nil,(nil,(nil,nil)))),nil)) 57 9 (nil,(((nil,nil),((nil,nil),nil)),(nil,nil))) 58 : (nil,(((nil,nil),((nil,nil),(nil,nil))),nil)) 59 ; (nil,(((nil,nil),((nil,(nil,nil)),nil)),nil)) 60 < (nil,(((nil,(nil,nil)),nil),(nil,nil))) 61 = (nil,(((nil,(nil,nil)),nil),(nil,(nil,nil)))) 62 > (nil,(((nil,(nil,nil)),(nil,nil)),nil)) 63 ? (nil,(((nil,(nil,nil)),(nil,nil)),(nil,nil))) 64 @@ (nil,(((nil,(nil,nil)),(nil,(nil,nil))),nil)) 65 A (nil,(((nil,(nil,(nil,nil))),nil),(nil,nil))) 66 B (nil,(((nil,(nil,(nil,nil))),(nil,nil)),nil)) 67 C (nil,(((nil,((nil,nil),nil)),nil),(nil,nil))) 68 D (nil,(((nil,((nil,nil),nil)),(nil,nil)),nil)) 69 E (nil,((((nil,nil),nil),nil),(nil,nil))) 70 F (nil,((((nil,nil),nil),nil),(nil,(nil,nil)))) 71 G (nil,((((nil,nil),nil),(nil,nil)),nil)) 72 H (nil,((((nil,nil),nil),(nil,nil)),(nil,nil))) 73 I (nil,((((nil,nil),nil),(nil,(nil,nil))),nil)) 74 J (nil,((((nil,nil),(nil,nil)),nil),(nil,nil))) 75 K (nil,((((nil,nil),(nil,nil)),(nil,nil)),nil)) 76 L (nil,((((nil,(nil,nil)),nil),nil),(nil,nil))) 77 M (nil,((((nil,(nil,nil)),nil),(nil,nil)),nil)) 78 N (nil,(((((nil,nil),nil),nil),nil),(nil,nil))) 79 O (nil,(((((nil,nil),nil),nil),(nil,nil)),nil)) 80 P ((nil,nil),(nil,nil)) 81 Q ((nil,nil),(nil,(nil,nil))) 82 R ((nil,nil),(nil,(nil,(nil,nil)))) 83 S ((nil,nil),(nil,(nil,(nil,(nil,nil))))) 84 T ((nil,nil),(nil,(nil,(nil,(nil,(nil,nil)))))) 85 U ((nil,nil),(nil,(nil,((nil,(nil,nil)),nil)))) 86 V ((nil,nil),(nil,(nil,(((nil,nil),nil),nil)))) 87 W ((nil,nil),(nil,((nil,nil),(nil,nil)))) 88 X ((nil,nil),(nil,((nil,(nil,nil)),nil))) 89 Y ((nil,nil),(nil,((nil,(nil,nil)),(nil,nil)))) 90 Z ((nil,nil),(nil,((nil,(nil,(nil,nil))),nil))) 91 [ ((nil,nil),(nil,((nil,((nil,nil),nil)),nil))) 92 \ ((nil,nil),(nil,(((nil,nil),nil),nil))) 93 ] ((nil,nil),(nil,(((nil,nil),nil),(nil,nil)))) 94 ^ ((nil,nil),(nil,(((nil,nil),(nil,nil)),nil))) 95 _ ((nil,nil),(nil,(((nil,(nil,nil)),nil),nil))) 96 ` ((nil,nil),(nil,((((nil,nil),nil),nil),nil))) 97 a ((nil,nil),((nil,nil),(nil,nil))) 98 b ((nil,nil),((nil,nil),(nil,(nil,nil)))) 99 c ((nil,nil),((nil,nil),(nil,(nil,(nil,nil)))))100 d ((nil,nil),((nil,nil),((nil,nil),(nil,nil))))101 e ((nil,nil),((nil,nil),((nil,(nil,nil)),nil)))102 f ((nil,nil),((nil,(nil,nil)),nil))103 g ((nil,nil),((nil,(nil,nil)),(nil,nil)))104 h ((nil,nil),((nil,(nil,nil)),(nil,(nil,nil))))105 i ((nil,nil),((nil,(nil,nil)),((nil,nil),nil)))106 j ((nil,nil),((nil,(nil,(nil,nil))),nil))107 k ((nil,nil),((nil,(nil,(nil,nil))),(nil,nil)))108 l ((nil,nil),((nil,(nil,(nil,(nil,nil)))),nil))109 m ((nil,nil),((nil,((nil,nil),nil)),(nil,nil)))110 n ((nil,nil),((nil,((nil,nil),(nil,nil))),nil))111 o ((nil,nil),((nil,((nil,(nil,nil)),nil)),nil))112 p ((nil,nil),(((nil,nil),nil),(nil,nil)))113 q ((nil,nil),(((nil,nil),nil),(nil,(nil,nil))))114 r ((nil,nil),(((nil,nil),(nil,nil)),nil))115 s ((nil,nil),(((nil,nil),(nil,nil)),(nil,nil)))116 t ((nil,nil),(((nil,nil),(nil,(nil,nil))),nil))117 u ((nil,nil),(((nil,(nil,nil)),nil),(nil,nil)))118 v ((nil,nil),(((nil,(nil,nil)),(nil,nil)),nil))119 w ((nil,nil),((((nil,nil),nil),nil),(nil,nil)))120 x ((nil,nil),((((nil,nil),nil),(nil,nil)),nil))121 y ((nil,nil),(((((nil,nil),nil),nil),nil),nil))122 z ((nil,(nil,nil)),(nil,nil))123 @{ ((nil,(nil,nil)),(nil,(nil,(nil,nil))))124 | ((nil,(nil,nil)),(nil,(nil,(nil,(nil,nil)))))125 @} ((nil,(nil,nil)),(nil,((nil,nil),nil)))126 ~ ((nil,(nil,nil)),(nil,((nil,nil),(nil,nil))))127   ((nil,(nil,nil)),(nil,((nil,(nil,nil)),nil)))128   ((nil,(nil,nil)),((nil,nil),(nil,nil)))129   ((nil,(nil,nil)),((nil,nil),(nil,(nil,nil))))130   ((nil,(nil,nil)),((nil,(nil,nil)),nil))131   ((nil,(nil,nil)),((nil,(nil,nil)),(nil,nil)))132   ((nil,(nil,nil)),((nil,(nil,(nil,nil))),nil))133   ((nil,(nil,nil)),(((nil,nil),nil),(nil,nil)))134   ((nil,(nil,nil)),(((nil,nil),(nil,nil)),nil))135   ((nil,(nil,(nil,nil))),(nil,nil))136   ((nil,(nil,(nil,nil))),(nil,(nil,nil)))137   ((nil,(nil,(nil,nil))),(nil,(nil,(nil,nil))))138   ((nil,(nil,(nil,nil))),(nil,((nil,nil),nil)))139   ((nil,(nil,(nil,nil))),((nil,nil),(nil,nil)))140   ((nil,(nil,(nil,nil))),((nil,(nil,nil)),nil))141   ((nil,(nil,(nil,(nil,nil)))),(nil,nil))142   ((nil,(nil,(nil,(nil,nil)))),(nil,(nil,nil)))143   ((nil,(nil,(nil,(nil,nil)))),((nil,nil),nil))144   ((nil,(nil,(nil,(nil,(nil,nil))))),(nil,nil))145   ((nil,(nil,(nil,((nil,nil),nil)))),(nil,nil))146   ((nil,(nil,((nil,nil),nil))),(nil,nil))147   ((nil,(nil,((nil,nil),(nil,nil)))),(nil,nil))148   ((nil,(nil,((nil,(nil,nil)),nil))),(nil,nil))149   ((nil,(nil,(((nil,nil),nil),nil))),(nil,nil))150   ((nil,((nil,nil),nil)),(nil,nil))151   ((nil,((nil,nil),nil)),(nil,(nil,nil)))152   ((nil,((nil,nil),nil)),(nil,(nil,(nil,nil))))153   ((nil,((nil,nil),nil)),(nil,((nil,nil),nil)))154   ((nil,((nil,nil),nil)),((nil,nil),(nil,nil)))155   ((nil,((nil,nil),nil)),((nil,(nil,nil)),nil))156   ((nil,((nil,nil),(nil,nil))),(nil,nil))157   ((nil,((nil,nil),(nil,nil))),(nil,(nil,nil)))158   ((nil,((nil,nil),(nil,(nil,nil)))),(nil,nil))159   ((nil,((nil,nil),((nil,nil),nil))),(nil,nil))160   ((nil,((nil,(nil,nil)),nil)),(nil,nil))161   ((nil,((nil,(nil,nil)),nil)),(nil,(nil,nil)))162   ((nil,((nil,(nil,nil)),nil)),((nil,nil),nil))163   ((nil,((nil,(nil,nil)),(nil,nil))),(nil,nil))164   ((nil,((nil,(nil,(nil,nil))),nil)),(nil,nil))165   ((nil,((nil,((nil,nil),nil)),nil)),(nil,nil))166   ((nil,(((nil,nil),nil),nil)),(nil,nil))167   ((nil,(((nil,nil),nil),(nil,nil))),(nil,nil))168   ((nil,(((nil,nil),(nil,nil)),nil)),(nil,nil))169   ((nil,(((nil,(nil,nil)),nil),nil)),(nil,nil))170   ((nil,((((nil,nil),nil),nil),nil)),(nil,nil))171   (((nil,nil),nil),(nil,nil))172   (((nil,nil),nil),(nil,(nil,nil)))173   (((nil,nil),nil),(nil,(nil,(nil,nil))))174   (((nil,nil),nil),(nil,(nil,(nil,(nil,nil)))))175   (((nil,nil),nil),(nil,(nil,((nil,nil),nil))))176   (((nil,nil),nil),(nil,((nil,nil),nil)))177   (((nil,nil),nil),(nil,((nil,nil),(nil,nil))))178   (((nil,nil),nil),(nil,((nil,(nil,nil)),nil)))179   (((nil,nil),nil),(nil,(((nil,nil),nil),nil)))180   (((nil,nil),nil),((nil,nil),(nil,nil)))181   (((nil,nil),nil),((nil,nil),(nil,(nil,nil))))182   (((nil,nil),nil),((nil,(nil,nil)),nil))183   (((nil,nil),nil),((nil,(nil,nil)),(nil,nil)))184   (((nil,nil),nil),((nil,(nil,(nil,nil))),nil))185   (((nil,nil),nil),(((nil,nil),nil),(nil,nil)))186   (((nil,nil),nil),(((nil,nil),(nil,nil)),nil))187   (((nil,nil),(nil,nil)),(nil,nil))188   (((nil,nil),(nil,nil)),(nil,(nil,nil)))189   (((nil,nil),(nil,nil)),(nil,(nil,(nil,nil))))190   (((nil,nil),(nil,nil)),(nil,((nil,nil),nil)))191   (((nil,nil),(nil,nil)),((nil,(nil,nil)),nil))192   (((nil,nil),(nil,(nil,nil))),(nil,nil))193   (((nil,nil),(nil,(nil,nil))),(nil,(nil,nil)))194   (((nil,nil),(nil,(nil,(nil,nil)))),(nil,nil))195   (((nil,nil),(nil,((nil,nil),nil))),(nil,nil))196   (((nil,nil),((nil,nil),nil)),(nil,nil))197   (((nil,nil),((nil,nil),nil)),(nil,(nil,nil)))198   (((nil,nil),((nil,nil),(nil,nil))),(nil,nil))199   (((nil,nil),((nil,(nil,nil)),nil)),(nil,nil))200   (((nil,nil),(((nil,nil),nil),nil)),(nil,nil))201   (((nil,(nil,nil)),nil),(nil,nil))202   (((nil,(nil,nil)),nil),(nil,(nil,nil)))203   (((nil,(nil,nil)),nil),(nil,(nil,(nil,nil))))204   (((nil,(nil,nil)),nil),(nil,((nil,nil),nil)))205   (((nil,(nil,nil)),nil),((nil,nil),(nil,nil)))206   (((nil,(nil,nil)),nil),((nil,(nil,nil)),nil))207   (((nil,(nil,nil)),(nil,nil)),(nil,nil))208   (((nil,(nil,nil)),(nil,nil)),(nil,(nil,nil)))209   (((nil,(nil,nil)),(nil,(nil,nil))),(nil,nil))210   (((nil,(nil,nil)),((nil,nil),nil)),(nil,nil))211   (((nil,(nil,(nil,nil))),nil),(nil,nil))212   (((nil,(nil,(nil,nil))),nil),(nil,(nil,nil)))213   (((nil,(nil,(nil,nil))),nil),((nil,nil),nil))214   (((nil,(nil,(nil,nil))),(nil,nil)),(nil,nil))215   (((nil,(nil,(nil,(nil,nil)))),nil),(nil,nil))216   (((nil,(nil,((nil,nil),nil))),nil),(nil,nil))217   (((nil,((nil,nil),nil)),nil),(nil,nil))218   (((nil,((nil,nil),nil)),nil),(nil,(nil,nil)))219   (((nil,((nil,nil),nil)),nil),((nil,nil),nil))220   (((nil,((nil,nil),nil)),(nil,nil)),(nil,nil))221   (((nil,((nil,nil),(nil,nil))),nil),(nil,nil))222   (((nil,((nil,(nil,nil)),nil)),nil),(nil,nil))223   (((nil,(((nil,nil),nil),nil)),nil),(nil,nil))224   ((((nil,nil),nil),nil),(nil,nil))225   ((((nil,nil),nil),nil),(nil,(nil,nil)))226   ((((nil,nil),nil),nil),(nil,(nil,(nil,nil))))227   ((((nil,nil),nil),nil),(nil,((nil,nil),nil)))228   ((((nil,nil),nil),nil),((nil,nil),nil))229   ((((nil,nil),nil),nil),((nil,nil),(nil,nil)))230   ((((nil,nil),nil),nil),((nil,(nil,nil)),nil))231   ((((nil,nil),nil),nil),(((nil,nil),nil),nil))232   ((((nil,nil),nil),(nil,nil)),(nil,nil))233   ((((nil,nil),nil),(nil,nil)),(nil,(nil,nil)))234   ((((nil,nil),nil),(nil,(nil,nil))),(nil,nil))235   ((((nil,nil),nil),((nil,nil),nil)),(nil,nil))236   ((((nil,nil),(nil,nil)),nil),(nil,nil))237   ((((nil,nil),(nil,nil)),nil),(nil,(nil,nil)))238   ((((nil,nil),(nil,nil)),(nil,nil)),(nil,nil))239   ((((nil,nil),(nil,(nil,nil))),nil),(nil,nil))240   ((((nil,nil),((nil,nil),nil)),nil),(nil,nil))241   ((((nil,(nil,nil)),nil),nil),(nil,nil))242   ((((nil,(nil,nil)),nil),nil),(nil,(nil,nil)))243   ((((nil,(nil,nil)),nil),nil),((nil,nil),nil))244   ((((nil,(nil,nil)),nil),(nil,nil)),(nil,nil))245   ((((nil,(nil,nil)),(nil,nil)),nil),(nil,nil))246   ((((nil,(nil,(nil,nil))),nil),nil),(nil,nil))247   ((((nil,((nil,nil),nil)),nil),nil),(nil,nil))248   (((((nil,nil),nil),nil),nil),(nil,nil))249   (((((nil,nil),nil),nil),nil),(nil,(nil,nil)))250   (((((nil,nil),nil),nil),nil),((nil,nil),nil))251   (((((nil,nil),nil),nil),(nil,nil)),(nil,nil))252   (((((nil,nil),nil),(nil,nil)),nil),(nil,nil))253   (((((nil,nil),(nil,nil)),nil),nil),(nil,nil))254   (((((nil,(nil,nil)),nil),nil),nil),(nil,nil))255   ((((((nil,nil),nil),nil),nil),nil),(nil,nil))@end example@node Reference Implementations, Changes, Character Table, Top@appendix Reference ImplementationsThis appendix contains some @code{silly} source code for severalfunctions that are mentioned in @ref{Virtual Code Semantics}, for specifying the virtualmachine code semantics, namely @code{pairwise}, @code{transition},@code{insert} and @code{replace}.The intention is to specify the virtual machine mathematically with aminimum of hand waving, by using only simple equations and smallfragments of @code{silly} code, which has a straightforward semantics.However, the @code{silly} code fragments are more significant in somecases than what could fit into a few lines or be mechanically derivedfrom an equation.The purpose of this appendix is therefore to avoid leaving any gaps inthe construction by demonstrating that everything mentioned can be done. Noneof this code is needed for any practical purpose, because itsfunctionality is inherent in the virtual machine, but it shows howcertain operations would be specified if they were not built in.@menu* Pairwise::                    * Insert::                      * Replace::                     * Transition::                  @end menu@node Pairwise, Insert, Reference Implementations, Reference Implementations@section Pairwise@cindex @code{pairwise}This @code{silly} code fragment is mentioned in @ref{Reduce}, in thediscussion of @code{reduce}, and is provided as an example of a solutionto equations @emph{E1} to @emph{E3}. It is written in the style of ahigher order function, in that it takes a function @code{@var{f}} as anargument and returns another function, [[@code{pairwise}]]@code{@var{f}} as a result.@exampleself     = leftargument = righthead     = lefttail     = rightpairwise =compose(   refer,   compose(      bu(         conditional,         conditional(argument,compose(tail,argument),constant nil)),      couple(         (hired couple)(            (hired compose)(               identity,               constant (hired fan head)(                  argument,                  compose(tail,argument))),            constant (hired meta)(               self,               compose(tail,compose(tail,argument)))),         constant argument)))@end example@noindentTo see how this works, one should evaluate it symbolically with anunknown @code{@var{f}}, which will result in some @code{silly}pseudocode, and then evaluate that symbolically with some sample lists.@node Insert, Replace, Pairwise, Reference Implementations@section Insert@cindex @code{insert}This function is mentioned in @ref{Sort}, on sorting. It takes thevirtual code for a partial order relational operator and returns thecode for a function of two arguments. The left argument is a list itemand the right argument is a list of items of the same type, which isalready sorted with respect to the relational operator given as theargument to @code{insert}. The result of the function returned by@code{insert} is a list similar to its right argument but with the leftargument inserted in the proper position to maintain the order.This code makes use of the @code{self}, @code{argument}, @code{head}and @code{tail} declarations associated with @code{pairwise}.@exampleinsert =bu(compose,refer) (hired conditional)(   constant compose(right,argument),   couple(      (hired conditional)(         (hired compose)(            identity,            constant compose(               couple(left,compose(head,right)),               argument)),         constant (            argument,            couple(               compose(head,compose(right,argument)),               (hired meta)(                  self,                  couple(                     compose(left,argument),                     compose(tail,compose(right,argument))))))),      constant argument))@end exampleAs with the other higher order functions in this appendix, the onlyfeasible ways to verify it would be either by formal proof or by someform of symbolic interpretation.@node Replace, Transition, Insert, Reference Implementations@section Replace@cindex @code{replace}This code is needed in the discussion of assignment in @ref{Assignment}.where it serves as a solution to equation @emph{E0}. The idea is thatthe function takes an argument of the form@code{((@var{locations},@var{values}),@var{store})} and returns thestore with the values stored at the locations indicated.@examplelocations = compose(left,compose(left,argument))values    = compose(right,compose(left,argument))store     = compose(right,argument)replace =refer conditional(   store,   (      conditional(         compose(left,locations),         (            conditional(               compose(right,locations),               (                  (hired meta)(                     self,                     couple(                        (hired fan right)(locations,values),                        (hired meta)(                           self,                           couple(                              (hired fan left)(locations,values),                              store)))),                  couple(                     (hired meta)(                        self,                        couple(                           couple(compose(left,locations),values),                           compose(left,store))),                     compose(right,store)))),            conditional(               compose(right,locations),               (                  couple(                     compose(left,store),                     (hired meta)(                        self,                        couple(                           couple(compose(right,locations),values),                           compose(right,store)))),                  values)))),         (hired meta)(            self,            couple(couple(locations,values),constant (nil,nil)))))@end example@node Transition,  , Replace, Reference Implementations@section TransitionThis code is relevant to the discussion of @code{transfer} in @ref{Transfer},where its specification is described in detail. When this codeis evaluated on a virtual code application @code{@var{f}}, the result isthe code for a transition function that takes one configuration to thenext in the course of evaluating a transfer function, as specified inequations @emph{E7} to @emph{E9}.@cindex @code{transition}@exampleoutput_buffer = compose(left,argument)input_buffer = compose(right,compose(right,argument))active = compose(left,compose(right,argument))state = compose(left,active)output = compose(right,active)transition =bu(compose,refer) (hired bu(conditional,active))(   (hired conditional)(      constant input_buffer,      bu(compose,(fan bu(hired meta,self))) (hired apply)(         constant fan bu(couple,couple(output,output_buffer)),         couple (fan bu(compose,couple))(            couple(               (hired apply)(                  hired,                  constant (state,compose(head,input_buffer))),               constant compose(tail,input_buffer)),            couple(               (hired apply)(hired,constant(state,constant nil)),               constant constant nil)))),   constant compose(flat,compose(reverse,output_buffer)))@end example@node Changes, External Libraries, Reference Implementations, Top@appendix ChangesThis section is reserved for brief updates due to changes in thesoftware that may be important enough to note temporarily until morethorough revisions to the document can be made.The lack of content here indicates that the current version is eithercompletely up to date or in such a sorry state of neglect that eventhis section is obsolete.@node External Libraries, Copying, Changes, Top@appendix External LibrariesVarious functions are callable from virtual code applications by wayof the @code{library} combinator as explained in @ref{Librarycombinator}. An expression (shown in @code{silly} syntax) of the form@code{library('foo','bar') x} applies a function named @code{'bar'}from a library named @code{'foo'} to an argument @code{x}.A brief overview of the libraries and functions can always be had byexecuting@example$ avram --external-libraries@end example@noindentThe listing displayed by this command may show some that are notincluded here if this version of the documentation is not current oryour installation has been locally enhanced. It may also lack somethat are documented here if your installation is not fully equipped.Although the overview from the command line is adequate for areminder, it is not informative enough to explain how each functionshould be used. The purpose of this section is to provide thisinformation in greater detail.Some general comments are applicable to all libraries.Each library documented in this section can generate error messages inthe event of exceptional conditions, that are documented individually.In addition to those, it's also possible for any library function toreturn error messages of@cindex unrecognized library@cindex unrecognized function name@example<'unrecognized library'><'unrecognized @var{xxxx} function name'>@end example@noindentwhere @var{xxxx} is the name of a library.  These indicate either thatthe library name is invalid, or the library name is valid but thefunction name is invalid, or that they're both valid but the librarywasn't detected on the host when @code{avram} was compiled. A virtualcode application can always avoid these errors by testing for theavailability of a function using the @code{have} combinator (@ref{Havecombinator}).In addition, any library function that operates on numerical values orlists thereof can return these messages in cases of invalid input.@cindex missing value@cindex invalid value@cindex bad vector specification@cindex bad matrix specification@example<'missing value'><'invalid value'><'bad vector specification'><'bad matrix specification'>@end example@noindentThese messages indicate that an input parameter that was required tobe a valid representation of a floating point number, a vector,or a matrix was something other than that (@ref{Type Conversions}).The last could also occur if a parameter that is required to bea square matrix has unequal numbers of rows and columns.@menu* bes::       Bessel functions* complex::   native complex arithmetic* fftw::      fast Fourier transforms* glpk::      simplex linear programming* gsldif::    numerical differentiation* gslevu::    series acceleration* gslint::    numerical integration* harminv::   harmonic inversion* kinsol::    constrained non-linear optimization* lapack::    linear algebra* math::      native floating point arithmetic* mtwist::    random number generation* minpack::   non-linear optimization* mpfr::      arbitrary precision arithmetic* lpsolve::   mixed integer programming* rmath::     statistical and special functions* umf::       sparse matrices@end menu@node bes, complex, External Libraries, External Libraries@section @code{bes}An interface to the Bessel functions as defined in the GNU ScientificLibrary (gsl) is available to virtual code applications by invoking afunction of the form@examplelibrary('bes',f)@end example@noindentwhere f is a character string identifying the Bessel function family.All functions in this library return a floating point number encodedas in @ref{math}.@menu* Bessel function calling conventions::* Bessel function errors::@end menu@node Bessel function calling conventions, Bessel function errors, bes, bes@subsection Bessel function calling conventions@cindex bessel functionsThe virtual code interface simplifies the gsl C language API byexcluding the facilities for error estimates, omitting certain arrayvalued functions, and subsuming sets of related functionswithin common ones where possible.The functions with names in the following group take an argument ofthe form @code{(n,x)}, where @code{n} identifies the member of thefunction family, and @code{x} is the argument to the function.@itemize @bullet@item @code{J}regular cylindrical Bessel functions@item @code{Y}irregular cylindrical Bessel functions@item @code{I}regular modified cylindrical Bessel functions@item @code{K}irregular modified cylindrical Bessel functions@end itemizeFor these functions, @code{n} can be either a natural number encodedas in @ref{Representation of Numeric and Textual Data}, or a floatingpoint number encoded as in @ref{math}. The latter case specifiesfunctions of a fractional order. The relevant gsl function is calledbased on the value and type of the parameter.Two further related families of functions follow the same callingconvention.@itemize @bullet@item @code{Isc}scaled regular modified cylindrical Bessel functions@item @code{Ksc}scaled irregular modified cylindrical Bessel functions@end itemize@noindentThe foregoing functions are related to those above by an exponential scalefactor as documented in the gsl reference manual.Functions with names in the following group also take an argument ofthe form @code{(n,x)}, but are not defined for fractional orders andso require a natural number for @code{n}.@itemize @bullet@item @code{j}regular spherical Bessel functions@item @code{y}irregular spherical Bessel functions@item @code{isc}regular modified spherical Bessel functions@item @code{ksc}irregular modified spherical Bessel functions@end itemizeThe functions in the remaining group follow idiosyncratic callingconventions.@itemize @bullet@item @code{zJ0}, @code{zJ1}These take a natural number @code{n} and return the @code{n}th root ofthe regular cylindrical Bessel functions of order 0 or 1,respectively.@item @code{zJnu}This takes a pair @code{(nu,n)} where @code{nu} is the (fractional)order of a regular cylindrical Bessel function, @code{n} is a naturalnumber. It returns the @code{n}th zero of the function.@item @code{lnKnu}This takes a pair of floating point numbers @code{(nu,x)} where@code{nu} is the (fractional) order of an irregular modifiedcylindrical Bessel and @code{x} is the argument to the function,and it returns the natural log of the function.@end itemize@node Bessel function errors, ,Bessel function calling conventions, bes@subsection Bessel function errorsMemory overflows and unrecognized function names can happen as withother library interfaces. A message of@cindex bad bessel function call@example<'bad bessel function call'>@end example@noindentmeans that invalid input parameters were given, such as a fractionalorder to a function family that is defined only for natural orders.@node complex, fftw, bes, External Libraries@section @code{complex}Complex numbers are represented according to the ISO C standard as@cindex complex numbersarrays of two IEEE double precision floating point numbers of 8 byteseach, with the number representing the real part first.A small selection of operations on complex numbers is available byfunction calls of the form @code{library('complex',f)}. Thesefunctions are implemented by the host system's C library.One example is @code{library('complex','create')} which takes a pairof floating point numbers @code{(@var{x},@var{y})} to a complex numberwhose real part is @var{x} and whose imaginary part is @var{y}.See @ref{math} for information about constructing floating pointnumbers.Other than that, the @code{complex} library functions @code{f} fallinto three main groups, which are the real valued unary operations,the complex valued unary operations, and the complex valued binaryoperations. All of these operations are designated by their standard Cnames as documented elsewhere, such as the GNU @code{libc} referencemanual, except as noted.@table @bullet@item @asis{} real valued unary operations@examplecreal  cimag  cabs  carg@end example@item @asis{} complex valued unary operations@exampleccos   cexp    clog   conj   csin    csqrtctan   csinh   ccosh  ctanh  casinh  cacoshcatanh casin   cacos  catan@end example@item @asis{} complex valued binary operations@examplecpow  vid  bus  mul  add  sub  div@end example@end tableThe last four correspond to the C language operators @code{*},@code{+}, @code{-}, and @code{/} for complex numbers.  The functionsnamed @code{vid} and @code{bus} are similar to @code{div} and@code{sub}, respectively, but with the operands interchanged. That is,@examplelibrary('complex','vid') (x,y)@end example@noindentis equivalent to@examplelibrary('complex','div') (y,x)@end exampleAll functions in this library taking complex numbers as input may alsooperate on real numbers, and binary operators can have either or bothoperands real. For real operands, a value of zero is inferred as theimaginary part. The result type of the function is the sameregardless.@node fftw, glpk, complex, External Libraries@section @code{fftw}Some functions in the @code{fftw} fast Fourier transform library are@cindex Fourier transforms@cindex Hartley transformscallable by virtual code programs of the form@code{library('fftw',f)}, where @code{f} can be one of the followingcharacter strings.@table @asis@item @code{u_fw_dft}(uni-dimensional forward Discrete Fourier transform)@item @code{u_bw_dft}(uni-dimensional backward Discrete Fourier transform)@item @code{b_fw_dft}(bi-dimensional forward Discrete Fourier transform)@item @code{b_bw_dft}(bi-dimensional backward Discrete Fourier transform)@item @code{u_dht}(uni-dimensional Discrete Hartley transform)@item @code{b_dht}(bi-dimensional Discrete Hartley transform)@end tableThese stand for the discrete Fourier transform, in one dimension and twodimensions, either backward or forward, and the discrete Hartleytransform in one dimension and two dimensions. The @code{fftw} librarydocumentation (@url{http://www.fftw.org}) can give more informationabout the meaning of these transformations.The interface is somewhat simplified compared to the API for the @code{fftw}C library because there are no considerations of memory management orplanning, nor any provision for dimensions higher than two.Furthermore, from the virtual side of the interface, thesefunctions operate on lists rather than arrays. The one dimensionalFourier transforms take a list of complex numbers to a list of complexnumbers (see @ref{complex}), and the one dimensional Hartleytransforms take a list of reals to a list of reals (see@ref{math}). The two dimensional transforms are analogous but theytake a matrix represented as a list of lists. Error messagespertaining to invalid input documented at the beginning ofthis section (@ref{External Libraries}) are relevant.Finally, unlike the native API for @code{fftw}, these transformations arescaled so that the backward transformation is the inverse of theforward, and the Hartley transformations are their own inverses(subject to roundoff error).@node glpk, gsldif, fftw, External Libraries@section @code{glpk}The @code{glpk} library (@url{ftp://ftp.gnu.org/pub/gnu/glpk/}) solveslinear programming problems by the either the simplex algorithm or@cindex linear programmingan interior point method.The API for C client programs involves a complicated protocol withmany optional settings, which is simplified for the virtual machineinterface. Specifically, the library gives a choice of only twofunctions, which can be expressed in the following forms.@examplelibrary('glpk','simplex')library('glpk','interior')@end example@noindentThese functions have the same calling convention and should returngenerally the same output for identical inputs, but differences inperformance, precision, and maybe correctness can be expected.The remainder of this section applies to both of them.@menu* glpk input parameters::* glpk output::* glpk errors::* Additional glpk notes::@end menu@node glpk input parameters, glpk output, glpk, glpk@subsection @code{glpk} input parametersThe argument must be a triple of the form,@code{(@var{c},(@var{m},@var{y}))}, subject to the following specification.@itemize @bullet@item @var{c}is a list of cost function coefficients as floating point numbers (see@ref{math}). There should be one item of @var{c} for each variable inthe linear programming problem (Note that there is no additiveconstant, which would require one extra).The interpretation of @var{c} is that an assignment of non-negativevalues to the variables @var{x} is sought to make the vector innerproduct @var{c} @var{x} as small as possible.@item @var{m}is a sparse matrix represented as a list of triples in the form@cindex sparse matrix@example<((@var{i},@var{j}),@var{a})...>@end example@noindentwhere @var{i} and @var{j} are row and column indices as naturalnumbers starting from 0 and @var{a} is a non-zero floating pointnumber. The presence of a triple @code{((@var{i},@var{j}),@var{a})} inthe list indicates that the @var{i},@var{j}-th entry in the matrix hasa value of @var{a}.  Missing combinations of @var{i} and @var{j}indicate that the corresponding entry is zero.The interpretation of @var{m} is that together with @var{y} itspecifies a system of equations the variables in the solution @var{x}must satisfy simultaneously, as explained below.@item @var{y}is a list of floating point numbers, with one number for each distinct value of@var{i} in @var{m}, above, needed to complete the equations.The interpretation of @var{y} is that in matrix notation, thecondition @var{m} @var{x} = @var{y} must be met by any acceptablesolution @var{x}.To put it another way, for each distinct value of @var{i}, the @var{i}-th itemof @var{y} has to equal the sum over all @var{j} of @var{xj} @var{a},where @var{a} is the real number appearing in the triple@code{((@var{i},@var{j}),@var{a})} in @var{m}, if any, and @var{xj} isthe @var{j}-th variable of the solution.@end itemize@node glpk output, glpk errors, glpk input parameters, glpk@subsection @code{glpk} outputIf a solution meeting the constraints is found, it is returned as alist of pairs of the form @code{<(@var{i},@var{x})...>}, where each@var{i} is a natural number and each @var{x} is a floating pointnumber giving the value obtained for the @var{i}-th variable numberedfrom zero. Any values of @var{i} that are omitted from the listindicate that the corresponding variable has a value of zero.If no solution is found due to infeasibility or because @code{glpk}just didn't find one, an empty list is returned. The lack of asolution is not treated as an exceptional condition.@node glpk errors, Additional glpk notes, glpk output, glpk@subsection @code{glpk} errorsPossible error messages are@example<'bad glpk specification'>@end example@noindentwhich means that the input did not conform to the description given above,and@example<'memory overflow'>@end exampleIt is not considered an exceptional condition for no feasible solutionto exist, and in that case an empty list is returned. The @code{glpk} documentation gives no assurance as to the correctnessof reported solutions, so the user should also take the possibility ofincorrect results into account.@node Additional glpk notes, , glpk errors, glpk@subsection Additional @code{glpk} notesA sparse matrix representation of @var{m} is used because in practice@cindex sparse matrixmost linear programming problems have very sparse systems of equations.Only the constraint of non-negativity is admitted.  Other@cindex constraintsconstraints such as upper bounds must be effected through a change ofvariables if required.The @code{glpk} library has a small memory leak, which @code{avram}corrects by methods described in @ref{Memory leaks}.@node gsldif, gslevu, glpk, External Libraries@section @code{gsldif}Numerical differentiation of a real valued function of a single real@cindex numerical differentiationvariable can be done by a library function of the form@examplelibrary('gsldif',method)@end example@noindentwhere @code{method} is one of@itemize @bullet@item @code{'backward'}@item @code{'central'}@item @code{'forward'}@item @code{'t_backward'}@item @code{'t_central'}@item @code{'t_forward'}@end itemize@menu* gsldif input parameters::* gsldif output::* gsldif exceptions::* Additional gsldif notes::@end menu@node gsldif input parameters, gsldif output, gsldif, gsldif@subsection @code{gsldif} input parametersThe argument to the functions with mnemonics of @code{backward},@code{central} or @code{forward} is a pair @code{(@var{f},@var{x})},where @var{f} is the virtual machine code for a real valued functionof a real variable, and @var{x} is the input to @var{f} where thederivative is sought. Real numbers are represented according to@ref{math}.The argument to the functions with mnemonics of @code{t_backward},@code{t_central} or @code{t_forward} is a pair @code{((@var{f},@var{t}),@var{x})},where @var{f} and @var{x} are as above, and @var{t} is a tolerance representedas a floating point number. The tolerance is passed throughto the GNU Scientific library (GSL) differentiation routines.When no tolerance is specified, the default is  @code{1.0e-8}.@node gsldif output, gsldif exceptions, gsldif input parameters, gsldif@subsection @code{gsldif} outputThe result returned by @code{library('gsldif',method) (f,x)} or@code{library('gsldif',method) ((f,t),x)}is an approximation of the first derivative of @var{f} evaluated at@var{x}. The result is obtained by the one of the GNU Scientific Library (GSL)@cindex GNU Scientific Libraryfunctions for numerical differentiation that matches the virtual codefunction name. These functions are documented in the GSL referencemanual. The three methods should have approximately the same resultsbut may differ in numerical properties.@node gsldif exceptions, Additional gsldif notes, gsldif output, gsldif@subsection @code{gsldif} exceptionsAn error message of@cindex bad derivative specification@example<'bad derivative specification'>@end example@noindentwill be returned if the either the whole argument, @var{f}, or @var{x} is@code{nil}. Any error message caused by the evaluation of @var{f} willpropagate to the result.@node Additional gsldif notes, , gsldif exceptions, gsldif@subsection Additional @code{gsldif} notesThe function @var{f} may be any expressible virtual machine codefunction that takes a real argument to a real result, including onethat uses other library functions. However, if @var{f} passesfunctions to other library functions as arguments, there is a constantoverhead in stack space for each level, and a remote possibility of a@cindex segmentation faultsegmentation fault if they are very deeply nested.Numerical instability is an issue for higher derivatives (i.e.,differentiating a function that is obtained by differentiating anotherfunction). Some experimentation with larger tolerances may be needed.@node gslevu, gslint, gsldif, External Libraries@section @code{gslevu}This library exports a pair of functions of the form@examplelibrary('gslevu','accel')library('gslevu','utrunc')@end example@noindentthat take a list of real numbers @var{x} to a pair of real numbers@code{(@var{s},@var{e})}.The idea is that @var{x} represents the first few terms of an infinite@cindex infinite seriesseries whose sum converges, but only very slowly. The functions@cindex convergenceextrapolate an estimate of the infinite summation by the Levin@cindex Levin u-transformu-transform as documented in the GNU Scientific Library referencemanual.For well behaved series, considerably fewer terms are needed for anaccurate estimate than a direct summation would require.@menu* gslevu calling conventions::* gslevu exceptions::@end menu@node gslevu calling conventions, gslevu exceptions, gslevu, gslevu@subsection @code{gslevu} calling conventionsThe input to either of these functions is a list of real numbersrepresented as explained in @ref{math}.The result is a pair @code{(@var{s},@var{e})} holding an estimate ofthe sum, @var{s}, and an estimate of the error in the sum,@var{e}, each being a real number.Both functions compute the same sum, @var{s}, but the @code{utrunc} functionis faster and@cindex infinite summore memory efficient, using a less trustworthy method of estimatingthe error.@node gslevu exceptions, , gslevu calling conventions, gslevu@subsection @code{gslevu} exceptionsIf an empty list is passed as a parameter to a function in this library,an error message of @code{<'empty gslevu sequence'>} is returned.If there is insufficient memory, an error message of @code{<'memoryoverflow'>} is returned.Other than that, no exceptional conditions are relevant other than thegeneral ones documented at the beginning of @ref{External Libraries}.@node gslint, harminv, gslevu, External Libraries@section @code{gslint}An interface to a selection of numerical integration routines from the@cindex numerical integrationGNU Scientific Library is provided by functions of the form@examplelibrary('gslint',q)@end example@noindentwhere q can be one of@code{'qng'}, @code{'qng_tol'},@code{'qagx'}, @code{'qagx_tol'},@code{'qagp'}, or @code{'qagp_tol'}.@menu* gslint input parameters::* gslint output::* gslint exceptions::* Additional gslint notes::@end menu@node gslint input parameters, gslint output, gslint, gslint@subsection @code{gslint} input parametersThe library functions @code{qng} and @code{qagx} take anargument of the form @code{(@var{f},(@var{a},@var{b}))}, where @var{f}is a function to be integrated, @var{a} is the lower limit, and@var{b} is the upper limit, both limits being floating point numbersas in @ref{math}.The @code{qng_tol} and @code{qagx_tol} functions take an argument of@cindex tolerancethe form @code{((@var{f},@var{t}),(@var{a},@var{b}))}, where @var{f},@var{a}, and @var{b} are as above, and @var{t} is a specifiedtolerance.The @code{qagp} and @code{qagp_tol} functions take arguments ofthe form @code{(@var{f},@var{p})} and@code{((@var{f},@var{t}),@var{p})}, respectively, where @var{f} and@var{t} are as above, and @var{p} is an ordered list of real numbersspecifying the limits of integration along with arbitrarily manyintervening breakpoints.The integrand @var{f} is expressed in virtual machine code, and takes asingle real argument to a real result. The argument and result of@var{f} are required to be floating point numbers as described in@ref{math}. Any expressible function of this type is acceptable, evenone defined in terms of other integrals, so that a double or tripleintegral can be expressed easily, albeit a costly computation.However, a constant overhead in stack space is required for eachnested library function call, and there is currently no mechanism to@cindex segmentation faultprevent segmentation faults due to a stack overflow.When no tolerance is specified, as with @code{qng}, @code{qagx}, and@code{qagp}, the tightest attainable tolerance is chosen by default,currently @code{2e-14}, in order find the most accurate resultpossible. A selection of progressively looser tolerances is triedautomatically if the tightest one is not successful, stopping wheneither a solution is found or ten orders of magnitude are covered.If a tolerance is explicitly specified, as with @code{qng_tol},@code{qagx_tol} or @code{qagp_tol}, only that tolerance is tried.@node gslint output, gslint exceptions, gslint input parameters, gslint@subsection @code{gslint} outputIn all cases, if no exception occurs, the result returned is anapproximation of the integral of @var{f} over the interval from@var{a} to @var{b} or from the first item of @var{p} to the last.Results may differ in numerical properties depending on theintegration method and the tolerance used. @itemize @bullet@itemThe @code{qagp}* and @code{qagx}* functions use an adaptive algorithm,@cindex adaptive integration@cindex non-adaptive integrationwhereas the @code{qng}* functions use a faster non-adaptive algorithmsuitable only for smooth integrands.@itemFaster and maybe more accurate results are obtained for discontinuousor non-differentiable integrands by the @code{qagp}* integrationmethods if the interior points in @var{p} are chosen to coincide withthe discontinuities or corners.@itemLarger tolerances are conducive to faster but less accurate results inmost cases.@end itemize@node gslint exceptions, Additional gslint notes, gslint output, gslint@subsection @code{gslint} exceptionsIf an argument of an inappropriate form can be detected (such as anempty pair or one without floating point numbers), it causes an errormessage to be returned saying @cindex bad integral specification@example<'bad integral specification'>@end example@noindentError messages signalled by the integrand @var{f} may also bereported, as well as any message returned by @code{gsl_strerror}. Atypical cause for a @code{gsl_strerror} message would be an explicitlyspecified tolerance that is too tight. An error message of@cindex slow convergence@example<'slow convergence'>@end example@noindentis returned in the event of excessively many function evaluations(currently 3600 at each tolerance level).@node Additional gslint notes, , gslint exceptions, gslint@subsection Additional @code{gslint} notesThe @code{qagx}* functions subsume the GSL variants @code{qags},@code{qagiu}, @code{qagil}, and @code{qagi} for finite, semi-infinite,and infinite intervals, which are seleted as appropriate based on the@cindex improper integralslimits of integration @var{a} and @var{b}.The @code{qagp} function reverts to the @code{qagx} function if thereare only two points given in @var{p}. Fewer than two will cause anerror.The library interface code relies on the standard @code{setjmp}@cindex setjmputility found in the system header file @code{setjmp.h} to break outof integrals that don't converge after excessively many functionevaluations. Non-termination has been an issue in the past with GSLintegration routines for very badly behaved integrands, and the APIprovides no documented means for the user supplied integrand functionto request a halt.Although it is meant to be standard, a host without @code{setjmp} willcause @code{avram} to be configured to abort the application with anerror message in the event of non-convergence. This behavior isconsidered preferable to the alternative of non-termination. Usuallyan effective workaround in such cases is to specify a sufficientlyloose tolerance explicitly by using one of the *@code{_tol} libraryfunctions.@node harminv, kinsol, gslint, External Libraries@section @code{harminv}The @code{harminv} library decomposes a complex valued function of a@cindex harminvdiscrete variable into a sum of decaying sinusoids given a finitesample. It uses a method with better accuracy and convergence thanFourier analysis or least squares curve fitting. More information@cindex least squares@cindex Fourier transformsis available at @url{http://ab-initio.mit.edu/wiki/index.php/Harminv}.@menu* harminv input parameters::* harminv output::* harminv exceptions::* Additional harminv notes::@end menu@node harminv input parameters, harminv output, harminv, harminv@subsection @code{harminv} input parametersThe virtual machine interface to the @code{harminv} library providesonly a single function, callable as@examplelibrary('harminv','hsolve')@end example@noindentThe input to this function is an operand of the form@example(signal,(fmin,fmax),nf)@end example@noindentwhere@itemize @bullet@item@code{signal} is a list of complex numbers containing samplesof the function to be decomposed at equal time steps(@ref{complex} and @ref{Representation of Numeric and Textual Data}).@item@code{fmin} and @code{fmax} are the band limits expressed in unitsof inverse time steps as floating point numbers (@ref{math}).@item@code{nf} is the number of spectral basis functions expressed as anatural (@ref{Representation of Numeric and Textual Data}).@end itemize@noindentIf a value of 0 is specified for @code{nf} a default value of@examplemin(300, (fmax - fmin) * n * 1.1)@end example@noindentis used, where @code{n} is the length of @code{signal}. Thecomputation time increases cubically with @code{nf}.@node harminv output, harminv exceptions, harminv input parameters, harminv@subsection @code{harminv} outputThe result returned by a call to@examplelibrary('harminv','hsolve')@end example@noindentwith valid input (@ref{harminv input parameters}) is a list of similar tuples of the form@example<(amplitude,frequency,decay,quality,error)...>@end example@noindentwith all members being real valued except for the amplitudes, which arecomplex. Each tuple describes a function of the form@examplef(t) = A * sin (frequency * t + P) * exp (-decay * t)@end example@noindentsuch that the summation of these functions approximates the originalgiven signal (@ref{harminv input parameters}). The real amplitude@code{A} and phase @code{P} are given by the modulus and argument ofthe complex amplitude returned in the result,@exampleA = library('complex','cabs') amplitudeP = library('complex','carg') amplitude@end example@noindentin terms of the complex library functions (@ref{complex}).The error values are measures of the goodness of fit, and the qualityfactors are defined as@examplequality = (pi * |frequency| / decay)@end example@noindentIt may be useful in some applications to ignore components withquality factors outside of a certain range.@node harminv exceptions, Additional harminv notes, harminv output, harminv@subsection @code{harminv} exceptionsVarious exceptional conditions are possible with the @code{harminv}library interface, and one of the following messages could bereturned. Each of them has the form of a list containing a singlecharacter string.@itemize @bullet@item @code{unrecognized harminv function name}is reported in case of a function call of the form@code{library('harminv',f)} where @code{f} is anything other thanthe character string @code{'hsolve'}, this being the only function inthe library.@item @code{bad harminv function call}is reported if the input parameters don't meet the specificationsdescribed in @ref{harminv input parameters}, or if @code{fmin} isgreater than @code{fmax}. @item @code{bad vector specification}could be the result of a list of real numbers rather than complexnumbers being passed as a @code{signal}. Real numbers canbe converted to complex numbers using the @code{create} function fromthe @code{complex} library (@ref{complex}).@item @code{memory overflow}can occur if @code{avram} is operating very close to the limit of hostmemory, or perhaps if infeasibly large values are passed as @code{nf}@item @code{counter overflow}is similar to a memory overflow@end itemize@node Additional harminv notes, , harminv exceptions, harminv@subsection Additional @code{harminv} notesThe @code{harminv} library interface requires the @code{harminv} and@code{lapack} libraries to be installed on the host system, and alsorequires standard complex number support from the system's C library.The author's installation of @code{avram} has been compiled againstthe Debian @code{harminv} development library package, which at thiswriting is unmaintained and is missing the necessary header file@file{harminv-int.h}, without which compilation of files including@file{harminv.h} fails. Some headers from @file{harminv.h} have beencopied directly into @file{avram-x.x.x/src/harminv.c} under the@code{avram} source tree to avoid this dependence, so that@code{avram} will compile correctly on a Debian system. These may needto be updated if necessary to track the @code{harminv} source.@node kinsol, lapack, harminv, External Libraries@section @code{kinsol}The @code{kinsol} library (@url{http://www.llnl.gov/CASC/sundials/})contains sophisticated routines for non-linear optimization and@cindex optimization@cindex non-linear optimizationconstrained non-linear optimization, some of which are available to@cindex constrained non-linear optimizationvirtual code applications by way of functions expressed as shown.@examplelibrary('kinsol',k)@end example@noindentThe function name @code{k} is a string of the form@code{'@var{xy}_@var{zzzzz}'}. The field @var{zzzzz} specifiesthe optimization algorithm, which can be one of @code{dense},@code{gmres}, @code{bicgs}, or @code{tfqmr}, following the names usedby the API for @code{kinsol} in C. The field @var{y} determinesthe way gradients are obtained, which is either @code{j} for a usersupplied Jacobian, or @code{d} for finite differences computed by@code{kinsol}. The remaining field @var{x} is either @code{c} forconstrained optimization, or @code{u} for unconstrained. Hence, thewhole function name can be one of sixteen possible alternatives.@examplecd_dense   cd_gmres   cd_bicgs   cd_tfqmrud_dense   ud_gmres   ud_bicgs   ud_tfqmrcj_dense   cj_gmres   cj_bicgs   cj_tfqmruj_dense   uj_gmres   uj_bicgs   uj_tfqmr@end exampleMore specific information about the optimization algorithms can befound in the @code{kinsol} documentation at the aboveaddress. Different algorithms may perform better on differentproblems.@menu* kinsol input parameters::* kinsol output::* kinsol exceptions::* Additional kinsol notes::@end menu@node kinsol input parameters, kinsol output, kinsol, kinsol@subsection @code{kinsol} input parametersFunctions whose names are of the form @code{@var{x}d_@var{zzzzz}}take an argument of the form@code{(@var{f},(@var{i},@var{o}))},and functions whose names are of the form @code{@var{x}j_@var{zzzzz}}take an argument of the form@code{((@var{f},@var{j}),(@var{i},@var{o}))}.The parameters have these interpretations.@itemize @bullet@item @var{f} is a function to be optimized, expressed in virtual machinecode. It takes a list of real numbers as input and returns a list ofreal numbers as output. The numbers must be in floating point formatas described in @ref{math}.  @item@var{j} is a function in virtual machine code that computes theJacobian or partial derivatives of @var{f} for a given list of input@cindex Jacobiannumbers. The exact calling convention for @var{j} depends on theoptimization algorithm selected, as explained below.@item@var{i} is a list of real numbers suitable as an input for @var{f}.The exact values of the numbers in @var{i} are not crucial but thelength of @var{i} is taken as an indication of the required length forany input list to @var{f}. In the case of constrained optimizationproblems (i.e., functions with names beginning with @code{c}), @var{i} mustconsist entirely of non-negative numbers.@item@var{o} is a list numbers indicating the ``optimal'' output from@var{f} in the sense described below (@ref{kinsol output}). Its lengthis taken to indicate the usual length of an output returned by@var{f}.@end itemizeIf the optimization problem is being solved by either the@code{cj_dense} or the @code{uj_dense} method, the Jacobian parameter@var{j} is expected to take a list @var{v} of real numbers the lengthof @var{i} as input and return a list of lists of reals as output. Thenumbers are represented as described in @ref{math}. The outer list inthe output from @var{j} is required to be the length of @var{o}, whileeach inner list is required to be the length of @var{i}.The output from @var{j} is interpreted as a matrix of the formdescribed in @ref{Two dimensional arrays}. The entry in row @var{m}and column @var{n} is the partial derivative (evaluated at @var{v}) ofthe @var{m}-th component of the output of @var{f} with respect to the@var{n}-th item of the input list.For optimization problems being solved by the methods of@code{@var{x}j_gmres}, @code{@var{x}j_bicgs}, or@code{@var{x}j_tfqmr}, (i.e., where @var{x} is either @code{c} or@code{u}) the Jacobian function @var{j} follows a different conventionthat is meant to be more memory efficient. Given an argument of theform @code{(@var{m},@var{v})}, it returns only the @var{m}-th row ofthe matrix described above instead of the whole thing. The parameter@var{m} is a natural number less than the length of @var{o}, and@var{v} is a list of real numbers the length of @var{i} the same asabove. The number @var{m} is encoded as described in@ref{Representation of Numeric and Textual Data}.@node kinsol output, kinsol exceptions, kinsol input parameters, kinsol@subsection @code{kinsol} outputThe @code{kinsol} functions attempt to search the domain of@var{f} for a vector @var{v} the length of @var{i} to satisfy@code{@var{f}(@var{v}) = @var{o}} as closely as possible. In the caseof constrained optimization, (i.e., functions whose names begin with@code{c}), only non-negative numbers are acceptable in @var{v}. Thesearch for @var{v} will start in the vicinity of @var{i}. The value of@var{i} will therefore determine a unique solution if multiplesolutions exist, and will save time if it is near a solution.In some cases when a solution can't be found due to non-convergence,@cindex non-convergencean empty list is returned. Non-convergence is not considered anexceptional condition. In all other cases where no exception occurs,the output from a @code{kinsol} function will be the list @var{v} ofreal numbers satisfying @code{@var{f}(@var{v}) = @var{o}} to the bestpossible tolerance.@cindex tolerance@node kinsol exceptions, Additional kinsol notes, kinsol output, kinsol@subsection @code{kinsol} exceptions@itemize @bullet@itemAny error messages that may be generated in the course of evaluatingthe functions @var{f} and @var{j} will propagate to the resultreturned by the @code{kinsol} library functions.@itemIf there is insufficient memory to complete any operation, the resultis a message of @example<'memory overflow'>@end example@itemIf the argument to the library function (i.e.,@code{(@var{f},(@var{i},@var{o}))} or@code{((@var{f},@var{j}),(@var{i},@var{o}))}) fails to meet therequired specifications in a detectable way, the result will be amessage of@cindex bad kinsol specification@example<'bad kinsol specification'>@end example@itemAny status returned by any @code{kinsol} API functions other thansuccess or one of several types of non-convergence results in amessage of @example<'kinsol error'>@end example@end itemize@node Additional kinsol notes, , kinsol exceptions, kinsol@subsection Additional @code{kinsol} notesWhen a user supplied Jacobian function @var{j} is specified, the@cindex Jacobiansolution is likely to be found faster and more accurately. TheJacobian should be given if an analytical form for @var{f} is known,from which the Jacobian can be obtained easily by partialdifferentiation. If the Jacobian is unavailable, a finite differencemethod implemented internally by @code{kinsol} is used as a substituteand will usually yield acceptable results.Tolerances are not explicitly specified on the virtual side of theinterface although the native @code{kinsol} API requires them. A rangeof tolerances over ten orders of magnitude is automatically triedbefore giving up.Similarly to the @code{glpk} and @code{lpsolve} library interfaces(@ref{glpk} and @ref{lpsolve}), the only expressible constraint through@cindex constraintsthe virtual code interface is that all variables arenon-negative. Arbitrary upper and lower bounds can be simulated byappropriate variable substitutions in the formulation of the problem.The @code{kinsol} library natively requires a system function @var{f}with equally many inputs as outputs, and will search only for theinput associated with an output vector of all zeros, but the virtualcode interface relaxes these requirements by allowing a function thattransforms between lists of unequal lengths, and will search for theinput of @var{f} causing it to match any given ``optimal'' output@var{o}. These effects are achieved by padding the shorter of the twovectors transparently and subtracting the specified optimum from theresult.The @code{kinsol} library can be configured to use single precision,double precision, or extended precision arithmetic, but only a doubleprecision configuration is compatible with @code{avram}. Thiscondition is checked when @code{avram} is configured and it will notinterface with alternative @code{kinsol} configurations.The @code{kinsol} library has some more advanced features to whichthis interface doesn't do justice, such as preconditioning, scaling,solution of systems with band limited Jacobians, and concurrentcomputation.@node lapack, math, kinsol, External Libraries@section @code{lapack}An arsenal of weapons grade linear algebra functions from the@cindex Fortran@code{LAPACK} Fortran library is accessible to virtual code@cindex linear algebraapplications through library calls of the form@examplelibrary('lapack',f)@end exampleEach library function @code{f} invokes a @code{LAPACK} function of thesame name, but the calling conventions on the virtual side are anartifact of the interface requiring their own documentation.Some functions that are part of @code{LAPACK} are not described here(mostly the so called computational and auxiliary routines, and@cindex single precisionanything in single precision), because they are not accessible bythe virtual code interface.@menu* lapack calling conventions::* lapack exceptions::* Additional lapack notes::@end menu@node lapack calling conventions, lapack exceptions, lapack, lapack@subsection @code{lapack} calling conventionsA table describing the inputs and outputs to the @code{lapack} libraryfunctions listed by their function names is given in thissection. Some general points related to most of the functions arementioned first.@itemize @bullet@itemReferences to vectors, matrices, and packed matrices should beunderstood as their list representations explained in @ref{TypeConversions}. Although @code{LAPACK} internally uses column orderarrays, the virtual code library interface exhibits a matrix as a listof lists with one inner list for each row.@itemSome functions require a symmetric matrix as an input parameter.  Any@cindex symmetric matricesinput parameter that is required to be a symmetric matrix may bespecified optionally either in square form or in triangular form as@cindex triangular matricesdescribed in @ref{Two dimensional arrays}. If a square matrix form isused, symmetry is not checked and the lower triangular portion isignored.@itemSome function names are listed in pairs differing only in the firstletter.  Function names beginning with @code{d} pertain to vectors ormatrices of real numbers (@ref{math}), and function names beginningwith @code{z} pertain to complex numbers (@ref{complex}). Thespecifications of similarly named functions are otherwise identical.@end itemize@table @asis@item @code{dgesvx}@item @code{zgesvx}These library functions take a pair @code{(@var{a},@var{b})} where@var{a} is an @var{n} by @var{n} matrix and @var{b} is a vector oflength @var{n}. If @var{a} is non-singular, they return avector @var{x} such that @code{@var{a} @var{x} = @var{b}}.Otherwise they return an empty list.@item @code{dgelsd}@item @code{zgelsd}These functions generalize those above by taking a pair@code{(@var{a},@var{b})} where @var{a} is an @var{m} by @var{n} matrixand @var{b} is a vector of length @var{m}, with @var{m} greater than@var{n}. They return a vector @var{x} of length @var{n} to minimizethe magnitude of @code{@var{b} - @var{a} @var{x}}.@item @code{dgesdd}@item @code{zgesdd}These functions take a list of @var{m} time series (i.e., vectors)each of length @var{n} and return a list of basis vectors each oflength @var{n}. The basis vectors span the set of time series in the@cindex singular value decompositiongiven list according to the singular value decomposition (i.e., withthe basis vectors forming a series in order of decreasingsignificance). The number of basis vectors is at most@code{@var{min}(@var{m},@var{n})} but could be less if the input timeseries aren't linearly independent. An empty list could be returneddue to lack of convergence.@item @code{dgeevx}@item @code{zgeevx}These functions take a non-symmetric square matrix andreturn a pair @code{(@var{e},@var{v})} where @var{e} is a list ofeigenvectors and @var{v} is a list of eigenvalues, both of which will@cindex eigenvectorscontain only complex numbers. (N.B., both functions return complexresults even though @code{dgeevx} takes real input.) They could alsoreturn @code{nil} due to a lack of convergence.@item @code{dpptrf}@item @code{zpptrf}These functions take a symmetric square matrix andreturn one of the Cholesky factors. The Cholesky factors are a pair@cindex Cholesky decompositionof triangular matrices, each equal to the transpose of the other,whose product is the original matrix. @itemize @bullet@itemIf the input matrix is specified in lower triangular form, the lowertriangular Cholesky factor is returned.@itemIf the input matrix is specified in square or upper triangular form,the upper triangular Cholesky factor is returned.@itemIn either case, the result is returned in triangular form.@end itemize@item @code{dggglm}@item @code{zggglm}The input is a pair of matrices and a vector@cindex generalized least squares@cindex least squares@code{((@var{A},@var{B}),@var{d})}. The output is a pair of vectors@code{(@var{x},@var{y})} satisfying @code{@var{A}@var{x} +@var{B}@var{y} = @var{d}} for which the magnitude of @var{y} isminimal. The dimensions all have to be consistent, which meansthe number of rows in @var{A} and @var{B} is the length of @var{d},the number of columns in @var{A} is the length of @var{x}, andthe number of columns in @var{B} is the length of @var{y}.@item @code{dgglse}@item @code{zgglse}The input is of the form @code{((@var{A},@var{c}),(@var{B},@var{d}))}where @var{A} and @var{B} are matrices and @var{c} and @var{d} arevectors. The output is a vector @var{x} to minimize the magnitude of@code{@var{A}@var{x} - @var{c}} subject to the constraint that@code{@var{B}@var{x} = @var{d}}. The dimensions have to be consistent,which means @var{A} has @var{m} rows, @var{c} has length @var{m},@var{B} has @var{p} rows, @var{d} has length @var{p}, both @var{A} and@var{B} have @var{n} columns, and the output @var{x} has length@var{n}. It is also a requirement that @code{@var{p} <= @var{n} <=@var{m} + @var{p}}.@item @code{dsyevr}This function takes a symmetric real matrix and returns a pair@code{(@var{e},@var{v})} where @var{e} is a list of eigenvectors and@var{v} is a list of eigenvalues. Both contain only real numbers.This function is fast and accurate but not as storage efficient aspossible. If there is insufficient memory, it automatically invokes@code{dspev}.@item @code{dspev}This function takes a symmetric real matrix and returns a pair@code{(@var{e},@var{v})} where @var{e} is a list of eigenvectors and@var{v} is a list of eigenvalues. Both contain only real numbers.  Ituses roughly half the memory of @code{dsyevr} but is not as fast oraccurate.@item @code{zheevr}This function takes a complex Hermitian matrix and returns a pair@cindex Hermitian matrix@code{(@var{e},@var{v})} where @var{e} is a list of eigenvectors and@var{v} is a list of eigenvalues. The eigenvectors are complex but theeigenvalues are real.@itemize @bullet@itemA Hermitian matrix has @var{Aij} equal to the complex conjugate of@var{Aji}.@itemAlthough not exactly symmetric, a Hermitian matrix may neverthelessbe given in either upper or lower triangular form.@itemThis function is faster but less storage efficient than @code{zhpev},and calls it automatically if it runs out of memory.@end itemize@item @code{zhpev}This function has the same inputs and approximate outputs as@code{zheevr} but is slower and more memory efficient because it usesonly packed matrices.@end table@node lapack exceptions, Additional lapack notes, lapack calling conventions, lapack@subsection @code{lapack} exceptions@itemize @bullet@itemAny of these functions can return a message of@example<'memory overflow'>@end exampleif it runs out of memory. @itemIf the input parameters don't meet thespecification, they can also return@cindex bad lapack specification@example<'bad lapack specification'>@end example@itemAny unexpected behavior from the @code{LAPACK} Fortran functions orirregular status returned by them is reported by the message@cindex lapack error@example<'lapack error'>@end example@noindentGetting to the bottom of it may require some debuggingof the @code{avram} source code in the file @file{lapack.c}.@end itemize@node Additional lapack notes, , lapack exceptions, lapack@subsection Additional @code{lapack} notesThe functions @code{dgesdd} and @code{zgesdd} are an effectivedimensionality reduction technique for a large database of time@cindex dimensionality reductionseries.  A set of basis vectors can be computed once for the database,and then any time series in the database can be expressed as a linearcombination thereof. To the extent that the data embody any redundantinformation, an approximate reconstruction of an individual seriesfrom the database will require fewer coefficients (maybe far fewer) interms of the basis than original length of the series.The library functions @code{dgelsd} and @code{zgelsd} are good for@cindex least squaresfinding least squares fits to empirical data. If the matrix parameter@var{a} is interpreted as a list of inputs and the vector parameter@var{b} as the list of corresponding output data from some unknownlinear function of @var{n} variables @var{f}, then @var{x} is the listof coefficients whereby @var{f} achieves the optimum fit to the datain the least squares sense.These functions solve a special case of the problem solved by@cindex generalized least squares@cindex least squares@code{dggglm} and @code{zggglm} where the parameter @var{B} is theidentity matrix. For the latter functions, the output vector @var{y}can be interpreted as a measure of the error, and @var{B} can bechosen to express unequal costs for errors at different points inthe fitted function.Cholesky decompositions obtained by @code{dpptrf} and @code{zpptrf}@cindex Cholesky decompositionare useful for generating correlated random numbers. A population ofvectors of uncorrelated standard normally distributed random numberscan be made to exhibit any correlations to order by multiplying all of@cindex correlationthe vectors by the lower Cholesky factor of the desired covariance@cindex covariance matrixmatrix.@node math, mtwist, lapack, External Libraries@section @code{math}The @code{math} library exports functions that operate on IEEE doubleprecision floating point numbers using the host system's Clibrary. The numbers are represented natively as contiguous blocks of8 bytes each, and on the virtual side as lists of eight characterrepresentations. (More explanation is given in @ref{TypeConversions}.) These functions take the form@examplelibrary('math',f)@end example@noindentwhere @code{f} is a character string identifying the function in mostcases by its standard name in the C library.@menu* math library operators::* math library predicates::* math library conversion functions::* math library exceptions::* Additional math library notes::@end menu@node math library operators, math library predicates, math, math@subsection @code{math} library operatorsThe unary operators take a single real number to a real result. They@cindex trigonometric functionsinclude@exampleceil  floor round truncsin   cos   tan   sinh   cosh   tanhasin  acos  atan  asinh  acosh  atanhexp   log   sqrt  cbrt   expm1  log1p  fabs@end exampleThe binary operators take a pair of real numbers @code{(@var{x},@var{y})} toa single real number output. They include@examplepow  hypot  atan2  remainder  bus  vid  add  sub  mul  div@end example@noindentwhere the last four correspond to the C language operators @code{+},@code{-}, @code{*}, and @code{/}. The functions named @code{bus} and@code{vid} are like the @code{sub} and @code{div} functions,respectively, with the order of the operands reversed, as explained in@ref{complex}.The meanings of these operators are documented in the GNU @code{libc} referencemanual or other C language references. They follow IEEE standards includingproper handling of @code{nan} and infinity.@node math library predicates, math library conversion functions, math library operators, math@subsection @code{math} library predicatesThere is one binary predicate, @code{islessequal}, and several unary@cindex predicatespredicates, @code{isinfinite}, @code{isnan}, @code{isnormal}, @code{isubnormal}and @code{iszero}.The predicate @code{islessequal} takes a pair of floating pointnumbers @code{(@var{x},@var{y})} as an argument, and returns@code{nil} for a false result and @code{(nil,nil)} for a true result.The unary predicates have the obvious interpretations asclassification functions, and should probably be used in preference tocomparison with constants in case the representations aren't unique.@node math library conversion functions, math library exceptions, math library predicates, math@subsection @code{math} library conversion functionsThe conversion function @code{strtod} takes a string representing a@cindex strtodfloating point number in C format to its representation. This functionis the primary means of creating or initializing floating pointnumbers in virtual code. A value of floating point 0.0 is returned ifthe string is not valid, but no exception is raised.The conversion @code{asprintf} is similar to the one by that name in@cindex asprintfC, but requires a pair @code{(@var{f},@var{x})} as an argument.  Theleft side @var{f} is a character string containing a C style formatconversion for exactly one double precision floating point number,such as @code{'%0.4e'}, and the parameter @var{x} is a floating pointnumber. The result returned will be a character string expressing thenumber in the specified format.@node math library exceptions, Additional math library notes, math library conversion functions, math@subsection @code{math} library exceptionsThe most likely cause of an exception is an attempt to apply a@code{math} library function to @code{nil} or to an argument thatdoesn't represent a floating point number. In these cases, an error@cindex missing value@cindex invalid valuemessage of @code{<'missing value'>} or @code{<'invalid value'>} willbe the result.An error message of @code{<'invalid asprintf() specifier'>} is@cindex invalid asprintf specifierreported by the @code{asprintf} function if the format specifier@cindex asprintfpertains to a string, such as @code{'%s'}. This error is specificallytrapped because the alternative would be a segmentation@cindex segmentation faultfault. Otherwise, invalid format specifiers are not detected orreported.Error messages of @code{<'invalid text format'>} can be generated@cindex invalid text formatby conversion functions if any parameters that are meant to becharacter string representations are something else.There is always a chance of a @code{<'memory overflow'>} error ifthere is insufficient memory to allocate a result.@node Additional math library notes, , math library exceptions, math@subsection Additional @code{math} library notesFloating point exceptions such as division by zero are notspecifically reported as exceptions, but invalid computations can be@cindex nandetected by the propagation of @code{nan} into the result, followingstandard conventions.The C function @code{feclearexcept (FE_ALL_EXCEPT)} is called before@cindex feclearexceptevery floating point operation so that no lingering exception flagscan affect it.There is no library predicate for exact comparison of floating pointnumbers, but none is required because the virtual machine's@code{compare} combinator will work on their representations as it@cindex compare combinatorwill on any other data. The usual caveats apply with regard tocomparing floating point numbers in the presence of roundoff error.@node mtwist, minpack, math, External Libraries@section @code{mtwist}The @code{mtwist} library interfaces to a random number generator@cindex random numbersbased on the Mersenne Twistor algorithm. The algorithm has goodproperties but is not meant to be cryptographically secure. Thelibrary functions are of the form@examplelibrary('mtwist',f)@end example@noindentwhere @code{f} is one of the followng character strings.@examplebern   u_cont   u_disc   u_path   u_enum   w_disc   w_enum@end exampleFormally they are not mathematical functions because their resultsdepend on a pseudo-random number that is not uniquely determined bytheir arguments. The numbers are generated deterministically in asequence starting from a seed derived from the system clock at thetime @code{avram} is launched, and each call uses the next numberin the sequence. In so doing, it simulates a random draw from auniformly distributed population.@menu* mtwist calling conventions::* mtwist exceptions::* Additional mtwist notes::@end menu@node mtwist calling conventions, mtwist exceptions, mtwist, mtwist@subsection @code{mtwist} calling conventionsAll of the functions in this library simulate a random draw from adistribution. There is a choice of distribution statistics dependingon the function used.@table @asis@item @code{bern}takes a floating point number @var{p} between 0 and 1, encoded as in@ref{math}, and returns a boolean value, either @code{(nil,nil)} fortrue or @code{nil} for false. A true value is returned only if arandom draw from a uniform distribution ranging from 0 to 1 is lessthan @var{p}.  This function therefore simulates a draw from aBernoulli distribution. A @code{nil} value of @var{p} is treated as1/2.@item @code{u_cont}takes a floating point number @var{x} as anargument, and returns a random draw from a continuous uniformdistribution ranging from 0 to @var{x}. A @code{nil} value of @var{x}is treated as unity.@item @code{u_disc}simulates a draw from a uniform discrete distribution whose domainis the set of natural numbers from 0 to @var{n} - 1. The number @var{n}is given as a parameter to this function, and the retuned valueis the draw.@itemize @bullet@itemThe returned value will have at most 64 bits regardless of @var{n}.@itemNatural numbers are encoded as described in@ref{Representation of Numeric and Textual Data}.@itemIf a value of 0 is passed for @var{n}, the full 64 bit range isused.@end itemize@item @code{u_path}takes a pair of natural numbers @code{(@var{n},@var{m})} and returns arandomly chosen tree (@ref{Raw Material}) with 1 leaf and @var{n}non-leaves each having either a left or a right descendent but notboth. The number @var{m} constrains the result to fall within thefirst @var{m} - 1 trees of this form enumerated by exhausting allpossibilities at lower levels before admitting a right descendent at ahigher level. Within these criteria, all possible results are equallyprobable. Both numbers are masked to 64 bits, but if @var{m} is zero,it is treated as 2^@var{n}.@item @code{u_enum}simulates a random draw from a uniform discrete distribution whosedomain is enumerated. The argument to the function is a non-empty list,and the result is an item selected from the list, with all choicesbeing equally probable.@item @code{w_disc}simulates a random draw from a non-uniform, or ``weighted'' discretedistribution whose domain is a set of consecutive natural numbersstarting from zero. The argument to the function is a list giving theprobability of each outcome starting from zero as a floating pointnumber. Probabilities must be non-negative but needn't be normalized.@item @code{w_enum}simulates a random draw from a non-uniform, or ``weighted'' discretedistribution with an arbitrary domain enumerated in the argument. Theargument is a list of pairs @code{<(@var{x},@var{p})..>}, where@var{x} is a possible outcome and @var{p} is its probability. Theresult returned is one of the values of @var{x} from the input listchosen at random according to the associatedprobability. Probabilities must be non-negative but needn't benormalized.@end table@node mtwist exceptions, Additional mtwist notes, mtwist calling conventions, mtwist@subsection @code{mtwist} exceptions@itemize @bullet@item@code{<'memory overflow'>} can be returned if there is insufficientmemory to allocate a result.@itemMessages of @code{<'missing value'>} and @code{<'invalid value'>} canbe returned if any floating point argument is @code{nil} or is not avalid floating point number, unless there is a designated defaultinterpretation for @code{nil} as in @code{bern} and @code{u_cont}.@itemA message of @code{<'bad mtwist specification'>} is returned if anargument to the @code{bern} function is not in the range of 0 to 1, orif any probability passed to the @code{w_}* functions is negative.@itemA message of @code{<'draw from empty list'>} is returned ifan argument to the *@code{_enum} functions is @code{nil}or if an argument to @code{w_enum} contains @code{nil}.@end itemize@node Additional mtwist notes, , mtwist exceptions, mtwist@subsection Additional @code{mtwist} notesAlthough the @code{mtwist} library is ``external'', it requires nospecial configuration on the host because the uniform variategenerator in the form developed by its original authors is short andelegant enough to be packaged easily within the @code{avram}distribution. All further embellishments are home grown despite theadvice at the end of @ref{Implementing new library functions}.The @code{u_path} function is intended to allow sampling from a largepopulation in logarithmic time when it is stored in a balanced tree. Aleft-heavy tree should be constructed initially with the data itemsall at the same level. Thereafter, a result returned by @code{u_path}with the appropriate dimensions can be used as an index into the treefor fast retrieval by the virtual machine's @code{field} combinator(@ref{Field}).The last three functions, @code{u_enum}, @code{w_disc}, and@code{w_enum} use an inversion method with a binary search.  The firstdraw from a given list will take a time asymptotically proportional tothe length of the list, but subsequent draws from the same list areconsiderably faster due to a persistent cache maintained transparentlyby @code{avram}. For lists whose length is up to 2^16, the timerequired for a subsequent draw consists mainly of constant overheadwith a small logarithmic component in the length of the list. Forlonger lists, the time ramps up linearly by a small factor.Information allowing fast draws from up to sixteen lists can be cachedsimultaneously. If an application uses more than sixteen, the cacheddata are replaced in first-in first-out order. The size of the cacheand the maximum list length for logarithmic time access can beadjusted easily by redefining constants in @file{mtwist.c} under the@code{avram} source tree, but will require recompilation.@node minpack, mpfr, mtwist, External Libraries@section @code{minpack}The @code{minpack} library contains functions to solve non-linear@cindex non-linear optimizationoptimization and least squares problems. The functions can be@cindex least squaresexpressed as@examplelibrary('minpack',f)@end example@noindentwhere @code{f} can be one of @code{'hybrd'}, @code{'hybrj'},@code{'lmder'}, @code{'lmdif'}, or @code{'lmstr'}, following the namesof the underlying Fortran subroutines.@menu* minpack calling conventions::* minpack exceptions::* Additional minpack notes::@end menu@node minpack calling conventions, minpack exceptions, minpack, minpack@subsection @code{minpack} calling conventionsThe @code{minpack} library solves a similar problem to that of the@code{kinsol} library (@ref{kinsol}), and the two libraries haveidentical calling conventions at the level of the virtual codeinterface.The @code{hybrd} and @code{lmdif} functions take input arguments ofthe form @code{(@var{f},(@var{i},@var{o}))}, whereas @code{hybrj},@code{lmder}, and @code{lmstr} take arguments of the form@code{((@var{f},@var{j}),(@var{i},@var{o}))}.  The interpretations ofthese parameters are explained in @ref{kinsol input parameters}.For the @code{lmstr} function, the Jacobian function @var{j} takes@cindex Jacobianan argument @code{(@var{m},@var{v})} and returns only the @var{m}-throw of the Jacobian matrix. For @code{lmder} and @code{hybrj}, theJacobian function takes only an input vector @var{v} and returns thewhole matrix. These specifications are also explained further inrelation to the @code{kinsol} library.The output from any minpack function is a vector @var{v} satisfying@code{@var{f}(@var{v}) = @var{o}} to the best possible tolerance if a@cindex tolerancesolution is found. A range of tolerances over ten orders of magnitudeis sampled starting from @code{1e-15}. If no solution is found, anempty list is returned.@node minpack exceptions, Additional minpack notes, minpack calling conventions, minpack@subsection @code{minpack} exceptions@itemize @bullet@itemA message of @code{<'memory overflow'>} is possible any time@code{minpack} runs out of memory.@itemA message of @code{<'bad minpack specification'>} will be returned@cindex bad minpack specificationif an input argument recognizably violates the required specification.@itemThe @code{<'minpack error'>} message is returned in the event of any@cindex minpack errorunexpected behavior or irregular status from the API.@itemAny error messages reported by the system function @var{f} or theJacobian function @var{j} are propagated to the result.@end itemize@node Additional minpack notes, , minpack exceptions, minpack@subsection Additional @code{minpack} notesThe @code{lm}* functions are better suited to problems in which thesystem function @var{f} has more outputs than inputs, and the@code{hybr}* functions are better suited to the alternative. If eitheris called when the other is more appropriate, the job is handed off tothe other automatically.The @code{lmstr} function is more memory efficient than the othersbecause it doesn't compute the whole Jacobian matrix at once. Any@cindex Jacobianof the @code{lm}* functions is more memory efficient thanthe @code{kinsol} equivalent when the output list is sufficientlylonger than the input list.Unlike @code{kinsol}, there is no provision in @code{minpack} for@cindex constrained optimizationconstrained optimization.The @code{minpack} documentation doesn't state whether it's@cindex re-entrancyre-entrant, but the odds are against it unless it uses no storageoutside the user provided work areas. If it isn't re-entrant,anomalous effects could occur when a virtual code function beingoptimized calls another @code{minpack} function.  A workaround wouldbe to use an equivalent @code{kinsol} function, which is re-entrant bydesign.The @code{avram} configuration script searches for a C header file@cindex header file@file{minpack.h} on the host system in order to build an interface tothis library. This file is specific to the Debian @code{minpack-dev}package and is not part of the upstream Fortran source. Configuring@code{avram} with an interface to the @code{minpack} library on a@cindex Debiannon-Debian system may require the administrator to retrieve the headerfile manually from the Debian archive and place it under@file{/usr/include} before running the configuration script (inaddition to installing the @code{minpack} library itself, of course).@node mpfr, lpsolve, minpack, External Libraries@section @code{mpfr}The @code{mpfr} library provides a rich assortment of floating pointoperations on arbitrary precision numbers(@url{http://www.mpfr.org}). These numbers are represented in a formatthat is not binary compatible with the standard IEEE floating pointnumber format used by other libraries, but they offer superiornumerical stability suitable for many ill conditioned problems.The virtual code interface to the @code{mpfr} library follows thenative API to the extent of using the same names for most operations,but excludes features pertaining to i/o, mutable storage, and memorymanagement.The @code{mpfr} library functions are invoked by an expression of theform@examplelibrary('mpfr',f)@end example@noindentAside from a few exceptions as noted, @code{f} is a character stringderived from the name of the related function from the @code{mpfr} Clibrary as documented at the above address, but without the@code{mpfr_} prefix.The full complement of available functions is documented in theremainder of this section.@itemize @bullet@itemReferences to natural numbers pertain to the list representationdescribed in @ref{Representation of Numeric and Textual Data}.@itemAll functions that perform rounding use a mode of @code{GMP_RNDN} for@cindex roundingrounding to nearest, which is not explicitly specified on the virtualside.@end itemize@menu* mpfr binary operators::* mpfr unary operators::* mpfr binary operators with a natural operand::* mpfr binary predicates::* mpfr unary predicates::* mpfr constants::* mpfr functions with miscellaneous calling conventions::* mpfr conversion functions::* mpfr exceptions::* Additional mpfr notes::@end menu@node mpfr binary operators, mpfr unary operators, mpfr, mpfr@subsection @code{mpfr} binary operatorsFunctions with these names take a pair of @code{mpfr} numbers@code{(@var{x},@var{y})} and return an @code{mpfr} number as a result.@itemize @bullet@item @code{add}@item @code{sub}@item @code{mul}@item @code{div}@item @code{pow}@item @code{atan2}@item @code{hypot}@item @code{min}@item @code{max}@item @code{vid}@item @code{bus}@end itemizeTheir semantics are similar to those listed in the @code{mpfr}documentation, with some minor qualifications.@itemize @bullet@itemUnlike the native API, there is no third argument to which the resultis assigned, because the result is the returned value.@itemThe precision of the result is the greater of the two precisions ofthe input numbers @var{x} and @var{y}.@itemThe @code{vid} and @code{bus} functions are added features of thevirtual code interface, corresponding to division and subtraction withthe order of the operands reversed, as explained in @ref{complex}.@end itemizeMathematically it might make more sense for the precision of the@cindex precisionresult to be the lesser of the two input precisions, but this way ismore convenient for virtual code programs that perform binaryoperations on their input with hard coded constants, because it makesone size fit all.@node mpfr unary operators, mpfr binary operators with a natural operand, mpfr binary operators, mpfr@subsection @code{mpfr} unary operatorsFunctions with these names take a single @code{mpfr} number as anargument and return a single @code{mpfr} number as a result.@cindex gamma functions@examplesqr      sqrt     cbrt     neg      abs      loglog2     log10    exp      exp2     exp10    cossin      tan      acos     asin     atan     coshsinh     tanh     acosh    asinh    atanh    lngammaexpm1    eint     gamma    erf      log1p    nextbelowceil     floor    round    trunc    frac     nextaboveerfc  @end exampleThe semantics of these functions are similar to those of theircounterparts in the native API, with these provisions.@itemize @bullet@itemThe precision of the result is the precision of the argument.@itemThere is no second argument for assigning the result.@itemThe @code{nextabove} and @code{nextbelow} functions do not modifytheir arguments in place, but return a freshly allocated resultlike all other functions.@end itemize@node mpfr binary operators with a natural operand, mpfr binary predicates, mpfr unary operators, mpfr@subsection @code{mpfr} binary operators with a natural operandFunctions with these names take an argument of the form@code{(@var{x},@var{n})}, where @var{x} is an @code{mpfr} numberand @var{n} is a natural number.@itemize @bullet@item @code{root}@item @code{pow_ui}@item @code{mul_2ui}@item @code{div_2ui}@item @code{grow}@item @code{shrink}@end itemizeThe last two are specific to the virtual code interface, having nocounterpart in the native API of the @code{mpfr} library.  The@code{grow} function returns a copy of @var{x} with its precisionincreased by @var{n} bits, and the @code{shrink} function returns acopy of @var{x} with its precision reduced by @var{n} bits. @itemize @bullet@itemThe precisions are silently capped at the maximum or floored at the@cindex precisionminimum allowable precisions if necessary.@itemIncreasing the precision by the @code{grow} function does not directlycause a more accurate result to be computed, but only pads an existingnumber with zeros.@itemDecreasing the precision by the @code{shrink} function does not preventvalid bits from being discarded.@end itemizeThe appropriate way to use @code{grow} is to grow the precision of anoperand before applying an operator to it, which will cause the resultto be computed to the full precision. This capability is suitable foralgorithms that iterate over increasing precisions until a stoppingcriterion is met.@node mpfr binary predicates, mpfr unary predicates, mpfr binary operators with a natural operand, mpfr@subsection @code{mpfr} binary predicatesThese predicates take a pair of @code{mpfr} numbers@code{(@var{x},@var{y})} as arguments and perform a logical operation.If the result is true, they return @code{(nil,nil)}, and if it'sfalse, they return @code{nil}.@itemize @bullet@item @code{equal_p}@item @code{unequal_abs}@item @code{greater_p}@item @code{greaterequal_p}@item @code{less_p}@item @code{lessequal_p}@item @code{lessgreater_p}@end itemizeThe name of the function @code{unequal_abs}, for comparing absolutevalues, has been changed from @code{mpfr_cmpabs} to avoid confusionwith the virtual machine's @code{compare} combinator. The@code{compare} combinator returns a @code{(nil,nil)} result (i.e.,true) if the@cindex compare combinatoroperands are equal and a @code{nil} result if they're unequal,opposite from @code{unequal_abs}.@node mpfr unary predicates, mpfr constants, mpfr binary predicates, mpfr@subsection @code{mpfr} unary predicatesEach of these predicates takes an @code{mpfr} number as an argumentand performs a logical operation. If the result is true, it returns@code{(nil,nil)}, and otherwise it returns @code{nil}.@itemize @bullet@item @code{nan_p}@item @code{inf_p}@item @code{number_p}@item @code{zero_p}@item @code{integer_p}@end itemize@node mpfr constants, mpfr functions with miscellaneous calling conventions, mpfr unary predicates, mpfr@subsection @code{mpfr} constantsEach of these functions takes a natural number as an argumentspecifying a precision, and returns a mathematical constant evaluatedto that precision.@itemize @bullet@item @code{const_log2}@item @code{pi}@item @code{const_catalan}@item @code{inf}@item @code{ninf}@item @code{nan}@end itemizeThe name of the constant @code{pi} has been shortened from@code{mpfr_const_pi}.  The functions @code{inf} and @code{ninf} returninfinity and negative infinity, respectively.The encoding of @code{nan}, used to represent the results of undefined@cindex nancomputations such as division by zero, is not unique even for a fixedprecision.  Applications should test for undefined results using@code{nan_p} rather than by comparing a result to a hard coded@code{nan} (@ref{mpfr unary predicates}).@node mpfr functions with miscellaneous calling conventions, mpfr conversion functions, mpfr constants, mpfr@subsection @code{mpfr} functions with miscellaneous calling conventionsSome functions listed below don't conform to any of the previouslymentioned calling conventions.@table @asis@item @code{eq}This is a ternary operator taking a triple@code{(@var{prec},(@var{x},@var{y}))}, where @var{prec} is a naturalnumber and @var{x} and @var{y} are @code{mpfr} numbers. It returns aresult of @code{(nil,nil)} (i.e., true) if the numbers agree up to thespecified precision measured in bits, and returns @code{nil}otherwise.@footnote{a potentially useful tool for algorithms concernedwith numerical approximations despite its inexplicable malignment inthe @code{mpfr} documentation}@item @code{urandomb}This function takes a natural number specifying a precision and@cindex random numbersreturns a uniformly distributed pseudo-random number of that precisionbetween 0 and 1.@item @code{prec}This function takes an @code{mpfr} number and returns a natural numberas a result, which is the precision of the argument in bits.@item @code{sin_cos}This function takes an @code{mpfr} number @var{z} as an argument andreturns a pair of @code{mpfr} numbers @code{(@var{x},@var{y})} as aresult, where @var{x} is the sine of @var{z} and @var{y} is the cosine.  Theprecisions of the results are the same as the precision of theargument.@end table@node mpfr conversion functions, mpfr exceptions, mpfr functions with miscellaneous calling conventions, mpfr@subsection @code{mpfr} conversion functionsThe functions described in this section convert between @code{mpfr}numbers and character strings, naturals, or standard IEEE floatingpoint format (in their list representations). Where these functionshave similar or equivalent counterparts in the @code{mpfr} library'snative API, the names have been changed for mnemonic reasons.@table @asis@item @code{dbl2mp}The input is a standard floating point number as in @ref{math}. Theresult is an @code{mpfr} number equal to the input with afixed precision, currently set to 160 bits.@item @code{mp2dbl}The input is an @code{mpfr} number, and the output is the bestpossible approximation to it by a standard a double precisionnumber.@item @code{str2mp}The input is a pair @code{(@var{prec},@var{s})}, where @var{prec} is anatural number specifying the precision, and @var{s} is a stringexpressing a floating point number in C format. The output is an@code{mpfr} number with the specified precision.@item @code{mp2str}The input is an @code{mpfr} number, and the output is a characterstring expressing the number in exponential decimal notation.Sufficiently many decimal digits are included in the string to expressthe full precision.@item @code{nat2mp}The input is a natural number represented as described in@ref{Representation of Numeric and Textual Data},and the output is an @code{mpfr} number of sufficient precision toexpress the natural number exactly.@end tableThe @code{mp2str} function enhances the native @code{mpfr_get_str}function by properly formatting the output string rather than onlylisting the digits of the mantissa.The @code{nat2mp} function does not rely on the @code{mpfr} nativeinteger conversion functions, so natural numbers with any number ofbits up to @code{MP_PREC_MAX} can be used losslessly. There iscurrently no conversion in the other direction.@node mpfr exceptions, Additional mpfr notes, mpfr conversion functions, mpfr@subsection @code{mpfr} exceptions@itemize @bullet@itemA message of @code{<'memory overflow'>} is possible any time@code{mpfr} runs out of memory.@itemA message of @code{<'bad mpfr specification'>} will be returned@cindex bad mpfr specificationif an input argument recognizably violates the required specification.@itemThe @code{<'mpfr error'>} message is returned in the event of any@cindex mpfr errorunexpected behavior or irregular status from the API.@itemThe message of @code{<'mpfr overflow'>} can be cause by the@code{nat2mp} function if a natural number has too many bits to berepresented exactly as an @code{mpfr} number.@end itemize@node Additional mpfr notes, , mpfr exceptions, mpfr@subsection Additional @code{mpfr} notesThe @code{eq} and @code{urandomb} functions depend not only on the@code{mpfr} library but on the @code{gmp} library@cindex gmp library(@url{http://ftp.gnu.org/gnu/gmp}). It's possible for them to beunavailable on a host without @code{gmp} even if the rest of the@code{mpfr} library is properly configured.The file @code{mpfr.c} in the @code{avram} source tree exports acouple of functions that may be of use to C hackers interested infurther development of @code{avram} with @code{mpfr}. The functions@code{avm_mpfr_of_list} and @code{avm_list_of_mpfr} convert betweenthe native representation for @code{mpfr} numbers and the caching listrepresentation used by @code{avram} (@ref{Type Conversions}). Thisconversion is non-trivial because the numbers are not storedcontiguously.@node lpsolve, rmath, mpfr, External Libraries@section @code{lpsolve}This library interface exports functions to solve linear programming@cindex mixed integer programming@cindex linear programmingand mixed integer programming problems using the @code{lpsolve}package documented at@url{http://lpsolve.sourceforge.net/5.5/}.@noindentOf the two linearprogramming solvers currently interfaced with @code{avram}, this oneis believed to be the more robust.@menu* lpsolve calling conventions::* lpsolve return values::* lpsolve errors::@end menu@node lpsolve calling conventions, lpsolve return values, lpsolve, lpsolve@subsection @code{lpsolve} calling conventionsThe library is able to solve linear and mixed integer programmingproblems, depending on which function is selected. The@cindex linear programmingfunction to call the linear programming solver is of the form@itemize @bullet@item @code{library('lpsolve','stdform')}@end itemize@noindent@cindex mixed integer programmingand the mixed integer programming functions are of the form@itemize @bullet@item @code{library('lpsolve','iform')}@item @code{library('lpsolve','bform')}@item @code{library('lpsolve','biform')}@end itemize@noindentThe argument to the @code{stdform} function represents a triple@code{(@var{c},(@var{m},@var{y}))}, which has the same interpretationdescribed in @ref{glpk input parameters}. The arguments to the @code{iform},@code{bform}, and @code{biform} functions are tuples@code{(@var{i},(@var{c},(@var{m},@var{y})))}@code{(@var{b},(@var{c},(@var{m},@var{y})))}, and@code{((@var{b},@var{i}),(@var{c},(@var{m},@var{y})))}, respectively, where@var{c}, @var{m}, and @var{y} are as above, and@itemize @bullet@item @var{b} is a list of binary variable column indices@item @var{i} is a list of integer variable column indices@end itemize@noindentwhere column indices pertain to the constraint matrix, and arenumbered from zero.  Specifying some or all variables as integersdirects the solver to seek only solutions in which those variableshave integer values, and specifying any as binary directs the solverto seek only solutions in which those variables have values of zero orone.  The IEEE floating point representation is used for all variablesregardless (@ref{math}).@node lpsolve return values, lpsolve errors, lpsolve calling conventions, lpsolve@subsection @code{lpsolve} return valuesIf a feasible and optimal solution is found, a list of values for the variablesis returned in the form @code{<(@var{i},@var{x})...>}, where @var{i} is a naturalnumber and @var{x} is a floating point number giving the value of the @var{i}-thvariable numbered from zero. Values of @var{x} equal to zero are omitted.@node lpsolve errors, , lpsolve return values, lpsolve@subsection @code{lpsolve} errorsIf any calling conventions are not followed, an exception is raised and a diagnosticmessage of @code{bad lpsolve problem specification} is reported. If no feasible solutioncan be found, no exception is raised but an empty list is returned.@node rmath, umf, lpsolve, External Libraries@section @code{rmath}A selection of mathematical and statistical functions from the GNU Rmath library has a virtual code interface of the form@examplelibrary('rmath',f)@end example@noindentwhere @code{f} is a character string derived from the name of afunction in the C language API described in the manual@file{R-exts.pdf}, available at @url{http://www.r-project.org}.Every function in the library returns a real result in the form of@ref{math}, but functions differ in the argument types. The argumentsare tuples of real numbers and booleans that also closely follow thenative API as explained below.@menu* rmath statistical functions::* rmath miscellaneous functions::* rmath exceptions::@end menu@node rmath statistical functions, rmath miscellaneous functions, rmath, rmath@subsection @code{rmath} statistical functionsFunctions for evaluating random draws, density, cumulative probabilityand inverse cumulative probability are provided for some of the morefrequently used probability distributions, which are chi-squared,non-central chi-squared, exponential, lognormal, normal, poisson,Student's t, and uniform.Each distribution is known by an abbreviated name and specified by one@cindex distributions@cindex probability distributions@cindex statistical distributionsor two real parameters as listed below. Names of distributions in thistable form the stem of a library function name.  The names of theparameters such as @var{mu} and @var{sigma} are not explicitlymentioned when invoking the functions, but are listed here forreference.  The precise definitions of the distribution functions andinterpretations of these parameters can be found in standard texts onprobability and statistics.@examplechisq         @var{df}nchisq        @var{df}, @var{lambda}exp           @var{scale}lnorm         @var{logmean}, @var{logsd}norm          @var{mu}, @var{sigma}pois          @var{lambda}t             @var{n}unif          @var{a}, @var{b}@end exampleThe virtual code interface follows a naming convention similar to thenative API, in that function names beginning with @code{r} representrandom draws from a distribution, with the argument to the functionbeing the parameters specifying the distribution. Functions in thisfirst group return a random draw from a distribution described by asingle real parameter.@itemize @bullet@item @code{rchisq}@item @code{rexp}@item @code{rpois}@item @code{rt}@end itemize@noindentThese next functions return random draws from distributions specifiedby a pair of parameters, @code{(@var{x},@var{y})}.@itemize @bullet@item @code{rnchisq}@item @code{rlnorm}@item @code{rnorm}@item @code{runif}@end itemizeFunctions whose names begin with @code{d} evaluate the probabilitydensity of a distribution at a given point. They require at least tworeal arguments, the first being the point whose probability density issought, and the remaining ones being the parameters that specify thedistribution. A boolean operand, which is @code{nil} for false and@code{(nil,nil)} for true, requests the logarithm of the density whentrue.Functions with names in the following group take a triple with tworeal operands and a boolean, @code{(@var{x},(@var{y},@var{a}))}, andreturn a probabiity density.@itemize @bullet@item @code{dchisq}@item @code{dexp}@item @code{dpois}@item @code{dt}@end itemize@noindentThe next functions pertain to distributions requiring two paramters tospecify them, so they take a quadruple with three real operands and aboolean, @code{(@var{x},(@var{y},(@var{z},@var{a})))}.@itemize @bullet@item @code{dnchisq}@item @code{dlnorm}@item @code{dnorm}@item @code{dunif}@end itemizeFunctions whose names begin with @code{p} or @code{q} obtain@cindex cumulative probabilitycumulative probabilities or inverse cumulative probabilitiesrespectively for a specified distribution. They require one realoperand to identify the point whose probability or inverse probabilityis sought, and other real operands to parameterize the distribution,as above. There are also two boolean operands. The first is true inorder to request a probability or inverse probability with respect tothe lower tail as opposed to the upper, and the other is true toindicate that probabilities are to be expressed logarithmically.The argument to these functions is a quadruple with two real operandsand two booleans, @code{(@var{x},(@var{y},(@var{a},@var{b})))}.@itemize @bullet@item @code{pchisq}, @code{qchisq}@item @code{pexp}, @code{qexp}@item @code{ppois}, @code{qpois}@item @code{pt}, @code{qt}@end itemize@noindentThe remaining functions pertain to distributions parameterized by tworeal operands. These take a quintuple with three real operands and twobooleans, @code{(@var{x},(@var{y},(@var{z},(@var{a},@var{b}))))}.@itemize @bullet@item @code{pnchisq},@code{qnchisq}@item @code{plnorm},@code{qlnorm}@item @code{pnorm},@code{qnorm}@item @code{punif},@code{qunif}@end itemize@node rmath miscellaneous functions, rmath exceptions, rmath statistical functions, rmath@subsection @code{rmath} miscellaneous functionsSome less frequently used real valued mathematical functions are alsoaccessible by the @code{rmath} library interface.  The functions with@cindex gamma functionsnames in this group take a single real operand.@examplegammafn         lgammafn        digammatrigamma        tetragamma      pentagamma@end example@noindentThe ones in this group take a pair of real operands@cindex bessel functions@code{(@var{x},@var{y})}.@examplebeta            lbeta           bessel_j       bessel_y@end example@noindentThose remaining take a triple of real operands@code{(@var{x},(@var{y},@var{z}))}.@examplebessel_i        bessel_k@end exampleAn alternative and better documented selection of Bessel functions isprovided by the @code{bes} library interface (@ref{bes}).@node rmath exceptions, , rmath miscellaneous functions, rmath@subsection @code{rmath} exceptionsThe only exceptional condition specific to the @code{rmath} libraryinterface is associated with the message @code{<'bad rmathspecification'>}, which means that a tuple given as an argument@cindex bad rmath specificationhas the wrong number or types of operands.@node umf, ,rmath, External Libraries@section @code{umf}Systems of equations described by sparse matrices (i.e., matrices@cindex sparse matricescontaining mostly zeros) arise in certain practical problems. Theusual array representation in which zeros are explicitly stored wouldbe prohibitive for large matrices occurring in many problems ofinterest. A more sophisticated approach is used by the @code{umf}library to manage memory efficiently, which is documented at@url{http://www.cise.ufl.edu/research/sparse/SuiteSparse/current/SuiteSparse/UMFPACK/Doc/}.A virtual code interface to functions for solving sparse systems ofequations by these methods is afforded by library functions of the form@examplelibrary('umf',f)@end example@noindentwhere the library function name, @code{f} is a character stringof the form @code{@var{tt}_@var{m}_@var{rrr}}.@itemize @bullet@item @var{tt}can be either @code{di} for real matrices, or @code{zi} for complex.@item @var{m}can be one of @code{a}, @code{t}, or @code{c} for solving a systemgiven either by a matrix, its transpose, or its conjugate transpose,respectively,@cindex conjugate transposecorresponding to mnemonics @code{A}, @code{Aat} and @code{At} used inthe C language API.@item @var{rrr}is either @code{trp} or @code{col}, to indicate a sparse matrix expressedeither as a list of triples, or in packed column form, as documented below.@end itemizeThe complete set of function names for this library interface is asfollows.@exampledi_a_trp      di_a_col       zi_a_trp       zi_a_coldi_t_trp      di_t_col       zi_t_trp       zi_t_col                             zi_c_trp       zi_c_col@end example@noindentNot all combinations are represented, because the conjugate transposeis relevant only to complex matrices.@menu* umf input parameters::* umf output::* umf exceptions::* Additional umf notes::@end menu@node umf input parameters, umf output, umf, umf@subsection @code{umf} input parametersFor a square matrix @var{A} and a column vector @var{b}, the@code{umf} functions find the solution @var{x} to the matrix equation@var{M} @var{x} = @var{b}, where @var{M} is either @var{A}, thetranspose of @var{A}, or its conjugate transpose. As noted above, thechoice is determined by whether the the function name is of the form*@code{_a_}*, *@code{_t_}*, or *@code{_c_}* respectively.The argument to any of these functions is a pair@code{(@var{A},@var{b})}, where @var{A} represents the matrixmentioned above and @var{b} represents the column vector.The parameter @var{b} is required to be a list of numbers whose lengthmatches the number of rows in the matrix. The numbers are either realnumbers for the @code{di_}* functions (@ref{math}), or complexfor the @code{zi_}* functions (@ref{complex}).There is a choice of representations for the parameter @var{A},depending on whether the function being called is one of the *@code{_trp}functions or one of the *@code{_col} functions.For the *@code{_trp} functions, @var{A} is represented as a non-emptylist of triples @code{<((@var{i},@var{j}),@var{v})...>}, where eachitem of the list corresponds to a non-zero entry in the matrix.@itemize @bullet@itemThe parameters @var{i} and @var{j} are natural numbers as in@ref{Representation of Numeric and Textual Data}. @itemThe value @var{v} is a real number for the @code{di_}*@code{_trp} functions or acomplex number for the @code{zi_}*@code{_trp} functions.@itemThe presence of a triple ((@var{i},@var{j}),@var{v}) in the listsignifies that the @var{i},@var{j}-th entry in the matrix @var{A}(numbered from zero) has a value of @var{v}.@end itemizeFor the *@code{_col} functions, the representation of @var{A} is morecomplicated but has a slight advantage in memory usage. It may alsohave an advantage in speed unless more time is wasted on the virtualside transforming a matrix to this representation than it saves.In this case, @var{A} is represented by a triple of the form@code{((@var{p},@var{i}),@var{v})}. The parameters @var{p} and @var{i}are lists of natural numbers. The parameter @var{v} is a list of realnumbers for the @code{di_}*@code{_col} functions and complex numbersfor the @code{zi_}*@code{_col} functions. They have the followinginterpretations.@itemize @bullet@item @var{v}is the list of non-zero entries in the matrix in@cindex column major ordercolumn major order.@item @var{i}has the same length as @var{v}, and each item of @var{i} is the rowindex of the corresponding item in @var{v}, numbered from zero.@item @var{p}has the length of the number of columns in the matrix, and eachitem identifies the starting position of a column in @var{v} and@var{i}, numbered from zero.@end itemize@noindentThe first item of @var{p} is always zero. Further explanation of thisformat in terms of an array representation can be found in the file@file{UMFPACK_UserGuide.pdf}, available from the @code{umf} libraryhome page at @url{http://www.cise.ufl.edu/research/sparse/SuiteSparse/current/SuiteSparse/}.@node umf output, umf exceptions, umf input parameters, umf@subsection @code{umf} outputIf no exception occurs, the solution @var{x} to the matrix equation@var{M} @var{x} = @var{b} noted previously will be returned if oneexists. The solution is represented as either a list of real numbers as in@ref{math}, or a list of complex numbers as in @ref{complex}. Realnumbers are returned by the @code{di_}* functions, and complex numbersare returned by the @code{zi_}* functions.If no solution exists due to a singular matrix, an empty list isreturned. The lack of a solution isn't treated as an exceptionalcondition.@node umf exceptions, Additional umf notes, umf output, umf@subsection @code{umf} exceptionsIf an exceptional condition arises from the use of this library, oneof the following lists of character strings may be returned as thefunction result.@itemize @bullet@item@code{<'memory overflow'>} means the library function ran out ofmemory, most likely due to a matrix being too large.@item@code{<'bad umf specification'>} means an input parameter didn't@cindex bad umf specificationconform to the appropriate format described above (@ref{umf inputparameters})@item@code{<'umf error'>} covers any unexpected behavior or abnormal@cindex umf errorstatus returned by any function from the C language API.@end itemizeFor the *@code{_trp} functions. A non-square matrix will cause thesecond exception above. For the *@code{_col} functions, a non-squarematrix will cause the third exception or cause an empty resultto be returned.The exceptions noted at the beginning of this section (@ref{ExternalLibraries}) are also possible.@node Additional umf notes, , umf exceptions, umf@subsection Additional @code{umf} notesThe C language API to @code{umf} provides very many less frequentlyused features that are not part of the virtual code interface, some ofwhich could be added by minor modifications to the file @file{umf.c}in the @code{avram} source tree. A set of @code{dl_}* and @code{zl_}* functions orthogonal to thosepresently accessible would enable matrices having billions of rows orcolumns by using long integers, but memory requirements on the virtualcode side for problems of that scale are probably prohibitive for theforeseeable future.@node Copying, Function Index, External Libraries, Top@setfilename gpl.info@appendix GNU GENERAL PUBLIC LICENCE@center Version 2, June 1991@displayCopyright @copyright{} 1989, 1991 Free Software Foundation, Inc.675 Mass Ave, Cambridge, MA 02139, USAEveryone is permitted to copy and distribute verbatim copiesof this license document, but changing it is not allowed.@end display@menu * Preamble::* Terms and Conditions::* How to Apply::@end menu@node Preamble, Terms and Conditions, ,Copying@unnumberedsec Preamble  The licenses for most software are designed to take away yourfreedom to share and change it.  By contrast, the GNU General PublicLicense is intended to guarantee your freedom to share and change freesoftware---to make sure the software is free for all its users.  ThisGeneral Public License applies to most of the Free SoftwareFoundation's software and to any other program whose authors commit tousing it.  (Some other Free Software Foundation software is covered bythe GNU Library General Public License instead.)  You can apply it toyour programs, too.  When we speak of free software, we are referring to freedom, notprice.  Our General Public Licenses are designed to make sure that youhave the freedom to distribute copies of free software (and charge forthis service if you wish), that you receive source code or can get itif you want it, that you can change the software or use pieces of itin new free programs; and that you know you can do these things.  To protect your rights, we need to make restrictions that forbidanyone to deny you these rights or to ask you to surrender the rights.These restrictions translate to certain responsibilities for you if youdistribute copies of the software, or if you modify it.  For example, if you distribute copies of such a program, whethergratis or for a fee, you must give the recipients all the rights thatyou have.  You must make sure that they, too, receive or can get thesource code.  And you must show them these terms so they know theirrights.  We protect your rights with two steps: (1) copyright the software, and(2) offer you this license which gives you legal permission to copy,distribute and/or modify the software.  Also, for each author's protection and ours, we want to make certainthat everyone understands that there is no warranty for this freesoftware.  If the software is modified by someone else and passed on, wewant its recipients to know that what they have is not the original, sothat any problems introduced by others will not reflect on the originalauthors' reputations.  Finally, any free program is threatened constantly by softwarepatents.  We wish to avoid the danger that redistributors of a freeprogram will individually obtain patent licenses, in effect making theprogram proprietary.  To prevent this, we have made it clear that anypatent must be licensed for everyone's free use or not licensed at all.  The precise terms and conditions for copying, distribution andmodification follow.@node Terms and Conditions, How to Apply, Preamble, Copying@unnumberedsec TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION@enumerate@itemThis License applies to any program or other work which containsa notice placed by the copyright holder saying it may be distributedunder the terms of this General Public License.  The ``Program'', below,refers to any such program or work, and a ``work based on the Program''means either the Program or any derivative work under copyright law:that is to say, a work containing the Program or a portion of it,either verbatim or with modifications and/or translated into anotherlanguage.  (Hereinafter, translation is included without limitation inthe term ``modification''.)  Each licensee is addressed as ``you''.Activities other than copying, distribution and modification are notcovered by this License; they are outside its scope.  The act ofrunning the Program is not restricted, and the output from the Programis covered only if its contents constitute a work based on theProgram (independent of having been made by running the Program).Whether that is true depends on what the Program does.@itemYou may copy and distribute verbatim copies of the Program'ssource code as you receive it, in any medium, provided that youconspicuously and appropriately publish on each copy an appropriatecopyright notice and disclaimer of warranty; keep intact all thenotices that refer to this License and to the absence of any warranty;and give any other recipients of the Program a copy of this Licensealong with the Program.You may charge a fee for the physical act of transferring a copy, andyou may at your option offer warranty protection in exchange for a fee.@itemYou may modify your copy or copies of the Program or any portionof it, thus forming a work based on the Program, and copy anddistribute such modifications or work under the terms of Section 1above, provided that you also meet all of these conditions:@enumerate a@itemYou must cause the modified files to carry prominent noticesstating that you changed the files and the date of any change.@itemYou must cause any work that you distribute or publish, that inwhole or in part contains or is derived from the Program or anypart thereof, to be licensed as a whole at no charge to all thirdparties under the terms of this License.@itemIf the modified program normally reads commands interactivelywhen run, you must cause it, when started running for suchinteractive use in the most ordinary way, to print or display anannouncement including an appropriate copyright notice and anotice that there is no warranty (or else, saying that you providea warranty) and that users may redistribute the program underthese conditions, and telling the user how to view a copy of thisLicense.  (Exception: if the Program itself is interactive butdoes not normally print such an announcement, your work based onthe Program is not required to print an announcement.)@end enumerateThese requirements apply to the modified work as a whole.  Ifidentifiable sections of that work are not derived from the Program,and can be reasonably considered independent and separate works inthemselves, then this License, and its terms, do not apply to thosesections when you distribute them as separate works.  But when youdistribute the same sections as part of a whole which is a work basedon the Program, the distribution of the whole must be on the terms ofthis License, whose permissions for other licensees extend to theentire whole, and thus to each and every part regardless of who wrote it.Thus, it is not the intent of this section to claim rights or contestyour rights to work written entirely by you; rather, the intent is toexercise the right to control the distribution of derivative orcollective works based on the Program.In addition, mere aggregation of another work not based on the Programwith the Program (or with a work based on the Program) on a volume ofa storage or distribution medium does not bring the other work underthe scope of this License.@itemYou may copy and distribute the Program (or a work based on it,under Section 2) in object code or executable form under the terms ofSections 1 and 2 above provided that you also do one of the following:@enumerate a@itemAccompany it with the complete corresponding machine-readablesource code, which must be distributed under the terms of Sections1 and 2 above on a medium customarily used for software interchange; or,@itemAccompany it with a written offer, valid for at least threeyears, to give any third party, for a charge no more than yourcost of physically performing source distribution, a completemachine-readable copy of the corresponding source code, to bedistributed under the terms of Sections 1 and 2 above on a mediumcustomarily used for software interchange; or,@itemAccompany it with the information you received as to the offerto distribute corresponding source code.  (This alternative isallowed only for noncommercial distribution and only if youreceived the program in object code or executable form with suchan offer, in accord with Subsection b above.)@end enumerateThe source code for a work means the preferred form of the work formaking modifications to it.  For an executable work, complete sourcecode means all the source code for all modules it contains, plus anyassociated interface definition files, plus the scripts used tocontrol compilation and installation of the executable.  However, as aspecial exception, the source code distributed need not includeanything that is normally distributed (in either source or binaryform) with the major components (compiler, kernel, and so on) of theoperating system on which the executable runs, unless that componentitself accompanies the executable.If distribution of executable or object code is made by offeringaccess to copy from a designated place, then offering equivalentaccess to copy the source code from the same place counts asdistribution of the source code, even though third parties are notcompelled to copy the source along with the object code.@itemYou may not copy, modify, sublicense, or distribute the Programexcept as expressly provided under this License.  Any attemptotherwise to copy, modify, sublicense or distribute the Program isvoid, and will automatically terminate your rights under this License.However, parties who have received copies, or rights, from you underthis License will not have their licenses terminated so long as suchparties remain in full compliance.@itemYou are not required to accept this License, since you have notsigned it.  However, nothing else grants you permission to modify ordistribute the Program or its derivative works.  These actions areprohibited by law if you do not accept this License.  Therefore, bymodifying or distributing the Program (or any work based on theProgram), you indicate your acceptance of this License to do so, andall its terms and conditions for copying, distributing or modifyingthe Program or works based on it.@itemEach time you redistribute the Program (or any work based on theProgram), the recipient automatically receives a license from theoriginal licensor to copy, distribute or modify the Program subject tothese terms and conditions.  You may not impose any furtherrestrictions on the recipients' exercise of the rights granted herein.You are not responsible for enforcing compliance by third parties tothis License.@itemIf, as a consequence of a court judgment or allegation of patentinfringement or for any other reason (not limited to patent issues),conditions are imposed on you (whether by court order, agreement orotherwise) that contradict the conditions of this License, they do notexcuse you from the conditions of this License.  If you cannotdistribute so as to satisfy simultaneously your obligations under thisLicense and any other pertinent obligations, then as a consequence youmay not distribute the Program at all.  For example, if a patentlicense would not permit royalty-free redistribution of the Program byall those who receive copies directly or indirectly through you, thenthe only way you could satisfy both it and this License would be torefrain entirely from distribution of the Program.If any portion of this section is held invalid or unenforceable underany particular circumstance, the balance of the section is intended toapply and the section as a whole is intended to apply in othercircumstances.It is not the purpose of this section to induce you to infringe anypatents or other property right claims or to contest validity of anysuch claims; this section has the sole purpose of protecting theintegrity of the free software distribution system, which isimplemented by public license practices.  Many people have madegenerous contributions to the wide range of software distributedthrough that system in reliance on consistent application of thatsystem; it is up to the author/donor to decide if he or she is willingto distribute software through any other system and a licensee cannotimpose that choice.This section is intended to make thoroughly clear what is believed tobe a consequence of the rest of this License.@itemIf the distribution and/or use of the Program is restricted incertain countries either by patents or by copyrighted interfaces, theoriginal copyright holder who places the Program under this Licensemay add an explicit geographical distribution limitation excludingthose countries, so that distribution is permitted only in or amongcountries not thus excluded.  In such case, this License incorporatesthe limitation as if written in the body of this License.@itemThe Free Software Foundation may publish revised and/or new versionsof the General Public License from time to time.  Such new versions willbe similar in spirit to the present version, but may differ in detail toaddress new problems or concerns.Each version is given a distinguishing version number.  If the Programspecifies a version number of this License which applies to it and ``anylater version'', you have the option of following the terms and conditionseither of that version or of any later version published by the FreeSoftware Foundation.  If the Program does not specify a version number ofthis License, you may choose any version ever published by the Free SoftwareFoundation.@itemIf you wish to incorporate parts of the Program into other freeprograms whose distribution conditions are different, write to the authorto ask for permission.  For software which is copyrighted by the FreeSoftware Foundation, write to the Free Software Foundation; we sometimesmake exceptions for this.  Our decision will be guided by the two goalsof preserving the free status of all derivatives of our free software andof promoting the sharing and reuse of software generally.@iftex@heading NO WARRANTY@end iftex@ifinfo@center NO WARRANTY@end ifinfo@itemBECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTYFOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW.  EXCEPT WHENOTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIESPROVIDE THE PROGRAM ``AS IS'' WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSEDOR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OFMERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.  THE ENTIRE RISK ASTO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.  SHOULD THEPROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,REPAIR OR CORRECTION.@itemIN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITINGWILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/ORREDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISINGOUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITEDTO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BYYOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHERPROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THEPOSSIBILITY OF SUCH DAMAGES.@end enumerate@iftex@heading END OF TERMS AND CONDITIONS@end iftex@ifinfo@center END OF TERMS AND CONDITIONS@end ifinfo@page@node How to Apply, , Terms and Conditions, Copying@unnumberedsec How to Apply These Terms to Your New Programs  If you develop a new program, and you want it to be of the greatestpossible use to the public, the best way to achieve this is to make itfree software which everyone can redistribute and change under these terms.  To do so, attach the following notices to the program.  It is safestto attach them to the start of each source file to most effectivelyconvey the exclusion of warranty; and each file should have at leastthe ``copyright'' line and a pointer to where the full notice is found.@smallexample@var{one line to give the program's name and an idea of what it does.}Copyright (C) 19@var{yy}  @var{name of author}This program is free software; you can redistribute it and/ormodify it under the terms of the GNU General Public Licenseas published by the Free Software Foundation; either version 2of the License, or (at your option) any later version.This program is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with this program; if not, write to the Free SoftwareFoundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.@end smallexampleAlso add information on how to contact you by electronic and paper mail.If the program is interactive, make it output a short notice like thiswhen it starts in an interactive mode:@smallexampleGnomovision version 69, Copyright (C) 19@var{yy} @var{name of author}Gnomovision comes with ABSOLUTELY NO WARRANTY; for detailstype `show w'.  This is free software, and you are welcometo redistribute it under certain conditions; type `show c' for details.@end smallexampleThe hypothetical commands @samp{show w} and @samp{show c} should showthe appropriate parts of the General Public License.  Of course, thecommands you use may be called something other than @samp{show w} and@samp{show c}; they could even be mouse-clicks or menu items---whateversuits your program.You should also get your employer (if you work as a programmer) or yourschool, if any, to sign a ``copyright disclaimer'' for the program, ifnecessary.  Here is a sample; alter the names:@smallexample@groupYoyodyne, Inc., hereby disclaims all copyrightinterest in the program `Gnomovision'(which makes passes at compilers) written by James Hacker.@var{signature of Ty Coon}, 1 April 1989Ty Coon, President of Vice@end group@end smallexampleThis General Public License does not permit incorporating your program intoproprietary programs.  If your program is a subroutine library, you mayconsider it more useful to permit linking proprietary applications with thelibrary.  If this is what you want to do, use the GNU Library GeneralPublic License instead of this License.@node Function Index, Concept Index, Copying, Top@unnumbered Function Index@printindex fn@node Concept Index,  , Function Index, Top@unnumbered Concept Index@printindex cp@byepcx has been ditched, but this section is left herein case someone decides to put it back@node pcx, lpsolve, mpfr, External Libraries@section @code{pcx}This library interface exports a function that uses the algorithmdocumented at @url{http://www-fp.mcs.anl.gov/otc/Tools/PCx/} to solvelinear programming problems by an interior point method. The library@cindex linear programmingfunction is of the form@examplelibrary('pcx','solution')@end example@noindentThis function has the same calling conventions as@code{library('glpk','simplex')} and @code{library('glpk','interior')}(@ref{glpk}).@cindex internal errorsError messages are also the same as @ref{glpk errors}, except that thea message text of @code{<'bad pcx specification'>} is used.  Inaddition, @code{pcx} can cause a virtual machine internal error (code70), which is raised when @code{avram} detects access anomalies by anexternal library, or in the worst case, a segmentation fault.@cindex segmentation faultA working configuration of this library interface requires a sharedlibrary @file{libPCx.so} to be installed on the host, which is not afeature of the standard installation distributed by the authors of@code{PCx}. However, the shared library can be built from the sourcepackage by any system administrator familiar with theseprocedures. Alternatively, an unofficial patched version of the Debian@cindex Debianpackage of @code{pcx} that includes the shared library is available onthe @code{avram} home page. This patch has been submitted to theDebian maintainer of @code{pcx} and may be expected in a futurerelease.If @code{avram} has been built already on a system that has the@code{pcx} header files but not the shared library, it should bepossible to get the @code{pcx} library interface to work just byinstalling the shared library without recompiling @code{avram},because @code{pcx} is dynamically loaded due to licensingrestrictions.
 |