GA - 1.4.5
Utilities
Configuration
GA
NNFW
WorldSim
Total 99%
Experiments
Main Page
Related Pages
Modules
Classes
Files
File List
ga
include
genotypes
signedrangegenotype.h
1
/********************************************************************************
2
* FARSA Genetic Algorithm Library *
3
* Copyright (C) 2007-2008 Gianluca Massera <emmegian@yahoo.it> *
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 Free Software *
17
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA *
18
********************************************************************************/
19
20
#ifndef SIGNEDRANGEGENOTYPE_H
21
#define SIGNEDRANGEGENOTYPE_H
22
23
#include "
gaconfig.h
"
24
#include "genotypes/doublegenotype.h"
25
26
namespace
farsa {
27
39
class
FARSA_GA_API
SignedRangeGenotype
:
public
DoubleGenotype
{
40
public
:
50
SignedRangeGenotype
(
unsigned
int
numGenes = 0,
double
max
= +1,
unsigned
int
bitPrecision = 8 );
52
virtual
~
SignedRangeGenotype
();
54
SignedRangeGenotype
(
const
SignedRangeGenotype
& genotype );
56
virtual
SignedRangeGenotype
& operator=(
const
Genotype
& genotype );
58
virtual
double
at(
unsigned
int
i )
const
;
60
virtual
void
set
(
unsigned
int
i,
double
value );
67
virtual
void
configure(
ConfigurationParameters
& params, QString prefix );
74
virtual
void
save(
ConfigurationParameters
& params, QString prefix );
76
static
void
describe( QString type );
78
virtual
SignedRangeGenotype
* clone()
const
;
79
private
:
81
double
dx;
82
};
83
84
}
// end namespace farsa
85
86
#endif