// @(#)root/tmva $Id: GeneticRange.cxx 20882 2007-11-19 11:31:26Z rdm $ // Author: Peter Speckmayer /********************************************************************************** * Project: TMVA - a Root-integrated toolkit for multivariate data analysis * * Package: TMVA * * Class : TMVA::GeneticRange * * Web : http://tmva.sourceforge.net * * * * Description: * * Implementation (see header for description) * * * * Authors (alphabetical): * * Peter Speckmayer <speckmay@mail.cern.ch> - CERN, Switzerland * * * * Copyright (c) 2005: * * CERN, Switzerland * * MPI-K Heidelberg, Germany * * * * Redistribution and use in source and binary forms, with or without * * modification, are permitted according to the terms listed in LICENSE * * (http://tmva.sourceforge.net/LICENSE) * * * * File and Version Information: * **********************************************************************************/ //_______________________________________________________________________ // // Range definition for genetic algorithm //_______________________________________________________________________ #include "TMVA/GeneticRange.h" #include "Riostream.h" ClassImp(TMVA::GeneticRange) //_______________________________________________________________________ TMVA::GeneticRange::GeneticRange( TRandom *rnd, Interval *interval ) { // defines the "f" (from) and "t" (to) of the coefficient // and takes a randomgenerator // fInterval = interval; fFrom = fInterval->GetMin(); fTo = fInterval->GetMax(); fNbins= fInterval->GetNbins(); fTotalLength = fTo-fFrom; fRandomGenerator = rnd; } //_______________________________________________________________________ Double_t TMVA::GeneticRange::RandomDiscrete() { // creates a new random value for the coefficient; returns a discrete value // Double_t value = fRandomGenerator->Uniform(0, 1); return fInterval->GetElement( Int_t(value*fNbins) ); } //_______________________________________________________________________ Double_t TMVA::GeneticRange::Random( Bool_t near, Double_t value, Double_t spread, Bool_t mirror ) { // creates a new random value for the coefficient // Parameters: // bool near : takes a random value near the current value // double value : this is the current value // double spread : the sigma of the gaussian which is taken to calculate the new value // bool mirror : if the new value would be outside of the range, mirror = false // maps the value between the constraints by periodic boundary conditions. // With mirror = true, the value gets "reflected" on the boundaries. // if (fInterval->GetNbins() > 0) { // discrete interval return RandomDiscrete(); } else if (fFrom == fTo) { return fFrom; } else if (near) { Double_t ret; ret = fRandomGenerator->Gaus( value, fTotalLength*spread ); if (mirror ) return ReMapMirror( ret ); else return ReMap( ret ); } return fRandomGenerator->Uniform(fFrom, fTo); } //_______________________________________________________________________ Double_t TMVA::GeneticRange::ReMap( Double_t val ) { // remapping the value to the allowed space // if (fFrom >= fTo ) return val; if (val < fFrom ) return ReMap( (val-fFrom) + fTo ); if (val >= fTo ) return ReMap( (val-fTo) + fFrom ); return val; } //_______________________________________________________________________ Double_t TMVA::GeneticRange::ReMapMirror( Double_t val ) { // remapping the value to the allowed space by reflecting on the // boundaries if (fFrom >= fTo ) return val; if (val < fFrom ) return ReMap( fFrom - (val-fFrom) ); if (val >= fTo ) return ReMap( fTo - (val-fTo) ); return val; } //_______________________________________________________________________ TMVA::GeneticRange::~GeneticRange() { // destructor }