1
0
This repository has been archived on 2025-03-06. You can view files and clone it, but cannot push or open issues or pull requests.
Jip J. Dekker 981be2067e Squashed 'software/gecode_on_replay/' content from commit 8051d92b9
git-subtree-dir: software/gecode_on_replay
git-subtree-split: 8051d92b9c89e49cccfbd1c201371580d7703ab4
2021-06-16 14:04:29 +10:00

67 lines
2.7 KiB
C++

/**** , [ qsolver.hh ],
Copyright (c) 2010 Universite de Caen-Basse Normandie - Jeremie Vautard
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
*************************************************************************/
#ifndef __QECODE_QSOLVER_QCSP__
#define __QECODE_QSOLVER_QCSP__
#include "QCOPPlus.hh"
#include <iostream>
#include <cstdlib>
#include "gecode/minimodel.hh"
#include "gecode/search.hh"
#include "gecode/search/support.hh"
#include "gecode/search/sequential/dfs.hh"
#include <climits>
#include "Strategy.hh"
#include "qecode.hh"
using namespace std;
using namespace Gecode::Support;
using namespace Gecode::Search;
using namespace Gecode::Search::Sequential;
/** General QCSP+ / QCOP+ Solver.
* This class is the search engine for Qcop objects.
*/
class QECODE_VTABLE_EXPORT QCSP_Solver {
private:
unsigned int limit;
int n;
Qcop* sp;
int* nbRanges;
Strategy rSolve(Qcop* qs,int scope,Engine* L,unsigned long int& nodes,bool allStrategies);
public:
/** Public constructor.
@param sp The problem to solve
*/
QECODE_EXPORT QCSP_Solver(Qcop* sp);
/** Solves the problem and returns a corresponding winning strategy.
@param nodes : A reference that is increased by the number of nodes encountered in the search tree.
@param limit : limit of the depth of the Strategy object returned. Any branch longer than this limit will be truncated.
@param allStrategies : indicate if the solver should return only one winning strategy, or all of them (condensed in one Strategy object, where existential nodes will not be unique)
*/
QECODE_EXPORT Strategy solve(unsigned long int& nodes,unsigned int limit=INT_MAX,bool allStrategies=false);
};
#endif