diff options
| author | Derick Huth <derickhuth@gmail.com> | 2014-10-06 12:42:34 -0600 | 
|---|---|---|
| committer | Derick Huth <derickhuth@gmail.com> | 2014-10-06 12:42:34 -0600 | 
| commit | 8d73c8fcc75556c1df71dd39dd99783f8f86fc3e (patch) | |
| tree | 157d627863d76a4c256a27cae27ce2e8566c7ea0 /omega/examples/c_code | |
| parent | e87b55ad69f0ac6211daae741b32c8ee9dcbe470 (diff) | |
| parent | 8c646f24570079eac53e58fcf42d0d4fbc437ee3 (diff) | |
| download | chill-8d73c8fcc75556c1df71dd39dd99783f8f86fc3e.tar.gz chill-8d73c8fcc75556c1df71dd39dd99783f8f86fc3e.tar.bz2 chill-8d73c8fcc75556c1df71dd39dd99783f8f86fc3e.zip | |
Merge pull request #2 from dhuth/master
Moved omega into chill.
Diffstat (limited to 'omega/examples/c_code')
| -rw-r--r-- | omega/examples/c_code/Makefile | 21 | ||||
| -rw-r--r-- | omega/examples/c_code/PT-example.c | 12 | ||||
| -rw-r--r-- | omega/examples/c_code/example.c | 89 | ||||
| -rw-r--r-- | omega/examples/c_code/library_example.c | 190 | 
4 files changed, 312 insertions, 0 deletions
| diff --git a/omega/examples/c_code/Makefile b/omega/examples/c_code/Makefile new file mode 100644 index 0000000..5d4dd61 --- /dev/null +++ b/omega/examples/c_code/Makefile @@ -0,0 +1,21 @@ +CC = g++ +INC_DIR = -I../../include +LIB_DIR = -L../../lib + +all: example library_example + + +example : example.o ../../lib/libomega.a +	${CC} -g $(LIB_DIR) example.o -lomega -o example + +example.o : example.c +	${CC} -Wall -g $(INC_DIR) -c example.c + +library_example : library_example.o ../../lib/libomega.a +	${CC} -g $(LIB_DIR) library_example.o -lomega -o library_example + +library_example.o : library_example.c +	${CC} -Wall -g $(INC_DIR) -c library_example.c + +clean: +	@rm -fr *.o example library_example diff --git a/omega/examples/c_code/PT-example.c b/omega/examples/c_code/PT-example.c new file mode 100644 index 0000000..c2560e7 --- /dev/null +++ b/omega/examples/c_code/PT-example.c @@ -0,0 +1,12 @@ +#if defined DONT_INCLUDE_TEMPLATE_CODE + +/* DONT BOTHER COMPILING THIS FILE UNLESS WE ARE USING G++ >= 260 +   AND  -fno-implicit-templates AND -DDONT_INCLUDE_TEMPLATE_CODE  */ + +#undef DONT_INCLUDE_TEMPLATE_CODE + +#include <omega_calc/PT-omega.c> + +// If we needed other templates, we would put them here + +#endif diff --git a/omega/examples/c_code/example.c b/omega/examples/c_code/example.c new file mode 100644 index 0000000..8bd84b3 --- /dev/null +++ b/omega/examples/c_code/example.c @@ -0,0 +1,89 @@ +#include <omega.h> + +// THIS NEEDS TO BE A LOT SIMPLER - I'M CUTTING IT DOWN + +// R := { [i,j] -> [i', j'] : +//        1 <= i, i' <= n && 1 <= j <= L(i) && 1 <= j' <= m && +//        j = j' && i < i' } +// +// S := { [x,y] : 1 <= x <= n && y <= x + 5 && x is divisible by 17 && +//        there exists z such that y <= z <= x && +//        ( z is divisible by 8 || z+5x is divisible by 12 ) } + +using namespace omega; +int main() { +  Relation S(2); +  S.name_set_var(1, "x"); +  S.name_set_var(2, "y"); + +  assert( S.is_set()); + +  Free_Var_Decl n("n"); + + +/*     Relation R(2,2); */ +/*     assert(!R.is_set()); */ + +/*     Free_Var_Decl m("m"); */ +/*     Free_Var_Decl l("L", 1); */ + +/*     Variable_ID local_n = R.get_local(&n); */ +/*     Variable_ID local_m = R.get_local(&m); */ +/*     Variable_ID l_in    = R.get_local(&l, Input_Tuple); */ +/*     Variable_ID l_out   = R.get_local(&l, Output_Tuple); */ +     +/*     Variable_ID in1 = R.input_var(1); */ +/*     Variable_ID in2 = R.input_var(2); */ +/*     Variable_ID out1 = R.output_var(1); */ +/*     Variable_ID out2 = R.output_var(2); */ + +  Variable_ID x = S.set_var(1); +  Variable_ID y = S.set_var(2); + +  F_And *S_root = S.add_and(); + +  GEQ_Handle xmin = S_root->add_GEQ();  // x-1 >= 0 +  xmin.update_coef(x, 1); +  xmin.update_const(-1); +  GEQ_Handle xmax = S_root->add_GEQ();  // n-x >= 0 +  xmax.update_coef(x, -1); +  xmax.update_coef(S.get_local(&n), 1); +  GEQ_Handle ymax = S_root->add_GEQ();  // x+5-y >= 0 +  ymax.update_coef(x, 1); +  ymax.update_coef(y, -1); +  ymax.update_const(5); + +  // x is divisible by 17 +  S_root->add_stride(17).update_coef(x,1);   + +  F_Exists *e = S_root->add_exists(); + +  Variable_ID z = e->declare("z");      // exists z +  F_And *z_stuff = e->add_and(); + +  GEQ_Handle zmin = z_stuff->add_GEQ(); // z-y >= 0 +  zmin.update_coef(z,1); +  zmin.update_coef(y,-1); +  GEQ_Handle zmax = z_stuff->add_GEQ(); // x-z >= 0 +  zmax.update_coef(x,1); +  zmax.update_coef(z,-1); + +  F_Or *o = z_stuff->add_or(); +  Stride_Handle z8  = o->add_and()->add_stride(8); +  z8.update_coef(z,1);         // z divisible by 8 + +  Stride_Handle z12 = o->add_and()->add_stride(12); +  z12.update_coef(z,1); +  z12.update_coef(x,5);    // z+5x divisible by 12 + + +  S.print();     +  S.finalize(); +  S.prefix_print(); +  S.is_upper_bound_satisfiable(); +  S.print(); +  S.prefix_print(); + +  return 0; +} + diff --git a/omega/examples/c_code/library_example.c b/omega/examples/c_code/library_example.c new file mode 100644 index 0000000..06f6570 --- /dev/null +++ b/omega/examples/c_code/library_example.c @@ -0,0 +1,190 @@ +/* +  IF THESE EXAMPLES CHANGE, CHANGE construction.tex CORRESPONDINGLY + +  S1 := { [t] : 1 <= t <= n } + +  S2 := { [x] : (0 <= x <= 100 and +  exists y : (2n <= y <= x and y is odd)) +  or x = 17 } + +  R := { [i,j] -> [i',j'] : 1 <= i <= i' <= n and not (F(i) = F(i')) +  and 1 <= j, j' <= m } +*/ + +//BEGIN PART 1 +#include <omega.h> +using namespace omega; +int main() { +  Relation S1(1), S2(1), R(2,2); +  S1.name_set_var(1, "t"); +  S2.name_set_var(1, "x"); + +  assert(!R.is_set()); +  assert(S1.is_set()); +  assert(S2.is_set()); + +  Free_Var_Decl n("n"); +  Free_Var_Decl m("m"); +  Free_Var_Decl f("F", 1); + +  Variable_ID S1s_n = S1.get_local(&n); +  Variable_ID S2s_n = S2.get_local(&n); + +  Variable_ID Rs_n = R.get_local(&n); +  Variable_ID Rs_m = R.get_local(&m); +  Variable_ID Rs_f_in  = R.get_local(&f, Input_Tuple); +  Variable_ID Rs_f_out = R.get_local(&f, Output_Tuple); +     +  R.name_input_var(1, "i"); +  R.name_input_var(2, "j"); +  R.name_output_var(1, "i'"); +  R.name_output_var(2, "j'"); +  Variable_ID i = R.input_var(1); +  Variable_ID j = R.input_var(2); +  Variable_ID i2 = R.output_var(1); +  Variable_ID j2 = R.output_var(2); + +  Variable_ID t = S1.set_var(1); +  Variable_ID x = S2.set_var(1); +//END PART 1 +//BEGIN PART 2 +  F_And *S1_root = S1.add_and(); + +  GEQ_Handle tmin = S1_root->add_GEQ();   // t-1 >= 0 +  tmin.update_coef(t, 10); +  tmin.update_coef(t, -9);       // t now has coef. 1 +  tmin.update_const(-1); +  GEQ_Handle tmax = S1_root->add_GEQ();   // n-t >= 0 +  tmax.update_coef(S1s_n,1); +  tmax.update_coef(t, -1); + + +  F_Or  *S2_root = S2.add_or(); +  F_And *part1 = S2_root->add_and(); + +  GEQ_Handle xmin = part1->add_GEQ(); +  xmin.update_coef(x,1); +  GEQ_Handle xmax = part1->add_GEQ(); +  xmax.update_coef(x,-1); +  xmax.update_const(100); + +  F_Exists *exists_y = part1->add_exists(); +  Variable_ID y = exists_y->declare("y"); + +  F_And *y_stuff = exists_y->add_and(); +  GEQ_Handle ymin = y_stuff->add_GEQ(); +  ymin.update_coef(y,1); +  ymin.update_coef(S2s_n,-2); +  GEQ_Handle ymax = y_stuff->add_GEQ(); +  ymax.update_coef(x,1); +  ymax.update_coef(y,-1); +  Stride_Handle y_even = y_stuff->add_stride(2); +  y_even.update_coef(y,1); +  y_even.update_const(1); + +  F_And *part2 = S2_root->add_and(); + +  EQ_Handle xvalue = part2->add_EQ(); +  xvalue.update_coef(x,1); +  xvalue.update_const(-17); +//END PART 2 +//BEGIN PART 3 +  F_And *R_root = R.add_and(); + +  GEQ_Handle imin = R_root->add_GEQ(); +  imin.update_coef(i,1); +  imin.update_const(-1); +  GEQ_Handle imax = R_root->add_GEQ(); +  imax.update_coef(i2,1); +  imax.update_coef(i,-1); +  GEQ_Handle i2max = R_root->add_GEQ(); +  i2max.update_coef(Rs_n,1); +  i2max.update_coef(i2,-1); + +  EQ_Handle f_eq = R_root->add_not()->add_and()->add_EQ(); +  f_eq.update_coef(Rs_f_in,-1); +  f_eq.update_coef(Rs_f_out,1);  // F(In) - F(Out) = 0 + +  GEQ_Handle jmin = R_root->add_GEQ(); +  jmin.update_coef(j,1); +  jmin.update_const(-1); +  GEQ_Handle jmax = R_root->add_GEQ(); +  jmax.update_coef(Rs_m,1); +  jmax.update_coef(j,-1); +     +  GEQ_Handle j2min = R_root->add_GEQ(); +  j2min.update_coef(j2,1); +  j2min.update_const(-1); +  GEQ_Handle j2max = R_root->add_GEQ(); +  j2max.update_coef(Rs_m,1); +  j2max.update_coef(j2,-1); +//END PART 3 +//BEGIN PART 4 +  S1.print_with_subs(stdout); +  assert(S1.is_upper_bound_satisfiable()); +  assert(!S1.is_tautology()); +  S1.print_with_subs(stdout);  // same as above print +  printf("\n"); + +  S2.print(); +  assert(S2.is_upper_bound_satisfiable()); +  assert(!S2.is_tautology()); +  S2.print();                 // different from above +  printf("\n"); + +  assert(R.is_upper_bound_satisfiable()); +  assert(!R.is_tautology()); +  R.print_with_subs(stdout); + +  coef_t lb, ub; +  bool coupled; +  R.query_difference(i2, i, lb, ub, coupled); +  assert(lb == 1);        // i < i2: i2 - i1 > 0 +  assert(ub == posInfinity); + +  for(DNF_Iterator di(R.query_DNF()); di; di++) { +    printf("In next conjunct,\n"); +    for(EQ_Iterator ei = (*di)->EQs(); ei; ei++) { +      printf("  In next equality constraint,\n"); +      for(Constr_Vars_Iter cvi(*ei); cvi; cvi++) +        printf("    Variable %s has coefficient "coef_fmt"\n", +               (*cvi).var->char_name(),  +               (*cvi).coef); +    } +    for(GEQ_Iterator gi = (*di)->GEQs(); gi; gi++) { +      printf("  In next inequality constraint,\n"); +      for(Constr_Vars_Iter cvi(*gi); cvi; cvi++) +        printf("    Variable %s has coefficient "coef_fmt"\n", +               (*cvi).var->char_name(),  +               (*cvi).coef); +      int c = (*gi).get_const(); +      if (c != 0) +        printf("    Constant %d\n", c); +    } +         +    printf("\n"); +  } +//END PART 4 +//BEGIN PART 5 +  Relation S1_or_S2 = Union(copy(S1), copy(S2)); + +  // NOTE! THE FOLLOWING KILLS S1 AND S2 +  Relation S1_and_S2 = Intersection(S1, S2); + +  S1_or_S2.is_upper_bound_satisfiable(); +  S1_and_S2.is_upper_bound_satisfiable(); + +  S1_or_S2.print(); +  printf("\n"); + +  S1_and_S2.print();     +  printf("\n"); + +  Relation R_R = Composition(copy(R), R); +  R_R.query_difference(i2, i, lb, ub, coupled); +  assert(lb == 2); +  assert(ub == posInfinity); + +  return 0; +} +//END PART 5 | 
