]> ruin.nu Git - germs.git/blob - src/model.cpp
More help output
[germs.git] / src / model.cpp
1 /***************************************************************************
2  *   Copyright (C) 2006 by Michael Andreen                                 *
3  *   andreen@student.chalmers.se                                           *
4  *                                                                         *
5  *   This program is free software; you can redistribute it and/or modify  *
6  *   it under the terms of the GNU General Public License as published by  *
7  *   the Free Software Foundation; either version 2 of the License, or     *
8  *   (at your option) any later version.                                   *
9  *                                                                         *
10  *   This program is distributed in the hope that it will be useful,       *
11  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
12  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
13  *   GNU General Public License for more details.                          *
14  *                                                                         *
15  *   You should have received a copy of the GNU General Public License     *
16  *   along with this program; if not, write to the                         *
17  *   Free Software Foundation, Inc.,                                       *
18  *   51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA          *
19  ***************************************************************************/
20
21 #include "model.h"
22 #include "models.h"
23
24 #include <stdexcept>
25
26 Model::Model(Models::ModelImpl* model): _impl(model){
27 }
28
29 double Model::score(const SortAction& sa, const GeneOrder& go) const{
30         return _impl->score(sa, go);
31 }
32
33 const char* Model::name() const{
34         return _impl->name();
35 }
36
37 bool operator<(const Model& lh,const Model& rh){
38         return &lh < &rh;
39 }
40
41 Model Model::modelFactory(const std::string& name){
42         if (name == "X"){
43                 return Model(new Models::X());
44         }else if(name == "Whirl"){
45                 return Model(new Models::Whirl());
46         }else if(name == "Standard"){
47                 return Model(new Models::ModelImpl());
48         }else if(name == "Zipper"){
49                 return Model(new Models::Zipper());
50         }else if(name == "FatX"){
51                 return Model(new Models::FatX());
52         }else if(name == "Cloud"){
53                 return Model(new Models::Cloud());
54         }
55         throw std::invalid_argument(name + " is not a valid model");
56 }