Skip to content

Commit

Permalink
add lowerBound and upperBound macro
Browse files Browse the repository at this point in the history
Addresses #653.
  • Loading branch information
PeiMu committed May 15, 2023
1 parent b4ddf10 commit 3f37e1f
Show file tree
Hide file tree
Showing 5 changed files with 188 additions and 8 deletions.
46 changes: 46 additions & 0 deletions analysis/statistics/0ea368e57710f6424cb888cebaff3fbd0e319897.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@

changeset: 1489:0ea368e57710f6424cb888cebaff3fbd0e319897
char kNewtonVersion[] = "0.3-alpha-1489 (0ea368e57710f6424cb888cebaff3fbd0e319897) (build 05-15-2023-18:[email protected]_64)";
\n./src/noisy/noisy-linux-EN -O0 applications/noisy/helloWorld.n -s
\n./src/newton/newton-linux-EN -v 0 -eP applications/newton/invariants/ViolinWithTemperatureDependence-pigroups.nt

Informational Report:
---------------------
Invariant "ViolinWithTemperatureDependenceForPiGroups" has 2 unique kernels, each with 2 column(s)...

Kernel 0 is a valid kernel:

1 1
-0.5 -0
1 0
0.5 0
0 -1
-0 -1


The ordering of parameters is: P1 P0 P3 P2 P4 P5

Pi group 0, Pi 0 is: P0^(-0.5) P1^( 1) P2^(0.5) P3^( 1) P4^( 0) P5^(-0)

Pi group 0, Pi 1 is: P0^(-0) P1^( 1) P2^( 0) P3^( 0) P4^(-1) P5^(-1)


Kernel 1 is a valid kernel:

1 0
-0.5 1
1 -2
0.5 -1
-0 -2
0 -2


The ordering of parameters is: P1 P0 P3 P2 P4 P5

Pi group 1, Pi 0 is: P0^(-0.5) P1^( 1) P2^(0.5) P3^( 1) P4^(-0) P5^( 0)

Pi group 1, Pi 1 is: P0^( 1) P1^( 0) P2^(-1) P3^(-2) P4^(-2) P5^(-2)




