PNG  IHDRX cHRMz&u0`:pQ<bKGD pHYsodtIME MeqIDATxw]Wug^Qd˶ 6`!N:!@xI~)%7%@Bh&`lnjVF29gΨ4E$|>cɚ{gk= %,a KX%,a KX%,a KX%,a KX%,a KX%,a KX%, b` ǟzeאfp]<!SJmɤY޲ڿ,%c ~ع9VH.!Ͳz&QynֺTkRR.BLHi٪:l;@(!MԴ=žI,:o&N'Kù\vRmJ雵֫AWic H@" !: Cé||]k-Ha oݜ:y F())u]aG7*JV@J415p=sZH!=!DRʯvɱh~V\}v/GKY$n]"X"}t@ xS76^[bw4dsce)2dU0 CkMa-U5tvLƀ~mlMwfGE/-]7XAƟ`׮g ewxwC4\[~7@O-Q( a*XGƒ{ ՟}$_y3tĐƤatgvێi|K=uVyrŲlLӪuܿzwk$m87k( `múcE)"@rK( z4$D; 2kW=Xb$V[Ru819קR~qloѱDyįݎ*mxw]y5e4K@ЃI0A D@"BDk_)N\8͜9dz"fK0zɿvM /.:2O{ Nb=M=7>??Zuo32 DLD@D| &+֎C #B8ַ`bOb $D#ͮҪtx]%`ES`Ru[=¾!@Od37LJ0!OIR4m]GZRJu$‡c=%~s@6SKy?CeIh:[vR@Lh | (BhAMy=݃  G"'wzn޺~8ԽSh ~T*A:xR[ܹ?X[uKL_=fDȊ؂p0}7=D$Ekq!/t.*2ʼnDbŞ}DijYaȲ(""6HA;:LzxQ‘(SQQ}*PL*fc\s `/d'QXW, e`#kPGZuŞuO{{wm[&NBTiiI0bukcA9<4@SӊH*؎4U/'2U5.(9JuDfrޱtycU%j(:RUbArLֺN)udA':uGQN"-"Is.*+k@ `Ojs@yU/ H:l;@yyTn}_yw!VkRJ4P)~y#)r,D =ě"Q]ci'%HI4ZL0"MJy 8A{ aN<8D"1#IJi >XjX֔#@>-{vN!8tRݻ^)N_╗FJEk]CT՟ YP:_|H1@ CBk]yKYp|og?*dGvzنzӴzjֺNkC~AbZƷ`.H)=!QͷVTT(| u78y֮}|[8-Vjp%2JPk[}ԉaH8Wpqhwr:vWª<}l77_~{s۴V+RCģ%WRZ\AqHifɤL36: #F:p]Bq/z{0CU6ݳEv_^k7'>sq*+kH%a`0ԣisqにtү04gVgW΂iJiS'3w.w}l6MC2uԯ|>JF5`fV5m`Y**Db1FKNttu]4ccsQNnex/87+}xaUW9y>ͯ骵G{䩓Գ3+vU}~jJ.NFRD7<aJDB1#ҳgSb,+CS?/ VG J?|?,2#M9}B)MiE+G`-wo߫V`fio(}S^4e~V4bHOYb"b#E)dda:'?}׮4繏`{7Z"uny-?ǹ;0MKx{:_pÚmFמ:F " .LFQLG)Q8qN q¯¯3wOvxDb\. BKD9_NN &L:4D{mm o^tֽ:q!ƥ}K+<"m78N< ywsard5+вz~mnG)=}lYݧNj'QJS{S :UYS-952?&O-:W}(!6Mk4+>A>j+i|<<|;ر^߉=HE|V#F)Emm#}/"y GII웻Jі94+v뾧xu~5C95~ūH>c@덉pʃ1/4-A2G%7>m;–Y,cyyaln" ?ƻ!ʪ<{~h~i y.zZB̃/,雋SiC/JFMmBH&&FAbϓO^tubbb_hZ{_QZ-sύodFgO(6]TJA˯#`۶ɟ( %$&+V'~hiYy>922 Wp74Zkq+Ovn錄c>8~GqܲcWꂎz@"1A.}T)uiW4="jJ2W7mU/N0gcqܗOO}?9/wìXžΏ0 >֩(V^Rh32!Hj5`;O28؇2#ݕf3 ?sJd8NJ@7O0 b־?lldщ̡&|9C.8RTWwxWy46ah嘦mh٤&l zCy!PY?: CJyв]dm4ǜҐR޻RլhX{FƯanшQI@x' ao(kUUuxW_Ñ줮[w8 FRJ(8˼)_mQ _!RJhm=!cVmm ?sFOnll6Qk}alY}; "baӌ~M0w,Ggw2W:G/k2%R,_=u`WU R.9T"v,<\Ik޽/2110Ӿxc0gyC&Ny޽JҢrV6N ``یeA16"J³+Rj*;BϜkZPJaÍ<Jyw:NP8/D$ 011z֊Ⱳ3ι֘k1V_"h!JPIΣ'ɜ* aEAd:ݺ>y<}Lp&PlRfTb1]o .2EW\ͮ]38؋rTJsǏP@芎sF\> P^+dYJLbJ C-xϐn> ι$nj,;Ǖa FU *择|h ~izť3ᤓ`K'-f tL7JK+vf2)V'-sFuB4i+m+@My=O҈0"|Yxoj,3]:cо3 $#uŘ%Y"y죯LebqtҢVzq¼X)~>4L׶m~[1_k?kxֺQ`\ |ٛY4Ѯr!)N9{56(iNq}O()Em]=F&u?$HypWUeB\k]JɩSع9 Zqg4ZĊo oMcjZBU]B\TUd34ݝ~:7ڶSUsB0Z3srx 7`:5xcx !qZA!;%͚7&P H<WL!džOb5kF)xor^aujƍ7 Ǡ8/p^(L>ὴ-B,{ۇWzֺ^k]3\EE@7>lYBȝR.oHnXO/}sB|.i@ɥDB4tcm,@ӣgdtJ!lH$_vN166L__'Z)y&kH;:,Y7=J 9cG) V\hjiE;gya~%ks_nC~Er er)muuMg2;֫R)Md) ,¶ 2-wr#F7<-BBn~_(o=KO㭇[Xv eN_SMgSҐ BS헃D%g_N:/pe -wkG*9yYSZS.9cREL !k}<4_Xs#FmҶ:7R$i,fi!~' # !6/S6y@kZkZcX)%5V4P]VGYq%H1!;e1MV<!ϐHO021Dp= HMs~~a)ަu7G^];git!Frl]H/L$=AeUvZE4P\.,xi {-~p?2b#amXAHq)MWǾI_r`S Hz&|{ +ʖ_= (YS(_g0a03M`I&'9vl?MM+m~}*xT۲(fY*V4x@29s{DaY"toGNTO+xCAO~4Ϳ;p`Ѫ:>Ҵ7K 3}+0 387x\)a"/E>qpWB=1 ¨"MP(\xp߫́A3+J] n[ʼnӼaTbZUWb={~2ooKױӰp(CS\S筐R*JغV&&"FA}J>G֐p1ٸbk7 ŘH$JoN <8s^yk_[;gy-;߉DV{c B yce% aJhDȶ 2IdйIB/^n0tNtџdcKj4϶v~- CBcgqx9= PJ) dMsjpYB] GD4RDWX +h{y`,3ꊕ$`zj*N^TP4L:Iz9~6s) Ga:?y*J~?OrMwP\](21sZUD ?ܟQ5Q%ggW6QdO+\@ ̪X'GxN @'4=ˋ+*VwN ne_|(/BDfj5(Dq<*tNt1х!MV.C0 32b#?n0pzj#!38}޴o1KovCJ`8ŗ_"]] rDUy޲@ Ȗ-;xџ'^Y`zEd?0„ DAL18IS]VGq\4o !swV7ˣι%4FѮ~}6)OgS[~Q vcYbL!wG3 7띸*E Pql8=jT\꘿I(z<[6OrR8ºC~ډ]=rNl[g|v TMTղb-o}OrP^Q]<98S¤!k)G(Vkwyqyr޽Nv`N/e p/~NAOk \I:G6]4+K;j$R:Mi #*[AȚT,ʰ,;N{HZTGMoּy) ]%dHء9Պ䠬|<45,\=[bƟ8QXeB3- &dҩ^{>/86bXmZ]]yޚN[(WAHL$YAgDKp=5GHjU&99v簪C0vygln*P)9^͞}lMuiH!̍#DoRBn9l@ xA/_v=ȺT{7Yt2N"4!YN`ae >Q<XMydEB`VU}u]嫇.%e^ánE87Mu\t`cP=AD/G)sI"@MP;)]%fH9'FNsj1pVhY&9=0pfuJ&gޤx+k:!r˭wkl03׼Ku C &ѓYt{.O.zҏ z}/tf_wEp2gvX)GN#I ݭ߽v/ .& и(ZF{e"=V!{zW`, ]+LGz"(UJp|j( #V4, 8B 0 9OkRrlɱl94)'VH9=9W|>PS['G(*I1==C<5"Pg+x'K5EMd؞Af8lG ?D FtoB[je?{k3zQ vZ;%Ɠ,]E>KZ+T/ EJxOZ1i #T<@ I}q9/t'zi(EMqw`mYkU6;[t4DPeckeM;H}_g pMww}k6#H㶏+b8雡Sxp)&C $@'b,fPߑt$RbJ'vznuS ~8='72_`{q纶|Q)Xk}cPz9p7O:'|G~8wx(a 0QCko|0ASD>Ip=4Q, d|F8RcU"/KM opKle M3#i0c%<7׿p&pZq[TR"BpqauIp$ 8~Ĩ!8Սx\ւdT>>Z40ks7 z2IQ}ItԀ<-%S⍤};zIb$I 5K}Q͙D8UguWE$Jh )cu4N tZl+[]M4k8֦Zeq֮M7uIqG 1==tLtR,ƜSrHYt&QP윯Lg' I,3@P'}'R˪e/%-Auv·ñ\> vDJzlӾNv5:|K/Jb6KI9)Zh*ZAi`?S {aiVDԲuy5W7pWeQJk֤#5&V<̺@/GH?^τZL|IJNvI:'P=Ϛt"¨=cud S Q.Ki0 !cJy;LJR;G{BJy޺[^8fK6)=yʊ+(k|&xQ2`L?Ȓ2@Mf 0C`6-%pKpm')c$׻K5[J*U[/#hH!6acB JA _|uMvDyk y)6OPYjœ50VT K}cǻP[ $:]4MEA.y)|B)cf-A?(e|lɉ#P9V)[9t.EiQPDѠ3ϴ;E:+Օ t ȥ~|_N2,ZJLt4! %ա]u {+=p.GhNcŞQI?Nd'yeh n7zi1DB)1S | S#ًZs2|Ɛy$F SxeX{7Vl.Src3E℃Q>b6G ўYCmtկ~=K0f(=LrAS GN'ɹ9<\!a`)֕y[uՍ[09` 9 +57ts6}b4{oqd+J5fa/,97J#6yν99mRWxJyѡyu_TJc`~W>l^q#Ts#2"nD1%fS)FU w{ܯ R{ ˎ󅃏џDsZSQS;LV;7 Od1&1n$ N /.q3~eNɪ]E#oM~}v֯FڦwyZ=<<>Xo稯lfMFV6p02|*=tV!c~]fa5Y^Q_WN|Vs 0ҘދU97OI'N2'8N֭fgg-}V%y]U4 峧p*91#9U kCac_AFңĪy뚇Y_AiuYyTTYЗ-(!JFLt›17uTozc. S;7A&&<ԋ5y;Ro+:' *eYJkWR[@F %SHWP 72k4 qLd'J "zB6{AC0ƁA6U.'F3:Ȅ(9ΜL;D]m8ڥ9}dU "v!;*13Rg^fJyShyy5auA?ɩGHRjo^]׽S)Fm\toy 4WQS@mE#%5ʈfFYDX ~D5Ϡ9tE9So_aU4?Ѽm%&c{n>.KW1Tlb}:j uGi(JgcYj0qn+>) %\!4{LaJso d||u//P_y7iRJ߬nHOy) l+@$($VFIQ9%EeKʈU. ia&FY̒mZ=)+qqoQn >L!qCiDB;Y<%} OgBxB!ØuG)WG9y(Ą{_yesuZmZZey'Wg#C~1Cev@0D $a@˲(.._GimA:uyw֬%;@!JkQVM_Ow:P.s\)ot- ˹"`B,e CRtaEUP<0'}r3[>?G8xU~Nqu;Wm8\RIkբ^5@k+5(By'L&'gBJ3ݶ!/㮻w҅ yqPWUg<e"Qy*167΃sJ\oz]T*UQ<\FԎ`HaNmڜ6DysCask8wP8y9``GJ9lF\G g's Nn͵MLN֪u$| /|7=]O)6s !ĴAKh]q_ap $HH'\1jB^s\|- W1:=6lJBqjY^LsPk""`]w)󭃈,(HC ?䔨Y$Sʣ{4Z+0NvQkhol6C.婧/u]FwiVjZka&%6\F*Ny#8O,22+|Db~d ~Çwc N:FuuCe&oZ(l;@ee-+Wn`44AMK➝2BRՈt7g*1gph9N) *"TF*R(#'88pm=}X]u[i7bEc|\~EMn}P瘊J)K.0i1M6=7'_\kaZ(Th{K*GJyytw"IO-PWJk)..axӝ47"89Cc7ĐBiZx 7m!fy|ϿF9CbȩV 9V-՛^pV̌ɄS#Bv4-@]Vxt-Z, &ֺ*diؠ2^VXbs֔Ìl.jQ]Y[47gj=幽ex)A0ip׳ W2[ᎇhuE^~q흙L} #-b۸oFJ_QP3r6jr+"nfzRJTUqoaۍ /$d8Mx'ݓ= OՃ| )$2mcM*cЙj}f };n YG w0Ia!1Q.oYfr]DyISaP}"dIӗթO67jqR ҊƐƈaɤGG|h;t]䗖oSv|iZqX)oalv;۩meEJ\!8=$4QU4Xo&VEĊ YS^E#d,yX_> ۘ-e\ "Wa6uLĜZi`aD9.% w~mB(02G[6y.773a7 /=o7D)$Z 66 $bY^\CuP. (x'"J60׿Y:Oi;F{w佩b+\Yi`TDWa~|VH)8q/=9!g߆2Y)?ND)%?Ǐ`k/sn:;O299yB=a[Ng 3˲N}vLNy;*?x?~L&=xyӴ~}q{qE*IQ^^ͧvü{Huu=R|>JyUlZV, B~/YF!Y\u_ݼF{_C)LD]m {H 0ihhadd nUkf3oٺCvE\)QJi+֥@tDJkB$1!Đr0XQ|q?d2) Ӣ_}qv-< FŊ߫%roppVBwü~JidY4:}L6M7f٬F "?71<2#?Jyy4뷢<_a7_=Q E=S1И/9{+93֮E{ǂw{))?maÆm(uLE#lïZ  ~d];+]h j?!|$F}*"4(v'8s<ŏUkm7^7no1w2ؗ}TrͿEk>p'8OB7d7R(A 9.*Mi^ͳ; eeUwS+C)uO@ =Sy]` }l8^ZzRXj[^iUɺ$tj))<sbDJfg=Pk_{xaKo1:-uyG0M ԃ\0Lvuy'ȱc2Ji AdyVgVh!{]/&}}ċJ#%d !+87<;qN޼Nفl|1N:8ya  8}k¾+-$4FiZYÔXk*I&'@iI99)HSh4+2G:tGhS^繿 Kتm0 вDk}֚+QT4;sC}rՅE,8CX-e~>G&'9xpW,%Fh,Ry56Y–hW-(v_,? ; qrBk4-V7HQ;ˇ^Gv1JVV%,ik;D_W!))+BoS4QsTM;gt+ndS-~:11Sgv!0qRVh!"Ȋ(̦Yl.]PQWgٳE'`%W1{ndΗBk|Ž7ʒR~,lnoa&:ü$ 3<a[CBݮwt"o\ePJ=Hz"_c^Z.#ˆ*x z̝grY]tdkP*:97YľXyBkD4N.C_[;F9`8& !AMO c `@BA& Ost\-\NX+Xp < !bj3C&QL+*&kAQ=04}cC!9~820G'PC9xa!w&bo_1 Sw"ܱ V )Yl3+ס2KoXOx]"`^WOy :3GO0g;%Yv㐫(R/r (s } u B &FeYZh0y> =2<Ϟc/ -u= c&׭,.0"g"7 6T!vl#sc>{u/Oh Bᾈ)۴74]x7 gMӒ"d]U)}" v4co[ ɡs 5Gg=XR14?5A}D "b{0$L .\4y{_fe:kVS\\O]c^W52LSBDM! C3Dhr̦RtArx4&agaN3Cf<Ԉp4~ B'"1@.b_/xQ} _߃҉/gٓ2Qkqp0շpZ2fԫYz< 4L.Cyυι1t@鎫Fe sYfsF}^ V}N<_`p)alٶ "(XEAVZ<)2},:Ir*#m_YӼ R%a||EƼIJ,,+f"96r/}0jE/)s)cjW#w'Sʯ5<66lj$a~3Kʛy 2:cZ:Yh))+a߭K::N,Q F'qB]={.]h85C9cr=}*rk?vwV렵ٸW Rs%}rNAkDv|uFLBkWY YkX מ|)1!$#3%y?pF<@<Rr0}: }\J [5FRxY<9"SQdE(Q*Qʻ)q1E0B_O24[U'],lOb ]~WjHޏTQ5Syu wq)xnw8~)c 쫬gٲߠ H% k5dƝk> kEj,0% b"vi2Wس_CuK)K{n|>t{P1򨾜j>'kEkƗBg*H%'_aY6Bn!TL&ɌOb{c`'d^{t\i^[uɐ[}q0lM˕G:‚4kb祔c^:?bpg… +37stH:0}en6x˟%/<]BL&* 5&fK9Mq)/iyqtA%kUe[ڛKN]Ě^,"`/ s[EQQm?|XJ߅92m]G.E΃ח U*Cn.j_)Tѧj̿30ڇ!A0=͜ar I3$C^-9#|pk!)?7.x9 @OO;WƝZBFU keZ75F6Tc6"ZȚs2y/1 ʵ:u4xa`C>6Rb/Yм)^=+~uRd`/|_8xbB0?Ft||Z\##|K 0>>zxv8۴吅q 8ĥ)"6>~\8:qM}#͚'ĉ#p\׶ l#bA?)|g g9|8jP(cr,BwV (WliVxxᡁ@0Okn;ɥh$_ckCgriv}>=wGzβ KkBɛ[˪ !J)h&k2%07δt}!d<9;I&0wV/ v 0<H}L&8ob%Hi|޶o&h1L|u֦y~󛱢8fٲUsւ)0oiFx2}X[zVYr_;N(w]_4B@OanC?gĦx>мgx>ΛToZoOMp>40>V Oy V9iq!4 LN,ˢu{jsz]|"R޻&'ƚ{53ўFu(<٪9:΋]B;)B>1::8;~)Yt|0(pw2N%&X,URBK)3\zz&}ax4;ǟ(tLNg{N|Ǽ\G#C9g$^\}p?556]/RP.90 k,U8/u776s ʪ_01چ|\N 0VV*3H鴃J7iI!wG_^ypl}r*jɤSR 5QN@ iZ#1ٰy;_\3\BQQ x:WJv츟ٯ$"@6 S#qe딇(/P( Dy~TOϻ<4:-+F`0||;Xl-"uw$Цi󼕝mKʩorz"mϺ$F:~E'ҐvD\y?Rr8_He@ e~O,T.(ފR*cY^m|cVR[8 JҡSm!ΆԨb)RHG{?MpqrmN>߶Y)\p,d#xۆWY*,l6]v0h15M˙MS8+EdI='LBJIH7_9{Caз*Lq,dt >+~ّeʏ?xԕ4bBAŚjﵫ!'\Ը$WNvKO}ӽmSşذqsOy?\[,d@'73'j%kOe`1.g2"e =YIzS2|zŐƄa\U,dP;jhhhaxǶ?КZ՚.q SE+XrbOu%\GتX(H,N^~]JyEZQKceTQ]VGYqnah;y$cQahT&QPZ*iZ8UQQM.qo/T\7X"u?Mttl2Xq(IoW{R^ ux*SYJ! 4S.Jy~ BROS[V|žKNɛP(L6V^|cR7i7nZW1Fd@ Ara{詑|(T*dN]Ko?s=@ |_EvF]׍kR)eBJc" MUUbY6`~V޴dJKß&~'d3i WWWWWW
Current Directory: /usr/share/texlive/texmf-dist/tex/generic/pgf/basiclayer
Viewing File: /usr/share/texlive/texmf-dist/tex/generic/pgf/basiclayer/pgfcorepoints.code.tex
% Copyright 2006 by Till Tantau % % This file may be distributed and/or modified % % 1. under the LaTeX Project Public License and/or % 2. under the GNU Public License. % % See the file doc/generic/pgf/licenses/LICENSE for more details. \ProvidesFileRCS $Header: /cvsroot/pgf/pgf/generic/pgf/basiclayer/pgfcorepoints.code.tex,v 1.20 2010/04/09 08:53:45 ludewich Exp $ \newdimen\pgf@picminx \newdimen\pgf@picmaxx \newdimen\pgf@picminy \newdimen\pgf@picmaxy \newdimen\pgf@pathminx \newdimen\pgf@pathmaxx \newdimen\pgf@pathminy \newdimen\pgf@pathmaxy \newif\ifpgf@relevantforpicturesize \def\pgf@process#1{{#1\global\pgf@x=\pgf@x\global\pgf@y=\pgf@y}} % Save a point. % % #1 = macro for storing point. % #2 = code for point (should define x and y) % % Example: % % \pgfextract@process\mypoint{\pgf@x=10pt \pgf@y10pt} % \pgfextract@process\myarcpoint{\pgfpointpolar{30}{5cm and 2cm}} \def\pgfextract@process#1#2{% \pgf@process{#2}% \edef#1{\noexpand\pgf@x=\the\pgf@x\noexpand\relax\noexpand\pgf@y=\the\pgf@y\noexpand\relax}% } % This needed until old shapes code changed. \let\pgfsavepgf@process\pgfextract@process% % Return a point % % #1 = x-coordinate of the point % #2 = y-coordinate of the point % % x = #1 % y = #2 % % Example: % % \pgfpathmoveto{\pgfpoint{2pt+3cm}{3cm}} \def\pgfpoint#1#2{% \pgfmathsetlength\pgf@x{#1}% \pgfmathsetlength\pgf@y{#2}\ignorespaces} % Quickly a point % % #1 = x-coordinate of the point (no calculations done) % #2 = y-coordinate of the point (no calculations done) % % x = #1 % y = #2 % % Example: % % \pgfpathmoveto{\pgfqpoint{2pt}{3cm}} \def\pgfqpoint#1#2{\pgf@x=#1\pgf@y=#2} % Return the origin. % % x = 0 % y = 0 % % Example: % % \pgfpathmoveto{\pgfpointorigin} \def\pgfpointorigin{\pgf@x=0pt\pgf@y=\pgf@x\ignorespaces} % Return a transformed point % % #1 = a point % % Description: % % This command applies pgf's current transformation matrix to the % given point. Normally, this is done automatically by commands like % lineto or moveto, but sometimes you may wish to access a transformed % point yourself. In the below example, this command is used for a low level % coordinate system shift. % % In addition to applying the transformation matrix to the given % point, this function also applies the pre- and post-morphing % macros. % % Example: % % \begin{pgflowleveltransformshiftscope}{\pgfpointtransformed{\pgfpointorigin}} % \pgfbox[center,center]{Hi!} % \end{pgflowleveltransformshiftscope} \def\pgfpointtransformed#1{% \pgf@process{% #1% \pgfmorph@prelist% \pgf@pos@transform{\pgf@x}{\pgf@y}% \pgfmorph@postlist% }% } % Return the difference vector of two points. % % #1 = start of vector % #2 = end of vector % % x = x-component of difference % y = y-component of difference % % Example: % % \pgfpathmoveto{\pgfpointdiff{\pgfpointxy{1}{1}}{\pgfpointxy{2}{3}}} \def\pgfpointdiff#1#2{% \pgf@process{#1}% \pgf@xa=\pgf@x% \pgf@ya=\pgf@y% \pgf@process{#2}% \advance\pgf@x by-\pgf@xa\relax% \advance\pgf@y by-\pgf@ya\relax\ignorespaces} % Add two vectors. % % #1 = first vector % #2 = second vector % % x = x-component of addition % y = y-component of addition % % Example: % % \pgfpathmoveto{\pgfpointadd{\pgfpointxy{0}{1}}{\pgfpointxy{2}{3}}} \def\pgfpointadd#1#2{% \pgf@process{#1}% \pgf@xa=\pgf@x% \pgf@ya=\pgf@y% \pgf@process{#2}% \advance\pgf@x by\pgf@xa% \advance\pgf@y by\pgf@ya} % Multiply a vector by a factor. % % #1 = factor % #2 = vector % % Example: % % \pgfpointscale{2}{\pgfpointxy{0}{1}} \def\pgfpointscale#1#2{% \pgf@process{#2}% \pgfmathparse{#1}% \pgf@x=\pgfmathresult\pgf@x% \pgf@y=\pgfmathresult\pgf@y% } % A "quick" variant of \pgfpointscale which doesn't invoke the math parser for '#1'. % #1 must be a number without units, no registers are accepted. \def\pgfqpointscale#1#2{% \pgf@process{#2}% \pgf@x=#1\pgf@x% \pgf@y=#1\pgf@y% } % The intersection of two lines % % #1 = point on first line % #2 = another point on first line % #3 = point on second line % #4 = another point on second line % % Returns the intersection of the two lines. If there is no % intersection or if the points #1 and #2 or the points #3 and #4 are % identical, the behaviour is not specified. % % Example: % % \pgfpointintersectionoflines{\pgfpointxy{0}{1}}{\pgfpointxy{1}{0}}{\pgfpointxy{2}{2}}{\pgfpointxy{3}{4}} \def\pgfpointintersectionoflines#1#2#3#4{% { % % Compute orthogonal vector to #1--#2 % \pgf@process{#2}% \pgf@xa=\pgf@x% \pgf@ya=\pgf@y% \pgf@process{#1}% \advance\pgf@xa by-\pgf@x% \advance\pgf@ya by-\pgf@y% \pgf@ya=-\pgf@ya% % Normalise a bit \c@pgf@counta=\pgf@xa% \ifnum\c@pgf@counta<0\relax% \c@pgf@counta=-\c@pgf@counta\relax% \fi% \c@pgf@countb=\pgf@ya% \ifnum\c@pgf@countb<0\relax% \c@pgf@countb=-\c@pgf@countb\relax% \fi% \advance\c@pgf@counta by\c@pgf@countb\relax% \divide\c@pgf@counta by 65536\relax% \ifnum\c@pgf@counta>0\relax% \divide\pgf@xa by\c@pgf@counta\relax% \divide\pgf@ya by\c@pgf@counta\relax% \fi% % % Compute projection % \pgf@xc=\pgf@sys@tonumber{\pgf@ya}\pgf@x% \advance\pgf@xc by\pgf@sys@tonumber{\pgf@xa}\pgf@y% % % The orthogonal vector is (\pgf@ya,\pgf@xa) % % % Compute orthogonal vector to #3--#4 % \pgf@process{#4}% \pgf@xb=\pgf@x% \pgf@yb=\pgf@y% \pgf@process{#3}% \advance\pgf@xb by-\pgf@x% \advance\pgf@yb by-\pgf@y% \pgf@yb=-\pgf@yb% % Normalise a bit \c@pgf@counta=\pgf@xb% \ifnum\c@pgf@counta<0\relax% \c@pgf@counta=-\c@pgf@counta\relax% \fi% \c@pgf@countb=\pgf@yb% \ifnum\c@pgf@countb<0\relax% \c@pgf@countb=-\c@pgf@countb\relax% \fi% \advance\c@pgf@counta by\c@pgf@countb\relax% \divide\c@pgf@counta by 65536\relax% \ifnum\c@pgf@counta>0\relax% \divide\pgf@xb by\c@pgf@counta\relax% \divide\pgf@yb by\c@pgf@counta\relax% \fi% % % Compute projection % \pgf@yc=\pgf@sys@tonumber{\pgf@yb}\pgf@x% \advance\pgf@yc by\pgf@sys@tonumber{\pgf@xb}\pgf@y% % % The orthogonal vector is (\pgf@yb,\pgf@xb) % % Setup transformation matrx (this is just to use the matrix % inversion) % \pgfsettransform{{\pgf@sys@tonumber\pgf@ya}{\pgf@sys@tonumber\pgf@yb}{\pgf@sys@tonumber\pgf@xa}{\pgf@sys@tonumber\pgf@xb}{0pt}{0pt}}% \pgftransforminvert% \pgf@process{\pgfpointtransformed{\pgfpoint{\pgf@xc}{\pgf@yc}}}% }% } % The intersection of two circles % % #1 = center of first circle % #2 = center of second circle % #3 = radius of first circle % #4 = radius of second circle % #5 = solution number % % Returns the intersection of the two circles. If #5 is to "1", the % first intersection is returned, otherwise the second. If the circles % do not intersect, an error may occur. % % Example: % % \pgfpointintersectionofcircles{\pgfpointxy{0}{1}}{\pgfpointxy{1}{0}}{1cm}{1cm}{1} \def\pgfpointintersectionofcircles#1#2#3#4#5{% {% % Store first point in (xa,ya) and radius in xc. \pgf@process{#1}% \pgf@xa=\pgf@x% \pgf@ya=\pgf@y% \pgfmathsetlength{\pgf@xc}{#3}% % Store second point in (xb,yb) and radius in yc. \pgf@process{#2}% \pgf@xb=\pgf@x% \pgf@yb=\pgf@y% \pgfmathsetlength{\pgf@yc}{#4}% % % Ok, now make numbers smaller, in case they are too large % \c@pgf@counta=1\relax% \loop% \pgf@scale@downfalse% \ifdim\pgf@xc>50pt\relax% \pgf@scale@downtrue% \fi% \ifdim\pgf@yc>50pt\relax% \pgf@scale@downtrue% \fi% \ifpgf@scale@down% \multiply\c@pgf@counta by2\relax% \divide\pgf@xa by2\relax% \divide\pgf@ya by2\relax% \divide\pgf@xb by2\relax% \divide\pgf@yb by2\relax% \divide\pgf@xc by2\relax% \divide\pgf@yc by2\relax% \repeat% % The following code is taken from the Dr. Math internet forum: % % Let the centers be: (a,b), (c,d) % Let the radii be: r, s % % e = c - a [difference in x coordinates] % f = d - b [difference in y coordinates] % p = sqrt(e^2 + f^2) [distance between centers] % k = (p^2 + r^2 - s^2)/(2p) [distance from center 1 to line % joining points of intersection] % x = a + ek/p + (f/p)sqrt(r^2 - k^2) % y = b + fk/p - (e/p)sqrt(r^2 - k^2) % OR % x = a + ek/p - (f/p)sqrt(r^2 - k^2) % y = b + fk/p + (e/p)sqrt(r^2 - k^2) % % Since we are running low on registers, use % \dimen0 for e % \dimen1 for f % \dimen2 for p % \dimen3 for p^2 % \dimen4 for k % \dimen5 for 1/p % \dimen6 for sqrt(r^2 - k^2) % \dimen7 for k^2 % \dimen8 for k/p % \dimen9 for sqrt(r^2 - k^2)/p % Also note that: % \pgf@xa for a % \pgf@ya for b % \pgf@xb for c % \pgf@yb for d % \pgf@xc for r % \pgf@yc for s % % Now: % e = c - a \dimen0=\pgf@xb% \advance\dimen0 by-\pgf@xa% % f = d - b \dimen1=\pgf@yb% \advance\dimen1 by-\pgf@ya% % p^2 = e^2 + f^2 \pgf@x=\dimen0\relax% \pgf@x=\pgf@sys@tonumber{\pgf@x}\pgf@x% \dimen3=\pgf@x% \pgf@x=\dimen1\relax% \advance\dimen3 by\pgf@sys@tonumber{\pgf@x}\pgf@x% % p = sqrt(p^2) \pgfmathparse{sqrt(\the\dimen3)}% \dimen2=\pgfmathresult pt% % 1/p = 1/p \pgfmathreciprocal@{\pgfmathresult}% \dimen5=\pgfmathresult pt% % k = (p^2 + r^2 - s^2)/(2p) \dimen4=\dimen3\relax% \pgf@x=\pgf@xc% \advance\dimen4 by\pgf@sys@tonumber{\pgf@x}\pgf@x\relax% \pgf@x=\pgf@yc% \advance\dimen4 by-\pgf@sys@tonumber{\pgf@x}\pgf@x\relax% \dimen4=.5\dimen4% \dimen4=\pgf@sys@tonumber{\dimen5}\dimen4% % dimen7 is k^2 \dimen7=\pgf@sys@tonumber{\dimen4}\dimen4\relax% % dimen6 is sqrt(r^2 - k^2) \pgfmathparse{sqrt(\pgf@sys@tonumber{\pgf@xc}\pgf@xc-\the\dimen7)}% \dimen6=\pgfmathresult pt% % dimen8 is k/p \dimen8=\pgf@sys@tonumber{\dimen4}\dimen5\relax% % dimen9 is sqrt(r^2 - k^2)/p \dimen9=\pgf@sys@tonumber{\dimen6}\dimen5\relax% \ifnum#5=1\relax% % x = a + ek/p + (f/p)sqrt(r^2 - k^2) \pgf@x=\pgf@xa% \advance\pgf@x by\pgf@sys@tonumber{\dimen0}\dimen8\relax% \advance\pgf@x by\pgf@sys@tonumber{\dimen1}\dimen9\relax% % y = b + fk/p - (e/p)sqrt(r^2 - k^2) \pgf@y=\pgf@ya% \advance\pgf@y by\pgf@sys@tonumber{\dimen1}\dimen8\relax% %temp \pgf@xb=\pgf@sys@tonumber{\dimen0}\dimen9% \pgf@xb=-\pgf@xb% \advance\pgf@y by\pgf@xb\relax% \else% % x = a + ek/p - (f/p)sqrt(r^2 - k^2) \pgf@x=\pgf@xa% \advance\pgf@x by\pgf@sys@tonumber{\dimen0}\dimen8\relax% %temp \pgf@xb=\pgf@sys@tonumber{\dimen1}\dimen9% \pgf@xb=-\pgf@xb% \advance\pgf@x by\pgf@xb\relax% % y = b + fk/p + (e/p)sqrt(r^2 - k^2) \pgf@y=\pgf@ya% \advance\pgf@y by\pgf@sys@tonumber{\dimen1}\dimen8\relax% \advance\pgf@y by\pgf@sys@tonumber{\dimen0}\dimen9\relax% \fi% \pgf@x=\c@pgf@counta\pgf@x% \pgf@y=\c@pgf@counta\pgf@y% \pgf@process{}% get results outside }% } \newif\ifpgf@scale@down % Returns point on a line from #2 to #3 at time #1. % % #1 = a time, where 0 is the start and 1 is the end % #2 = start point % #3 = end point % % x = x-component of #1*start + (1-#1)*end % y = y-component of #1*start + (1-#1)*end % % Example: % % % Middle of (1,1) and (2,3) % \pgfpathmoveto{\pgfpointlineattime{0.5}{\pgfpointxy{0}{1}}{\pgfpointxy{2}{3}}} \def\pgfpointlineattime#1#2#3{% \pgf@process{#3}% \pgf@xa=\pgf@x% \pgf@ya=\pgf@y% \pgf@process{#2}% \advance\pgf@xa by-\pgf@x\relax% \advance\pgf@ya by-\pgf@y\relax% \advance\pgf@x by #1\pgf@xa\relax% \advance\pgf@y by #1\pgf@ya\relax% \ignorespaces} % Move point #2 #1 many units in the direction of #3. % % #1 = a distance % #2 = start point % #3 = end point % % x = x-component of start + #1*(normalise(end-start)) % y = y-component of start + #1*(normalise(end-start)) % xa = #1*(normalise(end-start)) % ya = #1*(normalise(end-start)) % % Example: % % % \pgfpathmoveto{\pgfpointlineatdistance{2pt}{\pgfpointxy{0}{1}}{\pgfpointxy{2}{3}}} % \pgfpathlineto{\pgfpointlineatdistance{3pt}{\pgfpointxy{2}{3}}{\pgfpointxy{0}{1}}} \def\pgfpointlineatdistance#1#2#3{% \pgf@process{#2}% \pgf@xb=\pgf@x\relax% xb/yb = start point \pgf@yb=\pgf@y\relax% \pgf@process{#3}% \advance\pgf@x by-\pgf@xb\relax% \advance\pgf@y by-\pgf@yb\relax% \pgf@process{\pgfpointnormalised{}}% x/y = normalised vector \pgfmathsetlength\pgf@xa{#1}% \pgf@ya=\pgf@xa\relax% \pgf@xa=\pgf@sys@tonumber{\pgf@x}\pgf@xa% \pgf@ya=\pgf@sys@tonumber{\pgf@y}\pgf@ya% \pgf@x=\pgf@xb\relax% \pgf@y=\pgf@yb\relax% \advance\pgf@x by\pgf@xa\relax% \advance\pgf@y by\pgf@ya\relax% \ignorespaces} % Returns point on a curve from #2 to #5 with controls #3 and #4 at time #1. % % #1 = a time % #2 = start point % #3 = first control point % #4 = second control point % #5 = end point % % x = x-component of place on the curve at time t % y = y-component of place on the curve at time t % % Additionally, (\pgf@xa,\pgf@ya) and (\pgf@xb,\pgf@yb) will be on a % tangent to the point on the curve (this can be useful for computing % a label rotation). % % Example: % % % Middle of (1,1) and (2,3) % \pgfpathmoveto{\pgfpointcurveattime{0.5}{\pgfpointxy{0}{1}}{\pgfpointxy{1}{1}}{\pgfpointxy{1}{1}}{\pgfpointxy{2}{3}}} \def\pgfpointcurveattime#1#2#3#4#5{% \pgfmathparse{#1}% \let\pgf@time@s=\pgfmathresult% \pgf@x=\pgfmathresult pt% \pgf@x=-\pgf@x% \advance\pgf@x by 1pt% \edef\pgf@time@t{\pgf@sys@tonumber{\pgf@x}}% \pgf@process{#5}% \pgf@xc=\pgf@x% \pgf@yc=\pgf@y% \pgf@process{#4}% \pgf@xb=\pgf@x% \pgf@yb=\pgf@y% \pgf@process{#3}% \pgf@xa=\pgf@x% \pgf@ya=\pgf@y% \pgf@process{#2}% % First iteration: \pgf@x=\pgf@time@t\pgf@x\advance\pgf@x by\pgf@time@s\pgf@xa% \pgf@y=\pgf@time@t\pgf@y\advance\pgf@y by\pgf@time@s\pgf@ya% \pgf@xa=\pgf@time@t\pgf@xa\advance\pgf@xa by\pgf@time@s\pgf@xb% \pgf@ya=\pgf@time@t\pgf@ya\advance\pgf@ya by\pgf@time@s\pgf@yb% \pgf@xb=\pgf@time@t\pgf@xb\advance\pgf@xb by\pgf@time@s\pgf@xc% \pgf@yb=\pgf@time@t\pgf@yb\advance\pgf@yb by\pgf@time@s\pgf@yc% % Second iteration: \pgf@x=\pgf@time@t\pgf@x\advance\pgf@x by\pgf@time@s\pgf@xa% \pgf@y=\pgf@time@t\pgf@y\advance\pgf@y by\pgf@time@s\pgf@ya% \pgf@xa=\pgf@time@t\pgf@xa\advance\pgf@xa by\pgf@time@s\pgf@xb% \pgf@ya=\pgf@time@t\pgf@ya\advance\pgf@ya by\pgf@time@s\pgf@yb% % Save x/y \pgf@xb=\pgf@x% \pgf@yb=\pgf@y% % Third iteration: \pgf@x=\pgf@time@t\pgf@x\advance\pgf@x by\pgf@time@s\pgf@xa% \pgf@y=\pgf@time@t\pgf@y\advance\pgf@y by\pgf@time@s\pgf@ya% } % Internal registers \newdimen\pgf@xx \newdimen\pgf@xy \newdimen\pgf@yx \newdimen\pgf@yy \newdimen\pgf@zx \newdimen\pgf@zy % A polar coordinate % % #1 = a degree % #2 = a radius -- either a dimension or two dimensions separated by % " and ". % % x = (first dimension in #2) * cos(#1) % y = (second dimension in #2) * sin(#2) % % Example: % % \pgfpathmoveto{\pgfpointpolar{30}{1cm}} % \pgfpathlineto{\pgfpointpolar{30}{1cm and 2cm}} \def\pgfpointpolar#1#2{% \pgfutil@in@{and }{#2}% \ifpgfutil@in@% \pgf@polar@#2\@@% \else% \pgf@polar@#2 and #2\@@% \fi% \pgfmathparse{#1}% \let\pgfpoint@angle=\pgfmathresult% \pgfmathcos@{\pgfpoint@angle}% \pgf@x=\pgfmathresult\pgf@x% \pgfmathsin@{\pgfpoint@angle}% \pgf@y=\pgfmathresult\pgf@y% } \def\pgf@polar@#1and #2\@@{% \pgfmathsetlength{\pgf@y}{#2}% \pgfmathsetlength{\pgf@x}{#1}% } % Quick version of the polar coordinate method \def\pgfqpointpolar#1#2{% \pgf@x=#2% \pgf@y=\pgf@x% \pgfmathcos@{#1}% \pgf@x=\pgfmathresult\pgf@x% \pgfmathsin@{#1}% \pgf@y=\pgfmathresult\pgf@y\relax% } % A polar coordinate in the xy plane. % % #1 = a degree % #2 = a radius given as a number or two radi % % result = (first dim in #2) * x-vector * cos(#1) + % (second dim in #2) * y-vector * sin(#1) % % Example: % % \pgfpathmoveto{\pgfpointpolarxy{30}{2}} \def\pgfpointpolarxy#1#2{% \pgfutil@in@{and }{#2}% \ifpgfutil@in@% \pgf@polarxy@#2\@@% \else% \pgf@polarxy@#2and #2\@@% \fi% \pgfmathparse{#1}% \let\pgfpoint@angle=\pgfmathresult% \pgfmathcos@{\pgfpoint@angle}% \pgf@xa=\pgfmathresult\pgf@xa% \pgfmathsin@{\pgfpoint@angle}% \pgf@ya=\pgfmathresult\pgf@ya% \pgf@x=\pgf@sys@tonumber{\pgf@xa}\pgf@xx% \advance\pgf@x by \pgf@sys@tonumber{\pgf@ya}\pgf@yx% \pgf@y=\pgf@sys@tonumber{\pgf@xa}\pgf@xy% \advance\pgf@y by \pgf@sys@tonumber{\pgf@ya}\pgf@yy} \def\pgf@polarxy@#1and #2\@@{% \pgfmathsetlength{\pgf@xa}{#1}% \pgfmathsetlength{\pgf@ya}{#2}% } % A cylindrical coordinate. % % #1 = a degree % #2 = a radius given as a number % #3 = a height given as a number % % result = #2*(x-vector * cos(#1) + y-vector * sin(#1)) + #3*z-vector % % Example: % % \pgfpathmoveto{\pgfpointcylindrical{30}{2}{1}} \def\pgfpointcylindrical#1#2#3{% \pgfpointpolarxy{#1}{#2}% \pgfmathparse{#3}% \advance\pgf@x by \pgfmathresult\pgf@zx% \advance\pgf@y by \pgfmathresult\pgf@zy} % A spherical coordinate. % % #1 = a longitude % #2 = a latitude % #3 = a radius % % result = #3*(cos(#2)*(x-vector * cos(#1) + y-vector * sin(#1)) + sin(#2)*z-vector) % % Example: % % \pgfpathmoveto{\pgfpointspherical{30}{30}{2}} \def\pgfpointspherical#1#2#3{% \pgfmathparse{#1}% \let\pgfpoint@angle=\pgfmathresult% \pgfmathsin@{\pgfpoint@angle}% \pgf@xb=\pgfmathresult\pgf@xx% \pgf@yb=\pgfmathresult\pgf@xy% \pgfmathcos@{\pgfpoint@angle}% \advance\pgf@xb by \pgfmathresult\pgf@yx% \advance\pgf@yb by \pgfmathresult\pgf@yy% % \pgfmathparse{#2}% \let\pgfpoint@angle=\pgfmathresult% \pgfmathcos@{\pgfpoint@angle}% \pgf@xc=\pgfmathresult\pgf@xb% \pgf@yc=\pgfmathresult\pgf@yb% \pgfmathsin@{\pgfpoint@angle}% \advance\pgf@xc by \pgfmathresult\pgf@zx% \advance\pgf@yc by \pgfmathresult\pgf@zy% \pgfmathparse{#3}% \pgf@x=\pgfmathresult\pgf@xc% \pgf@y=\pgfmathresult\pgf@yc\relax% } % Store the vector #1 * x-vec + #2 * y-vec % % #1 = a factor for the x-vector % #2 = a factor fot the y-vector % % x = x-component of result vector % y = y-component of result vector % % Description: % % This command can be used to create a new coordinate system % without using the rotate/translate/scale commands. This % may be useful, if you do not want arrows and line width to % be scaled/transformed together with the coordinate system. % % Example: % % % Create a slanted rectangle % % \pgfsetxvec{\pgfpoint{1cm}{1cm}} % \pgfsetyvec{\pgfpoint{0cm}{1cm}} % % \pgfpathmoveto{\pgfpointxy{0}{0}} % \pgfpathlineto{\pgfpointxy{1}{0}} % \pgfpathlineto{\pgfpointxy{1}{1}} % \pgfpathlineto{\pgfpointxy{0}{1}} % \pgfclosestroke \def\pgfpointxy#1#2{% \pgfmathparse{#1}% \let\pgftemp@x=\pgfmathresult% \pgfmathparse{#2}% \let\pgftemp@y=\pgfmathresult% \pgf@x=\pgftemp@x\pgf@xx% \advance\pgf@x by \pgftemp@y\pgf@yx% \pgf@y=\pgftemp@x\pgf@xy% \advance\pgf@y by \pgftemp@y\pgf@yy} % "Quick" variant for \pgfpointxy. % % Only numbers without unit are allowed here. \def\pgfqpointxy#1#2{% \pgf@x=#1\pgf@xx% \advance\pgf@x by #2\pgf@yx% \pgf@y=#1\pgf@xy% \advance\pgf@y by #2\pgf@yy} % Store the vector #1 * x-vec + #2 * y-vec + #3 * z-vec % % #1 = a factor for the x-vector % #2 = a factor fot the y-vector % #3 = a factor fot the z-vector % % x = x-component of result vector % y = y-component of result vector % % % Description: % % This command allows you to use a 3d coordinate system. % % % Example: % % % Draw a cubus % % \pgfline{\pgfpointxyz{0}{0}{0}}{\pgfpointxyz{0}{0}{1}} % \pgfline{\pgfpointxyz{0}{1}{0}}{\pgfpointxyz{0}{1}{1}} % \pgfline{\pgfpointxyz{1}{0}{0}}{\pgfpointxyz{1}{0}{1}} % \pgfline{\pgfpointxyz{1}{1}{0}}{\pgfpointxyz{1}{1}{1}} % \pgfline{\pgfpointxyz{0}{0}{0}}{\pgfpointxyz{0}{1}{0}} % \pgfline{\pgfpointxyz{0}{0}{1}}{\pgfpointxyz{0}{1}{1}} % \pgfline{\pgfpointxyz{1}{0}{0}}{\pgfpointxyz{1}{1}{0}} % \pgfline{\pgfpointxyz{1}{0}{1}}{\pgfpointxyz{1}{1}{1}} % \pgfline{\pgfpointxyz{0}{0}{0}}{\pgfpointxyz{1}{0}{0}} % \pgfline{\pgfpointxyz{0}{0}{1}}{\pgfpointxyz{1}{0}{1}} % \pgfline{\pgfpointxyz{0}{1}{0}}{\pgfpointxyz{1}{1}{0}} % \pgfline{\pgfpointxyz{0}{1}{1}}{\pgfpointxyz{1}{1}{1}} \def\pgfpointxyz#1#2#3{% \pgfmathparse{#1}% \let\pgftemp@x=\pgfmathresult% \pgfmathparse{#2}% \let\pgftemp@y=\pgfmathresult% \pgfmathparse{#3}% \let\pgftemp@z=\pgfmathresult% \pgf@x=\pgftemp@x\pgf@xx% \advance\pgf@x by \pgftemp@y\pgf@yx% \advance\pgf@x by \pgftemp@z\pgf@zx% \pgf@y=\pgftemp@x\pgf@xy% \advance\pgf@y by \pgftemp@y\pgf@yy% \advance\pgf@y by \pgftemp@z\pgf@zy} % "Quick" variant for \pgfpointxyz. % % Only numbers without unit are allowed. \def\pgfqpointxyz#1#2#3{% \pgf@x=#1\pgf@xx% \advance\pgf@x by #2\pgf@yx% \advance\pgf@x by #3\pgf@zx% \pgf@y=#1\pgf@xy% \advance\pgf@y by #2\pgf@yy% \advance\pgf@y by #3\pgf@zy} % Set the x-vector % % #1 = a point the is the new x-vector % % Example: % % \pgfsetxvec{\pgfpoint{1cm}{0cm}} \def\pgfsetxvec#1{% \pgf@process{#1}% \pgf@xx=\pgf@x% \pgf@xy=\pgf@y% \ignorespaces} % Set the y-vector % % #1 = a point the is the new y-vector % % Example: % % \pgfsetyvec{\pgfpoint{0cm}{1cm}} \def\pgfsetyvec#1{% \pgf@process{#1}% \pgf@yx=\pgf@x% \pgf@yy=\pgf@y% \ignorespaces} % Set the z-vector % % #1 = a point the is the new z-vector % % Example: % % \pgfsetzvec{\pgfpoint{-0.385cm}{-0.385cm}} \def\pgfsetzvec#1{% \pgf@process{#1}% \pgf@zx=\pgf@x% \pgf@zy=\pgf@y% \ignorespaces} % Default values \pgfsetxvec{\pgfpoint{1cm}{0cm}} \pgfsetyvec{\pgfpoint{0cm}{1cm}} \pgfsetzvec{\pgfpoint{-0.385cm}{-0.385cm}} % Normalise a point. % % #1 = point with coordinates (a,b) % % x = a/\sqrt(a*a+b*b) % y = b/\sqrt(a*a+b*b) % % Example: % % \pgfpointnormalised{\pgfpointxy{2}{1}} \def\pgfpointnormalised#1{% \pgf@process{#1}% \pgf@xa=\pgf@x% \pgf@ya=\pgf@y% \ifdim\pgf@x<0pt\relax% move into first quadrant \pgf@x=-\pgf@x% \fi% \ifdim\pgf@y<0pt\relax% \pgf@y=-\pgf@y% \fi% \ifdim\pgf@x>\pgf@y% x > y % make point small \c@pgf@counta=\pgf@x% \divide\c@pgf@counta by 65536\relax% \ifnum\c@pgf@counta=0\relax% \c@pgf@counta=1\relax% \fi% \divide\pgf@x by\c@pgf@counta% \divide\pgf@y by\c@pgf@counta% \divide\pgf@xa by\c@pgf@counta% \divide\pgf@ya by\c@pgf@counta% % ok. \pgf@x=.125\pgf@x% \pgf@y=.125\pgf@y% \c@pgf@counta=\pgf@x% \c@pgf@countb=\pgf@y% \multiply\c@pgf@countb by 100% \ifnum\c@pgf@counta<64\relax% \pgf@x=1pt\relax% \pgf@y=0pt\relax% \else% \divide\c@pgf@countb by \c@pgf@counta% \pgf@x=\csname pgf@cosfrac\the\c@pgf@countb\endcsname pt% \pgf@xc=8192pt% \divide\pgf@xc by\c@pgf@counta% \pgf@y=\pgf@sys@tonumber{\pgf@xc}\pgf@ya% \pgf@y=\pgf@sys@tonumber{\pgf@x}\pgf@y% \fi% \ifdim\pgf@xa<0pt% \pgf@x=-\pgf@x% \fi% \else% x <= y % make point small \c@pgf@counta=\pgf@y% \divide\c@pgf@counta by 65536\relax% \ifnum\c@pgf@counta=0\relax% \c@pgf@counta=1\relax% \fi% \divide\pgf@x by\c@pgf@counta% \divide\pgf@y by\c@pgf@counta% \divide\pgf@xa by\c@pgf@counta% \divide\pgf@ya by\c@pgf@counta% % ok. \pgf@x=.125\pgf@x% \pgf@y=.125\pgf@y% \c@pgf@counta=\pgf@y% \c@pgf@countb=\pgf@x% \multiply\c@pgf@countb by 100% \ifnum\c@pgf@counta<64\relax% \pgf@y=1pt\relax% \pgf@x=0pt\relax% \else% \divide\c@pgf@countb by \c@pgf@counta% \pgf@y=\csname pgfmath@cosfrac@\the\c@pgf@countb\endcsname pt% \pgf@xc=8192pt% \divide\pgf@xc by\c@pgf@counta% \pgf@x=\pgf@sys@tonumber{\pgf@xc}\pgf@xa% \pgf@x=\pgf@sys@tonumber{\pgf@y}\pgf@x% \fi% \ifdim\pgf@ya<0pt% \pgf@y=-\pgf@y% \fi% \fi\ignorespaces% } % A point on a rectangle in a certain direction. % % #1 = a point pointing in some direction (length should be about 1pt, % but need not be exact) % #2 = upper right corner of a rectangle centered at the origin % % Returns the intersection of a line starting at the origin going in % the given direction and the rectangle's border. % % Example: % % \pgfpointborderrectangle{\pgfpointnormalised{\pgfpointxy{2}{1}} % {\pgfpoint{1cm}{2cm}} \def\pgfpointborderrectangle#1#2{% \pgf@process{#2}% \pgf@xb=\pgf@x% \pgf@yb=\pgf@y% \pgf@process{#1}% % Ok, let's find out about the direction: \pgf@xa=\pgf@x% \pgf@ya=\pgf@y% \ifnum\pgf@xa<0\relax% move into first quadrant \pgf@x=-\pgf@x% \fi% \ifnum\pgf@ya<0\relax% \pgf@y=-\pgf@y% \fi% \pgf@xc=.125\pgf@x% \pgf@yc=.125\pgf@y% \c@pgf@counta=\pgf@xc% \c@pgf@countb=\pgf@yc% \ifnum\c@pgf@countb<\c@pgf@counta% \ifnum\c@pgf@counta<255\relax% \pgf@y=\pgf@yb\relax% \pgf@x=0pt\relax% \else% \pgf@xc=8192pt% \divide\pgf@xc by\c@pgf@counta% \pgf@xc = 1/\pgf@x \pgf@y=\pgf@sys@tonumber{\pgf@xc}\pgf@y% \pgf@y=\pgf@sys@tonumber{\pgf@xb}\pgf@y% \ifnum\pgf@y<\pgf@yb% \pgf@x=\pgf@xb% \else% rats, calculate intersection on upper side \ifnum\c@pgf@countb<255\relax% \pgf@x=\pgf@xb\relax% \pgf@y=0pt\relax% \else% \pgf@yc=8192pt% \divide\pgf@yc by\c@pgf@countb% \pgf@xc = 1/\pgf@x \pgf@x=\pgf@sys@tonumber{\pgf@yc}\pgf@x% \pgf@x=\pgf@sys@tonumber{\pgf@yb}\pgf@x% \pgf@y=\pgf@yb% \fi% \fi% \fi% \else% \ifnum\c@pgf@countb<255\relax% \pgf@x=\pgf@xb\relax% \pgf@y=0pt\relax% \else% \pgf@yc=8192pt% \divide\pgf@yc by\c@pgf@countb% \pgf@xc = 1/\pgf@x \pgf@x=\pgf@sys@tonumber{\pgf@yc}\pgf@x% \pgf@x=\pgf@sys@tonumber{\pgf@yb}\pgf@x% \ifnum\pgf@x<\pgf@xb% \pgf@y=\pgf@yb% \else% \ifnum\c@pgf@counta<255\relax% \pgf@y=\pgf@yb\relax% \pgf@x=0pt\relax% \else% \pgf@xc=8192pt% \divide\pgf@xc by\c@pgf@counta% \pgf@xc = 1/\pgf@x \pgf@y=\pgf@sys@tonumber{\pgf@xc}\pgf@y% \pgf@y=\pgf@sys@tonumber{\pgf@xb}\pgf@y% \pgf@x=\pgf@xb% \fi% \fi% \fi% \fi% \ifnum\pgf@xa<0\relax\pgf@x=-\pgf@x\fi% \ifnum\pgf@ya<0\relax\pgf@y=-\pgf@y\fi% } % An approximation to a point on an ellipse in a certain % direction. Will be exact only if the ellipse is a circle. % % #1 = a point pointing in some direction % #2 = upper right corner of a bounding box for the ellipse % % Returns the intersection of a line starting at the origin going in % the given direction and the ellipses border. % % Example: % % \pgfpointborderellipse{\pgfpointnormalised{\pgfpointxy{2}{1}} % {\pgfpoint{1cm}{2cm}} \def\pgfpointborderellipse#1#2{% \pgf@process{#2}% \pgf@xa=\pgf@x% \pgf@ya=\pgf@y% \ifdim\pgf@xa=\pgf@ya% circle. that's easy! \pgf@process{\pgfpointnormalised{#1}}% \pgf@x=\pgf@sys@tonumber{\pgf@xa}\pgf@x% \pgf@y=\pgf@sys@tonumber{\pgf@xa}\pgf@y% \else% \ifdim\pgf@xa<\pgf@ya% % Ok, first, let's compute x/y: \c@pgf@countb=\pgf@ya% \divide\c@pgf@countb by65536\relax% \divide\pgf@x by\c@pgf@countb% \divide\pgf@y by\c@pgf@countb% \pgf@xc=\pgf@x% \pgf@yc=8192pt% \pgf@y=.125\pgf@y% \c@pgf@countb=\pgf@y% \divide\pgf@yc by\c@pgf@countb% \pgf@process{#1}% \pgf@y=\pgf@sys@tonumber{\pgf@yc}\pgf@y% \pgf@y=\pgf@sys@tonumber{\pgf@xc}\pgf@y% \pgf@process{\pgfpointnormalised{}}% \pgf@x=\pgf@sys@tonumber{\pgf@xa}\pgf@x% \pgf@y=\pgf@sys@tonumber{\pgf@ya}\pgf@y% \else% % Ok, now let's compute y/x: \c@pgf@countb=\pgf@xa% \divide\c@pgf@countb by65536\relax% \divide\pgf@x by\c@pgf@countb% \divide\pgf@y by\c@pgf@countb% \pgf@yc=\pgf@y% \pgf@xc=8192pt% \pgf@x=.125\pgf@x% \c@pgf@countb=\pgf@x% \divide\pgf@xc by\c@pgf@countb% \pgf@process{#1}% \pgf@x=\pgf@sys@tonumber{\pgf@yc}\pgf@x% \pgf@x=\pgf@sys@tonumber{\pgf@xc}\pgf@x% \pgf@process{\pgfpointnormalised{}}% \pgf@x=\pgf@sys@tonumber{\pgf@xa}\pgf@x% \pgf@y=\pgf@sys@tonumber{\pgf@ya}\pgf@y% \fi% \fi% } % Extract the x-coordinate of a point to a dimensions % % #1 = a TeX dimension % #2 = a point % % Example: % % \newdimen\mydim % \pgfextractx{\mydim}{\pgfpoint{2cm}{4pt}} % % \mydim is now 2cm \def\pgfextractx#1#2{% \pgf@process{#2}% #1=\pgf@x\relax} % Extract the y-coordinate of a point to a dimensions % % #1 = a TeX dimension % #2 = a point % % Example: % % \newdimen\mydim % \pgfextracty{\mydim}{\pgfpoint{2cm}{4pt}} % % \mydim is now 4pt \def\pgfextracty#1#2{% \pgf@process{#2}% #1=\pgf@y\relax} % Stores the most recently used (x,y) coordinates into two macros, #1 % and #2. \def\pgfgetlastxy#1#2{% \edef#1{\the\pgf@x}% \edef#2{\the\pgf@y}% }% \def\pgf@def#1#2#3{\expandafter\def\csname pgf@#1#2\endcsname{#3}} \pgf@def{cosfrac}{0}{1} \pgf@def{cosfrac}{1}{0.99995} \pgf@def{cosfrac}{2}{0.9998} \pgf@def{cosfrac}{3}{0.99955} \pgf@def{cosfrac}{4}{0.999201} \pgf@def{cosfrac}{5}{0.998752} \pgf@def{cosfrac}{6}{0.998205} \pgf@def{cosfrac}{7}{0.997559} \pgf@def{cosfrac}{8}{0.996815} \pgf@def{cosfrac}{9}{0.995974} \pgf@def{cosfrac}{10}{0.995037} \pgf@def{cosfrac}{11}{0.994004} \pgf@def{cosfrac}{12}{0.992877} \pgf@def{cosfrac}{13}{0.991656} \pgf@def{cosfrac}{14}{0.990342} \pgf@def{cosfrac}{15}{0.988936} \pgf@def{cosfrac}{16}{0.987441} \pgf@def{cosfrac}{17}{0.985856} \pgf@def{cosfrac}{18}{0.984183} \pgf@def{cosfrac}{19}{0.982424} \pgf@def{cosfrac}{20}{0.980581} \pgf@def{cosfrac}{21}{0.978653} \pgf@def{cosfrac}{22}{0.976644} \pgf@def{cosfrac}{23}{0.974555} \pgf@def{cosfrac}{24}{0.972387} \pgf@def{cosfrac}{25}{0.970143} \pgf@def{cosfrac}{26}{0.967823} \pgf@def{cosfrac}{27}{0.965429} \pgf@def{cosfrac}{28}{0.962964} \pgf@def{cosfrac}{29}{0.960429} \pgf@def{cosfrac}{30}{0.957826} \pgf@def{cosfrac}{31}{0.955157} \pgf@def{cosfrac}{32}{0.952424} \pgf@def{cosfrac}{33}{0.949629} \pgf@def{cosfrac}{34}{0.946773} \pgf@def{cosfrac}{35}{0.943858} \pgf@def{cosfrac}{36}{0.940887} \pgf@def{cosfrac}{37}{0.937862} \pgf@def{cosfrac}{38}{0.934784} \pgf@def{cosfrac}{39}{0.931655} \pgf@def{cosfrac}{40}{0.928477} \pgf@def{cosfrac}{41}{0.925252} \pgf@def{cosfrac}{42}{0.921982} \pgf@def{cosfrac}{43}{0.918669} \pgf@def{cosfrac}{44}{0.915315} \pgf@def{cosfrac}{45}{0.911922} \pgf@def{cosfrac}{46}{0.90849} \pgf@def{cosfrac}{47}{0.905024} \pgf@def{cosfrac}{48}{0.901523} \pgf@def{cosfrac}{49}{0.89799} \pgf@def{cosfrac}{50}{0.894427} \pgf@def{cosfrac}{51}{0.890835} \pgf@def{cosfrac}{52}{0.887217} \pgf@def{cosfrac}{53}{0.883573} \pgf@def{cosfrac}{54}{0.879905} \pgf@def{cosfrac}{55}{0.876216} \pgf@def{cosfrac}{56}{0.872506} \pgf@def{cosfrac}{57}{0.868777} \pgf@def{cosfrac}{58}{0.865031} \pgf@def{cosfrac}{59}{0.861269} \pgf@def{cosfrac}{60}{0.857493} \pgf@def{cosfrac}{61}{0.853704} \pgf@def{cosfrac}{62}{0.849903} \pgf@def{cosfrac}{63}{0.846092} \pgf@def{cosfrac}{64}{0.842271} \pgf@def{cosfrac}{65}{0.838444} \pgf@def{cosfrac}{66}{0.834609} \pgf@def{cosfrac}{67}{0.83077} \pgf@def{cosfrac}{68}{0.826927} \pgf@def{cosfrac}{69}{0.82308} \pgf@def{cosfrac}{70}{0.819232} \pgf@def{cosfrac}{71}{0.815383} \pgf@def{cosfrac}{72}{0.811534} \pgf@def{cosfrac}{73}{0.807687} \pgf@def{cosfrac}{74}{0.803842} \pgf@def{cosfrac}{75}{0.8} \pgf@def{cosfrac}{76}{0.796162} \pgf@def{cosfrac}{77}{0.792329} \pgf@def{cosfrac}{78}{0.788502} \pgf@def{cosfrac}{79}{0.784682} \pgf@def{cosfrac}{80}{0.780869} \pgf@def{cosfrac}{81}{0.777064} \pgf@def{cosfrac}{82}{0.773268} \pgf@def{cosfrac}{83}{0.769481} \pgf@def{cosfrac}{84}{0.765705} \pgf@def{cosfrac}{85}{0.761939} \pgf@def{cosfrac}{86}{0.758185} \pgf@def{cosfrac}{87}{0.754443} \pgf@def{cosfrac}{88}{0.750714} \pgf@def{cosfrac}{89}{0.746997} \pgf@def{cosfrac}{90}{0.743294} \pgf@def{cosfrac}{91}{0.739605} \pgf@def{cosfrac}{92}{0.735931} \pgf@def{cosfrac}{93}{0.732272} \pgf@def{cosfrac}{94}{0.728628} \pgf@def{cosfrac}{95}{0.724999} \pgf@def{cosfrac}{96}{0.721387} \pgf@def{cosfrac}{97}{0.717792} \pgf@def{cosfrac}{98}{0.714213} \pgf@def{cosfrac}{99}{0.710651} \pgf@def{cosfrac}{100}{0.707107} \endinput