Ignore:
Timestamp:
02/28/18 23:43:57 (6 years ago)
Author:
Maciej Komosinski
Message:

Mutation in the 'fn' encoding respects custom min,max,stddev for each variable

File:
1 edited

Legend:

Unmodified
Added
Removed
  • cpp/frams/genetics/fn/conv_fn.cpp

    r747 r752  
    2929vector<double> GenoConv_fn0::stringToVector(const char *input) //returns empty vector on error
    3030{
    31         vector<double> output;
     31        vector<double> empty;
    3232        ExtValue val;
    3333        const char* after_des = val.deserialize(input);
    34         if (after_des == NULL) // deserialization failed
     34        if (after_des == NULL) //deserialization failed
    3535        {
    36                 logPrintf("fn", "stringToVector", LOG_ERROR, "Unable to deserialize - expecting a vector of real values, got '%s'", input);
    37                 return output;
     36                logPrintf("GenoConv_fn0", "stringToVector", LOG_ERROR, "Unable to deserialize - expecting a vector of real values, got '%s'", input);
     37                return empty;
    3838        }
    39         if (after_des[0] != '\0') // not everything was consumed
     39        if (after_des[0] != '\0') //not everything was consumed
    4040        {
    41                 logPrintf("fn", "stringToVector", LOG_ERROR, "Extra characters after deserialized '%s'", input);
    42                 return output;
     41                logPrintf("GenoConv_fn0", "stringToVector", LOG_ERROR, "Extra characters after deserialized '%s'", input);
     42                return empty;
    4343        }
    4444
     
    4646        if (vec)
    4747        {
     48                vector<double> output;
    4849                for (int i = 0; i < vec->data.size(); i++)
    4950                {
     
    5152                        if (val == NULL)
    5253                        {
    53                                 logPrintf("fn", "stringToVector", LOG_ERROR, "Expecting a real value in a vector, got NULL");
     54                                logPrintf("GenoConv_fn0", "stringToVector", LOG_ERROR, "Expecting a real value in a vector, got NULL");
     55                                return empty;
    5456                        }
    5557                        else
    5658                                output.push_back(val->getDouble());
    5759                }
     60                return output;
    5861        }
    5962        else
    6063        {
    61                 logPrintf("fn", "stringToVector", LOG_ERROR, "Expecting a vector of real values, got '%s'", input);
     64                logPrintf("GenoConv_fn0", "stringToVector", LOG_ERROR, "Expecting a vector of real values, got '%s'", input);
     65                return empty;
    6266        }
    63         return output;
    6467}
    6568
Note: See TracChangeset for help on using the changeset viewer.