From df3ef2db3d9d01161973a67b4f7d25e1da4d502b Mon Sep 17 00:00:00 2001 From: Benjamin Auder <benjamin.auder@somewhere> Date: Sat, 14 Jan 2017 04:27:48 +0100 Subject: [PATCH] remove utils.c, prepare testing 'R-only' --- .../MATLAB_test_helpers/Octave.m | 5 - .../MATLAB_test_helpers/README | 1 - .../MATLAB_test_helpers/covariance.m | 9 -- .../R_test_helpers/checkOutput.R | 10 -- .../R_test_helpers/covariance.R | 9 -- .../R_test_helpers/testEMGLLF.R | 46 -------- .../{MATLAB_test_helpers => helpers}/EMGLLF.m | 0 .../EMGrank.m | 0 .../basicInitParameters.m | 0 .../generate_test_data/helpers/checkOutput.R | 12 ++ .../constructionModelesLassoMLE.m | 0 .../constructionModelesLassoRank.m | 0 .../generate_test_data/helpers/covariance.R | 8 ++ .../generateIO.m | 0 .../generateIOdefault.m | 0 .../selectiontotale.m | 0 src/test/testEMGLLF.R | 50 ++++++++ src/test/utils.c | 111 ------------------ src/test/utils.h | 17 --- 19 files changed, 70 insertions(+), 208 deletions(-) delete mode 100644 src/test/generate_test_data/MATLAB_test_helpers/Octave.m delete mode 100644 src/test/generate_test_data/MATLAB_test_helpers/README delete mode 100644 src/test/generate_test_data/MATLAB_test_helpers/covariance.m delete mode 100644 src/test/generate_test_data/R_test_helpers/checkOutput.R delete mode 100644 src/test/generate_test_data/R_test_helpers/covariance.R delete mode 100644 src/test/generate_test_data/R_test_helpers/testEMGLLF.R rename src/test/generate_test_data/{MATLAB_test_helpers => helpers}/EMGLLF.m (100%) rename src/test/generate_test_data/{MATLAB_test_helpers => helpers}/EMGrank.m (100%) rename src/test/generate_test_data/{MATLAB_test_helpers => helpers}/basicInitParameters.m (100%) create mode 100644 src/test/generate_test_data/helpers/checkOutput.R rename src/test/generate_test_data/{MATLAB_test_helpers => helpers}/constructionModelesLassoMLE.m (100%) rename src/test/generate_test_data/{MATLAB_test_helpers => helpers}/constructionModelesLassoRank.m (100%) create mode 100644 src/test/generate_test_data/helpers/covariance.R rename src/test/generate_test_data/{MATLAB_test_helpers => helpers}/generateIO.m (100%) rename src/test/generate_test_data/{MATLAB_test_helpers => helpers}/generateIOdefault.m (100%) rename src/test/generate_test_data/{MATLAB_test_helpers => helpers}/selectiontotale.m (100%) create mode 100644 src/test/testEMGLLF.R delete mode 100644 src/test/utils.c delete mode 100644 src/test/utils.h diff --git a/src/test/generate_test_data/MATLAB_test_helpers/Octave.m b/src/test/generate_test_data/MATLAB_test_helpers/Octave.m deleted file mode 100644 index 8f105d2..0000000 --- a/src/test/generate_test_data/MATLAB_test_helpers/Octave.m +++ /dev/null @@ -1,5 +0,0 @@ -% Run this file if using Octave -if exist('OCTAVE_VERSION', 'builtin') ~= 0 - pkg load statistics %for random() - more off %to prevent bufferizing output -end diff --git a/src/test/generate_test_data/MATLAB_test_helpers/README b/src/test/generate_test_data/MATLAB_test_helpers/README deleted file mode 100644 index e94c0a0..0000000 --- a/src/test/generate_test_data/MATLAB_test_helpers/README +++ /dev/null @@ -1 +0,0 @@ -Subset of select/ project: only files required to generate tests outputs diff --git a/src/test/generate_test_data/MATLAB_test_helpers/covariance.m b/src/test/generate_test_data/MATLAB_test_helpers/covariance.m deleted file mode 100644 index 839c33c..0000000 --- a/src/test/generate_test_data/MATLAB_test_helpers/covariance.m +++ /dev/null @@ -1,9 +0,0 @@ -%covariance matrix for tests on synthetic data: A(i,j) = a^|i-j| -function[A] = covariance(p,a) - - A = a*ones(p,p); - for i=1:p - A(i,:) = A(i,:) .^ abs(i-(1:p)); - end - -end diff --git a/src/test/generate_test_data/R_test_helpers/checkOutput.R b/src/test/generate_test_data/R_test_helpers/checkOutput.R deleted file mode 100644 index 1faddaa..0000000 --- a/src/test/generate_test_data/R_test_helpers/checkOutput.R +++ /dev/null @@ -1,10 +0,0 @@ -checkOutput = function(varName, matrix, refMatrix, tol){ - print('Checking %s\n',varName); - maxError = max(max(max(max(abs(matrix - refMatrix))))); - if(maxError >= tol){ - print('Inaccuracy: max(abs(error)) = %g >= %g\n',maxError,tol) - } - else{ - print('OK\n') - } -} \ No newline at end of file diff --git a/src/test/generate_test_data/R_test_helpers/covariance.R b/src/test/generate_test_data/R_test_helpers/covariance.R deleted file mode 100644 index 2dea7f2..0000000 --- a/src/test/generate_test_data/R_test_helpers/covariance.R +++ /dev/null @@ -1,9 +0,0 @@ -covariance= function(p,a){ - A = matrix(a, p,p) - for{i in 1:p}{ - for{k in 1:p}{ - A[i,]= A[i,]^abs(i-k) - } - } - return(A=A) -} \ No newline at end of file diff --git a/src/test/generate_test_data/R_test_helpers/testEMGLLF.R b/src/test/generate_test_data/R_test_helpers/testEMGLLF.R deleted file mode 100644 index 0eb3483..0000000 --- a/src/test/generate_test_data/R_test_helpers/testEMGLLF.R +++ /dev/null @@ -1,46 +0,0 @@ -testEMGLLF = function(){ - testFolder = 'data/' - - #get dimensions - dimensions = read.table(strcat(testFolder,'dimensions'), header=FALSE) - n = dimensions[1] - p = dimensions[2] - m = dimensions[3] - k = dimensions[4] - - #get all input arrays - phiInit = read.table(strcat(testFolder,'phiInit'), header=FALSE) - rhoInit = read.table(strcat(testFolder,'rhoInit'), header=FALSE) - piInit = t(read.table(strcat(testFolder,'piInit'), header=FALSE)) - gamInit = read.table(strcat(testFolder,'gamInit'), header=FALSE) - mini = read.table(strcat(testFolder,'mini'), header=FALSE) - maxi = read.table(strcat(testFolder,'maxi'), header=FALSE) - gamma = read.table(strcat(testFolder,'gamma'), header=FALSE) - lambda = read.table(strcat(testFolder,'lambda'), header=FALSE) - X = rread.table(strcat(testFolder,'X'), header=FALSE) - Y = read.table(strcat(testFolder,'Y'), header=FALSE) - tau = read.table(strcat(testFolder,'tau'), header=FALSE) - - #run EMGLLF.c - EMG = .Call("EMGLLF_core",phiInit,rhoInit,piInit1,gamInit,mini,maxi,gamma,lambda,X,Y,tau) - phi = EMG$phi - rho = EMG$rho - pi = EMG$pi - LLF = EMG$LLF - S = EMG$S - - #get all stored outputs - ref_phi =read.table(strcat(testFolder,'phi'), header=FALSE) - ref_rho = read.table(strcat(testFolder,'rho'), header=FALSE) - ref_pi = read.table(strcat(testFolder,'pi'), header=FALSE) - ref_LLF = read.table(strcat(testFolder,'LLF'), header=FALSE) - ref_S = read.table(strcat(testFolder,'S'), header=FALSE) - - #check that output correspond to stored output - tol = 1e-5; - checkOutput('phi',phi,ref_phi,tol); - checkOutput('rho',rho,ref_rho,tol); - checkOutput('pi',pi,ref_pi,tol); - checkOutput('LLF',LLF,ref_LLF,tol); - checkOutput('S',S,ref_S,tol); -} diff --git a/src/test/generate_test_data/MATLAB_test_helpers/EMGLLF.m b/src/test/generate_test_data/helpers/EMGLLF.m similarity index 100% rename from src/test/generate_test_data/MATLAB_test_helpers/EMGLLF.m rename to src/test/generate_test_data/helpers/EMGLLF.m diff --git a/src/test/generate_test_data/MATLAB_test_helpers/EMGrank.m b/src/test/generate_test_data/helpers/EMGrank.m similarity index 100% rename from src/test/generate_test_data/MATLAB_test_helpers/EMGrank.m rename to src/test/generate_test_data/helpers/EMGrank.m diff --git a/src/test/generate_test_data/MATLAB_test_helpers/basicInitParameters.m b/src/test/generate_test_data/helpers/basicInitParameters.m similarity index 100% rename from src/test/generate_test_data/MATLAB_test_helpers/basicInitParameters.m rename to src/test/generate_test_data/helpers/basicInitParameters.m diff --git a/src/test/generate_test_data/helpers/checkOutput.R b/src/test/generate_test_data/helpers/checkOutput.R new file mode 100644 index 0000000..187536a --- /dev/null +++ b/src/test/generate_test_data/helpers/checkOutput.R @@ -0,0 +1,12 @@ +checkOutput = function(varName, array, refArray, tol) +{ + print(paste("Checking ",varName,sep="")) + maxError = max(abs(array - refArray)) + if(maxError >= tol) + { + print(paste("Inaccuracy: max(abs(error)) = ",maxError," >= ",tol,sep="")) + } else + { + print("OK") + } +} diff --git a/src/test/generate_test_data/MATLAB_test_helpers/constructionModelesLassoMLE.m b/src/test/generate_test_data/helpers/constructionModelesLassoMLE.m similarity index 100% rename from src/test/generate_test_data/MATLAB_test_helpers/constructionModelesLassoMLE.m rename to src/test/generate_test_data/helpers/constructionModelesLassoMLE.m diff --git a/src/test/generate_test_data/MATLAB_test_helpers/constructionModelesLassoRank.m b/src/test/generate_test_data/helpers/constructionModelesLassoRank.m similarity index 100% rename from src/test/generate_test_data/MATLAB_test_helpers/constructionModelesLassoRank.m rename to src/test/generate_test_data/helpers/constructionModelesLassoRank.m diff --git a/src/test/generate_test_data/helpers/covariance.R b/src/test/generate_test_data/helpers/covariance.R new file mode 100644 index 0000000..15cd693 --- /dev/null +++ b/src/test/generate_test_data/helpers/covariance.R @@ -0,0 +1,8 @@ +covariance = function(p,a) +{ + A = matrix(a, p,p) + for (i in 1:p) + A[i,] = A[i,]^abs(i-(1:p)) + + return (A) +} diff --git a/src/test/generate_test_data/MATLAB_test_helpers/generateIO.m b/src/test/generate_test_data/helpers/generateIO.m similarity index 100% rename from src/test/generate_test_data/MATLAB_test_helpers/generateIO.m rename to src/test/generate_test_data/helpers/generateIO.m diff --git a/src/test/generate_test_data/MATLAB_test_helpers/generateIOdefault.m b/src/test/generate_test_data/helpers/generateIOdefault.m similarity index 100% rename from src/test/generate_test_data/MATLAB_test_helpers/generateIOdefault.m rename to src/test/generate_test_data/helpers/generateIOdefault.m diff --git a/src/test/generate_test_data/MATLAB_test_helpers/selectiontotale.m b/src/test/generate_test_data/helpers/selectiontotale.m similarity index 100% rename from src/test/generate_test_data/MATLAB_test_helpers/selectiontotale.m rename to src/test/generate_test_data/helpers/selectiontotale.m diff --git a/src/test/testEMGLLF.R b/src/test/testEMGLLF.R new file mode 100644 index 0000000..9ba7058 --- /dev/null +++ b/src/test/testEMGLLF.R @@ -0,0 +1,50 @@ +testEMGLLF = function() +{ + testFolder = "data/" + array_delimiter = " " + + #get dimensions + dimensions = read.table(paste(testFolder,"dimensions",sep=""), header=FALSE, + sep=array_delimiter) + n = dimensions[1] + p = dimensions[2] + m = dimensions[3] + k = dimensions[4] + + #get all input arrays + phiInit = read.table(paste(testFolder,"phiInit",sep=""), header=FALSE, sep=array_delimiter) + rhoInit = read.table(paste(testFolder,"rhoInit",sep=""), header=FALSE, sep=array_delimiter) + piInit = read.table(paste(testFolder,"piInit",sep=""), header=FALSE, sep=array_delimiter) + gamInit = read.table(paste(testFolder,"gamInit",sep=""), header=FALSE, sep=array_delimiter) + mini = read.table(paste(testFolder,"mini",sep=""), header=FALSE, sep=array_delimiter) + maxi = read.table(paste(testFolder,"maxi",sep=""), header=FALSE, sep=array_delimiter) + gamma = read.table(paste(testFolder,"gamma",sep=""), header=FALSE, sep=array_delimiter) + lambda = read.table(paste(testFolder,"lambda",sep=""), header=FALSE, sep=array_delimiter) + X = read.table(paste(testFolder,"X",sep=""), header=FALSE, sep=array_delimiter) + Y = read.table(paste(testFolder,"Y",sep=""), header=FALSE, sep=array_delimiter) + tau = read.table(paste(testFolder,"tau",sep=""), header=FALSE, sep=array_delimiter) + + #run EMGLLF.c + EMG = .Call("EMGLLF_core",phiInit,rhoInit,piInit1,gamInit,mini,maxi,gamma,lambda,X,Y,tau, + PACKAGE="valse") + phi = EMG$phi + rho = EMG$rho + pi = EMG$pi + LLF = EMG$LLF + S = EMG$S + + #get all stored outputs + ref_phi = read.table(paste(testFolder,"phi",sep=""), header=FALSE, sep=array_delimiter) + ref_rho = read.table(paste(testFolder,"rho",sep=""), header=FALSE, sep=array_delimiter) + ref_pi = read.table(paste(testFolder,"pi",sep=""), header=FALSE, sep=array_delimiter) + ref_LLF = read.table(paste(testFolder,"LLF",sep=""), header=FALSE, sep=array_delimiter) + ref_S = read.table(paste(testFolder,"S",sep=""), header=FALSE, sep=array_delimiter) + + #check that output correspond to stored output + tol = 1e-5; + checkOutput("phi",phi,ref_phi,tol); + checkOutput("rho",rho,ref_rho,tol); + checkOutput("pi",pi,ref_pi,tol); + checkOutput("LLF",LLF,ref_LLF,tol); + checkOutput("S",S,ref_S,tol); +} diff --git a/src/test/utils.c b/src/test/utils.c deleted file mode 100644 index a6370b0..0000000 --- a/src/test/utils.c +++ /dev/null @@ -1,111 +0,0 @@ -#include <stdlib.h> -#include <stdio.h> -#include <math.h> -#include <string.h> - -// Check if array == refArray -void compareArray(const char* ID, const void* array, const void* refArray, int size, - int isinteger) -{ - float EPS = 1e-5; //precision - printf("Checking %s\n",ID); - float maxError = 0.0; - for (int i=0; i<size; i++) - { - float error = isinteger - ? fabs(((int*)array)[i] - ((int*)refArray)[i]) - : fabs(((float*)array)[i] - ((float*)refArray)[i]); - if (error >= maxError) - maxError = error; - } - if (maxError >= EPS) - printf(" Inaccuracy: max(abs(error)) = %g >= %g\n",maxError,EPS); - else - printf(" OK\n"); -} - -void compareArray_real(const char* ID, const void* array, const void* refArray, int size) -{ - return compareArray(ID, array, refArray, size, 0); -} - -void compareArray_int(const char* ID, const void* array, const void* refArray, int size) -{ - return compareArray(ID, array, refArray, size, 1); -} - -// Read array by columns (as in MATLAB) and return by-rows encoding -void* readArray(const char* fileName, int isinteger) -{ - // need to prepend '../data/' (not really nice code...) - char* fullFileName = (char*)calloc(5+strlen(fileName)+1, sizeof(char)); - strcat(fullFileName, "data/"); - strcat(fullFileName, fileName); - - // first pass to know how many elements to allocate - char* command = (char*)calloc(12+strlen(fullFileName)+8+1, sizeof(char)); - strcat(command, "grep -o ' ' "); - strcat(command, fullFileName); - strcat(command, " | wc -l"); - FILE *countSpaces = popen(command, "r"); - char* buffer = (char*)calloc(32, sizeof(char)); - fgets(buffer, sizeof(buffer), countSpaces); - int n = atoi(buffer) + 1; - free(buffer); - pclose(countSpaces); - - // open file for reading - FILE* file = fopen(fullFileName, "r"); - free(fullFileName); - - int d = 1; - size_t elementSize = isinteger - ? sizeof(int) - : sizeof(float); - - // read all values, and convert them to by-rows matrices format - void* array = malloc(n*elementSize); - char curChar = ' '; - char bufferNum[64]; - for (int u=0; u<n; u++) - { - // read number (as a string) - int bufferIndex = 0; - while (!feof(file) && curChar!=' ') - { - curChar = fgetc(file); - bufferNum[bufferIndex++] = curChar; - } - bufferNum[bufferIndex] = 0; - // transform string into float, and store it at appropriate location - if (isinteger) - ((int*)array)[u] = atoi(bufferNum); - else - ((float*)array)[u] = atof(bufferNum); - // position to next non-separator character - curChar = fgetc(file); - } - fclose(file); - - return array; -} - -int* readArray_int(const char* fileName) -{ - return (int*)readArray(fileName, 1); -} - -float* readArray_real(const char* fileName) -{ - return (float*)readArray(fileName, 0); -} - -int read_int(const char* fileName) -{ - return readArray_int(fileName)[0]; -} - -float read_real(const char* fileName) -{ - return readArray_real(fileName)[0]; -} diff --git a/src/test/utils.h b/src/test/utils.h deleted file mode 100644 index cbffc24..0000000 --- a/src/test/utils.h +++ /dev/null @@ -1,17 +0,0 @@ -// Check if array == refArray -void compareArray(const char* ID, const void* array, const void* refArray, int size, int isInteger); - -void compareArray_real(const char* ID, const void* array, const void* refArray, int size); - -void compareArray_int(const char* ID, const void* array, const void* refArray, int size); - -// Read array by columns (as in MATLAB) and return by-rows encoding -void* readArray(const char* fileName, int isInteger); - -int* readArray_int(const char* fileName); - -float* readArray_real(const char* fileName); - -int read_int(const char* fileName); - -float read_real(const char* fileName); -- 2.44.0