Running a fixed point ANN is done much like running an ordinary ANN. The difference is that the inputs and outputs should be in fixed point
representation. Furthermore the inputs should be restricted to be between -multiplier and multiplier to
avoid integer overflow, where the multiplier is the value returned from
fann_get_multiplier
. This multiplier is the value that a floating point number should
be multiplied with, in order to be a fixed point number, likewise the output of the ANN should be divided by this multiplier in order to be between zero
and one.
To help using fixed point numbers, another function is provided.
fann_get_decimal_point
which returns the decimal point. The decimal point is the
position dividing the integer and fractional part of the fixed point number and is useful for doing operations on the fixed point inputs and outputs.
Example 3-2. An example of a program written to support both fixed point and floating point numbers
#include <time.h> #include <sys/time.h> #include <stdio.h> #include "fann.h" int main() { fann_type *calc_out; unsigned int i; int ret = 0; struct fann *ann; struct fann_train_data *data; printf("Creating network.\n"); #ifdef FIXEDFANN ann = fann_create_from_file("xor_fixed.net"); #else ann = fann_create_from_file("xor_float.net"); #endif if(!ann){ printf("Error creating ann --- ABORTING.\n"); return 0; } printf("Testing network.\n"); #ifdef FIXEDFANN data = fann_read_train_from_file("xor_fixed.data"); #else data = fann_read_train_from_file("xor.data"); #endif for(i = 0; i < data->num_data; i++){ fann_reset_MSE(ann); calc_out = fann_test(ann, data->input[i], data->output[i]); #ifdef FIXEDFANN printf("XOR test (%d, %d) -> %d, should be %d, difference=%f\n", data->input[i][0], data->input[i][1], *calc_out, data->output[i][0], (float)fann_abs(*calc_out - data->output[i][0])/fann_get_multiplier(ann)); if((float)fann_abs(*calc_out - data->output[i][0])/fann_get_multiplier(ann) > 0.1){ printf("Test failed\n"); ret = -1; } #else printf("XOR test (%f, %f) -> %f, should be %f, difference=%f\n", data->input[i][0], data->input[i][1], *calc_out, data->output[i][0], (float)fann_abs(*calc_out - data->output[i][0])); #endif } printf("Cleaning up.\n"); fann_destroy_train(data); fann_destroy(ann); return ret; }