From dec461bae51e434014025e0bc61f0bfb70d7bb0d Mon Sep 17 00:00:00 2001 From: Sebastien Fabbro Date: Thu, 12 Jan 2012 23:09:27 +0000 Subject: [PATCH] Trim the patch from garbage ascii Package-Manager: portage-2.1.10.41/cvs/Linux x86_64 --- sci-libs/qd/ChangeLog | 6 +- sci-libs/qd/Manifest | 10 +- sci-libs/qd/files/qd-2.3.12-autotools.patch | 718 +------------------- 3 files changed, 19 insertions(+), 715 deletions(-) diff --git a/sci-libs/qd/ChangeLog b/sci-libs/qd/ChangeLog index 801d7bd88035..5e6f14ceb3d2 100644 --- a/sci-libs/qd/ChangeLog +++ b/sci-libs/qd/ChangeLog @@ -1,6 +1,10 @@ # ChangeLog for sci-libs/qd # Copyright 1999-2012 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/sci-libs/qd/ChangeLog,v 1.8 2012/01/12 22:53:04 bicatali Exp $ +# $Header: /var/cvsroot/gentoo-x86/sci-libs/qd/ChangeLog,v 1.9 2012/01/12 23:09:27 bicatali Exp $ + + 12 Jan 2012; Sébastien Fabbro + files/qd-2.3.12-autotools.patch: + Trim the patch from garbage ascii *qd-2.3.12 (12 Jan 2012) diff --git a/sci-libs/qd/Manifest b/sci-libs/qd/Manifest index 22e01cce96c3..1f218759233c 100644 --- a/sci-libs/qd/Manifest +++ b/sci-libs/qd/Manifest @@ -3,7 +3,7 @@ Hash: SHA1 AUX qd-2.3.11-configure-version.patch 433 RMD160 4fbc1b82034698b50de75b88c9b6484586fc23f3 SHA1 94f64374762df6cd1da5d23aa5450c9828d4f4bf SHA256 116f808b5e25cb4911063dde20ebca568366e502d33a9dd3143412cd6c3a6173 AUX qd-2.3.11-docpath.patch 376 RMD160 577a0ba79455307b04c1d10ef610216f8a95f0b5 SHA1 f5606a3b5b98045a69ac8a528e32c8d577bd2a0e SHA256 52e2ca6ee5f80ed4c385645e7b316ac9c72e67c8dfac98fe73b2733b3352d07f -AUX qd-2.3.12-autotools.patch 51996 RMD160 8e7b883b35d776c55c307d44db2a64d79168f333 SHA1 569e17a509b34382e093c85ab3e0e4eeedac9554 SHA256 42c50d6a84f6cf820c287c1db3544fcb001a51c02c2f33903f9c683beb7e40c5 +AUX qd-2.3.12-autotools.patch 15939 RMD160 0dfba4b1cbfcbd89a9fc35032496f71e390d21d3 SHA1 c2331759cf4fef482456f43eb796db3be07fac69 SHA256 40f7b0d4f7783a9ef0e853d4e4bec5699a0734d5d6a9875c8bf3566c33a573f1 AUX qd-2.3.7-test.patch 305 RMD160 009f10bb3dba3b4191194dcd9418ce08b70e3bf0 SHA1 4f94582903ef6c75c8887df241e88d0a617ee057 SHA256 f4da52c9c23969bc07a178dd4a250cbbdb0f9fd8c5905620669c8a012548fbe2 DIST qd-2.3.11.tar.gz 700309 RMD160 44d858feba1190845ff17e1f2e54afc4c0643c62 SHA1 9f66ceb4a0d5373e8f02c783ceaa2d653114c6eb SHA256 0bbd376c45c6c8572fc86f9ed8a477f560b78dd5c0a9f63b6db1f46263c67970 DIST qd-2.3.12.tar.gz 700145 RMD160 daecff500f9f88fe5fe50eabffadd7b69b8ad12f SHA1 78ca159be52337d923b70cea1789d03d344fd663 SHA256 e13b99a3b2ff7f8a56a5fcdf1b238270d1581750ab23fef8eb386e63c0e04ff5 @@ -11,12 +11,12 @@ DIST qd-2.3.9.tar.gz 595952 RMD160 782b27a13654d9d132a6f9f885d8ad176e1e1fda SHA1 EBUILD qd-2.3.11.ebuild 965 RMD160 9e31365a6019524f9b1b891d928809d8a67259f9 SHA1 bb55684850242ed7520a936094c76f3078d5bde6 SHA256 cb67d20cdce9cd8bac4d0b3be7d269c4db803e4b14a086fe47ba2c478a27d192 EBUILD qd-2.3.12.ebuild 1015 RMD160 77458139b7b16d2c18cc63269b723bbba2779586 SHA1 38a6e8dd3fec8a8aaf0d5ec7d3683b2cd2f03ae5 SHA256 0725a2359e3c6b9539b92ee4ec6a61c1b05abe43a7ff60694b5ebbff5a00bb37 EBUILD qd-2.3.9.ebuild 974 RMD160 4fc054bad1e1447ec108f22a0a9be88f40155a4a SHA1 570b8bf5e34bee8369a3ce847587d4b3e262e3ba SHA256 c13f79d29b8e8ed1ac9f0e444028014e3edef7684ce29f3e66cb077ea390dfdb -MISC ChangeLog 1349 RMD160 69fc874bd8e34b837eb0dd840c966af64d8c404f SHA1 3fca08b1192f7f2eaa91997999b947bf9c39bb73 SHA256 4eed77ab00328bb006fc9ab9fe73dca8cf1b8e227b61444d598c98f6a52294c5 +MISC ChangeLog 1476 RMD160 3155550622c330cf30302a78ef6699ef325abfa2 SHA1 22bc3e3f4ebbd154f53440382d01558db7a6886d SHA256 7184a328a4308d9fdf22bf43c5d649e3e0ca59364c689eda3ca2c53ef67265b2 MISC metadata.xml 334 RMD160 40c1d8c9f178cd40a09f7c40e9ac335ade0059ca SHA1 b765fa3da44b33d6bce4f6d80ef34df1d9b6366c SHA256 3444d77952a6cffa63be0a5082a506a95fdf3cb93a0fc5811bd86dee40ae7cda -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.18 (GNU/Linux) -iEYEARECAAYFAk8PZFkACgkQ1ycZbhPLE2B2RQCgrTNcQ6zqbdqcZRv2QdyImbox -NKoAn3v8vJRGNyPyqdAnMfKINT5Te2Y2 -=LTS1 +iEYEARECAAYFAk8PaC8ACgkQ1ycZbhPLE2DpNQCeM+g/lRmp11jS6mAqEq/TiFZ3 +658AoJ6Sr7NvAg45Jd31J2GN0UmiNxVb +=DG6W -----END PGP SIGNATURE----- diff --git a/sci-libs/qd/files/qd-2.3.12-autotools.patch b/sci-libs/qd/files/qd-2.3.12-autotools.patch index e8a5fac5b454..f4ad4fbb5971 100644 --- a/sci-libs/qd/files/qd-2.3.12-autotools.patch +++ b/sci-libs/qd/files/qd-2.3.12-autotools.patch @@ -1,3 +1,11 @@ +Patch for autotools for: +* allow build of shared libraries with libtool +* fix m4 macros for newer autoconf +* modernize configure.ac +* fix parallel make issues with fortran modules + +Sebastien Fabbro Jan. 2012 + diff -Nur qd-2.3.12.orig/configure.ac qd-2.3.12/configure.ac --- qd-2.3.12.orig/configure.ac 2012-01-12 19:44:25.000000000 +0000 +++ qd-2.3.12/configure.ac 2012-01-12 22:34:18.000000000 +0000 @@ -386,715 +394,7 @@ diff -Nur qd-2.3.12.orig/Makefile.am qd-2.3.12/Makefile.am bin_SCRIPTS=qd-config -diff -Nur qd-2.3.12.orig/README.txt qd-2.3.12/README.txt ---- qd-2.3.12.orig/README.txt 1970-01-01 01:00:00.000000000 +0100 -+++ qd-2.3.12/README.txt 2012-01-12 20:17:09.000000000 +0000 -@@ -0,0 +1,704 @@ -+-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐   -+QUAD-­‐DOUBLE/DOUBLE-­‐DOUBLE  COMPUTATION  PACKAGE     -+   -+   -+   -+   -+   -+Copyright  (c)  2005-­‐2010     -+   -+   -+   -+   -+-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐-­‐   -+   -+Revision  date:    2010  June  14   -+   -+Authors:   -+Yozo  Hida   -+   -+U.C.  Berkeley           -+   -+yozo@cs.berkeley.edu   -+Xiaoye  S.  Li       -+Lawrence  Berkeley  Natl  Lab       xiaoye@nersc.gov   -+David  H.  Bailey       -+Lawrence  Berkeley  Natl  Lab       dhbailey@lbl.gov   -+   -+C++  usage  guide:   -+Alex  Kaiser       -+Lawrence  Berkeley  Natl  Lab     adkaiser@lbl.gov   -+   -+This  work  was  supported  by  the  Director,  Office  of  Science,  Division  of  Mathematical,   -+Information,  and  Computational  Sciences  of  the  U.S.  Department  of  Energy  under  contract   -+number  DE-­‐AC02-­‐05CH11231.   -+   -+This  work  was  supported  by  the  Director,  Office  of  Science,  Division  of  Mathematical,   -+Information,  and  Computational  Sciences  of  the  U.S.  Department  of  Energy  under  contract   -+numbers  DE-­‐AC03-­‐76SF00098  and  DE-­‐AC02-­‐05CH11231.   -+   -+***  IMPORTANT  NOTES:   -+   -+See  the  file  COPYING  for  modified  BSD  license  information.   -+See  the  file  INSTALL  for  installation  instructions.   -+See  the  file  NEWS  for  recent  revisions.   -+   -+Outline:   -+   -+I.      Introduction   -+II.    Directories  and  Files   -+III.  C++  Usage   -+IV.    Fortran  Usage   -+V.      Note  on  x86-­‐Based  Processors  (MOST  systems  in  use  today)   -+   -+   -+I.  Introduction   -+   -+This  package  provides  numeric  types  of  twice  the  precision  of  IEEE  double  (106  mantissa   -+bits,  or  approximately  32  decimal  digits)  and  four  times  the  precision  of  IEEE  double  (212   -+mantissa  bits,  or  approximately  64  decimal  digits).    Due  to  features  such  as  operator  and   -+function  overloading,  these  facilities  can  be  utilized  with  only  minor  modifications  to   -+conventional  C++  and  Fortran-­‐90  programs.   -+   -+In  addition  to  the  basic  arithmetic  operations  (add,  subtract,  multiply,  divide,  square  root),   -+common  transcendental  functions  such  as  the  exponential,  logarithm,  trigonometric  and   -+hyperbolic  functions  are  also  included.    A  detailed  description  of  the  algorithms  used  is   -+ -+ available  in  the  docs  subdirectory  (see  docs/qd.ps).    An  abridged  version  of  this  paper,   -+which  was  presented  at  the  ARITH-­‐15  conference,  is  also  available  in  this  same  directory   -+(see  docs/arith15.ps).   -+   -+II.  Directories  and  Files   -+   -+There  are  six  directories  and  several  files  in  the  main  directory  of  this  distribution,   -+described  below   -+   -+src       This  contains  the  source  code  of  the  quad-­‐double  and  double-­‐double   -+     -+   -+library.    This  source  code  does  not  include  inline  functions,   -+     -+   -+which  are  found  in  the  header  files  in  the  include  directory.   -+   -+include    This  directory  contains  the  header  files.   -+   -+fortran    This  directory  contains  Fortran-­‐90  files.   -+   -+tests   This  directory  contains  some  simple  (not  comprehensive)  tests.   -+   -+docs     This  directory  contains  two  papers  describing  the  algorithms.   -+   -+config      This  directory  contains  various  scripts  used  by  the  configure   -+     -+   -+script  and  the  Makefile.   -+   -+   -+   -+   -+C++  Usage:     -+   -+Please  note  that  all  commands  refer  to  a  Unix-­‐type  environment  such  as  Mac  OSX  or  Ubuntu   -+Linux  using  the  bash  shell.     -+   -+   -+A.  Building   -+   -+To  build  the  library,  first  run  the  included  configure  script  by  typing     -+   -+./configure   -+   -+This  script  automatically  generates  makefiles  for  building  the  library  and  selects  compilers   -+and  necessary  flags  and  libraries  to  include.  If  the  user  wishes  to  specify  compilers  or  flags   -+they  may  use  the  following  options.     -+   -+CXX                 -+C++  compiler  to  use   -+CXXFLAGS       C++  compiler  flags  to  use   -+CC                     -+C  compiler  to  use  (for  C  demo  program)   -+CFLAGS           -+C  compiler  flags  to  use  (for  C  demo  program)   -+FC                     -+Fortran  90  compiler   -+FCFLAGS         -+Fortran  90  compiler  flags  to  use   -+FCLIBS           -+Fortran  90  libraries  needed  to  link  with  C++  code.   -+   -+ -+ For  example,  if  one  is  using  GNU  compilers,  configure  with:   -+   -+./configure  CXX=g++  FC=gfortran   -+   -+The  Fortran  and  C++  compilers  must  produce  compatible  binaries.  On  some  systems   -+additional  flags  must  be  included  to  ensure  that  portions  of  the  library  are  not  built  with  32   -+and  64  bit  object  files.  For  example,  on  64-­‐Bit  Mac  OSX  10.6  (Snow  Leopard)  the  correct   -+configure  line  using  GNU  compilers  is:     -+   -+  ./configure  CXX=g++  FC=gfortran  FCFLAGS=-­‐m64   -+   -+To  build  the  library,  simply  type     -+   -+make     -+   -+and  the  automatically  generated  makefiles  will  build  the  library  including  archive  files.     -+   -+To  allow  for  easy  linking  to  the  library,  the  user  may  also  wish  to  install  the  archive  files  to  a   -+standard  place.  To  do  this  type:   -+   -+make  install   -+   -+This  will  also  build  the  library  if  it  has  not  already  been  built.  Many  systems,  including  Mac   -+and  Ubuntu  Linux  systems,  require  administrator  privileges  to  install  the  library  at  such   -+standard  places.  On  such  systems,  one  may  type:     -+   -+sudo  make  install     -+   -+instead  if  one  has  sufficient  access.     -+   -+The  directory  ‘tests’  contains  programs  for  high  precision  quadrature  and  integer-­‐relation   -+detection.  To  build  such  programs,  type:   -+   -+   -+make  demo   -+   -+in  the    ‘tests’  directory.     -+   -+B.  Linking     -+   -+The  simplest  way  to  link  to  the  library  is  to  install  it  to  a  standard  place  as  described  above,   -+and  use  the  –l  option.  For  example   -+   -+g++  compileExample.cpp  -­‐o  compileExample  -­‐l  qd   -+   -+One  can  also  use  this  method  to  build  with  make.  A  file  called  “compileExample.cpp”  and  the   -+associated  makefile  “makeCompileExample”  illustrate  the  process.     -+   -+A  third  alternative  is  to  use  a  link  script.  If  one  types  “make  demo”  in  the  test  directory,  the   -+output  produced  gives  guidance  as  to  how  to  build  the  files.  By  following  the  structure  of   -+the  compiling  commands  one  may  copy  the  appropriate  portions,  perhaps  replacing  the   -+ -+ filename  with  an  argument  that  the  user  can  include  at  link  time.  An  example  of  such  a   -+script  is  as  follows:   -+   -+g++  -­‐DHAVE_CONFIG_H      -­‐I..  -­‐I../include  -­‐I../include      -­‐O2    -­‐MT  $1.o  -­‐MD  -­‐MP  -­‐MF   -+.deps/qd_test.Tpo  -­‐c  -­‐o  $1.o  $1.cpp   -+mv  -­‐f  .deps/$1.Tpo  .deps/$1.Po   -+g++    -­‐O2        -­‐o  $1  $1.o  ../src/libqd.a  –lm   -+   -+To  use  it,  make  the  link  script  executable  and  type:   -+   -+./link.scr  compileExample   -+   -+Note  that  the  file  extension  is  not  included  because  the  script  handles  all  extensions,   -+expecting  the  source  file  to  have  the  extension  ‘.cpp’  .     -+   -+C.  Programming  techniques   -+   -+As  much  as  possible,  operator  overloading  is  included  to  make  basic  programming  as  much   -+like  using  standard  typed  floating-­‐point  arithmetic.  Changing  many  codes  should  be  as   -+simple  as  changing  type  statements  and  a  few  other  lines.     -+   -+i.  Constructors   -+   -+To  create  dd_real  and  qd_real  variables  calculated  to  the  proper  precision,  one  must  use   -+care  to  use  the  included  constructors  properly.  Many  computations  in  which  variables  are   -+not  explicitly  typed  to  multiple-­‐precision  may  be  evaluated  with  double-­‐precision   -+arithmetic.  The  user  must  take  care  to  ensure  that  this  does  not  cause  errors.  In  particular,   -+an  expression  such  as  1.0/3.0  will  be  evaluated  to  double  precision  before  assignment  or   -+further  arithmetic.  Upon  assignment  to  a  multi-­‐precision  variable,  the  value  will  be  zero   -+padded.  This  problem  is  serious  and  potentially  difficult  to  debug.  To  avoid  this,  use  the   -+included  constructors  to  force  arithmetic  to  be  performed  in  the  full  precision  requested.   -+Here  is  a  list  of  the  included  constructors  with  brief  descriptions:   -+   -+Type  dd_real,  with  text  of  inline  constructors  included:     -+   -+Constructor   -+Description     -+   -+   -+dd_real(double  hi,  double  lo)     -+Initializes  from  two  double  precision  values.     -+{  x[0]  =  hi;  x[1]  =  lo;  }   -+   -+   -+   -+dd_real()  {x[0]  =  0.0;  x[1]  =  0.0;  }   -+Default  constructor  initializes  to  zero.     -+   -+   -+dd_real(double  h)  {  x[0]  =  h;  x[1]  =  0.0;  }   -+Initializes  from  a  double  precision  value,   -+   -+setting  the  trailing  part  to  zero.  Use  care  to   -+   -+ensure  that  the  trailing  part  should  actually   -+   -+be  set  to  zero.     -+   -+   -+   -+   -+   -+   -+dd_real(int  h)  {   -+Initializes  from  an  integer  value,  setting  the   -+ -+        x[0]  =  (static_cast(h));   -+trailing  part  to  zero.  Use  care  to  ensure  that   -+        x[1]  =  0.0;   -+the  trailing  part  should  actually  be  set  to   -+    }   -+zero.     -+   -+   -+dd_real  (const  char  *s);   -+Initializes  from  a  string.     -+   -+   -+explicit  dd_real  (const  double  *d)  {   -+Initializes  from  a  length  two  array  of  double   -+        x[0]  =  d[0];  x[1]  =  d[1];   -+precision  values.     -+    }     -+   -+   -+   -+   -+   -+Type  qd_real,  with  their  functions  included  inline:     -+   -+Constructor     -+Description     -+   -+   -+inline  qd_real::qd_real   -+Initializes  from  four  double  precision  values.     -+(double  x0,  double  x1,  double  x2,  double  x3)     -+{   -+   -+       -+   x[0]  =  x0;   -+   -+       -+   x[1]  =  x1;   -+   -+       -+   x[2]  =  x2;   -+   -+       -+   x[3]  =  x3;   -+   -+}   -+   -+   -+   -+inline  qd_real::qd_real(const  double  *xx)  {   -+Initializes  from  a  length  four  array  of  double   -+       -+   x[0]  =  xx[0];   -+precision  values.     -+       -+   x[1]  =  xx[1];   -+   -+     -+   x[2]  =  xx[2];   -+   -+       -+   x[3]  =  xx[3];   -+   -+   -+}   -+   -+   -+   -+inline  qd_real::qd_real(double  x0)  {   -+Initializes  from  a  double  precision  value,   -+       -+   x[0]  =  x0;   -+setting  the  trailing  part  to  zero.  Use  care  to   -+       -+   x[1]  =  x[2]  =  x[3]  =  0.0;   -+ensure  that  the  trailing  part  should  actually   -+}   -+be  set  to  zero.     -+   -+   -+inline  qd_real::qd_real()  {   -+Default  constructor  initializes  to  zero.     -+   -+   x[0]  =  0.0;     -+   -+   -+   x[1]  =  0.0;     -+   -+   -+   x[2]  =  0.0;     -+   -+   -+   x[3]  =  0.0;     -+   -+}   -+   -+   -+   -+inline  qd_real::qd_real(const  dd_real  &a)  {   -+Initializes  from  a  double-­‐double  value,   -+       -+   x[0]  =  a._hi();   -+setting  the  trailing  part  to  zero.   -+       -+   x[1]  =  a._lo();   -+   -+       -+   x[2]  =  x[3]  =  0.0;   -+   -+}   -+   -+inline  qd_real::qd_real(int  i)  {   -+Initializes  from  an  integer  value,  setting  the   -+ -+       -+   x[0]  =  static_cast(i);   -+trailing  part  to  zero.  Use  care  to  ensure  that   -+       -+   x[1]  =  x[2]  =  x[3]  =  0.0;   -+the  trailing  part  should  actually  be  set  to   -+}   -+zero.     -+   -+   -+   -+   -+Some  examples  of  initialization  are  as  follows   -+   -+   -+qd_real  x  =  “1.0”  ;     -+   -+x  /=  3.0  ;     -+   -+or     -+   -+   -+qd_real  x  =  qd_real(1.0)  /  3.0  ;     -+   -+   -+ii.  Included  functions  and  Constants     -+   -+Supported  functions  include  assignment  operators,  comparisons,  arithmetic  and   -+assignment  operators,  and  increments  for  integer  types.  Standard  C  math  functions  such  as   -+exponentiation,  trigonometric,  logarithmic,  hyperbolic,  exponential  and  rounding  functions   -+are  included.  As  in  assignment  statements,  one  must  be  careful  with  implied  typing  of   -+constants  when  using  these  functions.  Many  codes  need  particular  conversion  for  the  power   -+function,  which  is  frequently  used  with  constants  that  must  be  explicitly  typed  for  multi-­‐ -+precision  codes.     -+   -+Many  constants  are  included,  which  are  global  and  calculated  upon  initialization.  The   -+following  list  of  constants  is  calculated  for  both  the  dd_real  and  qd_real  classes  separately.   -+Use  care  to  select  the  correct  value.  The  variables,  with  type  signatures,  are:   -+   -+Variable  Name   -+Explanation     -+static  const  qd_real  _2pi;   -+Two  pi.     -+static  const  qd_real  _pi;   -+Pi.     -+static  const  qd_real  _3pi4;   -+Three  pi  over  four.     -+static  const  qd_real  _pi2;   -+Pi  over  two.     -+static  const  qd_real  _pi4;   -+Pi  over  four   -+static  const  qd_real  _e;   -+e,  the  base  of  the  natural  logarithm.     -+static  const  qd_real  _log2;   -+Natural  logarithm  of  two.     -+static  const  qd_real  _log10;   -+Natural  logarithm  of  ten.     -+static  const  qd_real  _nan;   -+Not  a  number.  Behaves  like  a  double-­‐ -+   -+precision  nan.     -+static  const  qd_real  _inf;   -+Infinity.  Behaves  like  a  double-­‐precision  inf.     -+static  const  double  _eps;   -+Estimated  precision  for  dd_real  or  qd_real   -+   -+data  type.   -+static  const  double  _min_normalized;   -+Minimum  absolute  value  represent  able   -+   -+without  denormalization.     -+static  const  qd_real  _max;   -+Maximum  representable  value.     -+static  const  qd_real  _safe_max;   -+Maximum  safe  value.  Slightly  smaller  than   -+   -+maximum  representable  value.     -+static  const  int  _ndigits;   -+Number  of  digits  available  for  dd_real  or   -+ -+   -+qd_real  datatypes.   -+   -+   -+   -+ii.  Conversion  of  types     -+   -+Static  casts  may  be  used  to  convert  constants  between  types.  One  may  also  use  constructors   -+to  return  temporary  multi-­‐precision  types  within  expressions,  but  should  be  careful,  as  this   -+will  waste  memory  if  done  repeatedly.  For  example:     -+   -+   -+   qd_real  y  ;     -+y  =  sin(  qd_real(4.0)  /  3.0  )  ;   -+   -+C–style  casts  may  be  used,  but  are  not  recommended.    Dynamic  and  reinterpret  casts  are   -+not  supported  and  should  be  considered  unreliable.  Casting  between  multi-­‐precision  and   -+standard  precision  types  can  be  dangerous,  and  care  must  be  taken  to  ensure  that  programs   -+are  working  properly  and  accuracy  has  not  degraded  by  use  of  a  misplaced  type-­‐conversion.     -+   -+D.  Available  precision,  Control  of  Precision  Levels,   -+   -+The  library  provides  greatly  extended  accuracy  when  compared  to  standard  double   -+precision.  The  type  dd_real  provides  for  106  mantissa  bits,  or  about  32  decimal  digits.  The   -+type  qd_real  provides  for  212  mantissa  bits,  or  about  64  decimal  digits.     -+   -+Both  the  dd_real  and  qd_real  values  use  the  exponent  from  the  highest  double-­‐precision   -+word  for  arithmetic,  and  as  such  do  not  extend  the  total  range  of  values  available.  That   -+means  that  the  maximum  absolute  value  for  either  data  type  is  the  same  as  that  of  double-­‐ -+precision,  or  approximately  10^308.  The  precision  near  this  range,  however,  is  greatly   -+increased.     -+   -+To  ensure  that  arithmetic  is  carried  out  with  proper  precision  and  accuracy,  one  must  call   -+the  function  “fpu_fix_start”  before  performing  any  double-­‐double  or  quad-­‐double   -+arithmetic.  This  forces  all  arithmetic  to  be  carried  out  in  64-­‐bit  double  precision,  not  the  80-­‐ -+bit  precision  that  is  found  on  certain  compilers  and  interferes  with  the  existing  library.     -+   -+   -+   unsigned  int  old_cw;   -+   -+fpu_fix_start(&old_cw);   -+   -+To  return  standard  settings  for  arithmetic  on  one’s  system,  call  the  function  “fpu_fix_end”.   -+For  example:   -+   -+   -+fpu_fix_end(&old_cw);   -+   -+   -+E.  I/O     -+   -+The  standard  I/O  stream  routines  have  been  overloaded  to  be  fully  compatible  with  all   -+included  data  types.  One  may  need  to  manually  reset  the  precision  of  the  stream  to  obtain   -+full  output.  For  example,  if  60  digits  are  desired,  use:     -+   -+cout.precision(60)  ;     -+ -+   -+When  reading  values  using  cin,  each  input  numerical  value  must  start  on  a  separate   -+line.    Two  formats  are  acceptable:   -+   -+   -+1.  Write  the  full  constant     -+   -+3.  Mantissa  e  exponent   -+   -+Here  are  three  valid  examples:   -+   -+   -+1.1   -+   -+3.14159  26535  89793   -+   -+123.123123e50   -+   -+   -+When  read  using  cin,  these  constants  will  be  converted  using  full  multi-­‐precision  accuracy.   -+   -+   -+IV.  Fortran-­‐90  Usage   -+   -+NEW  (2007-­‐01-­‐10):  The  Fortran  translation  modules  now  support  the  complex  datatypes   -+"dd_complex"  and  "qd_complex".   -+   -+Since  the  quad-­‐double  library  is  written  in  C++,  it  must  be  linked  in  with  a  C++  compiler  (so   -+that  C++  specific  things  such  as  static  initializations  are  correctly  handled).    Thus  the  main   -+program  must  be  written  in  C/C++  and  call  the  Fortran  90  subroutine.  The  Fortran  90   -+subroutine  should  be  called  f_main.   -+   -+Here  is  a  sample  Fortran-­‐90  program,  equivalent  to  the  above  C++  program:   -+   -+    subroutine  f_main   -+   -+use  qdmodule     -+   -+implicit  none   -+   -+type  (qd_real)  a,  b   -+   -+integer*4  old_cw   -+   -+   -+call  f_fpu_fix_start(old_cw)   -+   -+a  =  1.d0   -+   -+b  =  cos(a)**2  +  sin(a)**2  -­‐  1.d0   -+   -+call  qdwrite(6,  b)   -+   -+stop   -+    end  subroutine   -+   -+This  verifies  that  cos^2(1)  +  sin^2(1)  =  1  to  64  digit  accuracy.   -+   -+Most  operators  and  generic  function  references,  including  many  mixed-­‐mode  type   -+combinations  with  double-­‐precision  (ie  real*8),  have  been  overloaded  (extended)  to  work   -+with  double-­‐double  and  quad-­‐double  data.    It  is  important,  however,  that  users  keep  in   -+mind  the  fact  that  expressions  are  evaluated  strictly  according  to  conventional  Fortran   -+operator  precedence  rules.    Thus  some  subexpressions  may  be  evaluated  only  to  15-­‐digit   -+accuracy.  For  example,  with  the  code   -+ -+   -+      real*8  d1   -+      type  (dd_real)  t1,  t2   -+      ...   -+      t1  =  cos  (t2)  +  d1/3.d0   -+   -+the  expression  d1/3.d0  is  computed  to  real*8  accuracy  only  (about  15  digits),  since  both  d1   -+and  3.d0  have  type  real*8.    This  result  is  then  converted  to  dd_real  by  zero  extension  before   -+being  added  to  cos(t2).  So,  for  example,  if  d1  held  the  value  1.d0,  then  the  quotient  d1/3.d0   -+would  only  be  accurate  to  15  digits.    If  a  fully  accurate  double-­‐double  quotient  is  required,   -+this  should  be  written:   -+   -+    real*8  d1   -+    type  (dd_real)  t1,  t2   -+      ...   -+    t1  =  cos  (t2)  +  ddreal  (d1)  /  3.d0   -+   -+which  forces  all  operations  to  be  performed  with  double-­‐double  arithmetic.   -+   -+Along  this  line,  a  constant  such  as  1.1  appearing  in  an  expression  is  evaluated  only  to  real*4   -+accuracy,  and  a  constant  such  as  1.1d0  is  evaluated  only  to  real*8  accuracy  (this  is   -+according  to  standard  Fortran  conventions).    If  full  quad-­‐double  accuracy  is  required,  for   -+instance,  one  should  write   -+   -+      type  (qd_real)  t1   -+      ...   -+      t1  =  '1.1'   -+   -+The  quotes  enclosing  1.1  specify  to  the  compiler  that  the  constant  is  to  be  converted  to   -+binary  using  quad-­‐double  arithmetic,  before  assignment  to  t1.    Quoted  constants  may  only   -+appear  in  assignment  statements  such  as  this.   -+   -+To  link  a  Fortran-­‐90  program  with  the  C++  qd  library,  it  is    recommended  to  link  with  the   -+C++  compiler  used  to  generate  the  library.      The  Fortran  90  interface  (along  with  a  C-­‐style   -+main  function  calling  f_main)  is  found  in  qdmod  library.    The  qd-­‐config  script  installed   -+during  "make  install"  can  be  used  to  determine  which  flags  to  pass  to  compile  and  link  your   -+programs:   -+   -+    "qd-­‐config  -­‐-­‐fcflags"    displays  compiler  flags  needed  to  compile  your  Fortran  files.   -+    "qd-­‐config  -­‐-­‐fclibs"      displays  linker  flags  needed  by  the  C++  linker  to  link  in  all  the     -+necessary  libraries.   -+   -+A  sample  Makefile  that  can  be  used  as  a  template  for  compiling  Fortran  programs  using   -+quad-­‐double  library  is  found  in  fortran/Makefile.sample.   -+   -+F90  functions  defined  with  dd_real  arguments:   -+    Arithmetic:    +  -­‐  *  /  **   -+    Comparison  tests:    ==  <  >  <=  >=  /=   -+    Others:  abs,  acos,  aint,  anint,  asin,  atan,  atan2,  cos,  cosh,  dble,  erf,   -+    erfc,  exp,  int,  log,  log10,  max,  min,  mod,  ddcsshf  (cosh  and  sinh),   -+ -+    ddcssnf  (cos  and  sin),  ddranf  (random  number  generator  in  (0,1)),     -+    ddnrtf  (n-­‐th  root),  sign,  sin,  sinh,  sqr,  sqrt,  tan,  tanh   -+Similar  functions  are  provided  for  qd_real  arguments  (with  function   -+    names  qdcsshf,  qdcssnf,  qdranf  and  qdnrtf  instead  of  the  names  in   -+    the  list  above).   -+   -+Input  and  output  of  double-­‐double  and  quad-­‐double  data  is  done  using  the  special   -+subroutines  ddread,  ddwrite,  qdread  and  qdwrite.    The  first  argument  of  these  subroutines   -+is  the  Fortran  I/O  unit  number,  while  additional  arguments  (as  many  as  needed,  up  to  9   -+arguments)  are  scalar  variables  or  array  elements  of  the  appropriate  type.    Example:   -+   -+      integer  n   -+      type  (qd_real)  qda,  qdb,  qdc(n)   -+      ...   -+      call  qdwrite  (6,  qda,  qdb)   -+      do  j  =  1,  n   -+   -+  call  qdwrite  (6,  qdc(j))   -+      enddo   -+   -+Each  input  values  must  be  on  a  separate  line,  and  may  include  D  or  E  exponents.    Double-­‐ -+double  and  quad-­‐double  constants  may  also  be  specified  in  assignment  statements  by   -+enclosing  them  in  quotes,  as  in   -+   -+    ...   -+    type  (qd_real)  pi   -+    ...   -+    pi  =   -+"3.14159265358979323846264338327950288419716939937510582097494459230"   -+    ...   -+   -+Sample  Fortran-­‐90  programs  illustrating  some  of  these  features  are  provided  in  the  f90   -+subdirectory.   -+   -+   -+V.  Note  on  x86-­‐Based  Processors  (MOST  systems  in  use  today)   -+   -+The  algorithms  in  this  library  assume  IEEE  double  precision  floating  point  arithmetic.    Since   -+Intel  x86  processors  have  extended  (80-­‐bit)  floating  point  registers,  the  round-­‐to-­‐double   -+flag  must  be  enabled  in  the  control  word  of  the  FPU  for  this  library  to  function  properly   -+under  x86  processors.    The  following  functions  contains  appropriate  code  to  facilitate   -+manipulation  of  this  flag.    For  non-­‐x86  systems  these  functions  do  nothing  (but  still  exist).   -+   -+fpu_fix_start   This  turns  on  the  round-­‐to-­‐double  bit  in  the  control  word.   -+fpu_fix_end   -+    This  restores  the  control  flag.   -+   -+These  functions  must  be  called  by  the  main  program,  as  follows:   -+   -+   -+int  main()  {   -+   -+    unsigned  int  old_cw;   -+   -+    fpu_fix_start(&old_cw);   -+ -+   -+   -+    ...  user  code  using  quad-­‐double  library  ...   -+   -+   -+    fpu_fix_end(&old_cw);   -+   -+}   -+   -+A  Fortran-­‐90  example  is  the  following:   -+   -+   -+subroutine  f_main   -+   -+use  qdmodule   -+   -+implicit  none   -+   -+integer*4  old_cw   -+   -+   -+call  f_fpu_fix_start(old_cw)   -+   -+   -+    ...  user  code  using  quad-­‐double  library  ...   -+   -+   -+call  f_fpu_fix_end(old_cw)   -+   -+end  subroutine   -+   -+ -+ -\ No newline at end of file + diff -Nur qd-2.3.12.orig/src/Makefile.am qd-2.3.12/src/Makefile.am --- qd-2.3.12.orig/src/Makefile.am 2012-01-12 19:44:25.000000000 +0000 +++ qd-2.3.12/src/Makefile.am 2012-01-12 19:49:45.000000000 +0000 -- 2.26.2