100 changes: 100 additions & 0 deletions applications/newton/llvm-ir/CHStone_test/dfadd/float64_add.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -249,3 +249,103 @@ const float64 z_output[N] = {
// printf ("%d\n", main_result);
// return main_result;
// }

// clang ../CHStone_test/dfadd/float64_add.cpp -D DEBUG -D ASSUME -D lowerBound=3 -D upperBound=10 -O3 -o float64_add_assume -lm
#ifdef DEBUG

#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/time.h>
#include <time.h>

#define iteration_num 50000

typedef struct timespec timespec;
timespec diff(timespec start, timespec end)
{
timespec temp;
if ((end.tv_nsec-start.tv_nsec)<0) {
temp.tv_sec = end.tv_sec-start.tv_sec-1;
temp.tv_nsec = 1000000000+end.tv_nsec-start.tv_nsec;
} else {
temp.tv_sec = end.tv_sec-start.tv_sec;
temp.tv_nsec = end.tv_nsec-start.tv_nsec;
}
return temp;
}

timespec sum(timespec t1, timespec t2) {
timespec temp;
if (t1.tv_nsec + t2.tv_nsec >= 1000000000) {
temp.tv_sec = t1.tv_sec + t2.tv_sec + 1;
temp.tv_nsec = t1.tv_nsec + t2.tv_nsec - 1000000000;
} else {
temp.tv_sec = t1.tv_sec + t2.tv_sec;
temp.tv_nsec = t1.tv_nsec + t2.tv_nsec;
}
return temp;
}

void printTimeSpec(timespec t, const char* prefix) {
printf("%s: %d.%09d\n", prefix, (int)t.tv_sec, (int)t.tv_nsec);
}

timespec tic( )
{
timespec start_time;
clock_gettime(CLOCK_REALTIME, &start_time);
return start_time;
}

void toc( timespec* start_time, const char* prefix )
{
timespec current_time;
clock_gettime(CLOCK_REALTIME, &current_time);
printTimeSpec( diff( *start_time, current_time ), prefix );
*start_time = current_time;
}

/*
* random floating point, [min, max]
* */
static double
randomDouble(double min, double max)
{
double randDbValue = min + 1.0 * rand() / RAND_MAX * (max - min);
return randDbValue;
}

int main(int argc, char** argv) {
double parameters[2];
char *pEnd;
if (argc == 3) {
for (size_t idx = 0; idx < argc - 1; idx++) {
parameters[idx] = strtod(argv[idx + 1], &pEnd);
}
} else {
parameters[0] = 3.0;
parameters[1] = 10.0;
}
float64 result[iteration_num];
double xOps[iteration_num];
double yOps[iteration_num];
for (size_t idx = 0; idx < iteration_num; idx++) {
xOps[idx] = randomDouble(parameters[0], parameters[1]);
yOps[idx] = randomDouble(parameters[0] + 0.6, parameters[1] + 0.3);
}

timespec timer = tic();
for (size_t idx = 0; idx < iteration_num; idx++) {
result[idx] = float64_add(*(bmx055xAcceleration*)(&xOps[idx]), *(bmx055xAcceleration*)(&yOps[idx]));
}

toc(&timer, "computation delay");

printf("results: %llx, %llx, %llx, %llx, %llx\n", result[0], result[1], result[2], result[3], result[4]);
// printf("results: %f\t%f\t%f\t%f\t%f\n", *(double*)(&result[0]), *(double*)(&result[1]),
// *(double*)(&result[2]), *(double*)(&result[3]), *(double*)(&result[4]));

return 0;
}
#endif
17 changes: 17 additions & 0 deletions applications/newton/llvm-ir/CHStone_test/dfadd/include/softfloat.c
Original file line number Diff line number Diff line change
Expand Up @@ -378,9 +378,26 @@ subFloat64Sigs (float64 a, float64 b, flag zSign)
typedef float64 bmx055xAcceleration;
typedef float64 bmx055yAcceleration;

#ifndef lowerBound
#define lowerBound 0
#endif
#ifndef upperBound
#define upperBound 16
#endif

float64
float64_add (bmx055xAcceleration a, bmx055yAcceleration b)
{
#ifdef ASSUME
double aLowerBound = lowerBound, aUpperBound = upperBound;
double bLowerBound = aLowerBound+0.6, bUpperBound = aUpperBound+0.3;
bmx055xAcceleration llhs = *(bmx055xAcceleration*)(&aLowerBound);
bmx055xAcceleration lrhs = *(bmx055xAcceleration*)(&aUpperBound);
bmx055yAcceleration rlhs = *(bmx055xAcceleration*)(&bLowerBound);
bmx055yAcceleration rrhs = *(bmx055xAcceleration*)(&bUpperBound);
__builtin_assume(a > llhs && a < lrhs);
__builtin_assume(b > rlhs && b < rrhs);
#endif
flag aSign, bSign;

aSign = extractFloat64Sign (a);
Expand Down
17 changes: 13 additions & 4 deletions applications/newton/llvm-ir/CHStone_test/dfdiv/float64_div.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -263,10 +263,18 @@ extern "C" {
typedef float64 bmx055xAcceleration;
typedef float64 bmx055yAcceleration;

#ifndef lowerBound
#define lowerBound 0
#endif
#ifndef upperBound
#define upperBound 16
#endif

float64 float64_div (bmx055xAcceleration a, bmx055yAcceleration b)
{
// printf("%llx, %f\n", a, *(double*)(&a));
#ifdef ASSUME
double aLowerBound = -16.0, aUpperBound = 16.0;
double aLowerBound = lowerBound, aUpperBound = upperBound;
double bLowerBound = aLowerBound+0.6, bUpperBound = aUpperBound+0.3;
bmx055xAcceleration llhs = *(bmx055xAcceleration*)(&aLowerBound);
bmx055xAcceleration lrhs = *(bmx055xAcceleration*)(&aUpperBound);
Expand Down Expand Up @@ -460,7 +468,7 @@ const float64 z_output[N] = {
// }


// clang ../CHStone_test/dfdiv/float64_div.cpp -D DEBUG -D ASSUME -O3 -o float64_div_assume -lm
// clang ../CHStone_test/dfdiv/float64_div.cpp -D DEBUG -D ASSUME -D lowerBound=3 -D upperBound=10 -O3 -o float64_div_assume -lm
#ifdef DEBUG

#include <stdint.h>
Expand Down Expand Up @@ -552,8 +560,9 @@ int main(int argc, char** argv) {

toc(&timer, "computation delay");

printf("results: %f\t%f\t%f\t%f\t%f\n", *(double*)(&result[0]), *(double*)(&result[1]),
*(double*)(&result[2]), *(double*)(&result[3]), *(double*)(&result[4]));
printf("results: %llx, %llx, %llx, %llx, %llx\n", result[0], result[1], result[2], result[3], result[4]);
// printf("results: %f\t%f\t%f\t%f\t%f\n", *(double*)(&result[0]), *(double*)(&result[1]),
// *(double*)(&result[2]), *(double*)(&result[3]), *(double*)(&result[4]));

return 0;
}
Expand Down
16 changes: 12 additions & 4 deletions applications/newton/llvm-ir/CHStone_test/dfmul/float64_mul.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -262,9 +262,16 @@ extern "C" {
typedef float64 bmx055xAcceleration;
typedef float64 bmx055yAcceleration;

#ifndef lowerBound
#define lowerBound 0
#endif
#ifndef upperBound
#define upperBound 16
#endif

float64 float64_mul (bmx055xAcceleration a, bmx055yAcceleration b) {
#ifdef ASSUME
double aLowerBound = -16.0, aUpperBound = 16.0;
double aLowerBound = lowerBound, aUpperBound = upperBound;
double bLowerBound = aLowerBound+0.6, bUpperBound = aUpperBound+0.3;
bmx055xAcceleration llhs = *(bmx055xAcceleration*)(&aLowerBound);
bmx055xAcceleration lrhs = *(bmx055xAcceleration*)(&aUpperBound);
Expand Down Expand Up @@ -434,7 +441,7 @@ const float64 z_output[N] = {
// }


// clang ../CHStone_test/dfmul/float64_mul.cpp -D DEBUG -D ASSUME -O3 -o float64_mul_assume -lm
// clang ../CHStone_test/dfmul/float64_mul.cpp -D DEBUG -D ASSUME -D lowerBound=3 -D upperBound=10 -O3 -o float64_mul_assume -lm
#ifdef DEBUG

#include <stdint.h>
Expand Down Expand Up @@ -526,8 +533,9 @@ int main(int argc, char** argv) {

toc(&timer, "computation delay");

printf("results: %f\t%f\t%f\t%f\t%f\n", *(double*)(&result[0]), *(double*)(&result[1]),
*(double*)(&result[2]), *(double*)(&result[3]), *(double*)(&result[4]));
printf("results: %llx, %llx, %llx, %llx, %llx\n", result[0], result[1], result[2], result[3], result[4]);
// printf("results: %f\t%f\t%f\t%f\t%f\n", *(double*)(&result[0]), *(double*)(&result[1]),
// *(double*)(&result[2]), *(double*)(&result[3]), *(double*)(&result[4]));

return 0;
}
Expand Down

0 comments on commit 3f37e1f

Please sign in to comment.