From e8bb47649b9f4e625ef050aae096d23cfc058163 Mon Sep 17 00:00:00 2001 From: Benjamin Auder <benjamin.auder@somewhere> Date: Fri, 10 Feb 2017 16:00:58 +0100 Subject: [PATCH] fix generateRunSave_EMGLLF, simplify arrays readings --- src/.gitignore | 1 - src/test/.gitignore | 1 + .../generateRunSaveTest_EMGLLF.R | 48 ++++++++++++------- src/test/generate_test_data/helpers/EMGLLF.R | 2 +- src/test/utils.c | 47 ++++++------------ 5 files changed, 47 insertions(+), 52 deletions(-) diff --git a/src/.gitignore b/src/.gitignore index bdfbcfb..da9ff21 100644 --- a/src/.gitignore +++ b/src/.gitignore @@ -1,4 +1,3 @@ #ignore object files, library and test executables *.o *.so -vgcore.* diff --git a/src/test/.gitignore b/src/test/.gitignore index 05354ad..1a02474 100644 --- a/src/test/.gitignore +++ b/src/test/.gitignore @@ -1,3 +1,4 @@ test.* !test.*.c /data/ +vgcore.* diff --git a/src/test/generate_test_data/generateRunSaveTest_EMGLLF.R b/src/test/generate_test_data/generateRunSaveTest_EMGLLF.R index 2c2dc2a..f6059e5 100644 --- a/src/test/generate_test_data/generateRunSaveTest_EMGLLF.R +++ b/src/test/generate_test_data/generateRunSaveTest_EMGLLF.R @@ -9,26 +9,38 @@ generateRunSaveTest_EMGLLF = function(n=200, p=15, m=10, k=3, mini=5, maxi=10, require(valse) params = valse:::basic_Init_Parameters(n, p, m, k) io = generateIOdefault(n, p, m, k) - write.table(paste(testFolder,"phiInit",sep=""), params$phiInit, sep=delimiter); - write.table(paste(testFolder,"rhoInit",sep=""), params$rhoInit, sep=delimiter); - write.table(paste(testFolder,"piInit",sep=""), params$piInit, sep=delimiter); - write.table(paste(testFolder,"gamInit",sep=""), params$gamInit, sep=delimiter); - write.table(paste(testFolder,"mini",sep=""), mini, sep=delimiter); - write.table(paste(testFolder,"maxi",sep=""), maxi, sep=delimiter); - write.table(paste(testFolder,"gamma",sep=""), gamma, sep=delimiter); - write.table(paste(testFolder,"lambda",sep=""), lambda, sep=delimiter); - write.table(paste(testFolder,"X",sep=""), io$X, sep=delimiter); - write.table(paste(testFolder,"Y",sep=""), io$Y, sep=delimiter); - write.table(paste(testFolder,"tau",sep=""), tau, sep=delimiter); - write.table(paste(testFolder,"dimensions",sep=""), c(n,p,m,k), sep=delimiter); + write.table(as.double(params$phiInit), paste(testFolder,"phiInit",sep=""), + row.names=F, col.names=F) + write.table(as.double(params$rhoInit), paste(testFolder,"rhoInit",sep=""), + row.names=F, col.names=F) + write.table(as.double(params$piInit), paste(testFolder,"piInit",sep=""), + row.names=F, col.names=F) + write.table(as.double(params$gamInit), paste(testFolder,"gamInit",sep=""), + row.names=F, col.names=F) + write.table(as.integer(mini), paste(testFolder,"mini",sep=""), + row.names=F, col.names=F) + write.table(as.integer(maxi), paste(testFolder,"maxi",sep=""), + row.names=F, col.names=F) + write.table(as.double(gamma), paste(testFolder,"gamma",sep=""), + row.names=F, col.names=F) + write.table(as.double(lambda), paste(testFolder,"lambda",sep=""), + row.names=F, col.names=F) + write.table(as.double(io$X), paste(testFolder,"X",sep=""), + row.names=F, col.names=F) + write.table(as.double(io$Y), paste(testFolder,"Y",sep=""), + row.names=F, col.names=F) + write.table(as.double(tau), paste(testFolder,"tau",sep=""), + row.names=F, col.names=F) + write.table(as.integer(c(n,p,m,k)), paste(testFolder,"dimensions",sep=""), + row.names=F, col.names=F) res = EMGLLF(params$phiInit,params$rhoInit,params$piInit,params$gamInit,mini,maxi, - gamma,lambda,io$X,io$Y,tau); + gamma,lambda,io$X,io$Y,tau) #save outputs - write.table(paste(testFolder,"phi",sep=""), res$phi, sep=delimiter); - write.table(paste(testFolder,"rho",sep=""), res$rho, sep=delimiter); - write.table(paste(testFolder,"pi",sep=""), res$pi, sep=delimiter); - write.table(paste(testFolder,"LLF",sep=""), res$LLF, sep=delimiter); - write.table(paste(testFolder,"S",sep=""), res$S, sep=delimiter); + write.table(as.double(res$phi), paste(testFolder,"phi",sep=""), row.names=F, col.names=F) + write.table(as.double(res$rho), paste(testFolder,"rho",sep=""), row.names=F, col.names=F) + write.table(as.double(res$pi), paste(testFolder,"pi",sep=""), row.names=F, col.names=F) + write.table(as.double(res$LLF), paste(testFolder,"LLF",sep=""), row.names=F, col.names=F) + write.table(as.double(res$S), paste(testFolder,"S",sep=""), row.names=F, col.names=F) } diff --git a/src/test/generate_test_data/helpers/EMGLLF.R b/src/test/generate_test_data/helpers/EMGLLF.R index b0d95a3..02fbb47 100644 --- a/src/test/generate_test_data/helpers/EMGLLF.R +++ b/src/test/generate_test_data/helpers/EMGLLF.R @@ -169,5 +169,5 @@ EMGLLF = function(phiInit,rhoInit,piInit,gamInit,mini,maxi,gamma,lambda,X,Y,tau) } Pi = t(Pi) - return(list(phi=phi, rho=rho, Pi=Pi, LLF=LLF, S=S)) + return(list("phi"=phi, "rho"=rho, "pi"=Pi, "LLF"=LLF, "S"=S)) } diff --git a/src/test/utils.c b/src/test/utils.c index a6370b0..2eac0c2 100644 --- a/src/test/utils.c +++ b/src/test/utils.c @@ -37,55 +37,38 @@ void compareArray_int(const char* ID, const void* array, const void* refArray, i // 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...) + // 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, "wc -l "); 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); + FILE *arraySize = popen(command, "r"); + char* bufferNum = (char*)calloc(64, sizeof(char)); + fgets(bufferNum, sizeof(bufferNum), arraySize); + int n = atoi(bufferNum); + pclose(arraySize); // open file for reading - FILE* file = fopen(fullFileName, "r"); + FILE* arrayFile = 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 + size_t elementSize = isinteger ? sizeof(int) : sizeof(float); void* array = malloc(n*elementSize); - char curChar = ' '; - char bufferNum[64]; - for (int u=0; u<n; u++) + for (int i=0; i<n; i++) { - // 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 + // transform buffer content into float or int, and store it at appropriate location if (isinteger) - ((int*)array)[u] = atoi(bufferNum); + ((int*)array)[i] = atoi(bufferNum); else - ((float*)array)[u] = atof(bufferNum); - // position to next non-separator character - curChar = fgetc(file); + ((float*)array)[i] = atof(bufferNum); } - fclose(file); + fclose(arrayFile); + free(bufferNum); return array; } -- 2.44.0