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)