source: tspsg/src/tspsolver.h @ caef58b531

0.1.3.145-beta1-symbian0.1.4.170-beta2-bb10appveyorimgbotreadme
Last change on this file since caef58b531 was caef58b531, checked in by Oleksii Serdiuk, 15 years ago

More code documentation.

  • Property mode set to 100644
File size: 2.6 KB
RevLine 
[caef58b531]1/*!
2 * \class CTSPSolver
3 * \author Copyright &copy; 2007-2009 Lёppa <contacts[at]oleksii[dot]name>
4 * \brief This class solves Travelling Salesman Problem task.
[67e53c96d7]5 *
6 *  $Id$
7 *  $URL$
8 *
[caef58b531]9 *  <b>TSPSG: TSP Solver and Generator</b>
10 *
[67e53c96d7]11 *  This file is part of TSPSG.
12 *
13 *  TSPSG is free software: you can redistribute it and/or modify
14 *  it under the terms of the GNU General Public License as published by
15 *  the Free Software Foundation, either version 3 of the License, or
16 *  (at your option) any later version.
17 *
18 *  TSPSG is distributed in the hope that it will be useful,
19 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
20 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21 *  GNU General Public License for more details.
22 *
23 *  You should have received a copy of the GNU General Public License
24 *  along with TSPSG.  If not, see <http://www.gnu.org/licenses/>.
[caef58b531]25 *
26 * \todo TODO: Deletion of solution tree on destroy and cleanup.
[67e53c96d7]27 */
28
29#ifndef TSPSOLVER_H
30#define TSPSOLVER_H
31
[993d5af6f6]32#include "globals.h"
[67e53c96d7]33
[bc1b8837b6]34#include "tspmodel.h"
35
[caef58b531]36//! A matrix of city-to-city travel costs.
[9aa0e521ed]37typedef QList<QList<double> > tMatrix;
[e664262f7d]38
[caef58b531]39/*!
40 * \brief This structure represents one step of solving.
41 *
42 *  A tree of such elements will represent the solving process.
43 */
44//! \todo TODO: List alternative candidates.
[67e53c96d7]45struct sStep {
[caef58b531]46        tMatrix matrix; //!< This step's matrix
47        double price; //!< The price of travel to this step
48        struct {
49                int nRow; //!< A zero-based row number of the candidate
50                int nCol; //!< A zero-based column number of the candidate
51        } candidate; //!< A candiadate for branching in the current matrix
52        bool alts; //!< Indicates whether or not matrix has alternative candidates
53        sStep *plNode; //!< Pointer to the left branch step
54        sStep *prNode; //!< Pointer to the right branch step
55
56        //! Assigns default values
57        sStep() {
58                price = candidate.nRow = candidate.nCol = -1;
59                alts = false;
60                plNode = prNode = NULL;
61        }
[67e53c96d7]62};
63
64class CTSPSolver
65{
[430bd7f7e9]66        Q_DECLARE_TR_FUNCTIONS(CTSPSolver)
67
[67e53c96d7]68public:
69        CTSPSolver();
[9cf98b9bd6]70        QString getSortedPath() const;
71        bool isOptimal() const;
[430bd7f7e9]72        sStep *solve(int, tMatrix, QWidget *parent = 0);
[55c4b858e9]73        static QString getVersionId();
[430bd7f7e9]74
[e664262f7d]75private:
[9cf98b9bd6]76        bool mayNotBeOptimal;
[e664262f7d]77        int nCities;
78        sStep *root;
[430bd7f7e9]79        QHash<int,int> route;
[aaf2113307]80//      QHash<int,int> forbidden;
[430bd7f7e9]81        double align(tMatrix &);
82        void cleanup();
[9cf98b9bd6]83        bool findCandidate(tMatrix, int &, int &);
[430bd7f7e9]84        double findMinInRow(int, tMatrix, int exc = -1);
85        double findMinInCol(int, tMatrix, int exr = -1);
86        bool hasSubCycles(int, int);
87        void subCol(tMatrix &, int, double);
88        void subRow(tMatrix &, int, double);
[67e53c96d7]89};
90
91#endif // TSPSOLVER_H
Note: See TracBrowser for help on using the repository browser.