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/doc/mpfr-3.1.1/mpfr
Viewing File: /usr/share/doc/mpfr-3.1.1/mpfr/FAQ.html
<?xml version="1.0" encoding="iso-8859-1"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <!-- Copyright 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 Free Software Foundation, Inc. Contributed by the AriC and Caramel projects, INRIA. This file is part of the GNU MPFR Library. The GNU MPFR Library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. The GNU MPFR Library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with the GNU MPFR Library; see the file COPYING.LESSER. If not, see http://www.gnu.org/licenses/ or write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. --> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <head><meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <title>Frequently Asked Questions about GNU MPFR</title> <style type="text/css">/*<![CDATA[*/ /* Global stylesheet for visual media */ html, body { background: white; color: black; } div.logo { float: right } div.logo img { border: 0 } div.footer img { border: 0 } dt { margin-top: 2ex; margin-bottom: 1ex; font-weight: bolder; } /* For testing: dd { background: #ddddff } */ table { margin: 0.5ex auto } li { margin-top: 0.5ex; margin-bottom: 0.5ex } dd + dd { margin-top: 0; margin-bottom: 0; padding-top: 0.5ex; padding-bottom: 0; } li > p, dd > p { margin-top: 0; margin-bottom: 0; padding-top: 0.5ex; padding-bottom: 0.5ex; } .block-code code, code.block-code, .block-code samp, samp.block-code { display: block; padding: 0.5ex 0; margin-left: 2em; } .nowrap { white-space: nowrap } /* dl.faq { counter-reset: faq } dl.faq dt:before { counter-increment: faq; content: counter(faq) ". "; } */ dl.faq dt { background: #dddddd } dl.faq dd { border-left: 4px solid; border-color: transparent; margin-left: 0em; padding-left: 1.5em; } dl.faq dt:target + dd { border-left-color: #aaaaaa; } var.env { font-style: normal } /*]]>*/</style> </head> <body> <h1>Frequently Asked Questions about <cite><acronym>GNU</acronym> <acronym>MPFR</acronym></cite></h1> <p><strong>Important notice: Problems with a particular version of <cite><acronym>MPFR</acronym></cite> are discussed in the corresponding bugs page.</strong></p> <p>The latest version of this <acronym>FAQ</acronym> is available at <a href="http://www.mpfr.org/faq.html">http://www.mpfr.org/faq.html</a>. Please look at this version if possible.</p> <ol> <li><a href="#mpfr_vs_mpf">What are the differences between <cite><acronym>MPF</acronym></cite> from <cite><acronym>GMP</acronym></cite> and <cite><acronym>MPFR</acronym></cite>?</a></li> <li><a href="#mpf2mpfr">How to convert my program written using <cite><acronym>MPF</acronym></cite> to <cite><acronym>MPFR</acronym></cite>?</a></li> <li><a href="#no_libgmp">At configure time, I get the error: <q>libgmp not found or uses a different ABI.</q></a></li> <li><a href="#undef_ref1">I get undefined reference to <code>__gmp_get_memory_functions</code>.</a></li> <li><a href="#undef_ref2">When I link my program with <cite><acronym>MPFR</acronym></cite>, I get undefined reference to <code>__gmpXXXX</code>.</a></li> <li><a href="#crash_high_prec">My program crashes with high precisions.</a></li> <li><a href="#accuracy">Though I have increased the precision, the results are not more accurate.</a></li> <li><a href="#detect_mpfr">How can I detect <cite><acronym>MPFR</acronym></cite> installation using <cite>autoconf</cite> or <cite>pkg-config</cite>?</a></li> <li><a href="#cite">How to cite <cite><acronym>MPFR</acronym></cite> in a scientific publication?</a></li> <li><a href="#fpic">When I build <cite><acronym>MPFR</acronym></cite>, I get an error asking me to recompile with <samp>-fPIC</samp>.</a></li> </ol> <dl class="faq"> <dt id="mpfr_vs_mpf">1. What are the differences between <cite><acronym>MPF</acronym></cite> from <cite><acronym>GMP</acronym></cite> and <cite><acronym>MPFR</acronym></cite>?</dt> <dd><p>The main differences are:</p> <ul> <li><p>The precision of a <cite><acronym>MPFR</acronym></cite> variable is the <em>exact</em> number of bits used for its mantissa, whereas in <cite><acronym>MPF</acronym></cite>, the precision requested by the user is a minimum value (<cite><acronym>MPF</acronym></cite> generally uses a higher precision). With the additional difference below, this implies that the <cite><acronym>MPFR</acronym></cite> results do not depend on the number of bits (16, 32, 64 or more) of the underlying architecture.</p></li> <li><p>As a consequence, <cite><acronym>MPFR</acronym></cite> uses a base-2 exponent, whereas in <cite><acronym>MPF</acronym></cite>, this is a base-2<sup>32</sup> or base-2<sup>64</sup> exponent, depending on the limb size. For this reason (and other internal ones), the maximum exponent range in <cite><acronym>MPFR</acronym></cite> is different (and smaller, if the exponent is represented by the same type as in <cite><acronym>MPF</acronym></cite>).</p></li> <li><p><cite><acronym>MPFR</acronym></cite> provides an additional rounding mode argument to its functions; furthermore, it is guaranteed that the result of any operation is the nearest possible floating-point value from the exact result (considering the input variables as exact values), taking into account the precision of the destination variable and the rounding mode. <cite><acronym>MPFR</acronym></cite> also says whether the rounded result is above or below the exact result.</p></li> <li><p><cite><acronym>MPFR</acronym></cite> supports much more functions (in particular transcendental functions such as exponentials, logarithms, trigonometric functions and so on) and special values: signed zeros, infinities, not-a-number (NaN).</p></li> </ul></dd> <dt id="mpf2mpfr">2. How to convert my program written using <cite><acronym>MPF</acronym></cite> to <cite><acronym>MPFR</acronym></cite>?</dt> <dd><p>You need to add <q><code>r</code></q> to the function names, and to specify the rounding mode (<code>MPFR_RNDN</code> for rounding to nearest, <code>MPFR_RNDZ</code> for rounding towards zero, <code>MPFR_RNDU</code> for rounding towards plus infinity, <code>MPFR_RNDD</code> for rounding towards minus infinity). You can also define macros as follows: <code class="block-code">#define mpf_add(a, b, c) mpfr_add(a, b, c, MPFR_RNDN)</code></p> <p>The header file <samp>mpf2mpfr.h</samp> from the <cite><acronym>MPFR</acronym></cite> distribution automatically redefines all <cite><acronym>MPF</acronym></cite> functions in this way, using the default <cite><acronym>MPFR</acronym></cite> rounding mode. Thus you simply need to add the following line in all your files using <cite><acronym>MPF</acronym></cite> functions: <code class="block-code">#include &lt;mpf2mpfr.h&gt;</code> just after the <samp>gmp.h</samp> and <samp>mpfr.h</samp> header files. If the program uses <cite><acronym>MPF</acronym></cite> internals (such as direct access to <code>__mpf_struct</code> members), additional changes will be needed.</p></dd> <dt id="no_libgmp">3. At configure time, I get the error: <q>libgmp not found or uses a different ABI.</q></dt> <dd><p>This test (<samp>checking for __gmpz_init in -lgmp</samp>) comes after the <samp>gmp.h</samp> detection. The failure occurs either because the <cite><acronym>GMP</acronym></cite> library could not be found (as it is not in the provided library search paths) or because the <cite><acronym>GMP</acronym></cite> library that was found does not have the expected <acronym title="Application Binary Interface">ABI</acronym> (<abbr>e.g.</abbr> 32-bit <abbr>vs</abbr> 64-bit). The former problem can be due to the fact that a static build of <cite><acronym>MPFR</acronym></cite> was requested while only a shared <cite><acronym>GMP</acronym></cite> library is installed (or the opposite, but another error can also show up in this case, see the <a href="#fpic">question about <samp>-fPIC</samp></a>). The latter problem can have several causes:</p> <ul> <li>A wrong libgmp library has been picked up. This can occur if you have several <cite><acronym>GMP</acronym></cite> versions installed on the machine and something is wrong with the provided library search paths.</li> <li>Wrong compiler options (<samp>CFLAGS</samp>) were given. In general, the presence or absence of the <samp>-m64</samp> compiler option must match the library <acronym title="Application Binary Interface">ABI</acronym>.</li> <li>A wrong <samp>gmp.h</samp> file has been picked up (if you have several <cite><acronym>GMP</acronym></cite> versions installed). Indeed, by default, <cite><acronym>MPFR</acronym></cite> gets the compiler options from the <samp>gmp.h</samp> file (with <cite><acronym>GMP</acronym></cite> 4.2.3 or later); this is needed because <cite><acronym>GMP</acronym></cite> does not necessarily use the default <acronym>ABI</acronym>. The consequence is that if the <samp>gmp.h</samp> file is associated with a library using a different <acronym>ABI</acronym>, the <acronym>ABI</acronym>-related options will be incorrect. Hence the failure.</li> </ul> <p>Note: The <samp>config.log</samp> output gives more information than the error message. In particular, see the output of the test: <samp>checking for CC and CFLAGS in gmp.h</samp>; it should give you the default compiler options (from <samp>gmp.h</samp>).</p> <p>See also the answer to the <a href="#undef_ref1">next question</a>.</p></dd> <dt id="undef_ref1">4. I get undefined reference to <code>__gmp_get_memory_functions</code>.</dt> <dd><p>Note: this was mainly a problem when upgrading from <cite><acronym>GMP</acronym></cite> 4.1.4 to a later version, but information given below may still be useful in other cases, when several <cite><acronym>GMP</acronym></cite> libraries are installed on the same machine.</p> <p>If you get such an error, in particular when running <samp>make check</samp>, then this probably means that you are using the header file from <cite><acronym>GMP</acronym></cite> 4.2.x but the <cite><acronym>GMP</acronym></cite> 4.1.4 library. This can happen if several <cite><acronym>GMP</acronym></cite> versions are installed on your machine (<abbr>e.g.</abbr>, one provided by the system in <samp>/usr/{include,lib}</samp> and a new one installed by the owner or administrator of the machine in <samp>/usr/local/{include,lib}</samp>) and your include and library search paths are inconsistent. On various <acronym>GNU</acronym>/Linux machines, this is unfortunately the case by default (<samp>/usr/local/include</samp> is in the default include search path, but <samp>/usr/local/lib</samp> is <em>not</em> in the default library search path). Typical errors are: <samp class="block-code">undefined reference to `__gmp_get_memory_functions'</samp> in <samp>make check</samp>. The best solution is to add <samp>/usr/local/include</samp> to your <var class="env">C_INCLUDE_PATH</var> environment variable and to add <samp>/usr/local/lib</samp> to your <var class="env">LIBRARY_PATH</var> and <var class="env">LD_LIBRARY_PATH</var> environment variables (and/or <var class="env">LD_RUN_PATH</var>). Alternatively, you can use <samp>--with-gmp*</samp> configure options, <abbr>e.g.</abbr> <samp>--with-gmp=/usr/local</samp>, but <strong>this is not guaranteed to work</strong> (in particular with <samp>gcc</samp> and system directories such as <samp>/usr</samp> or <samp>/usr/local</samp>), and other software that uses <cite><acronym>GMP</acronym></cite> and/or <cite><acronym>MPFR</acronym></cite> will need correct paths too; environment variables allow you to set them in a global way.</p> <p>Other information can be given in the <samp>INSTALL</samp> file and <samp>ld</samp> manual. Please look at them for more details. See also the <a href="#undef_ref2">next question</a>.</p></dd> <dt id="undef_ref2">5. When I link my program with <cite><acronym>MPFR</acronym></cite>, I get undefined reference to <code>__gmpXXXX</code>.</dt> <dd><p>Link your program with <cite><acronym>GMP</acronym></cite>. Assuming that your program is <samp>foo.c</samp>, you should link it using: <samp class="block-code">cc link.c -lmpfr -lgmp</samp> <cite><acronym>MPFR</acronym></cite> library reference (<samp>-lmpfr</samp>) should be before <cite><acronym>GMP</acronym></cite>'s one (<samp>-lgmp</samp>). Another solution is, with <acronym>GNU</acronym> <samp>ld</samp>, to give all the libraries inside a group: <samp class="block-code">gcc link.c -Wl,--start-group libgmp.a libmpfr.a -Wl,--end-group</samp> See <samp>INSTALL</samp> file and <samp>ld</samp> manual for more details.</p> <p>If you used correct link options, but still get an error, this may mean that your include and library search paths are inconsistent. Please see the <a href="#undef_ref1">previous question</a>.</p></dd> <dt id="crash_high_prec">6. My program crashes with high precisions.</dt> <dd><p>Your stack size limit may be too small; indeed, by default, <cite><acronym>GMP</acronym></cite> 4.1.4 and below allocates all temporary results on the stack, and in very high precisions, this limit may be reached. You can solve this problem in different ways:</p> <ul> <li><p>You can upgrade to <cite><acronym>GMP</acronym></cite> 4.2 (or above), which now makes temporary allocations on the stack only when they are small.</p></li> <li><p>You can increase the stack size limit with the <samp>limit</samp>, <samp>unlimit</samp> or <samp>ulimit</samp> command, depending on your shell. This may fail on some systems, where the maximum stack size cannot be increased above some value.</p></li> <li><p>You can rebuild both <cite><acronym>GMP</acronym></cite> and <cite><acronym>MPFR</acronym></cite> to use another allocation method.</p></li> </ul></dd> <dt id="accuracy">7. Though I have increased the precision, the results are not more accurate.</dt> <dd><p>The reason may be the use of C floating-point numbers. If you want to store a floating-point constant to a <code>mpfr_t</code>, you should use <code>mpfr_set_str</code> (or one of the <cite><acronym>MPFR</acronym></cite> constant functions, such as <code>mpfr_const_pi</code> for &#960;) instead of <code>mpfr_set_d</code> or <code>mpfr_set_ld</code>. Otherwise the floating-point constant will be first converted into a reduced-precision (<abbr>e.g.</abbr>, 53-bit) binary number before <cite><acronym>MPFR</acronym></cite> can work with it. This is the case in particular for most exact decimal numbers, such as 0.17, which are not exactly representable in binary.</p> <p>Also remember that <cite><acronym>MPFR</acronym></cite> does not track the accuracy of the results: copying a value <var>x</var> to <var>y</var> with <code>mpfr_set (y, x, MPFR_RNDN)</code> where the variable <var>y</var> is more precise than the variable <var>x</var> will not make it more accurate; the (binary) value will remain unchanged.</p></dd> <dt id="detect_mpfr">8. How can I detect <cite><acronym>MPFR</acronym></cite> installation using <cite>autoconf</cite> or <cite>pkg-config</cite>?</dt> <dd><p>The <cite><acronym>MPFR</acronym></cite> team does not currently recommend any <cite>autoconf</cite> code, but a section will later be added to the <cite><acronym>MPFR</acronym></cite> manual. The <cite><acronym>MPFR</acronym></cite> team does not wish to support <cite>pkg-config</cite> yet.</p></dd> <dt id="cite">9. How to cite <cite><acronym>MPFR</acronym></cite> in a scientific publication?</dt> <dd><p>To properly cite <cite><acronym>MPFR</acronym></cite> in a scientific publication, please cite the <a href="http://doi.acm.org/10.1145/1236463.1236468"><acronym title="Association for Computing Machinery">ACM</acronym> <acronym title="Transactions on Mathematical Software">TOMS</acronym> paper</a> (<a href="http://toms.acm.org/cgi/TOMSbibget.cgi?Fousse:2007:MMP">BibTeX</a>) and/or the library web page <a href="http://www.mpfr.org/">http://www.mpfr.org</a>. If your publication is related to a particular release of <cite><acronym>MPFR</acronym></cite>, for example if you report timings, please also indicate the release number for future reference.</p></dd> <dt id="fpic">10. When I build <cite><acronym>MPFR</acronym></cite>, I get an error asking me to recompile with <samp>-fPIC</samp>.</dt> <dd><p>A typical error looks like:</p> <p><tt>/usr/bin/ld: <em>/path/to/</em>libgmp.a(realloc.o): relocation R_X86_64_32 against `.rodata.str1.1' can not be used when making a shared object; recompile with -fPIC<br /> <em>/path/to/</em>libgmp.a: could not read symbols: Bad value<br /> collect2: ld returned 1 exit status</tt></p> <p>The probable reason is that you tried to build <cite><acronym>MPFR</acronym></cite> with the shared library enabled (this is the default), while only a static <cite><acronym>GMP</acronym></cite> library could be found. To solve this problem, either rebuild and reinstall <cite><acronym>GMP</acronym></cite> without the <samp>--disable-shared</samp> configure option, or configure <cite><acronym>MPFR</acronym></cite> with <samp>--disable-shared</samp>. If you did this and still get the above error, the cause may be conflicting <cite><acronym>GMP</acronym></cite> versions installed on your system; please check that your search path settings are correct.</p> <p>Additional note about the last sentence: Under <acronym>GNU</acronym>/Linux (for instance), the linker takes the first library found in the library search path, whether it is dynamic or static. The default behavior under darwin is different, but <cite><acronym>MPFR</acronym></cite> will change it.</p></dd> <!-- Reference concerning darwin: see MPFR_LD_SEARCH_PATHS_FIRST in MPFR's configure.{ac,in} and acinclude.m4 --> </dl> </body> </html>