this repo has no description
1/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
2/*
3 * Main authors:
4 * Christian Schulte <schulte@gecode.org>
5 *
6 * Contributing authors:
7 * Guido Tack <tack@gecode.org>
8 *
9 * Copyright:
10 * Christian Schulte, 2004
11 * Guido Tack, 2004
12 *
13 * This file is part of Gecode, the generic constraint
14 * development environment:
15 * http://www.gecode.org
16 *
17 * Permission is hereby granted, free of charge, to any person obtaining
18 * a copy of this software and associated documentation files (the
19 * "Software"), to deal in the Software without restriction, including
20 * without limitation the rights to use, copy, modify, merge, publish,
21 * distribute, sublicense, and/or sell copies of the Software, and to
22 * permit persons to whom the Software is furnished to do so, subject to
23 * the following conditions:
24 *
25 * The above copyright notice and this permission notice shall be
26 * included in all copies or substantial portions of the Software.
27 *
28 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
29 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
30 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
31 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
32 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
33 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
34 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
35 *
36 */
37
38#ifndef GECODE_SEARCH_SEQ_BAB_HH
39#define GECODE_SEARCH_SEQ_BAB_HH
40
41#include <gecode/search.hh>
42#include <gecode/search/support.hh>
43#include <gecode/search/worker.hh>
44#include <gecode/search/seq/path.hh>
45
46namespace Gecode { namespace Search { namespace Seq {
47
48 /// Implementation of depth-first branch-and-bound search engine
49 template<class Tracer>
50 class BAB : public Worker {
51 private:
52 /// Search tracer
53 Tracer tracer;
54 /// Search options
55 Options opt;
56 /// Current path in search tree
57 Path<Tracer> path;
58 /// Current space being explored
59 Space* cur;
60 /// Distance until next clone
61 unsigned int d;
62 /// Number of entries not yet constrained to be better
63 int mark;
64 /// Best solution found so far
65 Space* best;
66 public:
67 /// Initialize with space \a s and search options \a o
68 BAB(Space* s, const Options& o);
69 /// %Search for next better solution
70 Space* next(void);
71 /// Return statistics
72 Statistics statistics(void) const;
73 /// Constrain future solutions to be better than \a b
74 void constrain(const Space& b);
75 /// Reset engine to restart at space \a s
76 void reset(Space* s);
77 /// Return no-goods
78 NoGoods& nogoods(void);
79 /// Destructor
80 ~BAB(void);
81 };
82
83}}}
84
85#include <gecode/search/seq/bab.hpp>
86
87#endif
88
89// STATISTICS: search-seq