var-imp.hpp cmath gecode/int/var-imp/delta.hpp gecode/int/var-imp/int.hpp gecode/int/var-imp/bool.hpp /usr/include/gecode/int.hh Gecode::Int::IntDelta Gecode::Int::IntVarImp Gecode::Int::IntVarImp::RangeList Gecode::Int::IntVarImpFwd Gecode::Int::IntVarImpBwd Gecode::Int::BoolVarImp Gecode Gecode::Int /*-*-mode:C++;c-basic-offset:2;indent-tabs-mode:nil-*-*/ /* *Mainauthors: *ChristianSchulte<schulte@gecode.org> * *Contributingauthors: *GuidoTack<tack@gecode.org> * *Copyright: *ChristianSchulte,2002 *GuidoTack,2004 * *Lastmodified: *$Date:2013-02-1416:29:11+0100(Thu,14Feb2013)$by$Author:schulte$ *$Revision:13292$ * *ThisfileispartofGecode,thegenericconstraint *developmentenvironment: *http://www.gecode.org * *Permissionisherebygranted,freeofcharge,toanypersonobtaining *acopyofthissoftwareandassociateddocumentationfiles(the *"Software"),todealintheSoftwarewithoutrestriction,including *withoutlimitationtherightstouse,copy,modify,merge,publish, *distribute,sublicense,and/orsellcopiesoftheSoftware,andto *permitpersonstowhomtheSoftwareisfurnishedtodoso,subjectto *thefollowingconditions: * *Theabovecopyrightnoticeandthispermissionnoticeshallbe *includedinallcopiesorsubstantialportionsoftheSoftware. * *THESOFTWAREISPROVIDED"ASIS",WITHOUTWARRANTYOFANYKIND, *EXPRESSORIMPLIED,INCLUDINGBUTNOTLIMITEDTOTHEWARRANTIESOF *MERCHANTABILITY,FITNESSFORAPARTICULARPURPOSEAND *NONINFRINGEMENT.INNOEVENTSHALLTHEAUTHORSORCOPYRIGHTHOLDERSBE *LIABLEFORANYCLAIM,DAMAGESOROTHERLIABILITY,WHETHERINANACTION *OFCONTRACT,TORTOROTHERWISE,ARISINGFROM,OUTOFORINCONNECTION *WITHTHESOFTWAREORTHEUSEOROTHERDEALINGSINTHESOFTWARE. * */ #include<cmath> namespaceGecode{namespaceInt{ classIntVarImp; classBoolVarImp; classIntDelta:publicDelta{ friendclassIntVarImp; friendclassBoolVarImp; private: int_min; int_max; public: IntDelta(void); IntDelta(intmin,intmax); IntDelta(intmin); private: intmin(void)const; intmax(void)const; boolany(void)const; }; }} #include<gecode/int/var-imp/delta.hpp> namespaceGecode{namespaceInt{ classIntVarImpFwd; classIntVarImpBwd; classIntVarImp:publicIntVarImpBase{ friendclassIntVarImpFwd; friendclassIntVarImpBwd; protected: classRangeList:publicFreeList{ protected: int_min; int_max; public: RangeList(void); RangeList(intmin,intmax); RangeList(intmin,intmax,RangeList*p,RangeList*n); intmin(void)const; intmax(void)const; unsignedintwidth(void)const; RangeList*next(constRangeList*p)const; RangeList*prev(constRangeList*n)const; voidmin(intn); voidmax(intn); voidprevnext(RangeList*p,RangeList*n); voidnext(RangeList*o,RangeList*n); voidprev(RangeList*o,RangeList*n); voidfix(RangeList*n); voiddispose(Space&home,RangeList*p,RangeList*l); voiddispose(Space&home,RangeList*l); voiddispose(Space&home); staticvoid*operatornew(size_ts,Space&home); staticvoid*operatornew(size_ts,void*p); staticvoidoperatordelete(void*); staticvoidoperatordelete(void*,Space&); staticvoidoperatordelete(void*,void*); }; RangeListdom; RangeList*_lst; RangeList*fst(void)const; voidfst(RangeList*f); RangeList*lst(void)const; voidlst(RangeList*l); unsignedintholes; protected: IntVarImp(Space&home,boolshare,IntVarImp&x); public: IntVarImp(Space&home,intmin,intmax); IntVarImp(Space&home,constIntSet&d); intmin(void)const; intmax(void)const; intval(void)const; GECODE_INT_EXPORTintmed(void)const; unsignedintsize(void)const; unsignedintwidth(void)const; unsignedintregret_min(void)const; unsignedintregret_max(void)const; private: GECODE_INT_EXPORTboolin_full(intn)const; public: boolrange(void)const; boolassigned(void)const; boolin(intn)const; boolin(longlongintn)const; protected: constRangeList*ranges_fwd(void)const; constRangeList*ranges_bwd(void)const; private: boolcloser_min(intb)const; GECODE_INT_EXPORTModEventlq_full(Space&home,intn); GECODE_INT_EXPORTModEventgq_full(Space&home,intn); GECODE_INT_EXPORTModEventeq_full(Space&home,intn); GECODE_INT_EXPORTModEventnq_full(Space&home,intn); public: ModEventlq(Space&home,intn); ModEventlq(Space&home,longlongintn); ModEventgq(Space&home,intn); ModEventgq(Space&home,longlongintn); ModEventnq(Space&home,intn); ModEventnq(Space&home,longlongintn); ModEventeq(Space&home,intn); ModEventeq(Space&home,longlongintn); template<classI> ModEventnarrow_r(Space&home,I&i,booldepends=true); template<classI> ModEventinter_r(Space&home,I&i,booldepends=true); template<classI> ModEventminus_r(Space&home,I&i,booldepends=true); template<classI> ModEventnarrow_v(Space&home,I&i,booldepends=true); template<classI> ModEventinter_v(Space&home,I&i,booldepends=true); template<classI> ModEventminus_v(Space&home,I&i,booldepends=true); voidsubscribe(Space&home,Propagator&p,PropCondpc,boolschedule=true); voidcancel(Space&home,Propagator&p,PropCondpc); voidsubscribe(Space&home,Advisor&a); voidcancel(Space&home,Advisor&a); staticModEventDeltamed(ModEventme); private: GECODE_INT_EXPORTIntVarImp*perform_copy(Space&home,boolshare); public: IntVarImp*copy(Space&home,boolshare); staticintmin(constDelta&d); staticintmax(constDelta&d); staticboolany(constDelta&d); }; classIntVarImpFwd{ private: constIntVarImp::RangeList*p; constIntVarImp::RangeList*c; public: IntVarImpFwd(void); IntVarImpFwd(constIntVarImp*x); voidinit(constIntVarImp*x); booloperator ()(void)const; voidoperator ++(void); intmin(void)const; intmax(void)const; unsignedintwidth(void)const; }; classIntVarImpBwd{ private: constIntVarImp::RangeList*n; constIntVarImp::RangeList*c; public: IntVarImpBwd(void); IntVarImpBwd(constIntVarImp*x); voidinit(constIntVarImp*x); booloperator ()(void)const; voidoperator ++(void); intmin(void)const; intmax(void)const; unsignedintwidth(void)const; }; }} #include<gecode/int/var-imp/int.hpp> namespaceGecode{ classIntVar; classBoolVar; } namespaceGecode{namespaceInt{ typedefunsignedintBoolStatus; classBoolVarImp:publicBoolVarImpBase{ friendclass::Gecode::BoolVar; private: GECODE_INT_EXPORTstaticBoolVarImps_one; GECODE_INT_EXPORTstaticBoolVarImps_zero; BoolVarImp(Space&home,boolshare,BoolVarImp&x); BoolVarImp(intn); public: BoolVarImp(Space&home,intmin,intmax); staticconstintBITS=2; staticconstBoolStatusZERO=0; staticconstBoolStatusONE=3; staticconstBoolStatusNONE=2; BoolStatusstatus(void)const; intmin(void)const; intmax(void)const; intval(void)const; intmed(void)const; unsignedintsize(void)const; unsignedintwidth(void)const; unsignedintregret_min(void)const; unsignedintregret_max(void)const; boolzero(void)const; boolone(void)const; boolnone(void)const; boolrange(void)const; boolassigned(void)const; boolin(intn)const; boolin(longlongintn)const; ModEventlq(Space&home,intn); ModEventlq(Space&home,longlongintn); ModEventgq(Space&home,intn); ModEventgq(Space&home,longlongintn); ModEventnq(Space&home,intn); ModEventnq(Space&home,longlongintn); ModEventeq(Space&home,intn); ModEventeq(Space&home,longlongintn); template<classI> ModEventnarrow_r(Space&home,I&i,booldepends=true); template<classI> ModEventinter_r(Space&home,I&i,booldepends=true); template<classI> ModEventminus_r(Space&home,I&i,booldepends=true); template<classI> ModEventnarrow_v(Space&home,I&i,booldepends=true); template<classI> ModEventinter_v(Space&home,I&i,booldepends=true); template<classI> ModEventminus_v(Space&home,I&i,booldepends=true); ModEventzero(Space&home); ModEventone(Space&home); GECODE_INT_EXPORTModEventzero_none(Space&home); GECODE_INT_EXPORTModEventone_none(Space&home); public: voidsubscribe(Space&home,Propagator&p,PropCondpc,boolschedule=true); voidcancel(Space&home,Propagator&p,PropCondpc); voidsubscribe(Space&home,Advisor&a); voidcancel(Space&home,Advisor&a); staticvoidschedule(Space&home,Propagator&p,ModEventme); staticModEventDeltamed(ModEventme); staticModEventmodevent(constDelta&d); staticintmin(constDelta&d); staticintmax(constDelta&d); staticboolany(constDelta&d); staticboolzero(constDelta&d); staticboolone(constDelta&d); BoolVarImp*copy(Space&home,boolshare); }; }} #include<gecode/int/var-imp/bool.hpp> //STATISTICS:int-var