Generated on Mon Aug 25 11:35:36 2008 for Gecode by doxygen 1.5.6

circuit.cc

Go to the documentation of this file.
00001 /* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
00002 /*
00003  *  Main authors:
00004  *     Christian Schulte <schulte@gecode.org>
00005  *
00006  *  Copyright:
00007  *     Christian Schulte, 2007
00008  *
00009  *  Last modified:
00010  *     $Date: 2007-09-13 13:10:46 +0200 (Thu, 13 Sep 2007) $ by $Author: schulte $
00011  *     $Revision: 5022 $
00012  *
00013  *  This file is part of Gecode, the generic constraint
00014  *  development environment:
00015  *     http://www.gecode.org
00016  *
00017  *  Permission is hereby granted, free of charge, to any person obtaining
00018  *  a copy of this software and associated documentation files (the
00019  *  "Software"), to deal in the Software without restriction, including
00020  *  without limitation the rights to use, copy, modify, merge, publish,
00021  *  distribute, sublicense, and/or sell copies of the Software, and to
00022  *  permit persons to whom the Software is furnished to do so, subject to
00023  *  the following conditions:
00024  *
00025  *  The above copyright notice and this permission notice shall be
00026  *  included in all copies or substantial portions of the Software.
00027  *
00028  *  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
00029  *  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
00030  *  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
00031  *  NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
00032  *  LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
00033  *  OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
00034  *  WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
00035  *
00036  */
00037 
00038 #include "test/int.hh"
00039 
00040 namespace Test { namespace Int {
00041 
00043    namespace Circuit {
00044    
00050 
00051      class Circuit : public Test {
00052      public:
00054        Circuit(int n, int min, int max, Gecode::IntConLevel icl)
00055          : Test("Circuit::" + str(icl) + "::" + str(n),
00056                    n,min,max,false,icl) {
00057          testdomcon = false;
00058        }
00060        virtual bool solution(const Assignment& x) const {
00061          for (int i=x.size(); i--; )
00062            if ((x[i] < 0) || (x[i] > x.size()-1))
00063              return false;
00064          int reachable = 0;
00065          {
00066            int j=0;
00067            for (int i=x.size(); i--; ) {
00068              j=x[j]; reachable |= (1 << j);
00069            }
00070          }
00071          for (int i=x.size(); i--; )
00072            if (!(reachable & (1 << i)))
00073              return false;
00074          return true;
00075        }
00077        virtual void post(Gecode::Space* home, Gecode::IntVarArray& x) {
00078          circuit(home, x, icl);
00079        }
00080      };
00081    
00083      class Create {
00084      public:
00086        Create(void) {
00087          for (int i=1; i<=6; i++) {
00088            (void) new Circuit(i,0,i-1,Gecode::ICL_VAL);
00089            (void) new Circuit(i,0,i-1,Gecode::ICL_DOM);
00090          }
00091        }
00092      };
00093    
00094      Create c;
00096    
00097    }
00098 }}
00099 
00100 // STATISTICS: test-int