Changes in src/examples/sum.c [6e7e2b36:dd51906]
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/examples/sum.c
r6e7e2b36 rdd51906 5 5 // file "LICENCE" distributed with Cforall. 6 6 // 7 // sum.c -- 7 // sum.c -- test resolvers ability to deal with many variables with the same name and to use the minimum number of casts 8 // necessary to disambiguate overloaded variable names. 8 9 // 9 // Author : Richard C. Bilson10 // Author : Peter A. Buhr 10 11 // Created On : Wed May 27 17:56:53 2015 11 12 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Mon Jun 1 20:46:35 201513 // Update Count : 1813 // Last Modified On : Thu May 26 09:25:42 2016 14 // Update Count : 201 14 15 // 15 16 16 extern "C" { 17 int printf( const char *, ... ); 18 } 17 #include <fstream> 19 18 20 context sumable(type T ) {19 trait sumable( otype T ) { 21 20 const T 0; 22 21 T ?+?( T, T ); 22 T ?+=?( T *, T ); 23 T ++?( T * ); 23 24 T ?++( T * ); 24 T ?+=?( T *, T ); 25 }; 25 }; // sumable 26 26 27 forall( type T | sumable( T ) ) 28 T sum( int n, T a[] ) { 29 T total; // instantiate T, select 0 30 total = 0; 31 for ( int i = 0; i < n; i += 1 ) 32 total = total + a[i]; // select + 27 forall( otype T | sumable( T ) ) 28 T sum( unsigned int n, T a[] ) { 29 T total = 0; // instantiate T, select 0 30 for ( unsigned int i = 0; i < n; i += 1 ) 31 total += a[i]; // select + 33 32 return total; 34 } 33 } // sum 35 34 36 35 // Required to satisfy sumable as char does not have addition. 37 36 const char 0; 38 char ?+?( char op1, char op2 ) { return op1 + op2; } 39 char ?++( char *op ) { return *op + 1; } 37 char ?+?( char t1, char t2 ) { return (int)t1 + t2; } // cast forces integer addition, otherwise recursion 38 char ?+=?( char *t1, char t2 ) { *t1 = *t1 + t2; return *t1; } 39 char ++?( char *t ) { *t += 1; return *t; } 40 char ?++( char *t ) { char temp = *t; *t += 1; return temp; } 40 41 41 const double 0; // TEMPORARY, incorrect use of int 0 42 int main( void ) { 43 const int low = 5, High = 15, size = High - low; 42 44 43 int main() { 44 const int low = 5, High = 15, size = High - low; 45 int si = 0, ai[size]; 46 int v = low; 45 char s = 0, a[size], v = low; 47 46 for ( int i = 0; i < size; i += 1, v += 1 ) { 48 s i+= v;49 a i[i] = v;50 } 51 printf( "sum from %d to %d is %d, check %d\n",52 low, High, sum( size, ai ), si );47 s += v; 48 a[i] = v; 49 } // for 50 sout | "sum from" | low | "to" | High | "is" 51 | (int)sum( size, a ) | ", check" | (int)s | endl; 53 52 54 // char ci[size]; 55 // char c = sum( size, ci ); 56 // float fi[size]; 57 // float f = sum( size, fi ); 53 int s = 0, a[size], v = low; 54 for ( int i = 0; i < size; i += 1, v += 1 ) { 55 s += (int)v; 56 a[i] = (int)v; 57 } // for 58 sout | "sum from" | low | "to" | High | "is" 59 | sum( size, (int *)a ) | ", check" | (int)s | endl; 58 60 59 double sd = 0.0, ad[size]; 60 double v = low / 10.0; 61 float s = 0.0, a[size], v = low / 10.0; 62 for ( int i = 0; i < size; i += 1, v += 0.1f ) { 63 s += (float)v; 64 a[i] = (float)v; 65 } // for 66 sout | "sum from" | low / 10.0 | "to" | High / 10.0 | "is" 67 | sum( size, (float *)a ) | ", check" | (float)s | endl; 68 69 double s = 0, a[size], v = low / 10.0; 61 70 for ( int i = 0; i < size; i += 1, v += 0.1 ) { 62 sd += v; 63 ad[i] = v; 64 } 65 printf( "sum from %g to %g is %g, check %g\n", 66 low / 10.0, High / 10.0, sum( size, ad ), sd ); 67 } 71 s += (double)v; 72 a[i] = (double)v; 73 } // for 74 sout | "sum from" | low / 10.0 | "to" | High / 10.0 | "is" 75 | sum( size, (double *)a ) | ", check" | (double)s | endl; 76 77 struct S { int i, j; } 0 = { 0, 0 }, 1 = { 1, 1 }; 78 S ?+?( S t1, S t2 ) { return (S){ t1.i + t2.i, t1.j + t2.j }; } 79 S ?+=?( S *t1, S t2 ) { *t1 = *t1 + t2; return *t1; } 80 S ++?( S *t ) { *t += 1; return *t; } 81 S ?++( S *t ) { S temp = *t; *t += 1; return temp; } 82 ofstream * ?|?( ofstream * os, S v ) { return os | v.i | v.j; } 83 84 S s = 0, a[size], v = { low, low }; 85 for ( int i = 0; i < size; i += 1, v += (S)1 ) { 86 s += (S)v; 87 a[i] = (S)v; 88 } // for 89 sout | "sum from" | low | "to" | High | "is" 90 | sum( size, (S *)a ) | ", check" | (S)s | endl; 91 } // main 68 92 69 93 // Local Variables: //
Note:
See TracChangeset
for help on using the changeset viewer.