2018-04-26 16:39:47 +02:00
//
2018-05-11 11:30:17 +02:00
//
2018-05-02 09:44:53 +02:00
// NLMSvariants.c
2018-04-26 16:39:47 +02:00
//
2018-04-30 14:38:28 +02:00
// Created by FBRDNLMS on 26.04.18.
2018-05-11 11:30:17 +02:00
//
2018-04-26 16:39:47 +02:00
//
# include <stdio.h>
# include <math.h>
# include <time.h>
# include <stdlib.h>
# include <string.h>
2018-05-03 18:30:42 +02:00
# include <float.h> // DBL_MAX
2018-04-26 16:39:47 +02:00
2018-05-11 11:30:17 +02:00
# define NUMBER_OF_SAMPLES 1000
# define WINDOWSIZE 5
2018-04-30 14:38:28 +02:00
# define tracking 40 //Count of weights
2018-05-11 11:30:17 +02:00
# define learnrate 0.8
2018-05-03 18:30:42 +02:00
# define PURE_WEIGHTS 0
# define USED_WEIGHTS 1
2018-05-04 16:30:12 +02:00
# define RESULTS 3
# define DIRECT_PREDECESSOR 2
# define LOCAL_MEAN 4
2018-05-07 22:39:31 +02:00
# define TEST_VALUES 5
2018-05-11 11:30:17 +02:00
# define DIFFERENTIAL_PREDECESSOR 6
2018-05-07 00:18:25 +02:00
# define RGB_COLOR 255
2018-05-07 15:36:46 +02:00
# if defined(_MSC_VER)
# include <BaseTsd.h>
typedef SSIZE_T ssize_t ;
# endif
2018-05-07 15:49:17 +02:00
2018-05-11 11:30:17 +02:00
//double x[] = { 0.0 };
double xSamples [ NUMBER_OF_SAMPLES ] = { 0.0 } ;
double w [ WINDOWSIZE ] [ NUMBER_OF_SAMPLES ] = { { 0.0 } , { 0.0 } } ;
2018-05-07 15:36:46 +02:00
2018-05-07 00:18:25 +02:00
/* *svg graph building* */
2018-05-07 15:36:46 +02:00
typedef struct {
2018-05-04 16:30:12 +02:00
double xVal [ 7 ] ;
double yVal [ 7 ] ;
} point_t ;
2018-05-11 11:30:17 +02:00
point_t points [ NUMBER_OF_SAMPLES ] ; // [0] = xActual, [1]=xpredicted from localMean, [2]=xpredicted from directPredecessor, [3] = xpredicted from differentialpredecessor, [4] = xError from localMean, [5] xError from directPredecessor, [6] xError from differentialPredecessor
2018-05-04 16:30:12 +02:00
2018-05-11 11:30:17 +02:00
/* *ppm read, copy, write* */
2018-05-07 00:18:25 +02:00
typedef struct {
unsigned char red , green , blue ;
} colorChannel_t ;
typedef struct {
2018-05-07 15:36:46 +02:00
int x , y ;
2018-05-07 00:18:25 +02:00
colorChannel_t * data ;
} imagePixel_t ;
2018-05-07 22:39:31 +02:00
static imagePixel_t * rdPPM ( char * fileName ) ; // read PPM file format
void mkPpmFile ( char * fileName , imagePixel_t * image ) ; // writes PPM file
int ppmColorChannel ( FILE * fp , imagePixel_t * image ) ; // writes colorChannel from PPM file to log file
2018-05-11 11:30:17 +02:00
void colorSamples ( FILE * fp ) ; // stores color channel values in xSamples[]
2018-05-07 00:18:25 +02:00
2018-05-03 18:30:42 +02:00
/* *file handling* */
2018-05-07 15:36:46 +02:00
char * mkFileName ( char * buffer , size_t max_len , int suffixId ) ;
char * fileSuffix ( int id ) ;
void myLogger ( FILE * fp , point_t points [ ] ) ;
void mkSvgGraph ( point_t points [ ] ) ;
2018-04-26 16:39:47 +02:00
2018-05-04 01:28:36 +02:00
/* *rand seed* */
2018-05-07 15:36:46 +02:00
double r2 ( void ) ;
double rndm ( void ) ;
2018-05-03 18:30:42 +02:00
2018-05-04 01:28:36 +02:00
/* *math* */
2018-05-07 15:36:46 +02:00
double sum_array ( double x [ ] , int length ) ;
void directPredecessor ( void ) ;
void localMean ( void ) ;
2018-05-11 11:30:17 +02:00
void differentialPredecessor ( void ) ;
double * popNAN ( double * xError , int xErrorLength ) ; //return new array without NAN values
double windowXMean ( int _arraylength , int xCount ) ;
2018-05-07 15:36:46 +02:00
int main ( int argc , char * * argv ) {
char fileName [ 50 ] ;
2018-05-11 11:30:17 +02:00
int i , k , xLength ;
int * colorChannel ;
2018-05-07 17:10:43 +02:00
imagePixel_t * image ;
2018-05-11 11:30:17 +02:00
image = rdPPM ( " cow.ppm " ) ;
2018-05-07 22:39:31 +02:00
mkFileName ( fileName , sizeof ( fileName ) , TEST_VALUES ) ;
FILE * fp5 = fopen ( fileName , " w " ) ;
xLength = ppmColorChannel ( fp5 , image ) ;
2018-05-11 11:30:17 +02:00
printf ( " %d \n " , xLength ) ;
2018-05-07 22:39:31 +02:00
FILE * fp6 = fopen ( fileName , " r " ) ;
2018-05-11 11:30:17 +02:00
colorSamples ( fp6 ) ;
2018-05-07 15:36:46 +02:00
srand ( ( unsigned int ) time ( NULL ) ) ;
2018-05-11 11:30:17 +02:00
for ( i = 0 ; i < NUMBER_OF_SAMPLES ; i + + ) {
2018-05-07 22:39:31 +02:00
// _x[i] += ((255.0 / M) * i); // Init test values
2018-05-11 11:30:17 +02:00
for ( int k = 0 ; k < WINDOWSIZE ; k + + ) {
w [ k ] [ i ] = rndm ( ) ; // Init weights
2018-05-07 15:36:46 +02:00
}
}
mkFileName ( fileName , sizeof ( fileName ) , PURE_WEIGHTS ) ;
// save plain test_array before math magic happens
FILE * fp0 = fopen ( fileName , " w " ) ;
for ( i = 0 ; i < = tracking ; i + + ) {
2018-05-11 11:30:17 +02:00
for ( k = 0 ; k < WINDOWSIZE ; k + + ) {
2018-05-07 15:36:46 +02:00
fprintf ( fp0 , " [%d][%d] %lf \n " , k , i , w [ k ] [ i ] ) ;
}
}
fclose ( fp0 ) ;
// math magic
localMean ( ) ;
2018-05-11 11:30:17 +02:00
//directPredecessor();
//differentialPredecessor();
2018-05-07 22:39:31 +02:00
// save test_array after math magic happened
// memset( fileName, '\0', sizeof(fileName) );
2018-05-07 15:36:46 +02:00
mkFileName ( fileName , sizeof ( fileName ) , USED_WEIGHTS ) ;
FILE * fp1 = fopen ( fileName , " w " ) ;
for ( i = 0 ; i < tracking ; i + + ) {
2018-05-11 11:30:17 +02:00
for ( int k = 0 ; k < WINDOWSIZE ; k + + ) {
2018-05-07 15:36:46 +02:00
fprintf ( fp1 , " [%d][%d] %lf \n " , k , i , w [ k ] [ i ] ) ;
}
}
fclose ( fp1 ) ;
// getchar();
printf ( " DONE! " ) ;
2018-04-26 16:39:47 +02:00
}
2018-04-30 14:38:28 +02:00
2018-05-07 15:36:46 +02:00
/*
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
localMean
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
Variant ( 1 / 3 ) , substract local mean .
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 15:36:46 +02:00
*/
void localMean ( void ) {
char fileName [ 50 ] ;
2018-05-11 11:30:17 +02:00
double xError [ NUMBER_OF_SAMPLES ] ; // includes e(n)
memset ( xError , 0.0 , NUMBER_OF_SAMPLES ) ; // initialize xError-array with Zero
int xCount = 0 , i ; // runtime var;
2018-05-07 15:36:46 +02:00
mkFileName ( fileName , sizeof ( fileName ) , LOCAL_MEAN ) ;
FILE * fp4 = fopen ( fileName , " w " ) ;
2018-05-11 11:30:17 +02:00
fprintf ( fp4 , " \n =====================================LocalMean===================================== \n " ) ;
double xMean = xSamples [ 0 ] ;
double weightedSum = 0.0 ;
double filterOutput = 0.0 ;
double xSquared = 0.0 ;
double xPredicted = 0.0 ;
double xActual = 0.0 ;
for ( xCount = 1 ; xCount < NUMBER_OF_SAMPLES ; xCount + + ) { // first value will not get predicted
double xPartArray [ xCount ] ; //includes all values at the size of runtime var
//int _sourceIndex = (xCount > WINDOWSIZE) ? xCount - WINDOWSIZE : xCount;
int _arrayLength = ( xCount > WINDOWSIZE ) ? WINDOWSIZE + 1 : xCount ;
//printf("xCount:%d, length:%d\n", xCount, _arrayLength);
xMean = ( xCount > 0 ) ? windowXMean ( _arrayLength , xCount ) : 0 ;
// printf("WINDOWSIZE:%f\n", windowXMean(_arrayLength, xCount));
xPredicted = 0.0 ;
xActual = xSamples [ xCount + 1 ] ;
// weightedSum += _x[ xCount-1 ] * w[xCount][0];
for ( i = 1 ; i < _arrayLength ; i + + ) { //get predicted value
xPredicted + = ( w [ i ] [ xCount ] * ( xSamples [ xCount - i ] - xMean ) ) ;
2018-04-30 14:38:28 +02:00
2018-05-07 15:36:46 +02:00
}
xPredicted + = xMean ;
xError [ xCount ] = xActual - xPredicted ;
2018-05-11 11:30:17 +02:00
printf ( " Pred: %f \t \t Actual:%f \n " , xPredicted , xActual ) ;
points [ xCount ] . xVal [ 1 ] = xCount ;
points [ xCount ] . yVal [ 1 ] = xPredicted ;
points [ xCount ] . xVal [ 4 ] = xCount ;
points [ xCount ] . yVal [ 4 ] = xError [ xCount ] ;
xSquared = 0.0 ;
for ( i = 1 ; i < _arrayLength ; i + + ) { //get xSquared
//xSquared += pow(xSamples[xCount - i], 2);
xSquared + = pow ( xSamples [ xCount - i ] - xMean , 2 ) ;
printf ( " xSquared:%f \n " , xSquared ) ;
2018-05-07 15:36:46 +02:00
}
2018-05-11 11:30:17 +02:00
if ( xSquared = = 0.0 ) { // returns Pred: -1.#IND00
xSquared = 1.0 ;
}
//printf("%f\n", xSquared);
for ( i = 1 ; i < _arrayLength ; i + + ) { //update weights
w [ i ] [ xCount + 1 ] = w [ i ] [ xCount ] + learnrate * xError [ xCount ] * ( ( xSamples [ xCount - i ] - xMean ) / xSquared ) ;
2018-05-07 15:36:46 +02:00
}
fprintf ( fp4 , " {%d}. \t xPredicted{%f} \t xActual{%f} \t xError{%f} \n " , xCount , xPredicted , xActual , xError [ xCount ] ) ;
2018-05-11 11:30:17 +02:00
2018-04-30 14:38:28 +02:00
}
2018-05-07 15:36:46 +02:00
int xErrorLength = sizeof ( xError ) / sizeof ( xError [ 0 ] ) ;
2018-05-11 11:30:17 +02:00
printf ( " vor:%d " , xErrorLength ) ;
popNAN ( xError , xErrorLength ) ;
printf ( " nach:%d " , xErrorLength ) ;
xErrorLength = sizeof ( xError ) / sizeof ( xError [ 0 ] ) ;
double mean = sum_array ( xError , xErrorLength ) / xErrorLength ;
2018-05-07 15:36:46 +02:00
double deviation = 0.0 ;
// Mean square
2018-05-11 11:30:17 +02:00
for ( i = 0 ; i < xErrorLength - 1 ; i + + ) {
deviation + = pow ( xError [ i ] - mean , 2 ) ;
2018-05-07 15:36:46 +02:00
}
deviation / = xErrorLength ;
// write in file
mkFileName ( fileName , sizeof ( fileName ) , RESULTS ) ;
FILE * fp2 = fopen ( fileName , " w " ) ;
fprintf ( fp2 , " quadr. Varianz(x_error): {%f} \n Mittelwert:(x_error): {%f} \n \n " , deviation , mean ) ;
fclose ( fp2 ) ;
fclose ( fp4 ) ;
2018-04-26 16:39:47 +02:00
}
2018-04-30 14:38:28 +02:00
/*
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
directPredecessor
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
Variant ( 2 / 3 ) ,
substract direct predecessor
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 15:36:46 +02:00
*/
void directPredecessor ( void ) {
char fileName [ 512 ] ;
double xError [ 2048 ] ;
int xCount = 0 , i ;
double xActual ;
2018-05-11 11:30:17 +02:00
int xPredicted = 0.0 ;
2018-05-07 15:36:46 +02:00
// File handling
mkFileName ( fileName , sizeof ( fileName ) , DIRECT_PREDECESSOR ) ;
FILE * fp3 = fopen ( fileName , " w " ) ;
2018-05-11 11:30:17 +02:00
fprintf ( fp3 , " \n =====================================DirectPredecessor===================================== \n " ) ;
for ( xCount = 1 ; xCount < NUMBER_OF_SAMPLES + 1 ; xCount + + ) {
double xPartArray [ xCount ] ; //includes all values at the size of runtime var
//int _sourceIndex = (xCount > WINDOWSIZE) ? xCount - WINDOWSIZE : xCount;
int _arrayLength = ( xCount > WINDOWSIZE ) ? WINDOWSIZE + 1 : xCount ;
printf ( " xCount:%d, length:%d \n " , xCount , _arrayLength ) ;
double xMean = ( xCount > 0 ) ? windowXMean ( _arrayLength , xCount ) : 0 ;
printf ( " %f \n " , windowXMean ( _arrayLength , xCount ) ) ;
xPredicted = 0.0 ;
xActual = xSamples [ xCount + 1 ] ;
for ( i = 1 ; i < _arrayLength ; i + + ) {
xPredicted + = ( w [ i ] [ xCount ] * ( xSamples [ xCount - 1 ] - xSamples [ xCount - i - 1 ] ) ) ;
2018-05-07 15:36:46 +02:00
}
2018-05-11 11:30:17 +02:00
xPredicted + = xSamples [ xCount - 1 ] ;
2018-05-07 15:36:46 +02:00
xError [ xCount ] = xActual - xPredicted ;
fprintf ( fp3 , " {%d}. \t xPredicted{%f} \t xActual{%f} \t xError{%f} \n " , xCount , xPredicted , xActual , xError [ xCount ] ) ;
2018-05-11 11:30:17 +02:00
points [ xCount ] . xVal [ 2 ] = xCount ;
points [ xCount ] . yVal [ 2 ] = xPredicted ;
points [ xCount ] . xVal [ 5 ] = xCount ;
points [ xCount ] . yVal [ 5 ] = xError [ xCount ] ;
2018-05-07 15:36:46 +02:00
double xSquared = 0.0 ;
2018-05-11 11:30:17 +02:00
for ( i = 1 ; i < _arrayLength ; i + + ) {
xSquared + = pow ( xSamples [ xCount - 1 ] - xSamples [ xCount - i - 1 ] , 2 ) ; // substract direct predecessor
2018-05-07 15:36:46 +02:00
}
2018-05-11 11:30:17 +02:00
for ( i = 1 ; i < _arrayLength ; i + + ) {
w [ i ] [ xCount + 1 ] = w [ i ] [ xCount ] + learnrate * xError [ xCount ] * ( ( xSamples [ xCount - 1 ] - xSamples [ xCount - i - 1 ] ) / xSquared ) ;
2018-05-07 15:36:46 +02:00
}
}
int xErrorLength = sizeof ( xError ) / sizeof ( xError [ 0 ] ) ;
2018-05-11 11:30:17 +02:00
printf ( " vor:%d " , xErrorLength ) ;
popNAN ( xError , xErrorLength ) ;
printf ( " nach:%d " , xErrorLength ) ;
xErrorLength = sizeof ( xError ) / sizeof ( xError [ 0 ] ) ;
2018-05-07 15:36:46 +02:00
double mean = sum_array ( xError , xErrorLength ) / xErrorLength ;
double deviation = 0.0 ;
for ( i = 0 ; i < xErrorLength - 1 ; i + + ) {
deviation + = pow ( xError [ i ] - mean , 2 ) ;
}
2018-05-11 11:30:17 +02:00
deviation / = xErrorLength ;
2018-05-07 15:36:46 +02:00
mkSvgGraph ( points ) ;
fprintf ( fp3 , " {%d}. \t Least Mean Squared{%f} \t Mean{%f} \n \n " , xCount , deviation , mean ) ;
fclose ( fp3 ) ;
2018-04-26 16:39:47 +02:00
}
2018-05-11 11:30:17 +02:00
/*
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
differentialPredecessor
variant ( 3 / 3 ) ,
differenital predecessor .
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
*/
void differentialPredecessor ( void ) {
char fileName [ 512 ] ;
double xError [ 2048 ] ;
int xCount = 0 , i ;
double xActual ;
// File handling
mkFileName ( fileName , sizeof ( fileName ) , DIFFERENTIAL_PREDECESSOR ) ;
FILE * fp6 = fopen ( fileName , " w " ) ;
fprintf ( fp6 , " \n =====================================DifferentialPredecessor===================================== \n " ) ;
for ( xCount = 1 ; xCount < NUMBER_OF_SAMPLES + 1 ; xCount + + ) {
xActual = xSamples [ xCount + 1 ] ;
double xPredicted = 0.0 ;
for ( i = 1 ; i < xCount ; i + + ) {
xPredicted + = ( w [ i ] [ xCount ] * ( xSamples [ xCount - i ] - xSamples [ xCount - i - 1 ] ) ) ;
}
xPredicted + = xSamples [ xCount - 1 ] ;
xError [ xCount ] = xActual - xPredicted ;
fprintf ( fp6 , " {%d}. \t xPredicted{%f} \t xActual{%f} \t xError{%f} \n " , xCount , xPredicted , xActual , xError [ xCount ] ) ;
points [ xCount ] . xVal [ 3 ] = xCount ;
points [ xCount ] . yVal [ 3 ] = xPredicted ;
points [ xCount ] . xVal [ 6 ] = xCount ;
points [ xCount ] . yVal [ 6 ] = xError [ xCount ] ;
double xSquared = 0.0 ;
for ( i = 1 ; i < xCount ; i + + ) {
xSquared + = pow ( xSamples [ xCount - i ] - xSamples [ xCount - i - 1 ] , 2 ) ; // substract direct predecessor
}
for ( i = 1 ; i < xCount ; i + + ) {
w [ i ] [ xCount + 1 ] = w [ i ] [ xCount ] + learnrate * xError [ xCount ] * ( ( xSamples [ xCount - i ] - xSamples [ xCount - i - 1 ] ) / xSquared ) ;
}
}
int xErrorLength = sizeof ( xError ) / sizeof ( xError [ 0 ] ) ;
double mean = sum_array ( xError , xErrorLength ) / xErrorLength ;
double deviation = 0.0 ;
for ( i = 0 ; i < xErrorLength - 1 ; i + + ) {
deviation + = pow ( xError [ i ] - mean , 2 ) ;
}
deviation / = xErrorLength ;
mkSvgGraph ( points ) ;
fprintf ( fp6 , " {%d}. \t Least Mean Squared{%f} \t Mean{%f} \n \n " , xCount , deviation , mean ) ;
fclose ( fp6 ) ;
}
2018-05-03 18:30:42 +02:00
2018-04-30 14:38:28 +02:00
/*
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
mkFileName
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
Writes the current date plus the suffix with index suffixId
into the given buffer . If the total length is longer than max_len ,
only max_len characters will be written .
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 15:36:46 +02:00
*/
char * mkFileName ( char * buffer , size_t max_len , int suffixId ) {
2018-05-03 18:30:42 +02:00
const char * format_str = " %Y-%m-%d_%H_%M_%S " ;
size_t date_len ;
2018-05-07 15:36:46 +02:00
const char * suffix = fileSuffix ( suffixId ) ;
2018-05-03 18:30:42 +02:00
time_t now = time ( NULL ) ;
2018-05-07 15:36:46 +02:00
strftime ( buffer , max_len , format_str , localtime ( & now ) ) ;
2018-05-03 18:30:42 +02:00
date_len = strlen ( buffer ) ;
2018-05-07 15:36:46 +02:00
strncat ( buffer , suffix , max_len - date_len ) ;
return buffer ;
2018-04-26 16:39:47 +02:00
}
2018-04-30 14:38:28 +02:00
2018-04-26 16:39:47 +02:00
/*
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-03 18:30:42 +02:00
2018-05-11 11:30:17 +02:00
fileSuffix
2018-05-03 18:30:42 +02:00
2018-05-11 11:30:17 +02:00
Contains and returns every suffix for all existing filenames
2018-05-03 18:30:42 +02:00
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-03 18:30:42 +02:00
*/
2018-05-07 15:36:46 +02:00
char * fileSuffix ( int id ) {
2018-05-11 11:30:17 +02:00
char * suffix [ ] = { " _weights_pure.txt " , " _weights_used.txt " , " _direct_predecessor.txt " , " _ergebnisse.txt " , " _localMean.txt " , " _testvalues.txt " , " _differential_predecessor.txt " } ;
2018-05-03 18:30:42 +02:00
return suffix [ id ] ;
}
/*
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-03 18:30:42 +02:00
2018-05-11 11:30:17 +02:00
myLogger
2018-05-03 18:30:42 +02:00
2018-05-11 11:30:17 +02:00
Logs x , y points to svg graph
2018-05-03 18:30:42 +02:00
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 15:36:46 +02:00
*/
void bufferLogger ( char * buffer , point_t points [ ] ) {
int i ;
char _buffer [ 512 ] = " " ;
2018-05-03 18:30:42 +02:00
2018-05-11 11:30:17 +02:00
for ( i = 0 ; i < NUMBER_OF_SAMPLES - 1 ; i + + ) { // xActual
2018-05-07 15:36:46 +02:00
sprintf ( _buffer , " L %f %f \n " , points [ i ] . xVal [ 0 ] , points [ i ] . yVal [ 0 ] ) ;
strcat ( buffer , _buffer ) ;
}
2018-05-11 11:30:17 +02:00
strcat ( buffer , " \" fill= \" none \" stroke= \" black \" stroke-width= \" 0.4px \" /> \n <path d= \" M0 0 \n " ) ;
for ( i = 0 ; i < NUMBER_OF_SAMPLES - 1 ; i + + ) { // xPrediceted from localMean
2018-05-07 15:36:46 +02:00
sprintf ( _buffer , " L %f %f \n " , points [ i ] . xVal [ 1 ] , points [ i ] . yVal [ 1 ] ) ;
strcat ( buffer , _buffer ) ;
}
strcat ( buffer , " \" fill= \" none \" stroke= \" green \" stroke-width= \" 0.4px \" /> \n <path d= \" M0 0 \n " ) ;
2018-05-11 11:30:17 +02:00
for ( i = 0 ; i < = NUMBER_OF_SAMPLES - 1 ; i + + ) { //xPreddicted from directPredecessor
2018-05-07 15:36:46 +02:00
sprintf ( _buffer , " L %f %f \n " , points [ i ] . xVal [ 2 ] , points [ i ] . yVal [ 2 ] ) ;
strcat ( buffer , _buffer ) ;
}
2018-05-11 11:30:17 +02:00
strcat ( buffer , " \" fill= \" none \" stroke= \" blue \" stroke-width= \" 0.4px \" /> \n <path d= \" M0 0 \n " ) ;
for ( i = 0 ; i < NUMBER_OF_SAMPLES - 1 ; i + + ) { //xPredicted from diff Pred
sprintf ( _buffer , " L %f %f \n " , points [ i ] . xVal [ 3 ] , points [ i ] . xVal [ 3 ] ) ;
strcat ( buffer , _buffer ) ;
}
2018-05-07 15:36:46 +02:00
}
2018-05-03 18:30:42 +02:00
/*
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
sum_array
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
Sum of all elements in x within a defined length
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 15:36:46 +02:00
*/
2018-05-11 11:30:17 +02:00
double sum_array ( double x [ ] , int xlength ) {
2018-05-07 15:36:46 +02:00
int i = 0 ;
double sum = 0.0 ;
2018-05-11 11:30:17 +02:00
if ( xlength ! = 0 ) {
for ( i = 0 ; i < xlength ; i + + ) {
sum + = x [ i ] ;
}
}
2018-05-07 15:36:46 +02:00
return sum ;
2018-04-26 16:39:47 +02:00
}
2018-04-30 14:38:28 +02:00
/*
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-04-30 14:38:28 +02:00
2018-05-11 11:30:17 +02:00
popNanLength
2018-04-30 14:38:28 +02:00
2018-05-11 11:30:17 +02:00
returns length of new array without NAN values
2018-04-30 14:38:28 +02:00
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
*/
double * popNAN ( double * xError , int xErrorLength ) {
int i , counter ;
double noNAN [ xErrorLength ] ;
for ( i = 0 ; i < xErrorLength ; i + + ) {
if ( ! isnan ( xError [ i ] ) ) {
noNAN [ i ] = xError [ i ] ;
counter + + ;
}
}
realloc ( noNAN , counter * sizeof ( double ) ) ;
int noNANLength = sizeof ( noNAN ) / sizeof ( noNAN [ 0 ] ) ;
memcpy ( xError , noNAN , noNANLength ) ;
return xError ;
}
/*
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
r2
returns a random double value between 0 and 1
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-04-30 14:38:28 +02:00
*/
2018-05-03 18:30:42 +02:00
2018-05-07 15:36:46 +02:00
double r2 ( void ) {
return ( ( rand ( ) % 10000 ) / 10000.0 ) ;
2018-04-30 14:38:28 +02:00
}
2018-05-03 18:30:42 +02:00
/*
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-04-30 14:38:28 +02:00
2018-05-11 11:30:17 +02:00
rndm
2018-04-30 14:38:28 +02:00
2018-05-11 11:30:17 +02:00
fills a double variable with random value and returns it
2018-04-30 14:38:28 +02:00
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-04-30 14:38:28 +02:00
*/
2018-05-03 18:30:42 +02:00
2018-05-07 15:36:46 +02:00
double rndm ( void ) {
double rndmval = r2 ( ) ;
return rndmval ;
2018-04-30 14:38:28 +02:00
}
2018-05-04 01:28:36 +02:00
2018-05-04 16:30:12 +02:00
/*
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-04 16:30:12 +02:00
2018-05-11 11:30:17 +02:00
mkSvgGraph
2018-05-04 16:30:12 +02:00
2018-05-11 11:30:17 +02:00
parses template . svg and writes results in said template
2018-05-04 01:28:36 +02:00
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-04 01:28:36 +02:00
*/
2018-05-07 15:36:46 +02:00
void mkSvgGraph ( point_t points [ ] ) {
FILE * input = fopen ( " template.svg " , " r " ) ;
FILE * target = fopen ( " output.svg " , " w " ) ;
char line [ 512 ] ;
2018-05-11 11:30:17 +02:00
char firstGraph [ 15 ] = { " <path d= \" M0 0 " } ;
2018-05-07 15:36:46 +02:00
if ( input = = NULL ) {
exit ( EXIT_FAILURE ) ;
}
2018-05-11 11:30:17 +02:00
2018-05-07 15:36:46 +02:00
char buffer [ 131072 ] = " " ;
2018-05-11 11:30:17 +02:00
2018-05-07 15:36:46 +02:00
memset ( buffer , ' \0 ' , sizeof ( buffer ) ) ;
while ( ! feof ( input ) ) {
fgets ( line , 512 , input ) ;
strncat ( buffer , line , strlen ( line ) ) ;
2018-05-07 15:49:17 +02:00
// printf("%s\n", line);
2018-05-07 15:36:46 +02:00
if ( strstr ( line , firstGraph ) ! = NULL ) {
bufferLogger ( buffer , points ) ;
}
}
fprintf ( target , buffer ) ;
2018-05-07 15:49:17 +02:00
//puts(buffer);
2018-05-04 01:28:36 +02:00
}
2018-05-07 15:49:17 +02:00
2018-05-07 00:18:25 +02:00
/*
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 00:18:25 +02:00
2018-05-11 11:30:17 +02:00
rdPPM
2018-05-07 00:18:25 +02:00
2018-05-11 11:30:17 +02:00
reads data from file of type PPM , stores colorchannels in a struct in the
size of given picture
2018-05-07 00:18:25 +02:00
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 15:36:46 +02:00
*/
2018-05-07 17:10:43 +02:00
static imagePixel_t * rdPPM ( char * fileName ) {
2018-05-07 15:36:46 +02:00
char buffer [ 16 ] ;
2018-05-07 00:18:25 +02:00
imagePixel_t * image ;
2018-05-07 15:36:46 +02:00
int c , rgbColor ;
FILE * fp = fopen ( fileName , " rb " ) ;
if ( ! fp ) {
exit ( EXIT_FAILURE ) ;
2018-05-07 00:18:25 +02:00
}
2018-05-07 15:36:46 +02:00
if ( ! fgets ( buffer , sizeof ( buffer ) , fp ) ) {
2018-05-07 00:18:25 +02:00
perror ( fileName ) ;
exit ( EXIT_FAILURE ) ;
}
2018-05-07 15:36:46 +02:00
if ( buffer [ 0 ] ! = ' P ' | | buffer [ 1 ] ! = ' 6 ' ) {
fprintf ( stderr , " No PPM file format \n " ) ;
2018-05-07 00:18:25 +02:00
exit ( EXIT_FAILURE ) ;
}
2018-05-07 15:36:46 +02:00
image = ( imagePixel_t * ) malloc ( sizeof ( imagePixel_t ) ) ;
if ( ! image ) {
2018-05-07 00:18:25 +02:00
fprintf ( stderr , " malloc() failed " ) ;
}
c = getc ( fp ) ;
2018-05-07 15:36:46 +02:00
while ( c = = ' # ' ) {
while ( getc ( fp ) ! = ' \n ' ) ;
2018-05-07 00:18:25 +02:00
c = getc ( fp ) ;
}
ungetc ( c , fp ) ;
2018-05-07 15:36:46 +02:00
if ( fscanf ( fp , " %d %d " , & image - > x , & image - > y ) ! = 2 ) {
2018-05-07 00:18:25 +02:00
fprintf ( stderr , " Invalid image size in %s \n " , fileName ) ;
exit ( EXIT_FAILURE ) ;
}
2018-05-07 15:36:46 +02:00
if ( fscanf ( fp , " %d " , & rgbColor ) ! = 1 ) {
2018-05-07 00:18:25 +02:00
fprintf ( stderr , " Invalid rgb component in %s \n " , fileName ) ;
}
2018-05-07 15:36:46 +02:00
if ( rgbColor ! = RGB_COLOR ) {
fprintf ( stderr , " Invalid image color range in %s \n " , fileName ) ;
2018-05-07 00:18:25 +02:00
exit ( EXIT_FAILURE ) ;
}
2018-05-07 15:36:46 +02:00
while ( fgetc ( fp ) ! = ' \n ' ) ;
image - > data = ( colorChannel_t * ) malloc ( image - > x * image - > y * sizeof ( imagePixel_t ) ) ;
if ( ! image ) {
fprintf ( stderr , " malloc() failed " ) ;
2018-05-07 00:18:25 +02:00
exit ( EXIT_FAILURE ) ;
}
2018-05-07 15:36:46 +02:00
if ( fread ( image - > data , 3 * image - > x , image - > y , fp ) ! = image - > y ) {
2018-05-07 00:18:25 +02:00
fprintf ( stderr , " Loading image failed " ) ;
exit ( EXIT_FAILURE ) ;
}
fclose ( fp ) ;
return image ;
}
/*
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 00:18:25 +02:00
2018-05-11 11:30:17 +02:00
mkPpmFile
2018-05-07 00:18:25 +02:00
2018-05-11 11:30:17 +02:00
gets output from the result of rdPpmFile and writes a new PPM file . Best Case is a
carbon copy of the source image . Build for debugging
2018-05-07 00:18:25 +02:00
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 00:18:25 +02:00
*/
2018-05-07 15:36:46 +02:00
void mkPpmFile ( char * fileName , imagePixel_t * image ) {
FILE * fp = fopen ( fileName , " wb " ) ;
if ( ! fp ) {
fprintf ( stderr , " Opening file failed. " ) ;
exit ( EXIT_FAILURE ) ;
}
fprintf ( fp , " P6 \n " ) ;
fprintf ( fp , " %d %d \n " , image - > x , image - > y ) ;
fprintf ( fp , " %d \n " , RGB_COLOR ) ;
fwrite ( image - > data , 3 * image - > x , image - > y , fp ) ;
fclose ( fp ) ;
2018-05-07 00:18:25 +02:00
}
2018-05-11 11:30:17 +02:00
2018-05-07 00:18:25 +02:00
/*
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 15:36:46 +02:00
2018-05-11 11:30:17 +02:00
ppmColorChannel
2018-05-07 00:18:25 +02:00
2018-05-11 11:30:17 +02:00
gets one of the rgb color channels and writes them to a file
2018-05-07 00:18:25 +02:00
2018-05-11 11:30:17 +02:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2018-05-07 15:36:46 +02:00
*/
2018-05-07 00:18:25 +02:00
2018-05-07 22:39:31 +02:00
int ppmColorChannel ( FILE * fp , imagePixel_t * image ) {
2018-05-11 11:30:17 +02:00
// int length = 1000; // (image->x * image->y) / 3;
int i = 0 ;
2018-05-07 15:36:46 +02:00
if ( image ) {
2018-05-11 11:30:17 +02:00
for ( i = 0 ; i < NUMBER_OF_SAMPLES - 1 ; i + + ) {
2018-05-07 22:39:31 +02:00
fprintf ( fp , " %d \n " , image - > data [ i ] . green ) ;
2018-05-07 00:18:25 +02:00
}
2018-05-11 11:30:17 +02:00
}
2018-05-07 22:39:31 +02:00
fclose ( fp ) ;
2018-05-11 11:30:17 +02:00
return NUMBER_OF_SAMPLES ;
2018-05-07 22:39:31 +02:00
}
2018-05-11 11:30:17 +02:00
/*
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
colorSamples
reads colorChannel values from file and stores them in xSamples as well as points datatype for
creating the SVG graph
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
*/
void colorSamples ( FILE * fp ) {
2018-05-07 22:39:31 +02:00
int i = 0 ;
int d , out ;
double f ;
2018-05-11 11:30:17 +02:00
char buffer [ NUMBER_OF_SAMPLES ] ;
2018-05-07 22:39:31 +02:00
while ( ! feof ( fp ) ) {
2018-05-11 11:30:17 +02:00
if ( fgets ( buffer , NUMBER_OF_SAMPLES , fp ) ! = NULL ) {
sscanf ( buffer , " %lf " , & xSamples [ i ] ) ;
//printf("%lf\n", xSamples[i] );
points [ i ] . yVal [ 0 ] = xSamples [ i ] ;
points [ i ] . xVal [ 0 ] = i ;
2018-05-07 22:39:31 +02:00
+ + i ;
}
2018-05-11 11:30:17 +02:00
}
2018-05-07 22:39:31 +02:00
fclose ( fp ) ;
2018-05-07 00:18:25 +02:00
}
2018-05-11 11:30:17 +02:00
double windowXMean ( int _arraylength , int xCount ) {
int count ;
double sum = 0.0 ;
double * ptr ;
// printf("*window\t\t*base\t\txMean\n\n");
for ( ptr = & xSamples [ xCount - _arraylength ] ; ptr ! = & xSamples [ xCount ] ; ptr + + ) { //set ptr to beginning of window
//window = xCount - _arraylength
//base = window - _arraylength;
//sum = 0.0;
//for( count = 0; count < _arraylength; count++){
sum + = * ptr ;
// printf("%f\n", *base);
//}
}
//printf("\n%lf\t%lf\t%lf\n", *ptr, *ptr2, (sum/(double)WINDOW));
return sum / ( double ) _arraylength ;
}