/usr/include/ga/GAStringGenome.h is in libga-dev 2.4.7-3.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 | // $Header$
/* ----------------------------------------------------------------------------
string.h
mbwall 25feb95
Copyright (c) 1995 Massachusetts Institute of Technology
DESCRIPTION:
This header defines the interface for the string genome.
---------------------------------------------------------------------------- */
#ifndef _ga_string_h_
#define _ga_string_h_
#include <ga/GAAllele.h>
#include <ga/GA1DArrayGenome.h>
typedef GAAlleleSet<char> GAStringAlleleSet;
typedef GAAlleleSet<char> GACharacterAlleleSet;
typedef GAAlleleSetArray<char> GAStringAlleleSetArray;
typedef GA1DArrayAlleleGenome<char> GAStringGenome;
// in one (and only one) place in the code that uses the string genome, you
// should define INSTANTIATE_STRING_GENOME in order to force the specialization
// for this genome.
#if defined(INSTANTIATE_STRING_GENOME)
#include <ga/GAStringGenome.C>
#endif
inline void GAStringUniformInitializer(GAGenome& g){
GA1DArrayAlleleGenome<char>::UniformInitializer(g);
}
inline void GAStringOrderedInitializer(GAGenome& g){
GA1DArrayAlleleGenome<char>::OrderedInitializer(g);
}
inline int GAStringFlipMutator(GAGenome& g, float pmut){
return GA1DArrayAlleleGenome<char>::FlipMutator(g, pmut);
}
inline int GAStringSwapMutator(GAGenome& g, float pmut){
return GA1DArrayGenome<char>::SwapMutator(g, pmut);
}
inline int GAStringUniformCrossover(const GAGenome& a, const GAGenome& b,
GAGenome* c, GAGenome* d) {
return GA1DArrayGenome<char>::UniformCrossover(a,b,c,d);
}
inline int GAStringEvenOddCrossover(const GAGenome& a, const GAGenome& b,
GAGenome* c, GAGenome* d) {
return GA1DArrayGenome<char>::EvenOddCrossover(a,b,c,d);
}
inline int GAStringOnePointCrossover(const GAGenome& a, const GAGenome& b,
GAGenome* c, GAGenome* d) {
return GA1DArrayGenome<char>::OnePointCrossover(a,b,c,d);
}
inline int GAStringTwoPointCrossover(const GAGenome& a, const GAGenome& b,
GAGenome* c, GAGenome* d) {
return GA1DArrayGenome<char>::TwoPointCrossover(a,b,c,d);
}
inline int GAStringPartialMatchCrossover(const GAGenome& a, const GAGenome& b,
GAGenome* c, GAGenome* d) {
return GA1DArrayGenome<char>::PartialMatchCrossover(a,b,c,d);
}
inline int GAStringOrderCrossover(const GAGenome& a, const GAGenome& b,
GAGenome* c, GAGenome* d) {
return GA1DArrayGenome<char>::OrderCrossover(a,b,c,d);
}
inline int GAStringCycleCrossover(const GAGenome& a, const GAGenome& b,
GAGenome* c, GAGenome* d) {
return GA1DArrayGenome<char>::CycleCrossover(a,b,c,d);
}
#endif
|