view.hpp iostream gecode/set/var/set.hpp gecode/set/view/set.hpp gecode/set/view/const.hpp gecode/set/view/singleton.hpp gecode/set/view/complement.hpp gecode/set/view/cached.hpp gecode/set/view/print.hpp gecode/set/var/print.hpp /usr/include/gecode/set.hh Gecode::Set::SetView Gecode::Set::ConstSetView Gecode::Set::EmptyView Gecode::Set::UniverseView Gecode::Set::SingletonView Gecode::Set::ComplementView Gecode::Set::LubDiffRanges Gecode::Set::GlbDiffRanges Gecode::Set::CachedView Gecode::Set::GlbDiffRanges Gecode::Set::LubDiffRanges Gecode Gecode::Set /*-*-mode:C++;c-basic-offset:2;indent-tabs-mode:nil-*-*/ /* *Mainauthors: *GuidoTack<tack@gecode.org> * *Contributingauthors: *ChristianSchulte<schulte@gecode.org> * *Copyright: *GuidoTack,2004 *ChristianSchulte,2004 * *Lastmodified: *$Date:2011-08-1916:47:28+0200(Fri,19Aug2011)$by$Author:tack$ *$Revision:12318$ * *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<iostream> namespaceGecode{namespaceSet{ classSetView:publicVarImpView<SetVar>{ protected: usingVarImpView<SetVar>::x; public: SetView(void); SetView(constSetVar&y); SetView(SetVarImp*y); unsignedintcardMin(void)const; unsignedintcardMax(void)const; intlubMin(void)const; intlubMax(void)const; intlubMinN(unsignedintn)const; intglbMin(void)const; intglbMax(void)const; unsignedintglbSize(void)const; unsignedintlubSize(void)const; unsignedintunknownSize(void)const; boolcontains(inti)const; boolnotContains(inti)const; ModEventcardMin(Space&home,unsignedintm); ModEventcardMax(Space&home,unsignedintm); ModEventinclude(Space&home,inti,intj); ModEventexclude(Space&home,inti,intj); ModEventinclude(Space&home,inti); ModEventexclude(Space&home,inti); ModEventintersect(Space&home,inti,intj); ModEventintersect(Space&home,inti); template<classI>ModEventexcludeI(Space&home,I&i); template<classI>ModEventincludeI(Space&home,I&i); template<classI>ModEventintersectI(Space&home,I&iter); staticModEventmodevent(constDelta&d); intglbMin(constDelta&d)const; intglbMax(constDelta&d)const; boolglbAny(constDelta&d)const; intlubMin(constDelta&d)const; intlubMax(constDelta&d)const; boollubAny(constDelta&d)const; }; template<classChar,classTraits> std::basic_ostream<Char,Traits>& operator<<(std::basic_ostream<Char,Traits>&os,constSetView&x); //Forwarddeclarationsforfriends classConstSetView; boolsame(constConstSetView&,constConstSetView&); boolbefore(constConstSetView&,constConstSetView&); classConstSetView:publicConstView<SetView>{ friendclassLubRanges<ConstSetView>; friendclassGlbRanges<ConstSetView>; friendboolGecode::Set::same(constGecode::Set::ConstSetView&, constGecode::Set::ConstSetView&); friendboolGecode::Set::before(constGecode::Set::ConstSetView&, constGecode::Set::ConstSetView&); private: int*ranges; intsize; unsignedintdomSize; public: ConstSetView(void); ConstSetView(Space&home,constIntSet&s); unsignedintcardMin(void)const; unsignedintcardMax(void)const; intlubMin(void)const; intlubMax(void)const; intlubMinN(unsignedintn)const; intglbMin(void)const; intglbMax(void)const; unsignedintglbSize(void)const; unsignedintlubSize(void)const; unsignedintunknownSize(void)const; boolcontains(inti)const; boolnotContains(inti)const; ModEventcardMin(Space&home,unsignedintm); ModEventcardMax(Space&home,unsignedintm); ModEventinclude(Space&home,inti,intj); ModEventexclude(Space&home,inti,intj); ModEventinclude(Space&home,inti); ModEventexclude(Space&home,inti); ModEventintersect(Space&home,inti,intj); ModEventintersect(Space&home,inti); template<classI>ModEventexcludeI(Space&home,I&i); template<classI>ModEventincludeI(Space&home,I&i); template<classI>ModEventintersectI(Space&home,I&iter); voidupdate(Space&home,boolshare,ConstSetView&y); intglbMin(constDelta&d)const; intglbMax(constDelta&d)const; boolglbAny(constDelta&d)const; intlubMin(constDelta&d)const; intlubMax(constDelta&d)const; boollubAny(constDelta&d)const; }; template<classChar,classTraits> std::basic_ostream<Char,Traits>& operator<<(std::basic_ostream<Char,Traits>&os,constConstSetView&x); boolsame(constConstSetView&x,constConstSetView&y); boolbefore(constConstSetView&x,constConstSetView&y); classEmptyView:publicConstView<SetView>{ public: EmptyView(void); unsignedintcardMin(void)const; unsignedintcardMax(void)const; intlubMin(void)const; intlubMax(void)const; intlubMinN(unsignedintn)const; intglbMin(void)const; intglbMax(void)const; unsignedintglbSize(void)const; unsignedintlubSize(void)const; unsignedintunknownSize(void)const; boolcontains(inti)const; boolnotContains(inti)const; ModEventcardMin(Space&home,unsignedintm); ModEventcardMax(Space&home,unsignedintm); ModEventinclude(Space&home,inti,intj); ModEventexclude(Space&home,inti,intj); ModEventinclude(Space&home,inti); ModEventexclude(Space&home,inti); ModEventintersect(Space&home,inti,intj); ModEventintersect(Space&home,inti); template<classI>ModEventexcludeI(Space&home,I&i); template<classI>ModEventincludeI(Space&home,I&i); template<classI>ModEventintersectI(Space&home,I&iter); intglbMin(constDelta&d)const; intglbMax(constDelta&d)const; boolglbAny(constDelta&d)const; intlubMin(constDelta&d)const; intlubMax(constDelta&d)const; boollubAny(constDelta&d)const; }; template<classChar,classTraits> std::basic_ostream<Char,Traits>& operator<<(std::basic_ostream<Char,Traits>&os,constEmptyView&x); boolsame(constEmptyView&x,constEmptyView&y); classUniverseView:publicConstView<SetView>{ public: UniverseView(void); unsignedintcardMin(void)const; unsignedintcardMax(void)const; intlubMin(void)const; intlubMax(void)const; intlubMinN(unsignedintn)const; intglbMin(void)const; intglbMax(void)const; unsignedintglbSize(void)const; unsignedintlubSize(void)const; unsignedintunknownSize(void)const; boolcontains(inti)const; boolnotContains(inti)const; ModEventcardMin(Space&home,unsignedintm); ModEventcardMax(Space&home,unsignedintm); ModEventinclude(Space&home,inti,intj); ModEventexclude(Space&home,inti,intj); ModEventinclude(Space&home,inti); ModEventexclude(Space&home,inti); ModEventintersect(Space&home,inti,intj); ModEventintersect(Space&home,inti); template<classI>ModEventexcludeI(Space&home,I&i); template<classI>ModEventincludeI(Space&home,I&i); template<classI>ModEventintersectI(Space&home,I&iter); intglbMin(constDelta&d)const; intglbMax(constDelta&d)const; boolglbAny(constDelta&d)const; intlubMin(constDelta&d)const; intlubMax(constDelta&d)const; boollubAny(constDelta&d)const; }; template<classChar,classTraits> std::basic_ostream<Char,Traits>& operator<<(std::basic_ostream<Char,Traits>&os,constUniverseView&x); boolsame(constUniverseView&x,constUniverseView&y); classSingletonView: publicDerivedView<Gecode::Int::IntView>{ protected: usingDerivedView<Gecode::Int::IntView>::x; staticPropCondpc_settoint(PropCondpc); staticModEventme_inttoset(ModEventme); staticModEventme_settoint(ModEventme); public: SingletonView(void); SingletonView(Gecode::Int::IntView&y); SingletonView(constGecode::IntVar&y); unsignedintcardMin(void)const; unsignedintcardMax(void)const; intlubMin(void)const; intlubMax(void)const; intlubMinN(unsignedintn)const; intglbMin(void)const; intglbMax(void)const; unsignedintglbSize(void)const; unsignedintlubSize(void)const; unsignedintunknownSize(void)const; boolcontains(inti)const; boolnotContains(inti)const; ModEventcardMin(Space&home,unsignedintm); ModEventcardMax(Space&home,unsignedintm); ModEventinclude(Space&home,inti,intj); ModEventexclude(Space&home,inti,intj); ModEventinclude(Space&home,inti); ModEventexclude(Space&home,inti); ModEventintersect(Space&home,inti,intj); ModEventintersect(Space&home,inti); template<classI>ModEventexcludeI(Space&home,I&i); template<classI>ModEventincludeI(Space&home,I&i); template<classI>ModEventintersectI(Space&home,I&iter); staticvoidschedule(Space&home,Propagator&p,ModEventme); staticModEventme(constModEventDelta&med); staticModEventDeltamed(ModEvent); voidsubscribe(Space&home,Propagator&p,PropCondpc,boolschedule=true); voidcancel(Space&home,Propagator&p,PropCondpc); voidsubscribe(Space&home,Advisor&a); voidcancel(Space&home,Advisor&a); staticModEventmodevent(constDelta&d); intglbMin(constDelta&d)const; intglbMax(constDelta&d)const; boolglbAny(constDelta&d)const; intlubMin(constDelta&d)const; intlubMax(constDelta&d)const; boollubAny(constDelta&d)const; }; template<classChar,classTraits> std::basic_ostream<Char,Traits>& operator<<(std::basic_ostream<Char,Traits>&os,constSingletonView&x); template<classView> classComplementView :publicDerivedView<View>{ protected: usingDerivedView<View>::x; public: staticPropCondpc_negateset(PropCondpc); staticModEventme_negateset(ModEventme); ComplementView(void); explicitComplementView(View&y); unsignedintcardMin(void)const; unsignedintcardMax(void)const; intlubMin(void)const; intlubMax(void)const; intlubMinN(unsignedintn)const; intglbMin(void)const; intglbMax(void)const; unsignedintglbSize(void)const; unsignedintlubSize(void)const; unsignedintunknownSize(void)const; boolcontains(inti)const; boolnotContains(inti)const; ModEventcardMin(Space&home,unsignedintm); ModEventcardMax(Space&home,unsignedintm); ModEventinclude(Space&home,inti,intj); ModEventexclude(Space&home,inti,intj); ModEventinclude(Space&home,inti); ModEventexclude(Space&home,inti); ModEventintersect(Space&home,inti,intj); ModEventintersect(Space&home,inti); template<classI>ModEventexcludeI(Space&home,I&i); template<classI>ModEventincludeI(Space&home,I&i); template<classI>ModEventintersectI(Space&home,I&iter); staticvoidschedule(Space&home,Propagator&p,ModEventme); staticModEventme(constModEventDelta&med); staticModEventDeltamed(ModEvent); voidsubscribe(Space&home,Propagator&p,PropCondpc,boolschedule=true); voidcancel(Space&home,Propagator&p,PropCondpc); voidsubscribe(Space&home,Advisor&a); voidcancel(Space&home,Advisor&a); staticModEventmodevent(constDelta&d); intglbMin(constDelta&d)const; intglbMax(constDelta&d)const; boolglbAny(constDelta&d)const; intlubMin(constDelta&d)const; intlubMax(constDelta&d)const; boollubAny(constDelta&d)const; }; template<classChar,classTraits,classView> std::basic_ostream<Char,Traits>& operator<<(std::basic_ostream<Char,Traits>&os, constComplementView<View>&x); template<classView>classLubDiffRanges; template<classView>classGlbDiffRanges; template<classView> classCachedView :publicDerivedView<View>{ friendclassLubDiffRanges<View>; friendclassGlbDiffRanges<View>; protected: usingDerivedView<View>::x; LUBndSetlubCache; GLBndSetglbCache; public: CachedView(void); explicitCachedView(constView&y); unsignedintcardMin(void)const; unsignedintcardMax(void)const; intlubMin(void)const; intlubMax(void)const; intlubMinN(unsignedintn)const; intglbMin(void)const; intglbMax(void)const; unsignedintglbSize(void)const; unsignedintlubSize(void)const; unsignedintunknownSize(void)const; boolcontains(inti)const; boolnotContains(inti)const; ModEventcardMin(Space&home,unsignedintm); ModEventcardMax(Space&home,unsignedintm); ModEventinclude(Space&home,inti,intj); ModEventexclude(Space&home,inti,intj); ModEventinclude(Space&home,inti); ModEventexclude(Space&home,inti); ModEventintersect(Space&home,inti,intj); ModEventintersect(Space&home,inti); template<classI>ModEventexcludeI(Space&home,I&i); template<classI>ModEventincludeI(Space&home,I&i); template<classI>ModEventintersectI(Space&home,I&iter); staticvoidschedule(Space&home,Propagator&p,ModEventme); staticModEventme(constModEventDelta&med); staticModEventDeltamed(ModEvent); voidsubscribe(Space&home,Propagator&p,PropCondpc,boolschedule=true); voidcancel(Space&home,Propagator&p,PropCondpc); voidsubscribe(Space&home,Advisor&a); voidcancel(Space&home,Advisor&a); staticModEventmodevent(constDelta&d); intglbMin(constDelta&d)const; intglbMax(constDelta&d)const; boolglbAny(constDelta&d)const; intlubMin(constDelta&d)const; intlubMax(constDelta&d)const; boollubAny(constDelta&d)const; voidinitCache(Space&home,constIntSet&glb,constIntSet&lub); voidcacheGlb(Space&home); voidcacheLub(Space&home); boolglbModified(void)const; boollubModified(void)const; voidupdate(Space&home,boolshare,CachedView<View>&y); }; template<classChar,classTraits,classView> std::basic_ostream<Char,Traits>& operator<<(std::basic_ostream<Char,Traits>&os, constCachedView<View>&x); template<classView> classGlbDiffRanges :publicIter::Ranges::Diff<GlbRanges<View>,BndSetRanges>{ protected: GlbRanges<View>gr; BndSetRangescr; public: GlbDiffRanges(constCachedView<View>&x); }; template<classView> classLubDiffRanges :publicIter::Ranges::Diff<BndSetRanges,LubRanges<View>>{ protected: BndSetRangescr; LubRanges<View>lr; public: LubDiffRanges(constCachedView<View>&x); }; }} #include<gecode/set/var/set.hpp> #include<gecode/set/view/set.hpp> #include<gecode/set/view/const.hpp> #include<gecode/set/view/singleton.hpp> #include<gecode/set/view/complement.hpp> #include<gecode/set/view/cached.hpp> #include<gecode/set/view/print.hpp> #include<gecode/set/var/print.hpp> //STATISTICS:set-var