Candl
0.6.1
|
00001 00037 /****************************************************************************** 00038 * THIS FILE HAS BEEN AUTOMATICALLY GENERATED FROM candl.h.in BY configure * 00039 ******************************************************************************/ 00040 00041 00042 #ifndef CANDL_H 00043 # define CANDL_H 00044 00045 # define CANDL_RELEASE "0.6.1" 00046 # define CANDL_VERSION "64" 00047 # define CANDL_SUPPORTS_SCOPLIB 00048 # define CANDL_SUPPORTS_ISL 00049 00050 00051 # include <piplib/piplib64.h> 00052 # include <candl/options.h> 00053 # include <candl/matrix.h> 00054 # include <candl/statement.h> 00055 # include <candl/program.h> 00056 # include <candl/dependence.h> 00057 # include <candl/ddv.h> 00058 # include <candl/violation.h> 00059 # include <candl/pruning.h> 00060 00061 # define CANDL_UNSET -1 /* Must be negative (we do use that property). 00062 * All other constants have to be different. 00063 */ 00064 00065 # define CANDL_RAW 1 00066 # define CANDL_WAR 2 00067 # define CANDL_WAW 3 00068 # define CANDL_RAR 4 00069 00070 # define CANDL_ASSIGNMENT 1 00071 # define CANDL_P_REDUCTION 2 00072 # define CANDL_M_REDUCTION 3 00073 # define CANDL_T_REDUCTION 4 00074 00075 # define CANDL_EQUAL 1 00076 # define CANDL_POSIT 2 00077 # define CANDL_LATER 3 00078 # define CANDL_NEVER 4 00079 00080 # define CANDL_NB_INFOS 3 00081 00082 # define CANDL_MAX_STRING 2048 00083 # define CANDL_TEMP_OUTPUT "candl.temp" 00084 00085 /* Useful macros. */ 00086 # define CANDL_max(x,y) ((x) > (y)? (x) : (y)) 00087 # define CANDL_min(x,y) ((x) < (y)? (x) : (y)) 00088 00089 # define CANDL_FAIL(msg) { fprintf(stderr, "[Candl] " msg "\n"); exit(1); } 00090 00091 /****************************************************************************** 00092 * FORMAT * 00093 ******************************************************************************/ 00094 #if defined(LINEAR_VALUE_IS_LONGLONG) 00095 #define CANDL_FMT "%4lld " 00096 #elif defined(LINEAR_VALUE_IS_LONG) 00097 #define CANDL_FMT "%4ld " 00098 #else /* GNUMP */ 00099 #define CANDL_FMT "%4s" 00100 #endif 00101 00102 /****************************************************************************** 00103 * CANDL GMP MACROS * 00104 ******************************************************************************/ 00105 #ifdef LINEAR_VALUE_IS_MP 00106 /* Basic Macros */ 00107 #define CANDL_init(val) (mpz_init((val))) 00108 #define CANDL_assign(v1,v2) (mpz_set((v1),(v2))) 00109 #define CANDL_set_si(val,i) (mpz_set_si((val),(i))) 00110 #define CANDL_get_si(val) (mpz_get_si((val))) 00111 #define CANDL_clear(val) (mpz_clear((val))) 00112 #define CANDL_print(Dst,fmt,val) { char *str; \ 00113 str = mpz_get_str(0,10,(val)); \ 00114 fprintf((Dst),(fmt),str); free(str); \ 00115 } 00116 00117 /* Boolean operators on 'Value' or 'Entier' */ 00118 #define CANDL_eq(v1,v2) (mpz_cmp((v1),(v2)) == 0) 00119 #define CANDL_ne(v1,v2) (mpz_cmp((v1),(v2)) != 0) 00120 00121 /* Binary operators on 'Value' or 'Entier' */ 00122 #define CANDL_increment(ref,val) (mpz_add_ui((ref),(val),1)) 00123 #define CANDL_decrement(ref,val) (mpz_sub_ui((ref),(val),1)) 00124 #define CANDL_subtract(ref,val1,val2) (mpz_sub((ref),(val1),(val2))) 00125 #define CANDL_oppose(ref,val) (mpz_neg((ref),(val))) 00126 00127 /* Conditional operations on 'Value' or 'Entier' */ 00128 #define CANDL_zero_p(val) (mpz_sgn(val) == 0) 00129 #define CANDL_notzero_p(val) (mpz_sgn(val) != 0) 00130 00131 /****************************************************************************** 00132 * CANDL BASIC TYPES MACROS * 00133 ******************************************************************************/ 00134 #else 00135 /* Basic Macros */ 00136 #define CANDL_init(val) ((val) = 0) 00137 #define CANDL_assign(v1,v2) ((v1) = (v2)) 00138 #define CANDL_set_si(val,i) ((val) = (Entier)(i)) 00139 #define CANDL_get_si(val) ((val)) 00140 #define CANDL_clear(val) ((val) = 0) 00141 #define CANDL_print(Dst,fmt,val) (fprintf((Dst),(fmt),(val))) 00142 00143 /* Boolean operators on 'Value' or 'Entier' */ 00144 #define CANDL_eq(v1,v2) ((v1)==(v2)) 00145 #define CANDL_ne(v1,v2) ((v1)!=(v2)) 00146 00147 /* Binary operators on 'Value' or 'Entier' */ 00148 #define CANDL_increment(ref,val) ((ref) = (val)+(Entier)(1)) 00149 #define CANDL_decrement(ref,val) ((ref) = (val)-(Entier)(1)) 00150 #define CANDL_subtract(ref,val1,val2) ((ref) = (val1)-(val2)) 00151 #define CANDL_oppose(ref,val) ((ref) = (-(val))) 00152 00153 /* Conditional operations on 'Value' or 'Entier' */ 00154 #define CANDL_zero_p(val) CANDL_eq(val,0) 00155 #define CANDL_notzero_p(val) CANDL_ne(val,0) 00156 00157 #endif 00158 00159 #endif // !CANDL_H