// Rascal, the Advanced Scientific CALculator
// Copyright (C) 2001, Sebastian Ritterbusch (Rascal@Ritterbusch.de)
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more detauls.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
//

int rinterval_precision_init=0;
int rinterval_precision1=1;
int rinterval_precision2=10;

using cxsc::SetPrecision;
using cxsc::SetDotPrecision;

inline void do_rinterval_precicison_init(void)
{
   if(!rinterval_precision_init)
   {
      rinterval_precision_init=1;
      cout << SetPrecision(rinterval_precision1,rinterval_precision2);
      cout << SetDotPrecision(rinterval_precision1,rinterval_precision2);
   }
}

string output(const cxscinterval & a)
{
   if(rinterval_precision2>=0)
   {
      string b; b << a;
      return b;
   } else
   {
      int p2=rinterval_precision2;
      int p1=rinterval_precision1;
      rinterval_precision(p1,0);
      string b;
      b << a;
      string beststring=b;
      real bestdiam=diam(stringinterval(b));
      real optimal=diam(a);
      int p3;
      for(p3=1;p3<=-p2;p3++)
      {
         rinterval_precision(p1,p3);
         b="";
         b << a;
         real now=diam(stringinterval(b));
         if(now<bestdiam)
         {
            beststring=b;
            bestdiam=now;
         }
         if(now==optimal)
            break;
      }
      rinterval_precision(p1,p2);
      return beststring;
   }
}

string outputreal(const double & a)
{
   if(rinterval_precision2>=0)
   {
      string b; b << real(a);
      return b;
   } else
   {
      int p2=rinterval_precision2;
      int p1=rinterval_precision1;
      rinterval_precision(p1,0);
      string b;
      b << real(a);
      string beststring=b;
      double bestdistance=fabs(a-stringtodouble(b).asDOUBLE());
      int p3;
      for(p3=1;p3<=-p2;p3++)
      {
         rinterval_precision(p1,p3);
         b="";
         b << real(a);
         double now=fabs(a-stringtodouble(b).asDOUBLE());
         if(now<bestdistance)
         {
            beststring=b;
            bestdistance=now;
         }
         if(now==0)
            break;
      }
      rinterval_precision(p1,p2);
      return beststring;
   }
}

cxscinterval stringinterval(const string & a)
{
   cxscinterval b;
   a>>b;
   return b;
}

int rinterval_precision(int a)
{
   if(a>300)
      a=300;
   if(a<-300)
      a=-300;
   cout << SetPrecision(rinterval_precision1=a,rinterval_precision2=a);
   cout << SetDotPrecision(rinterval_precision1=a,rinterval_precision2=a);
   return 0;
}

int rinterval_precision(int a,int b)
{
   if(b>300)
      b=300;
   if(b<-300)
      b=-300;
   cout << SetPrecision(rinterval_precision1=a,rinterval_precision2=b);
   cout << SetDotPrecision(rinterval_precision1=a,rinterval_precision2=b);
   return 0;
}

int rinterval_showprecision(void)
{
   cout << "Precision(" << rinterval_precision1 << "," << rinterval_precision2 << ")" << endl;
   return 0;
}


syntax highlighted by Code2HTML, v. 0.9.1