Trait
num_trait_params=8
genomestart 1
trait 1 0.1 0 0 0 0 0 0 0
trait 2 0.2 0 0 0 0 0 0 0
trait 3 0.3 0 0 0 0 0 0 0
node 1 0 1 3
node 2 0 1 1
node 3 0 1 1
node 4 0 0 2
gene 1 1 4 0.0 0 1 0 1
gene 2 2 4 0.0 0 2 0 1
gene 3 3 4 0.0 0 3 0 1
genomeend 1
////////////////////////////////////////////////////////////////////////////////////////
#ifndef _TRAIT_H_
#define _TRAIT_H_
#include <fstream>
#include "neat.h"
namespace NEAT {
// ------------------------------------------------------------------
// TRAIT: A Trait is a group of parameters that can be expressed
// as a group more than one time. Traits save a genetic
// algorithm from having to search vast parameter landscapes
// on every node. Instead, each node can simply point to a trait
// and those traits can evolve on their own
class Trait {
// ************ LEARNING PARAMETERS ***********
// The following parameters are for use in
// neurons that learn through habituation,
// sensitization, or Hebbian-type processes
public:
int trait_id; // Used in file saving and loading
double params[NEAT::num_trait_params]; // Keep traits in an array
Trait ();
Trait(int id,double p1,double p2,double p3,double p4,double p5,double p6,double p7,double p8,double p9);
// Copy Constructor
Trait(const Trait& t);
// Create a trait exactly like another trait
Trait(Trait *t);
// Special constructor off a file assume word "trait" has been read in
Trait(const char *argline);
// Special Constructor creates a new Trait which is the average of 2 existing traits passed in
Trait(Trait *t1,Trait *t2);
// Dump trait to a stream
void print_to_file(std::ostream &outFile);
void print_to_file(std::ofstream &outFile);
// Perturb the trait parameters slightly
void mutate();
};
} // namespace NEAT
#endif
///////////////////////////////////////////////////////////////////////////////////////
#include "trait.h"
#include <iostream>
#include <sstream>
using namespace NEAT;
Trait::Trait () {
for (int count=0;count<NEAT::num_trait_params;count++)
params[count]=0;
trait_id=0;
}
Trait::Trait(int id,double p1,double p2,double p3,double p4,double p5,double p6,double p7,double p8,double p9) {
trait_id=id;
params[0]=p1;
params[1]=p2;
params[2]=p3;
params[3]=p4;
params[4]=p5;
params[5]=p6;
params[6]=p7;
params[7]=0;
}
Trait::Trait(const Trait& t) {
for(int count=0; count < NEAT::num_trait_params; count++)
params[count]=(t.params)[count];
trait_id = t.trait_id;
}
Trait::Trait(Trait *t) {
for(int count=0;count<NEAT::num_trait_params;count++)
params[count]=(t->params)[count];
trait_id=t->trait_id;
}
Trait::Trait(const char *argline) {
std::stringstream ss(argline);
//Read in trait id
// std::string curword;
//char delimiters[] = " \n";
//int curwordnum = 0;
//strcpy(curword, NEAT::getUnit(argline, curwordnum++, delimiters));
// trait_id = atoi(curword);
ss >> trait_id;
//std::cout << ss.str() << " trait_id: " << trait_id << std::endl;
//IS THE STOPPING CONDITION CORRECT? ALERT
for(int count=0;count<NEAT::num_trait_params;count++) {
//strcpy(curword, NEAT::getUnit(argline, curwordnum++, delimiters));
//params[count] = atof(curword);
ss >> params[count];
//iFile>>params[count];
}
}
Trait::Trait(Trait *t1,Trait *t2) {
for(int count=0;count<NEAT::num_trait_params;count++)
params[count]=(((t1->params)[count])+((t2->params)[count]))/2.0;
trait_id=t1->trait_id;
}
void Trait::print_to_file(std::ofstream &outFile) {
outFile<<"trait "<<trait_id<<" ";
for(int count=0;count<NEAT::num_trait_params;count++)
outFile<<params[count]<<" ";
outFile<<std::endl;
}
void Trait::print_to_file(std::ostream &outFile) {
//outFile<<"trait "<<trait_id<<" ";
//for(int count=0;count<NEAT::num_trait_params;count++)
// outFile<<params[count]<<" ";
//outFile<<endl;
char tempbuf[128];
sprintf(tempbuf, "trait %d ", trait_id);
outFile << tempbuf;
for (int count = 0; count<NEAT::num_trait_params;count++) {
char tempbuf2[128];
sprintf(tempbuf2, "%f ", params[count]);
outFile << tempbuf2;
}
outFile << std::endl;
}
void Trait::mutate() {
for(int count=0;count<NEAT::num_trait_params;count++) {
if (randfloat()>NEAT::trait_param_mut_prob) {
params[count]+=(randposneg()*randfloat())*NEAT::trait_mutation_power;
if (params[count]<0) params[count]=0;
if (params[count]>1.0) params[count]=1.0;
}
}
}