int-gq.hpp gecode/int/rel.hh gecode/int/distinct.hh /usr/include/gecode/int/nvalues.hh Gecode Gecode::Int Gecode::Int::NValues /*-*-mode:C++;c-basic-offset:2;indent-tabs-mode:nil-*-*/ /* *Mainauthors: *ChristianSchulte<schulte@gecode.org> * *Copyright: *ChristianSchulte,2011 * *Lastmodified: *$Date:2012-09-0717:31:22+0200(Fri,07Sep2012)$by$Author:schulte$ *$Revision:13068$ * *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<gecode/int/rel.hh> #include<gecode/int/distinct.hh> namespaceGecode{namespaceInt{namespaceNValues{ template<classVY> forceinline GqInt<VY>::GqInt(Homehome,ValSet&vs,ViewArray<IntView>&x,VYy) :IntBase<VY>(home,vs,x,y){} template<classVY> inlineExecStatus GqInt<VY>::post(Homehome,ViewArray<IntView>&x,VYy){ if(x.size()==0){ GECODE_ME_CHECK(y.lq(home,0)); returnES_OK; } x.unique(home); if(x.size()==1){ GECODE_ME_CHECK(y.lq(home,1)); returnES_OK; } GECODE_ME_CHECK(y.lq(home,x.size())); if(y.max()<=1) returnES_OK; if(y.min()==x.size()){ assert(y.assigned()); returnDistinct::Dom<IntView>::post(home,x); } //Eliminateassignedviewsandstorethemintothevalueset ValSetvs; intn=x.size(); for(inti=n;i--;) if(x[i].assigned()){ vs.add(home,x[i].val()); x[i]=x[--n]; } GECODE_ME_CHECK(y.lq(home,n+vs.size())); if(n==0){ assert(vs.size()>=y.max()); returnES_OK; } x.size(n); (void)new(home)GqInt<VY>(home,vs,x,y); returnES_OK; } template<classVY> forceinline GqInt<VY>::GqInt(Space&home,boolshare,GqInt<VY>&p) :IntBase<VY>(home,share,p){} template<classVY> Propagator* GqInt<VY>::copy(Space&home,boolshare){ returnnew(home)GqInt<VY>(home,share,*this); } template<classVY> ExecStatus GqInt<VY>::propagate(Space&home,constModEventDelta&med){ if(IntView::me(med)==ME_INT_VAL) add(home); //Eliminatesubsumedviews eliminate(home); GECODE_ME_CHECK(y.lq(home,x.size()+vs.size())); if(x.size()==0) returnhome.ES_SUBSUMED(*this); if(vs.size()>=y.max()) returnhome.ES_SUBSUMED(*this); GECODE_ES_CHECK(prune_upper(home,g)); returnES_NOFIX; } }}} //STATISTICS:int-prop