1 /***************************************************************************
2 * Copyright (C) 2006 by Michael Andreen *
3 * andreen@student.chalmers.se *
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. *
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. *
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 ***************************************************************************/
26 Model::Model(Models::ModelImpl* model): _impl(model){
29 double Model::score(const SortAction& sa, const GeneOrder& go) const{
30 return _impl->score(sa, go);
33 const char* Model::name() const{
37 bool operator<(const Model& lh,const Model& rh){
41 Model Model::modelFactory(const std::string& name){
43 return Model(new Models::X());
44 }else if(name == "Whirl" || name == "Standard"){
45 return Model(new Models::ModelImpl());
46 }else if(name == "Zipper"){
47 return Model(new Models::Zipper());
48 }else if(name == "FatX"){
49 return Model(new Models::FatX());
50 }else if(name == "Cloud"){
51 return Model(new Models::Cloud());
53 throw std::invalid_argument(name + " is not a valid model");