source: tspsg/src/tspsolver.h @ bc1b8837b6

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

Started documenting the source code in doxygen format.

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