/* * linear_var.h * * Created on: 07/12/2016 * Author: pedro */ #ifndef SRC_CONSTRAINTS_LINEAR_VAR_H_ #define SRC_CONSTRAINTS_LINEAR_VAR_H_ #include #include #include "../config.h" #include "../constraints.h" #include "../kernels/cl_aux_functions.h" #include "../kernels/cl_constraints.h" #include "../kernels/cl_ttl.h" unsigned int c_linear_var(int* K, unsigned int* Y_ids, unsigned int n, unsigned int z_id); unsigned int c_linear_var_reif(int* K, unsigned int* Y_ids, unsigned int n, unsigned int z_id, int reif_v_id); bool linear_var_check(constr* c, bool explored); #if CS_LINEAR_VAR == 1 void linear_var_prop(CL_INTS_MEM int* vs_per_c_idx, CL_INTS_MEM int* c_consts, CL_MEMORY VARS_PROP* vs_prop_, CL_CS_MEM cl_constr* current_cs, CL_MEMORY unsigned short* vs_id_to_prop_, bool* prop_ok, __global int* terms_mem CS_IGNORE_FUNC TTL_CTR); #if CS_R_LINEAR_VAR == 1 void linear_var_reif( CL_INTS_MEM int* vs_per_c_idx, CL_INTS_MEM int* c_consts, CL_MEMORY VARS_PROP* vs_prop_, CL_CS_MEM cl_constr* current_cs, CL_MEMORY unsigned short* vs_id_to_prop_, __global int* terms_mem CS_IGNORE_FUNC TTL_CTR); void linear_var_prop_opposite(CL_INTS_MEM int* vs_per_c_idx, CL_INTS_MEM int* c_consts, CL_MEMORY VARS_PROP* vs_prop_, CL_CS_MEM cl_constr* current_cs, CL_MEMORY unsigned short* vs_id_to_prop_, bool* prop_ok, __global int* terms_mem CS_IGNORE_FUNC TTL_CTR); #endif void linear_var_propagate(CL_INTS_MEM int* vs_per_c_idx, CL_INTS_MEM int* c_consts, CL_MEMORY VARS_PROP* vs_prop_, CL_CS_MEM cl_constr* current_cs, CL_MEMORY unsigned short* vs_id_to_prop_, bool* prop_ok, __global int* terms_mem PROPAGATED_FUNC CS_IGNORE_FUNC TTL_CTR); #endif #endif /* SRC_CONSTRAINTS_LINEAR_VAR_H_ */