33#include "DGtal/base/Common.h" 
   34#include "DGtal/kernel/CPointPredicate.h" 
   35#include "DGtal/arithmetic/IntegerComputer.h" 
   36#include "DGtal/arithmetic/SternBrocot.h" 
   37#include "DGtal/arithmetic/Pattern.h" 
   38#include "DGtal/arithmetic/StandardDSLQ0.h" 
   48template <
typename DSL>
 
   50                            const typename DSL::Point & A, 
 
   51                            const typename DSL::Point & B ) 
 
   53  DSL S = D.reversedSmartDSS( A, B );
 
 
   61template <
typename Fraction>
 
   63                           typename Fraction::Integer moda, 
 
   64                           typename Fraction::Integer modb, 
 
   65                           typename Fraction::Integer modx )
 
   68  typedef typename Fraction::Integer 
Integer;
 
   69  typedef typename DSL::Point 
Point;
 
   74  std::cout << 
"# a b mu a1 b1 mu1 Ax Ay Bx By" << std::endl;
 
   77  clock_t timeBegin, timeEnd;
 
   81  for ( 
unsigned int i = 0; i < nbtries; ++i )
 
   90      if ( ic.
gcd( a, b ) == 1 )
 
   92          for ( 
int j = 0; j < 5; ++j )
 
   94              Integer mu = rand() % (moda+modb);
 
   96              for ( 
Integer x = 0; x < 10; ++x )
 
   99                  Integer x2 = x1 + 1 + ( rand() % modx );
 
  100                  Point A = D.lowestY( x1 );
 
  101                  Point B = D.lowestY( x2 );
 
  110  CPUTime =  ((double)timeEnd-(
double)timeBegin)/((
double)CLOCKS_PER_SEC);  
 
  112  std::cout << 
" " << (
long double) CPUTime/(nbtries*5*10);
 
 
  122int main( 
int argc, 
char** argv)
 
  125  typedef SB::Fraction Fraction;
 
  126  typedef Fraction::Integer 
Integer;
 
  127  unsigned int nbtries = ( argc > 1 ) ? atoi( argv[ 1 ] ) : 10000;
 
  128  Integer moda = ( argc > 2 ) ? atoll( argv[ 2 ] ) : 1000000000000;
 
  129  Integer modb = ( argc > 3 ) ? atoll( argv[ 3 ] ) : 1000000000000;
 
  130  Integer modx = ( argc > 4 ) ? atoll( argv[ 4 ] ) : 1000;
 
 
Aim: This class gathers several types and methods to make computation with integers.
 
Integer gcd(IntegerParamType a, IntegerParamType b) const
 
Aim: Represents a digital straight line with slope in the first quadrant (Q0: x >= 0,...
 
Aim: The Stern-Brocot tree is the tree of irreducible fractions. This class allows to construct it pr...
 
Point::Coordinate Integer
 
DGtal is the top-level namespace which contains all DGtal functions and types.
 
bool testSubStandardDSLQ0()
 
bool checkSubStandardDSLQ0(const DSL &D, const typename DSL::Point &A, const typename DSL::Point &B)