ÿØÿà JFIF    ÿÛ „ !.%+&8&+/1555$;@;4?.451 4,$,44444444444414444444444444444444444444444444444444ÿÀ  á á" ÿÄ     ÿÄ ?    !1AQaq"2‘¡±ÁðBRbrÑá#‚’¢²3S CñÿÄ   ÿÄ !    !1QAa‘2ÿÚ   ? 5˜Z¯V¦cø)›t/? z¨±>Õ5€¶‹Á¤·¼z¼Ü¬+ñ®v¤¨_ˆR­BFn©—˜ý®ç̝P8gýt·ÉSTŦˆìät?þé¼íìN/Þa)ì–í6ô… Ï¿øÃj´¿KÇü]ÿ ªô¹-eKànëÕHTx}ýSÜ›ÿ ”7Ø×&µ<¦  ¥ÑO¶[Ù¯ä¨ÞÃÿ PZ-¬;#õ|•oaÿ ©CìÞz3˜öː/¤­ñTûIØ}š^ mÓ%ªxˆ¥ÉŸu=Z+ISe¿45™¼u;ú&WØ÷€æßQ™®{|íx*TC“#ZŠìZ§²‹ 6pv…³¿¡äª*áZÐ%ÒOáˆo"x«OHk w±æ+¬V(kMúŸ5Vö«$ ÁrÏbàb57/luR ¸ÑÛj Òµì`Мq­û žICÀÊ•©4€Âcà¨Ï€O´<èÐ:›ù(Ë^L8þ‘ÍÌ#¸Ð_Ì©ÙK(Öz 4¬û+¸;ü’V’84‘¬ÃŽ:[â‡ÔÌáõp¢~§ªlæ£ö{®G>J¼"°‡7¯ÆÉèßû ‹É‹§ÁòÃýâßî ^ƾÙõ‹×óH#«LP½ïX=xÑÍ$|W?•~• îëÔ©ª‹ {ÝT…Kÿ ”hûâá)J*ö˜–ÔU;iÇ€/ ÆþjóZ\ýwØ=Ìm ºèËL9 ýèÆð/¨’¥öo=nË.%Îì ŽÕ¯È|{Oj²ƒE6e/ßdÄõ²Ìâ1O®ò×TsəԸhOMýíMˆ¿¼H˜l²,7Â¥#MF/Úf°Ö½± ¸–dr‹NýÊ íjqx{œÉ ä-È ¦ øÄër¨q°ð †nцýÑÄÆ’mä…n<0È™;ÁÝá¯ÁZƒ7FÀmì­ É&9ˆîéi¶ùN§Y• ÃZãAâ?•‡©‰ , ó¾IŸŠc1 4â&y­&pŠ­6;M À 0¹qç»p.á …ŸÅáK@%6·y6ƒ‰3?”úºŽ‰éX5ªPT §µ!=Mž«Ú½‹ÅgÂSâÉaþÓoö–¯ÁÔìR>5éÿ üs¶ÆUcÌ kÇR ]ÿ ù¬¼«VŽ;Â|‡~¢¦”ÏŰæ {L™Õ°Óv¹ò¸írޡעCÃ!íVÕ {¶»sŒNPg/ "uÕbkm²“$ďå¿é¹§°½æz¯6 †s¿!s–wÚÝ“™Œ °.ûj>·+™Òa…©Œ&rÝÎtÛë긪Ît’LAVp%c Úý[ÄzJ¾ÇàXXç@˜ó<êL]·T˜¾¥1Ó©V‡g´æ½¦Ý@¹óø!_@´ÞâSÁ —S3™•& ]@JHÚý©ZŽ €×æÔr»Áf!‡yÞ4Mv*èÓã_{‘åóUuљØ«Oïé*®EvÑ Œ÷‡U \"㪒ÍK+À 4“M¡ï:0¥5í!'<@î´”>Ç»&Z–ïCCV˜Ì5Šo&îhè.žû |ÓK©h$s6KìŒëã)¹hI¦GïOåóI;ììü#É$Š0…Ææ¥TØ.5­¾gn´ “ÂÖ\:hœ89G)J@„}œ:’Ò{/Š"¦_Æ×7Æ3VÇŠÊa]ÚŒÙ€Ä–=®uÁßâACZƒ§§£ Qnâ:«,×{tyø¬iÛcœÜÄ€H½ÄÍCk´÷šß .W'b¤Íåh]÷€=,Žv×cÚEÚHXJX¶îo¨FÒtèöŸ>ªª6[J®Fµ£sGÁeqõfe\íjÒÐïÄÐGˆe1Ø‹.Ø”‘Ëuø Y­ˆÜ ŽG|zùªüMpDnQWÄ”%JŠ™)â*p@Örš«ÕT2Ð%ˆG#ª„ ·¤!°ŸOTÂT¸aÚ%4&h™LµšØüÐ.F¿²ÐÞ_Ç‚¾ÅÃaÜ÷09Æ q€öy˜v‡85õN÷]¬äѼóS{°_MެúÔ#°Ç¸0åÞè2ëôPcvÆw9®ií1Ä8F™˜à‰´+‰Ik1òÝ7“Ñ×ÒsÝ\x‚h`ÞÑ`ó"|µEcý£n˜h`}GÞ !±ù²Ápü²ß6 0ïi󜵩SÈÇ7˜-ÕURO˜¦´f$ªž-Í6(œ}<„ éc øs]ŽŽ„*—¾ ìdŽ„)méª\¿êÎIg¾ØÞ~I#C/¼¼´EÁÈŽi8“©õådô·>euä ƒ'Ê×लR1ÉJE1ÐAát`t;ÇР%Ý<‡¥„ÍÆ`×Oyó)õiI€ñQaŸ4Ûù\áàaÃÔ¹HÃu¹*k€¦<„e S‡&õÏ B!ŽhüÞ`yj}mªf×\¿ Ç~æ­9‡û\՞Ǖg²1Žû5V7 !àöšm° c`ܬøÇìµÒ'P"?…´Ö,"§^•õލsÔ)6˜sæéÍR¼ ò|Sl”‹7 nPW Gòú÷½§O¯‡„l¡kSÞŒr½PÊ@æ¢pŽ-mÿ #Ÿ˜Àº¶Áä¦;ïÔæ$1££`“Õ>„—·ž)ßð³ñ#Ï Ô$¶œ‰ÊE‹À;÷º ¯«P:Ñ”8–IÊtpÞ3ª“>ê“þës4ò2OÏÕ­±zô†Õ§‰.÷ä¸;¿˜“'œ›žª}«Œ{ª±Ì 9ÔóÞÕ‡0 $íWV3Üì¬ —@kÝ4@¿r¼±½¬™›?øØæ´'Áé®CË3-g$˜ö‡×auÚi´Žp/êÛ æF›Ú2v‹ã¿¿,nB1̨ƃqÞa5͝@&Æû“él÷ \C²½UÍc ¯k×¢U ÖéQå™—-r wô ÞÏ<Ò=&=ÿ Ôê Òêˈt,i—;LîÜ á¸*ÚÃ1$êL•LÍ <É)ýÐà’ ;F™{ƒ™˜€&'}‚ãÄK`¡ÞT@I;®žZóè‚s’7®°›+§O­Åq©é»²9<Ô J ¼9O’HL»Ùïì¸rk¼Ž_ý‘TŸu[²ßÚŒ·ü÷B%¯E ŸÔX5êO´ Ç•€’I0 ÉJX` ñ¹õ%;µŸD‘«´€àwÒ™U ûئžÖö\×®×´8 ½‡ºÐÆÓ§?Àkmœ=;d5*@-ì0F Rªýš[Ü6âö̃ڸr*KA9· u*µæ£?U¸Âêí†8@¦X4 e-ò„0s{ HâUpU?¼mñRa°®a%Ð'tÉ×’\¾ÊÉ]t›h>·(Ë@R¼¡Ãt h}’O÷au<+nT…Ö…MӐ??Óe95 q>í/;&JSû °¯ÊéÞ øƒ*Ã2½Ài&:nôUl=¾¿5eˆ3”ñc|Ú2V”>„»&eE;«ÚäC p¢Û úy 9š[ŒÌx¼擼A&DåÒ¯ˆ¤ÀÌ;"˜ ÏQä¸åhÊ}Ûq«Û0WžÒ|»€ø®öCm5•\ÇÀ§Pe3£]0ÃàLDÉ‰1øªxjgwT‚÷¿LΨK‹›ùs—xˆÜ±µ kæ¸f‰‰ÜGk/LÛØ6d9ò¶ùA{ƒA3š/¬D¬khÓk‰`˜"㯒r¿±Óã jx‡°e}<Ñø\3y:'À•/h½Í€Ç4~g ?Û(¼]v‘ªlKÎâ~?O‚W%{Ì:“'©úNq¾›úo(X’¥¯ˆ nFê{Ç€ü?º'ë ø‹ì Þ09ŒÌç9Æ —ËC`j@ÓÄ(+a‹un¸#ÂꟋ{K`‘ÑÍÍ'à´»/Û,KW;Þ4²þð ï Nm|~fGÏ(…³Ã)«1ö­Õ ¥‡¨©ƒÃ™ü-s=à=U66Ï«Ýc蓦W¹íž®›nÔ%êÇìŒ<#Ü×84ån®Ð ÒåOC` ñânÑs‡¢ç 1õ%Îhì½Ã½® e:ݼUZo™`  ÅZŸŒÊ«ê1ÏÄo$q¹Þ€©ˆhÐÉä¯ñ[!…Ú˜àJ:x2$Íß&PåT£6ç— ‡Í*4Ýšçjÿ ‰É nófÐ ó(L5C•åÆ\rMÒ@ò }y-W}™üýVù—ú¢=Ù”c®‘< M ž ´Phr ¦©TD ‘ù.$´÷O‡‘V2Æò.=IUŒ=ž‡â¬i™aþÓåÙ?òUø'ØÖ•.~* šTŒ!•-×áºTâ®ä#õü'´ eýlYÅÓeÕKÂrT"CÚ@u!Óxƒ{š3€}1¿(r}%«nËamjÑ%ÑNEò v ˜à  σöK³,*º.àzù¨™Ó ÚçâU¦*¿ 9{%Ö¹ njûdaXöb) kÛÆ±ûÓ\°M7ˆÂ=û›ç¿Ã‚­V»Cg–8ÙêE- j)k$º`Ã-ùEýeBÆÇ]c¡°ñty&Òd0nõ'¡W+ƒ*|–øµFa\GQªEAÔp5\Ǽ·¼Ç8·õ -â§Ú[ ‡ uZeÖ 3}×d'+¹:ð+K†Û®s!Ï$úe€<Û”x)1»a­¡LC]¸µík…ÚàA»AYº{†ªS[¦5HÒ7ù --,ísòDØ€èk ÞÀîÜ ò@â( ËNˆë›4ô½•/¦o‡€Û7 ê•ÆêòðÜy'Án½µ á˜ݦ ndeo…[ì¶Ê,¥R³Ä=À±—–ß;£™´ñSâ*g§”ïaið‘Jå~™ÓÞ ß³Õ¢»8x埒²52>AÊb&-÷\7´éÄù€T˜,w;3{ï˜k…à¹ÄqÀ«œ{€\ ˆ¾[´¨јr &Úé„Ívˆ±8†¿]|¬ņ4I×pÞS1ÈÖz‰#Ìv‡G!YNògñ:màTz¢Ý1ô©^O=~ë|5Bã™ç•¼µõ•bÆ@úÕS¬ÈŒ#¬zünrŸ û” Z²•èðV"ÁHÚý©wÝ €7¼Ìu1hÑa3Éä û f$o¿É ™Ú›ÝçnpÒ3äÌ3†Í§,Äï]$‰/pê †«À¼¸e9­Æê_C]žƒ·ý·frÁN«, E=›Çq -‰öŒ:aÏ¿±í&£Í:-} 84‘ÿ eƒQÑeëSsuiA ³g㟥ú£?ÿ ʼn*”“÷aühe:ÊWa@ÒÞk±eØ] F Ô—r.åä˜ @ö¥ªZoÐýYL·¥S²G/‡ñ <~*ZÆ´è>JlòàÛÆ½ÿ 窘ìGN¢:I®KšJp/`íIÁÀõ#Ä-€ö­šµŒoF4|ÆQØÆ@Ì|£Ô…¢À{9˜è½Üó›€ôYÒÎYsið;ís¤€à²ˆ‚4qÉVŒI$ ‰"° æµ8cXGjœˏ¡Aâý•ËÜ¢ûï e·çLx']á"oÅÎê3¯Ç—¹”ó0nå‚âg{Œñ> S´˜îè°g238‚ãköÝfÚd´6Ò€;ò÷±¢™¼›º ¢Æ'¥Ðx'e¬ç ]bÈÆV¢ó‹kýBO ðÊâ$Ÿ!×T 3Mýמ žìٍàÌü‘8÷€àæØ8æ©6‰©L´«…oãpð„~Çk‰!ñ;‹”ÛžÍ àž±z Ÿôû øŸÝužÏ;ÿ #|u6™Þ¬ÚˆÐõA4¶â|ôl|Ê2ŽÇ¤ÝÅÇY.<#Aí.k§hóF‚”Y; M½Ö4hŸ4&›­¿tès´%FìL¥£Ãk‰ÇT¤haÁ¤ÚxfÉ`ÑìË›>i 3t‚:,–+^÷´–{Û–Nxi"x‘Ûg î¨>¥Õ܁ùZH,2Û“:8xÊ¢Çí9.É-Ìâã-=çjwµS˜dütžçwýGòú®®ûº_ˆýx$–¡ãøO EÚÛÏ÷R„×w+3£Á£öUMyR²¹âŒ°š›¸Ñãò9§Ó_Dl+Ùßc›úšGÅÌc†Ž!Ko=¶.‘Îÿ c²(2®V mª.ÿ ¹B›¹å ù„öŸSV>™ü¯$y:G¢Z×àøúdî¹û­·ýÇ´:•c LÍõi_‹ö+ÎæGÊè>OŠ•äž´§Þ{X}¨1ÚTc›»Qþ•êô°t¿OP?eæ~É{5]•ÙR£r5†nZ\ã@ &îJõ ¾àC°þV>fé¥/ü5ñÊIº_é5 ;e­h<@ Ä&æÃëE%;X,ÒãÆÞ`Oò¦kŸm#˜!ÀyÄ¢| óLšò¥Ä` ¶R=|ÈCâh5ò3DˆïF†ðÒ#ÅìÛœ?¸yhBãœí ZxßÎÄhºRK„`Þödvײ™ÀÈÑÒgŒuY w³%†ƒÓzõ ÖÏp‚dH®¦A´ù§»ÓÇMæ~)ˆð‡û:ù&Ä •vGD´À n ݇¼Ö8Fö óáà£~Ë¥x`oK|Ä?fxiØü%pìR>éò+Û±éÎ>núlFŤ'tq8LZÏvÃ?„¡ß±È⽆¯³íü@x|PöUäèØã¡ð‚ŒAìÏ"vÍwóŸÍ{ ý0.z È•Ö{,N¡£¡ŸKÕÙž>Ýœþ ÍÀ°<×EA!Å‚D™IúOÍ¡>ôG}Â` ÍßkÜL™Ž Þð™ {IøF²¹òQ3&!ÃÂÞz.d&Ï-sH¸,Ôõ˜ŽP€ 77ˆÝ¼ÊëÜw =cÕ Ú,ØÐ5ÎYÐ)ì´öœgŒ[¤ßv㙑8心>h]§µháYš£²ºÑ.{Ï7Sð•?´~×SÃKýJÛ˜ ™Íäiúu<µX¶1õ^kâçIÑ£sZ4h>j*ÔšD:4­¿_ ÷¸ Õxæÿ ¸?Mù _•­ÊÐ ä ÷ý ÑwL œ­ïnTkÛUÍN©ë:¦fV ¶ÜÔÜMªÅâA½–¿R×TXš-%iTÊT•‡Ù‚JôϐZxWÑè‰f‰òG º ×Õû2aZ7OU3[“×AT–ÞŒ…-‘¤”Ì ì&(ˆ¿­•ƒkï’:ðY¦W‘ Å)“†‘˜³Åtcø˜ñTÂwÚÇ4|üLÇªí–v- qˆèU qPE.†â‘˜µ Æ,ÐÅs]8¾„oúÑ i>ÜxxÈó)ƒ ´æÁâØ$À‰vžŸf$Ž |ãw;ÀÁIJ»b` {¦Ó¤Ú$©YÀ‘n@Óïž«9J¼êG m¤ ܯ¹ÌW4€ÐÒÅÛ‡#褕Ÿn-?í|с¥÷Ú¹¬'´ÞÜ9ÓK `hê£SÄSà?7—Wí_´…óB›»:=Ãïq`<8ñÓŒÑlú2d¬ê³£hÖ[l|$vÝro~'R®‰§°ñmY ͧäP |PUª¹·:3Œ[Û{Xÿ ºâ@‚W–Äé u‚ ¯´*=íή.pûÒdt @G‰¬ s¸ ëÉücr ÞæÑ¨Ê@>¤¢Ö±. Þ'¯°ÌME[YéïĵÂCå½ Ué©Áû'Ê9%eÔðNU”ë‘ÌsD3/®+UI˜9h.WC”빓$#:pz:YÓ ¿xž* ³$Í +$kñAŠ‹†¢ Uê>¸)_š¬÷©ßAÂÔb9ÇU ¯¾á•9¯ÏÏ÷O÷¼¼Fähal1‰3Ì[Ïr•´UCksNÐ] R‘¸¥H+§Šé†c©vÖÞ0iÓ76s†î!§=ß ¼~Ô'°Ãmäoäš³ªøi1úÉ)³yV8 CLÄØÁ‘WYïi€H6ÖÑiámø^ÈY´°Ñ7¥Û*—Ñ©L«Qƒï—Ùrÿ ›£Ð*š¸ˆL©ˆ$ˆ ÷¾D§9È®«qbqC)–ˆïv´çñsÑVT­Ø, <àïºÀO«Jý·õ àfPìð .wFšir´þ’2_Y *Æ€x\« ì€9š@ Ž|F⇥ˆkZ@hÖÄ0t¿-<“‹qµ¾*ZL¤Ú)&BJpÓF5=$„at*Zš$’ÑtdûÝRI1 2މ$€$I$#‰SÞ’Hë¬ï;Á$¡t$’`<(ñÇt)$‡Ð.Êf¢X’Kt=Éé$‚ˆªè¢oÝëòI%Rgcª÷ŠyI%¡‰ÿ !ñ)´õ $¤ Ô’IIGÿÙa 3g@s(ddlZddlmZddlZddlZddlZddlZejjZ de Z e dZ dZ dZ ddde e d?ddgZd Zede D]Zeeded>Zqz[ed d eDd d eD7ZejjZejjZejjZejjZdedeedZd dZddZGdddejZ e!dkr$e"dS)N)supportFlUU*UU*l*UU*UU cCsg|] }|qSr.0xrr-/opt/python39/lib/python3.9/test/test_long.py r cCsg|] }| qSrrr rrr r rcCstjjd}tjj|}d|>}gd}|dkr4dS|dkrHt|  S||}|dkrf|| >n||?t|d|>@B}|||d@7}|||k|krtdt t ||S) Nrr)rrrrrrrrz%integer too large to convert to float) sys float_infomant_digmax_exp int_to_float bit_lengthbool OverflowErrormathldexpfloat)nZ PRECISIONZ SHIFT_MAXZQ_MAXZROUND_HALF_TO_EVEN_CORRECTIONshiftqrrr r's    , rcCs ||Adk}t|t|}}|s*td|t|kr>td||}|dkrf|d||ks|dkr|d| |kr|d7}t|tt}|t| d>|t|d>}}t||\}}d||ksd||kr|ddkr|d7}t ||}|r| S|S)Nrzdivision by zeroz)int/int too large to represent as a floatrr) absZeroDivisionErrorDBL_MIN_OVERFLOWrrmax DBL_MIN_EXP DBL_MANT_DIGdivmodrr)abnegativedexpr rresultrrr truedivUs   2 $ r/c@seZdZddZddZddZddZd d Zd d Zd dZ ddZ ddZ ddZ ddZ ddZddZddZddZejdd Zd!d"Zd#d$Zd%d&Zd'd(Zd)d*Zd+d,Zd-d.Zd/d0Zd[d2d3Zejd4d5Zd6d7Zd8d9Z ej!d:d;Z"ej!ej#e$j%d<d=d>d?d@dAZ&dBdCZ'ej!ej#e$j%dDdEd>d?dFdGZ(ej!dHdIZ)dJdKZ*dLdMZ+dNdOZ,dPdQZ-dRdSZ.dTdUZ/dVdWZ0dXdYZ1dZS)\LongTestcCs||d|t}|td}d}d}tttddB}||kr|d?d}t|||}|d|koxtkn||}||>}|d@r|d|>dB}tttd}q@|||ko|kntdkr| }|S)Nrrr?)Z assertGreaterSHIFTintrandommin assertTrue)selfndigitsZnbits_hiZnbits_loanswerZnbitsr-bitsrrr getran{s&    zLongTest.getrancCs<d}t|D]}|t>tdtB}q tdkr8| }|S)Nrr1)ranger2r4randintMASK)r8r9irrr getran2s   zLongTest.getran2c Cs|j}|j||dt||\}}||||}}||||}} ||| d|||d|||d|||||d|dkr|d|ko|kndn |||kodkndWdn1s0YdS)Nr yzmultiplication does not commutez(divmod returns different quotient than /z#divmod returns different mod than %zx != q*y + r after divmodrzbad mod from divmod) assertEqualsubTestr'r6) r7r rBeqr r-Zq2Zr2ZpabZpbarrr check_divisions   "zLongTest.check_divisioncCsttdtdttttd}|td|D]2}||}|D]}||pXd}|||qHq6|dd|dd|dd |d d |d d |dd|dd|dd|dd|dd|dd|dddS)Nrl!Us/w3alZW3al+Q@{dB]OlNlOOlNlteo%gqCgxd}|D]|}||krjq\|j||dPd|>d}||}d||>d|>d|>d}|||Wdq\1s0Yq\qHdS)Nr dcSsg|] }|tqSr)r2)r digitrrr r rz+LongTest.test_karatsuba..)abitsbbits)rIr<rKextendrDrC) r7rMr:rUr(rVr)r rBrrr test_karatsubas*   zLongTest.test_karatsubac Cs|j}|j|d||d@d||dB|||dA|||d@|||dBd||dA|||||||@||||B||||Ad|||@d|||Bd|||Ad|| d||| |dWdn1s 0YtdtD]}d|}|j|||dx|||>|?||||||?|||||>||| @||?|>||| @||d@Wdn1s0Yq"dS)N)r rrrr)r rp2)rCrDr<r2)r7r rErrYrrr check_bitop_identities_1s22z!LongTest.check_bitop_identities_1cCs|j}|j||d|||@||@|||B||B|||A||A|||A|A||||@||B|||B||@|||A||B||@@|||A||@||@B|||A||B||B@Wdn1s0YdS)NrArCrD)r7r rBrErrr check_bitop_identities_2sz!LongTest.check_bitop_identities_2cCs|j}|j|||d|||@|@|||@@|||B|B|||BB|||A|A|||AA||||B@||@||@B||||@B||B||B@Wdn1s0YdS)N)r rBzr[)r7r rBr]rErrr check_bitop_identities_3sz!LongTest.check_bitop_identities_3c CstD]}||qtdtd}|D]T}||}|||D]6}||}|||||||||dqBq&dS)Nrr)specialrZr<rJr;r\r^)r7r rMrNrOrBrrr test_bitop_identitiess     zLongTest.test_bitop_identitiescCsg}d}|dkrd| }}|r>t||\}}|t|q||pNdg}dd|ddddd|dd d |DS) Nrr-Z0bZ0o0x)rrRcss|]}d|VqdS)Z0123456789abcdefNrr r?rrr 1rz'LongTest.slow_format..)r'rLr3reversejoin)r7r baserMsignr-rrr slow_format%s   zLongTest.slow_formatc CsdtfdtfdtfdtfdtffD]\}}||}|j||jd(|||}|||Wdn1sp0Y|j|d"|t |d|Wdq"1s0Yq"dS)NrrdrRre)r mapper)gotr) binoctstrreprhexrD__name__rlrCr3)r7r rjrmrnexpectedrrr check_format_13s* *zLongTest.check_format_1cCsNtD]}||qtdD],}tdtdD]}||}||q.qdS)NrRr)r_rvr<rJr;)r7r r?rNrrr test_format<s    zLongTest.test_formatc Cs"ddddfg}|D]j\}}dD]\}dD]R}|||}|}|dkrR|turR| }z|t||Wq(tyxYq(0q(q q|ttd|ttd |ttd |ttd |ttd d |ttdd|tddd|tddd|tddd|tddd|tddd|tddd|tddd|tddd|tddd|tddd|tddd|td dd|ttd!d|ttd"dd#d$d%d&d'd(d)d*d+d,dd,d g }|D]} |ttd-| q|ttd.dS)/N)Z100000000000000000000l Fx:^VZe10000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000rRrS)rb+ra)rb  z raZ123LZ123lZ0Lz-37LZ0x32LreZ1L+Z000rZ0o123SZ0x123i#Z0b100rz 0O123 z 0X123 z 0B100 0z+0z-0Z00Z08z-012395isilllrZ42uこんにちは) ValueErrorrCr3 assertRaises) r7ZLLsvrkprefixssZvvZ invalid_basesrjrrr test_longDsT     zLongTest.test_longcCsBGddd}|tt|Gddd}|t|ddS)Nc@seZdZddZdS)z*LongTest.test_conversion..JustLongcSsdSN*rr7rrr __long__sz3LongTest.test_conversion..JustLong.__long__N)rt __module__ __qualname__rrrrr JustLongsrc@seZdZddZddZdS)z+LongTest.test_conversion..LongTrunccSsdSrrrrrr rsz4LongTest.test_conversion..LongTrunc.__long__cSsdS)Nrrrrr __trunc__sz5LongTest.test_conversion..LongTrunc.__trunc__N)rtrrrrrrrr LongTruncsrr)r TypeErrorr3rC)r7rrrrr test_conversion}szLongTest.test_conversioncCshz t|}Wnty"d}Yn0z t|}WntyFd}Yn0d|||}||||dS)NoverflowzAError in conversion of integer {} to float. Got {}, expected {}.)rrrformatrC)r7ractualrumsgrrr check_float_conversions      zLongTest.check_float_conversionc Csgd}|D](}|t|||t| | q dD]B\}}tdD]0}|ttd|d|d|d|qJq:dD]B\}}tdD]0}|ttd|d|d|d|qqtt}dt}||d}|t|t|t|dt|t|dt|tt||td|t |tt| |tt|d|tt||tt|d|ttd|d|ttd||tt||td D]b}d|d d}d|d }|tt||d|d }d|d}|tt||q|d||d|d||d|d||dd|dd|||g }||td d D].}tddD]}| d|d|qq~|D]} | | | | qdS)N) rrrllllll)rr)rrrHrrrrQr)rrrdrrr))rrr)rrrrr)rrdr)rdrd) rd)rRrd) )rr) r)rGre)rrerrrSlrrd5) rCrr<r3DBL_MAX DBL_MAX_EXPrrrWrLr) r7Z exact_valuesr rBpZ int_dbl_maxZ top_powerZhalfwayZ test_valuesvaluerrr test_float_conversionsX   0  0       zLongTest.test_float_conversioncCsrdD]}|tt||qd}dd>}| }|||td}dD]}|tt||qB|t|t|ddS)N)gr?@AX123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345123451234512345ri0u)hugemhugeshuger)$ float(huge) float(mhuge)z complex(huge)zcomplex(mhuge)zcomplex(huge, 1)zcomplex(mhuge, 1)zcomplex(1, huge)zcomplex(1, mhuge)z 1. + hugez huge + 1.z 1. + mhugez mhuge + 1.z 1. - hugez huge - 1.z 1. - mhugez mhuge - 1.z 1. * hugez huge * 1.z 1. * mhugez mhuge * 1.z 1. // hugez huge // 1.z 1. // mhugez mhuge // 1.z 1. / hugez huge / 1.z 1. / mhugez mhuge / 1.z 1. ** hugez huge ** 1.z 1. ** mhugez mhuge ** 1.zmath.sin(huge)zmath.sin(mhuge)zmath.sqrt(huge)zmath.sqrt(mhuge)z(float(shuge) should not equal int(shuge))rCrr3rrrevalZassertNotEqual)r7r rrr namespacetestrrr test_float_overflowszLongTest.test_float_overflowcCsttj}ttdgdD]@}d|}t|}|||||}t|}|||q dd> ddfD]$}|ttj||ttj|qrdS)NrR)rS'rrrr) rlog10erIr<ZassertAlmostEquallogrr)r7ZLOG10Er,rrrurZbadrrr test_logss    zLongTest.test_logsc s|j}Gfdddgd}dD]B}||d|d||d|dt|dt|t|dgq$|ddd tjttjgtd }|ddd dd >|d||dg|d d |D|D]}|}|D]}|}||k||k}|j|||d||k||k} ||| |||k|dk|||k|dk|||k|dk|||k|dk|||k|dk|||k|dkWdq1s0YqqdS)NcsHeZdZddZfddZddZddZd d Zd d Zd dZ dS)z)LongTest.test_mixed_compares..Ratc Sst|tr||_d|_nt|trtt|\}}d}d}|rrt||}t|}||>|B}||8}||8}q<|dkr||>}d}n|}d| >}|dkr| }||_||_n t d|dS)Nrrzcan't deal with %r) isinstancer3rr+rrfrexpr!rr) r7rfrZCHUNKtoprTrr+rrr __init__s0      z2LongTest.test_mixed_compares..Rat.__init__cs<t|s|}|j|j|j|j}}||k||kS)N)rrr+)r7otherr rBRatrr _cmp__Fs z0LongTest.test_mixed_compares..Rat._cmp__cSs||dkSNrrr7rrrr __eq__Ksz0LongTest.test_mixed_compares..Rat.__eq__cSs||dkSrrrrrr __ge__Msz0LongTest.test_mixed_compares..Rat.__ge__cSs||dkSrrrrrr __gt__Osz0LongTest.test_mixed_compares..Rat.__gt__cSs||dkSrrrrrr __le__Qsz0LongTest.test_mixed_compares..Rat.__le__cSs||dkSrrrrrr __lt__Ssz0LongTest.test_mixed_compares..Rat.__lt__N) rtrrrrrrrrrrrrr rs( r)rgMbP?gGz?rg?g@xDZbti)gBgCg@Crg333333?rrrri NcSsg|] }| qSrrr rrr r arz0LongTest.test_mixed_compares..)r rBRcmp)rCrWr3rmaxsizerrD) r7rEZcasestr ZRxrBZRyrZxycmprrr test_mixed_comparess29$ zLongTest.test_mixed_comparescCs|tddd|tddd|tddd|tddd|tdd d |td d d |tdd d|td d d|tddd|td dd|tddd|td dd|tddd|td dd |tddd|tddd|tddd|tddd|tddd|tddd|tddd|tddd|td dd |td dd |ttd!d"dd!|ttd!d"dd#|ttd!d" dd$|ttd!d" dd%|ttd&d'|td&d(d)|td&d*d+|tdd,d|td d,d |tdd,d-|tdd,d.|tdd/d-|tdd/d.|tdd0d1|tdd0d.|tdd2d3|tdd2d.|ttd&d4|td&d5d6|tdd7d8|td d7d9|tdd7d:|tdd7d;|tdd<d:|tdd<d;|tdd=d>|tdd=d;|tdd?d@|tdd?d;|ttd&dA|tdBdCdD|ttddE|ttddF|ttddG|ttddH|tdItddJ|tdItddK|tdItddL|tdItddM|tdNtddO|tdPtddQdRdSttdTtdUdDdVdSttdWtdXdDD]j}|dYvr|ttdZ||ttd||ttd ||ttd[d\||ttd[d\ |qd]D].}d^D]"}|t||tt||qXqPdS)_Ni[r+Z 123456789,z 123,456,789_Z 123_456_789rra1rz-1z-3z 1z -1z+3z +1z 3ryz 1rHr 3XiZ4d2i.z-4d2Z8xz 4d2z -4d2bereZBEz-bez-BEIz,xZ_xZ 4996_02d2Z_XZ 4996_02D2oZ2322z-2322z-oz oz 2322z+oz+2322z,oZ_oZ 111_4540_1322r)Z11z-11Z 10011010010z -10011010010z-bz bz 10011010010z+bz +10011010010z,b90Z_bZ11_0000_0011_1001z1.3Z_cz,cz+czCannot specify bothz_,z,_z_,dz,_dzCannot specify ',' with 's'z,szCannot specify '_' with 's'Z_scSsg|] }t|qSrchrr rrr r rz+LongTest.test__format__..r(r]cSsg|] }t|qSrrr rrr r rAZzbcdoxXeEfFgGn%rrrSzeEfFgG%)rrrrSri.i) rCrr3rrZassertRaisesRegexr<ordr)r7 format_specrrrr test__format__qs   zLongTest.test__format__cCs:|tttd|tttd|tttddS)Ninfz-infnan)rrr3rrrrrr test_nan_infszLongTest.test_nan_infcCs|tdd}Wdn1s(0Y|dd|dd|dd|dd|dd|dd|dd|dddS)NrrrHrrrr"rCr7rrrr test_mod_divisions &       zLongTest.test_mod_divisioncCsdd>}| }|||d|||d|||d|||d|d|d|d|d|d|d|d|d|d||d?|d|d||d?|d|d||d?|d|d||d?|d|||d>d |d ||d ||d }d D]}|tt||q4d D]"}t||}||dd|qPdD]}|tt||qxdS)Nri@rrrigԄ@gԄr1i@B)rr)rrzhuge / 1zhuge / 2z huge / -1z huge / -2z mhuge / 100z mhuge / 200)z1 / hugez2 / hugez -1 / hugez -2 / hugez 100 / mhugez 200 / mhugezexpected underflow to 0 from %r)zhuge / 0z mhuge / 0)rCrrrr")r7rrrrZ underflowr.Zzerorrr test_true_divisions4  zLongTest.test_true_divisioncCs|tdd}Wdn1s(0Y|dd|dd|dd|dd|dd|dd|dd|dd|dd|dd|dd|dddS)NrrrrHrrrrrrr test_floordivs &           zLongTest.test_floordivTc Cs|r"tt|t|dtkr"dSztt||}Wn*tyJd}Ynty^d}Yn0zt||}Wn*tyd}Yntyd}Yn0|||d||||dS)NrrZ zerodivisionz7Incorrectly rounded division {}/{}: expected {}, got {}) r$r!r&rrr/rr"rCr)r7r(r)Z skip_smallrurnrrr check_truedivs"        zLongTest.check_truedivcCs|dd|dd|dd|dd|dd|ddtd|dd dtt|ddd d |d d d ddtttttf}|D]p}t|d|dD]X}|ddt|dddt| d|ddt|dddt| dqqddd ddd d ddddddd f D]B}tddD]0}||t||||t|| qLq>tdD]6}|dtddddd|dtdq|dd|d d!td"D]6}|d|dd||d|d|dqddd#d d$d%dd&dd d ddddddd fD]0}tddD]}|dt|||qVqHtd'd(D]}||dd)qd*dd dd"fD]n}td"D]^}td|}t|d|d} ||| || | ||| || | qqtd+D]r} td"} tdd"} td| } tdd| }|| ||| | || ||| | q&dS),N{ri8rHrige~rriNFrSíl90rQri0&iCrrrii)2rRi lE,J_lJbrrrdre ii4ld( r) rrr&r%r<r$r#r4 randrange)r7basesrjr,mrr?Mr(r)rZa_bitsZb_bitsr rBrrr $test_correctly_rounded_true_division8sn     *. "            z-LongTest.test_correctly_rounded_true_divisioncCs|tdd>Wdn1s(0Y|tddd> >Wdn1s`0Y|tdd?Wdn1s0Y|tddd> ?Wdn1s0YdS)Nrrrr)rrrrrr test_negative_shift_counts & , & z"LongTest.test_negative_shift_countcCs|dd|dd|tdd>Wdn1s@0Y|ddd>>d|tddd> >Wdn1s0YdS)Nrrrr)rCrrrrrr test_lshift_of_zeros   & zLongTest.test_lshift_of_zerocCs,|dtj>d|dtjd>ddS)NrrrCrrrrrr test_huge_lshift_of_zerosz!LongTest.test_huge_lshift_of_zerorg?F)Zmemusedry_runcCs$|dtjd>dd>tj>dS)Nrrr )r7sizerrr test_huge_lshiftszLongTest.test_huge_lshiftcCs,|ddd>?d|ddd>?ddS)Nrrrrir)rCrrrr test_huge_rshiftszLongTest.test_huge_rshiftg?cCsJdd>dtj>}||tjd?dd>d||tjd?ddS)NrrrirQrr)rrrC)r7r rrrr test_huge_rshift_of_hugesz!LongTest.test_huge_rshift_of_hugecCs>dd}| d}|d}|||d|||ddS)NrrSr)assertIs)r7r(r)crrr #test_small_ints_in_huge_calculations  z,LongTest.test_small_ints_in_huge_calculationcCstddD]}|||d|||d|||d|||d|||d@|||dB|||dA||||||d||tt||||d>d?t|q d}|||d|d|ddS)Nrirrrrl)r<rr3rq)r7r?rrr test_small_intsszLongTest.test_small_intsc Csd}tddD]}|}||tt|d|dkrl|d|dt|kobd|knn ||d|dkr||dt t t|t d|q|dd|dd|dd|dd|d dd D]}d|}||d||d|||||d|| |d||d|d|| d|dqdS) Ng|=iiz-0brrrrr) rrHrrerr!?@) r<rrClenrolstripr6r!rfloorr)r7Ztinyr kr?r(rrr test_bit_lengths00   zLongTest.test_bit_lengthcCsddddddddddddddddddddd}tdddD]H}|D]:\}}t||d}||}||||t|tqFq:|tdd d |td d d |td d d |tdd d|tdd d|tdd d|tdd d|tdd d|tdd d|tdd d|tdd d|tdd d|tdd d|tdd d|tdd d|tddd|tddd|td dd!|td d d"|td dd#|td d$d%|td d&d'|td d(d)|td d*d+|td d,d-|td d.d/|td d0d1|td d2d|td d3d|td d4dtddD]@}td|d5d}d|d6}||||t|tqtd7D]H}tdD]8} td8d9} t| |}||| |t|tqqd:d;ddddfD]} |td?| d?qVtdD]6} td8d9} t| }||| |t|tqxd@} | D]} | t tdA| qdS)BNrrRr)rrrrHrrQrrrdrrRrrrrGrreriirijri8ikriiir1r3rSrri,iԡriiil!l !l~!l!rl !rl`!il!rl'!ilz+ilv|orl,GxiiiiFirQirrrrrri{)ZbrianryrH) r<itemsroundrCrtyper3r4rrr)r7Z test_dictoffsetrrrnruexpectrr?r Zhuge_nZ bad_exponentsrrrr test_roundsz             zLongTest.test_roundcsd0fdd }dddddd d d d d dddddddd}||dddddddddd dddd dd ddddd}||d ddddd ddddd!d"d#d$ }||dddddd dddd dd"d%d$ }||d ddjtd&jd'dddjtd&jd'dddjtd&jd'd ddjtd&jd'd ddjtd(jd)dddjtd(jd)d ddd*d*dd+d'd,dd-d*d,dd.d(jd,dddd/td'jd*ddS)1NFc sp|D]b\}}z |jt|||d|Wqtyh}z td||||WYd}~qd}~00qdS)Nsignedz7failed to convert {0} with byteorder={1} and signed={2})r&rCto_bytesr ExceptionAssertionErrorrtests byteorderr-rruerrrrr checkFsz%LongTest.test_to_bytes..checks)rrrrbigTr,little) rrrHrrLrMrNrPrMrrrrrrQsss)F)rrr.rC)r7r5tests1tests2tests3tests4rrr test_to_bytesEs   zLongTest.test_to_bytesc sd3fdd }dddddddddd d d d d dddddddd}||ddddddddddddd d d d d dddddddd}||ddddddd dddddddd }||ddddddd dddddddd }||dddGd d!d!t}t|d"d||d#ddt|jd"ddd||jd#ddddt|d"d||d#ddt|jd"ddd||jd#ddddtjgd$ddddtjd$ddddtjtd%ddddtjtd%ddddtjtd&d%ddddtjtd%ddddt tjdgdt tjdgd't tjdgd(t tjd)dt tjd*dt tjddt tjdddt |jd)dt |jd*dt |jddt tjdddGd+d,d,t}|d#d}t|||d-Gd.d/d/t} | d#d}t|| |dt |d0d1d2dS)4NFc sl|D]^\}}ztj|||d|Wqtyd}z td||||WYd}~qd}~00qdS)Nr,z9failed to convert {0} with byteorder={1!r} and signed={2})r&rCr3 from_bytesr/r0rr1rrr r5sz'LongTest.test_from_bytes..checkrrrrFrrGrHrIrJrKrLrMrNrOrPrQrR)rr6r7rVr8r]r9r:r;r<r=r>r?r@rArBr\rCrDrErSTr,)rr6rhr7rVr8r]r9r:rBr<rTrUr@r?rVr;rWrXrYrZr[rr_r`) rr6r7r<r:r8rArBr\r]r^) rr6r7r<r:r8rVr;rWr]rac@s eZdZdS)z'LongTest.test_from_bytes..myintNrtrrrrrr myintsrjr6r7)rLrrrDBzbigzlittlerbc@seZdZddZdS)z(LongTest.test_from_bytes..myint2cSst||dS)Nr)r3__new__)clsrrrr rm.sz0LongTest.test_from_bytes..myint2.__new__Nrtrrrmrrrr myint2-srprc@seZdZddZdS)z(LongTest.test_from_bytes..myint3cSs d|_dS)Nbar)foo)r7rrrr r6sz1LongTest.test_from_bytes..myint3.__init__N)rtrrrrrrr myint35srsrrZnonerq)F) r3rr(rgrC bytearrayarray memoryviewrrrgetattr) r7r5rbrcrdrerjrpr?rsrrr test_from_bytess            zLongTest.test_from_bytescsFGdddtfddtdD}tt|D]}||dq0dS)Nc@seZdZdddZdS)z.IntegerrcSst||}d|_|S)Nrr)r3rmrr)rnrr7rrr rmCs zDLongTest.test_access_to_nonexistent_digit_0..Integer.__new__N)rrorrrr IntegerBsrycsg|] }dqS)rrrfryrr r Hrz?LongTest.test_access_to_nonexistent_digit_0..rr)r3r<maprC)r7Zintegersrrrzr "test_access_to_nonexistent_digit_0>sz+LongTest.test_access_to_nonexistent_digit_0cCs@dD]6}dD],}|t||>t|t||?tq qdS)N)TF)rr)rCr(r3)r7rrrrr test_shift_boolLszLongTest.test_shift_boolc CsGdddt}ddddtjddd|d g}|D]H}|\}}|||ft|df|t|t|t|tq2dS) Nc@s eZdZdS)z-LongTest.test_as_integer_ratio..myintNrirrrr rjTsrjrRrrrTFr)r3rras_integer_ratiorCr()r7rjr2r numerator denominatorrrr test_as_integer_ratioSs zLongTest.test_as_integer_ratioN)T)2rtrrr;r@rFrPrXrZr\r^r`rlrvrwrrrrZrequires_IEEE_754rrrrrrrrrrrrrZ cpython_onlyr Z bigmemtestrrr rrrrrr+rfrxr|r}rrrrr r0ssd'    9 E\a"  [      "Jcr0__main__)#Zunittestrrrr4rruint_infobits_per_digitr2ZBASEr>rKrJr_rYr<r?rLrr$rrrmin_expr%rr&r#rr/ZTestCaser0rtmainrrrr sH   .t