From afa07d41c7592ac0ccd55d7af23c3bfef213291e Mon Sep 17 00:00:00 2001 From: Benjamin Auder <benjamin.auder@somewhere> Date: Thu, 12 Jan 2017 20:39:50 +0100 Subject: [PATCH] C-part of tests ready [TODO: R part] --- .gitignore | 5 +- src/.gitignore | 5 + src/sources/EMGLLF.c | 130 ++++++++++----------- src/sources/EMGLLF.h | 28 ++--- src/sources/EMGrank.c | 72 ++++++------ src/sources/EMGrank.h | 14 +-- src/sources/constructionModelesLassoMLE.c | 54 ++++----- src/sources/constructionModelesLassoMLE.h | 28 ++--- src/sources/constructionModelesLassoRank.c | 26 ++--- src/sources/constructionModelesLassoRank.h | 14 +-- src/sources/selectiontotale.c | 36 +++--- src/sources/selectiontotale.h | 24 ++-- src/test/.Makefile.swp | Bin 12288 -> 0 bytes src/test/Makefile | 16 +-- src/test/OLD_TEST_MATLAB/TODO | 5 +- src/test/test.EMGLLF.c | 4 +- src/test/utils.c | 9 +- 17 files changed, 240 insertions(+), 230 deletions(-) create mode 100644 src/.gitignore delete mode 100644 src/test/.Makefile.swp diff --git a/.gitignore b/.gitignore index b5f5640..767ee1a 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,5 @@ +#global ignores .Rhistory .RData -*.o -*.so +*.swp +*~ diff --git a/src/.gitignore b/src/.gitignore new file mode 100644 index 0000000..d8d0ef0 --- /dev/null +++ b/src/.gitignore @@ -0,0 +1,5 @@ +#ignore object files, library and test executables +*.o +*.so +test.* +!test.*.c diff --git a/src/sources/EMGLLF.c b/src/sources/EMGLLF.c index 42419ac..1439416 100644 --- a/src/sources/EMGLLF.c +++ b/src/sources/EMGLLF.c @@ -5,23 +5,23 @@ // TODO: don't recompute indexes every time...... void EMGLLF_core( // IN parameters - const double* phiInit, // parametre initial de moyenne renormalisé - const double* rhoInit, // parametre initial de variance renormalisé - const double* piInit, // parametre initial des proportions - const double* gamInit, // paramètre initial des probabilités a posteriori de chaque échantillon + const float* phiInit, // parametre initial de moyenne renormalisé + const float* rhoInit, // parametre initial de variance renormalisé + const float* piInit, // parametre initial des proportions + const float* gamInit, // paramètre initial des probabilités a posteriori de chaque échantillon int mini, // nombre minimal d'itérations dans l'algorithme EM int maxi, // nombre maximal d'itérations dans l'algorithme EM - double gamma, // puissance des proportions dans la pénalisation pour un Lasso adaptatif - double lambda, // valeur du paramètre de régularisation du Lasso - const double* X, // régresseurs - const double* Y, // réponse - double tau, // seuil pour accepter la convergence + float gamma, // puissance des proportions dans la pénalisation pour un Lasso adaptatif + float lambda, // valeur du paramètre de régularisation du Lasso + const float* X, // régresseurs + const float* Y, // réponse + float tau, // seuil pour accepter la convergence // OUT parameters (all pointers, to be modified) - double* phi, // parametre de moyenne renormalisé, calculé par l'EM - double* rho, // parametre de variance renormalisé, calculé par l'EM - double* pi, // parametre des proportions renormalisé, calculé par l'EM - double* LLF, // log vraisemblance associée à cet échantillon, pour les valeurs estimées des paramètres - double* S, + float* phi, // parametre de moyenne renormalisé, calculé par l'EM + float* rho, // parametre de variance renormalisé, calculé par l'EM + float* pi, // parametre des proportions renormalisé, calculé par l'EM + float* LLF, // log vraisemblance associée à cet échantillon, pour les valeurs estimées des paramètres + float* S, // additional size parameters int n, // nombre d'echantillons int p, // nombre de covariables @@ -37,32 +37,32 @@ void EMGLLF_core( //Other local variables //NOTE: variables order is always [maxi],n,p,m,k - double* gam = (double*)malloc(n*k*sizeof(double)); + float* gam = (float*)malloc(n*k*sizeof(float)); copyArray(gamInit, gam, n*k); - double* b = (double*)malloc(k*sizeof(double)); - double* Phi = (double*)malloc(p*m*k*sizeof(double)); - double* Rho = (double*)malloc(m*m*k*sizeof(double)); - double* Pi = (double*)malloc(k*sizeof(double)); - double* gam2 = (double*)malloc(k*sizeof(double)); - double* pi2 = (double*)malloc(k*sizeof(double)); - double* Gram2 = (double*)malloc(p*p*k*sizeof(double)); - double* ps = (double*)malloc(m*k*sizeof(double)); - double* nY2 = (double*)malloc(m*k*sizeof(double)); - double* ps1 = (double*)malloc(n*m*k*sizeof(double)); - double* ps2 = (double*)malloc(p*m*k*sizeof(double)); - double* nY21 = (double*)malloc(n*m*k*sizeof(double)); - double* Gam = (double*)malloc(n*k*sizeof(double)); - double* X2 = (double*)malloc(n*p*k*sizeof(double)); - double* Y2 = (double*)malloc(n*m*k*sizeof(double)); + float* b = (float*)malloc(k*sizeof(float)); + float* Phi = (float*)malloc(p*m*k*sizeof(float)); + float* Rho = (float*)malloc(m*m*k*sizeof(float)); + float* Pi = (float*)malloc(k*sizeof(float)); + float* gam2 = (float*)malloc(k*sizeof(float)); + float* pi2 = (float*)malloc(k*sizeof(float)); + float* Gram2 = (float*)malloc(p*p*k*sizeof(float)); + float* ps = (float*)malloc(m*k*sizeof(float)); + float* nY2 = (float*)malloc(m*k*sizeof(float)); + float* ps1 = (float*)malloc(n*m*k*sizeof(float)); + float* ps2 = (float*)malloc(p*m*k*sizeof(float)); + float* nY21 = (float*)malloc(n*m*k*sizeof(float)); + float* Gam = (float*)malloc(n*k*sizeof(float)); + float* X2 = (float*)malloc(n*p*k*sizeof(float)); + float* Y2 = (float*)malloc(n*m*k*sizeof(float)); gsl_matrix* matrix = gsl_matrix_alloc(m, m); gsl_permutation* permutation = gsl_permutation_alloc(m); - double* YiRhoR = (double*)malloc(m*sizeof(double)); - double* XiPhiR = (double*)malloc(m*sizeof(double)); - double dist = 0.; - double dist2 = 0.; + float* YiRhoR = (float*)malloc(m*sizeof(float)); + float* XiPhiR = (float*)malloc(m*sizeof(float)); + float dist = 0.; + float dist2 = 0.; int ite = 0; - double EPS = 1e-15; - double* dotProducts = (double*)malloc(k*sizeof(double)); + float EPS = 1e-15; + float* dotProducts = (float*)malloc(k*sizeof(float)); while (ite < mini || (ite < maxi && (dist >= tau || dist2 >= sqrt(tau)))) { @@ -90,7 +90,7 @@ void EMGLLF_core( //ps2(:,mm,r)=transpose(X2(:,:,r))*Y2(:,mm,r); for (int u=0; u<p; u++) { - double dotProduct = 0.; + float dotProduct = 0.; for (int v=0; v<n; v++) dotProduct += X2[ai(v,u,r,n,m,k)] * Y2[ai(v,mm,r,n,m,k)]; ps2[ai(u,mm,r,n,m,k)] = dotProduct; @@ -101,7 +101,7 @@ void EMGLLF_core( for (int s=0; s<p; s++) { //Gram2(j,s,r)=transpose(X2(:,j,r))*(X2(:,s,r)); - double dotProduct = 0.; + float dotProduct = 0.; for (int u=0; u<n; u++) dotProduct += X2[ai(u,j,r,n,p,k)] * X2[ai(u,s,r,n,p,k)]; Gram2[ai(j,s,r,p,p,k)] = dotProduct; @@ -117,7 +117,7 @@ void EMGLLF_core( for (int r=0; r<k; r++) { //b(r) = sum(sum(abs(phi(:,:,r)))); - double sumAbsPhi = 0.; + float sumAbsPhi = 0.; for (int u=0; u<p; u++) for (int v=0; v<m; v++) sumAbsPhi += fabs(phi[ai(u,v,r,p,m,k)]); @@ -126,16 +126,16 @@ void EMGLLF_core( //gam2 = sum(gam,1); for (int u=0; u<k; u++) { - double sumOnColumn = 0.; + float sumOnColumn = 0.; for (int v=0; v<n; v++) sumOnColumn += gam[mi(v,u,n,k)]; gam2[u] = sumOnColumn; } //a=sum(gam*transpose(log(pi))); - double a = 0.; + float a = 0.; for (int u=0; u<n; u++) { - double dotProduct = 0.; + float dotProduct = 0.; for (int v=0; v<k; v++) dotProduct += gam[mi(u,v,n,k)] * log(pi[v]); a += dotProduct; @@ -144,7 +144,7 @@ void EMGLLF_core( //tant que les proportions sont negatives int kk = 0; int pi2AllPositive = 0; - double invN = 1./n; + float invN = 1./n; while (!pi2AllPositive) { //pi2(:)=pi(:)+0.1^kk*(1/n*gam2(:)-pi(:)); @@ -164,15 +164,15 @@ void EMGLLF_core( //t(m) la plus grande valeur dans la grille O.1^k tel que ce soit décroissante ou constante //(pi.^gamma)*b - double piPowGammaDotB = 0.; + float piPowGammaDotB = 0.; for (int v=0; v<k; v++) piPowGammaDotB += pow(pi[v],gamma) * b[v]; //(pi2.^gamma)*b - double pi2PowGammaDotB = 0.; + float pi2PowGammaDotB = 0.; for (int v=0; v<k; v++) pi2PowGammaDotB += pow(pi2[v],gamma) * b[v]; //transpose(gam2)*log(pi2) - double prodGam2logPi2 = 0.; + float prodGam2logPi2 = 0.; for (int v=0; v<k; v++) prodGam2logPi2 += gam2[v] * log(pi2[v]); while (-invN*a + lambda*piPowGammaDotB < -invN*prodGam2logPi2 + lambda*pi2PowGammaDotB @@ -190,9 +190,9 @@ void EMGLLF_core( prodGam2logPi2 += gam2[v] * log(pi2[v]); kk++; } - double t = pow(0.1,kk); + float t = pow(0.1,kk); //sum(pi+t*(pi2-pi)) - double sumPiPlusTbyDiff = 0.; + float sumPiPlusTbyDiff = 0.; for (int v=0; v<k; v++) sumPiPlusTbyDiff += (pi[v] + t*(pi2[v] - pi[v])); //pi=(pi+t*(pi2-pi))/sum(pi+t*(pi2-pi)); @@ -207,7 +207,7 @@ void EMGLLF_core( for (int i=0; i<n; i++) { //< X2(i,:,r) , phi(:,mm,r) > - double dotProduct = 0.0; + float dotProduct = 0.0; for (int u=0; u<p; u++) dotProduct += X2[ai(i,u,r,n,p,k)] * phi[ai(u,mm,r,n,m,k)]; //ps1(i,mm,r)=Y2(i,mm,r)*dot(X2(i,:,r),phi(:,mm,r)); @@ -215,12 +215,12 @@ void EMGLLF_core( nY21[ai(i,mm,r,n,m,k)] = Y2[ai(i,mm,r,n,m,k)] * Y2[ai(i,mm,r,n,m,k)]; } //ps(mm,r)=sum(ps1(:,mm,r)); - double sumPs1 = 0.0; + float sumPs1 = 0.0; for (int u=0; u<n; u++) sumPs1 += ps1[ai(u,mm,r,n,m,k)]; ps[mi(mm,r,m,k)] = sumPs1; //nY2(mm,r)=sum(nY21(:,mm,r)); - double sumNy21 = 0.0; + float sumNy21 = 0.0; for (int u=0; u<n; u++) sumNy21 += nY21[ai(u,mm,r,n,m,k)]; nY2[mi(mm,r,m,k)] = sumNy21; @@ -237,7 +237,7 @@ void EMGLLF_core( { //sum(phi(1:j-1,mm,r).*transpose(Gram2(j,1:j-1,r)))+sum(phi(j+1:p,mm,r) // .*transpose(Gram2(j,j+1:p,r))) - double dotPhiGram2 = 0.0; + float dotPhiGram2 = 0.0; for (int u=0; u<j; u++) dotPhiGram2 += phi[ai(u,mm,r,p,m,k)] * Gram2[ai(j,u,r,p,p,k)]; for (int u=j+1; u<p; u++) @@ -262,12 +262,12 @@ void EMGLLF_core( ///////////// int signum; - double sumLogLLF2 = 0.0; + float sumLogLLF2 = 0.0; for (int i=0; i<n; i++) { - double sumLLF1 = 0.0; - double sumGamI = 0.0; - double minDotProduct = INFINITY; + float sumLLF1 = 0.0; + float sumGamI = 0.0; + float minDotProduct = INFINITY; for (int r=0; r<k; r++) { @@ -300,7 +300,7 @@ void EMGLLF_core( if (dotProducts[r] < minDotProduct) minDotProduct = dotProducts[r]; } - double shift = 0.5*minDotProduct; + float shift = 0.5*minDotProduct; for (int r=0; r<k; r++) { //compute det(rho(:,:,r)) [TODO: avoid re-computations] @@ -310,7 +310,7 @@ void EMGLLF_core( matrix->data[u*m+v] = rho[ai(u,v,r,m,m,k)]; } gsl_linalg_LU_decomp(matrix, permutation, &signum); - double detRhoR = gsl_linalg_LU_det(matrix, signum); + float detRhoR = gsl_linalg_LU_det(matrix, signum); Gam[mi(i,r,n,k)] = pi[r] * detRhoR * exp(-0.5*dotProducts[r] + shift); sumLLF1 += Gam[mi(i,r,n,k)] / pow(2*M_PI,m/2.0); @@ -327,7 +327,7 @@ void EMGLLF_core( } //sum(pen(ite,:)) - double sumPen = 0.0; + float sumPen = 0.0; for (int r=0; r<k; r++) sumPen += pow(pi[r],gamma) * b[r]; //LLF(ite)=-1/n*sum(log(LLF2(ite,:)))+lambda*sum(pen(ite,:)); @@ -338,14 +338,14 @@ void EMGLLF_core( dist = (LLF[ite] - LLF[ite-1]) / (1.0 + fabs(LLF[ite])); //Dist1=max(max((abs(phi-Phi))./(1+abs(phi)))); - double Dist1 = 0.0; + float Dist1 = 0.0; for (int u=0; u<p; u++) { for (int v=0; v<m; v++) { for (int w=0; w<k; w++) { - double tmpDist = fabs(phi[ai(u,v,w,p,m,k)]-Phi[ai(u,v,w,p,m,k)]) + float tmpDist = fabs(phi[ai(u,v,w,p,m,k)]-Phi[ai(u,v,w,p,m,k)]) / (1.0+fabs(phi[ai(u,v,w,p,m,k)])); if (tmpDist > Dist1) Dist1 = tmpDist; @@ -353,14 +353,14 @@ void EMGLLF_core( } } //Dist2=max(max((abs(rho-Rho))./(1+abs(rho)))); - double Dist2 = 0.0; + float Dist2 = 0.0; for (int u=0; u<m; u++) { for (int v=0; v<m; v++) { for (int w=0; w<k; w++) { - double tmpDist = fabs(rho[ai(u,v,w,m,m,k)]-Rho[ai(u,v,w,m,m,k)]) + float tmpDist = fabs(rho[ai(u,v,w,m,m,k)]-Rho[ai(u,v,w,m,m,k)]) / (1.0+fabs(rho[ai(u,v,w,m,m,k)])); if (tmpDist > Dist2) Dist2 = tmpDist; @@ -368,12 +368,12 @@ void EMGLLF_core( } } //Dist3=max(max((abs(pi-Pi))./(1+abs(Pi)))); - double Dist3 = 0.0; + float Dist3 = 0.0; for (int u=0; u<n; u++) { for (int v=0; v<k; v++) { - double tmpDist = fabs(pi[v]-Pi[v]) / (1.0+fabs(pi[v])); + float tmpDist = fabs(pi[v]-Pi[v]) / (1.0+fabs(pi[v])); if (tmpDist > Dist3) Dist3 = tmpDist; } diff --git a/src/sources/EMGLLF.h b/src/sources/EMGLLF.h index d09d27c..005c05b 100644 --- a/src/sources/EMGLLF.h +++ b/src/sources/EMGLLF.h @@ -3,23 +3,23 @@ void EMGLLF_core( // IN parameters - const double* phiInit, - const double* rhoInit, - const double* piInit, - const double* gamInit, + const float* phiInit, + const float* rhoInit, + const float* piInit, + const float* gamInit, int mini, int maxi, - double gamma, - double lambda, - const double* X, - const double* Y, - double tau, + float gamma, + float lambda, + const float* X, + const float* Y, + float tau, // OUT parameters - double* phi, - double* rho, - double* pi, - double* LLF, - double* S, + float* phi, + float* rho, + float* pi, + float* LLF, + float* S, // additional size parameters int n, int p, diff --git a/src/sources/EMGrank.c b/src/sources/EMGrank.c index 0791892..3d5a9c7 100644 --- a/src/sources/EMGrank.c +++ b/src/sources/EMGrank.c @@ -3,13 +3,13 @@ #include "utils.h" // Compute pseudo-inverse of a square matrix -static double* pinv(const double* matrix, int dim) +static float* pinv(const float* matrix, int dim) { gsl_matrix* U = gsl_matrix_alloc(dim,dim); gsl_matrix* V = gsl_matrix_alloc(dim,dim); gsl_vector* S = gsl_vector_alloc(dim); gsl_vector* work = gsl_vector_alloc(dim); - double EPS = 1e-10; //threshold for singular value "== 0" + float EPS = 1e-10; //threshold for singular value "== 0" //copy matrix into U copyArray(matrix, U->data, dim*dim); @@ -19,12 +19,12 @@ static double* pinv(const double* matrix, int dim) gsl_vector_free(work); // Obtain pseudo-inverse by V*S^{-1}*t(U) - double* inverse = (double*)malloc(dim*dim*sizeof(double)); + float* inverse = (float*)malloc(dim*dim*sizeof(float)); for (int i=0; i<dim; i++) { for (int ii=0; ii<dim; ii++) { - double dotProduct = 0.0; + float dotProduct = 0.0; for (int j=0; j<dim; j++) dotProduct += V->data[i*dim+j] * (S->data[j] > EPS ? 1.0/S->data[j] : 0.0) * U->data[ii*dim+j]; inverse[i*dim+ii] = dotProduct; @@ -40,17 +40,17 @@ static double* pinv(const double* matrix, int dim) // TODO: comment EMGrank purpose void EMGrank_core( // IN parameters - const double* Pi, // parametre de proportion - const double* Rho, // parametre initial de variance renormalisé + const float* Pi, // parametre de proportion + const float* Rho, // parametre initial de variance renormalisé int mini, // nombre minimal d'itérations dans l'algorithme EM int maxi, // nombre maximal d'itérations dans l'algorithme EM - const double* X, // régresseurs - const double* Y, // réponse - double tau, // seuil pour accepter la convergence + const float* X, // régresseurs + const float* Y, // réponse + float tau, // seuil pour accepter la convergence const int* rank, // vecteur des rangs possibles // OUT parameters - double* phi, // parametre de moyenne renormalisé, calculé par l'EM - double* LLF, // log vraisemblance associé à cet échantillon, pour les valeurs estimées des paramètres + float* phi, // parametre de moyenne renormalisé, calculé par l'EM + float* LLF, // log vraisemblance associé à cet échantillon, pour les valeurs estimées des paramètres // additional size parameters int n, // taille de l'echantillon int p, // nombre de covariables @@ -58,20 +58,20 @@ void EMGrank_core( int k) // nombre de composantes { // Allocations, initializations - double* Phi = (double*)calloc(p*m*k,sizeof(double)); - double* hatBetaR = (double*)malloc(p*m*sizeof(double)); + float* Phi = (float*)calloc(p*m*k,sizeof(float)); + float* hatBetaR = (float*)malloc(p*m*sizeof(float)); int signum; - double invN = 1.0/n; + float invN = 1.0/n; int deltaPhiBufferSize = 20; - double* deltaPhi = (double*)malloc(deltaPhiBufferSize*sizeof(double)); + float* deltaPhi = (float*)malloc(deltaPhiBufferSize*sizeof(float)); int ite = 0; - double sumDeltaPhi = 0.0; - double* YiRhoR = (double*)malloc(m*sizeof(double)); - double* XiPhiR = (double*)malloc(m*sizeof(double)); - double* Xr = (double*)malloc(n*p*sizeof(double)); - double* Yr = (double*)malloc(n*m*sizeof(double)); - double* tXrXr = (double*)malloc(p*p*sizeof(double)); - double* tXrYr = (double*)malloc(p*m*sizeof(double)); + float sumDeltaPhi = 0.0; + float* YiRhoR = (float*)malloc(m*sizeof(float)); + float* XiPhiR = (float*)malloc(m*sizeof(float)); + float* Xr = (float*)malloc(n*p*sizeof(float)); + float* Yr = (float*)malloc(n*m*sizeof(float)); + float* tXrXr = (float*)malloc(p*p*sizeof(float)); + float* tXrYr = (float*)malloc(p*m*sizeof(float)); gsl_matrix* matrixM = gsl_matrix_alloc(p, m); gsl_matrix* matrixE = gsl_matrix_alloc(m, m); gsl_permutation* permutation = gsl_permutation_alloc(m); @@ -115,7 +115,7 @@ void EMGrank_core( { for (int jj=0; jj<p; jj++) { - double dotProduct = 0.0; + float dotProduct = 0.0; for (int u=0; u<cardClustR; u++) dotProduct += Xr[mi(u,j,n,p)] * Xr[mi(u,jj,n,p)]; tXrXr[mi(j,jj,p,p)] = dotProduct; @@ -123,14 +123,14 @@ void EMGrank_core( } //Get pseudo inverse = (t(Xr)*Xr)^{-1} - double* invTXrXr = pinv(tXrXr, p); + float* invTXrXr = pinv(tXrXr, p); // Compute tXrYr = t(Xr) * Yr for (int j=0; j<p; j++) { for (int jj=0; jj<m; jj++) { - double dotProduct = 0.0; + float dotProduct = 0.0; for (int u=0; u<cardClustR; u++) dotProduct += Xr[mi(u,j,n,p)] * Yr[mi(u,j,n,m)]; tXrYr[mi(j,jj,p,m)] = dotProduct; @@ -142,7 +142,7 @@ void EMGrank_core( { for (int jj=0; jj<m; jj++) { - double dotProduct = 0.0; + float dotProduct = 0.0; for (int u=0; u<p; u++) dotProduct += invTXrXr[mi(j,u,p,p)] * tXrYr[mi(u,jj,p,m)]; matrixM->data[j*m+jj] = dotProduct; @@ -164,7 +164,7 @@ void EMGrank_core( { for (int jj=0; jj<m; jj++) { - double dotProduct = 0.0; + float dotProduct = 0.0; for (int u=0; u<m; u++) dotProduct += U[j*m+u] * S->data[u] * V->data[jj*m+u]; hatBetaR[mi(j,jj,p,m)] = dotProduct; @@ -176,7 +176,7 @@ void EMGrank_core( { for (int jj=0; jj<m; jj++) { - double dotProduct=0.0; + float dotProduct=0.0; for (int u=0; u<m; u++) dotProduct += hatBetaR[mi(j,u,p,m)] * Rho[ai(u,jj,r,m,m,k)]; phi[ai(j,jj,r,p,m,k)] = dotProduct; @@ -188,11 +188,11 @@ void EMGrank_core( // Etape E // ///////////// - double sumLogLLF2 = 0.0; + float sumLogLLF2 = 0.0; for (int i=0; i<n; i++) { - double sumLLF1 = 0.0; - double maxLogGamIR = -INFINITY; + float sumLLF1 = 0.0; + float maxLogGamIR = -INFINITY; for (int r=0; r<k; r++) { //Compute @@ -207,7 +207,7 @@ void EMGrank_core( matrixE->data[j*m+jj] = Rho[ai(j,jj,r,m,m,k)]; } gsl_linalg_LU_decomp(matrixE, permutation, &signum); - double detRhoR = gsl_linalg_LU_det(matrixE, signum); + float detRhoR = gsl_linalg_LU_det(matrixE, signum); //compute Y(i,:)*Rho(:,:,r) for (int j=0; j<m; j++) @@ -226,10 +226,10 @@ void EMGrank_core( } //compute dotProduct < Y(:,i)*rho(:,:,r)-X(i,:)*phi(:,:,r) . Y(:,i)*rho(:,:,r)-X(i,:)*phi(:,:,r) > - double dotProduct = 0.0; + float dotProduct = 0.0; for (int u=0; u<m; u++) dotProduct += (YiRhoR[u]-XiPhiR[u]) * (YiRhoR[u]-XiPhiR[u]); - double logGamIR = log(Pi[r]) + log(detRhoR) - 0.5*dotProduct; + float logGamIR = log(Pi[r]) + log(detRhoR) - 0.5*dotProduct; //Z(i) = index of max (gam(i,:)) if (logGamIR > maxLogGamIR) @@ -247,14 +247,14 @@ void EMGrank_core( *LLF = -invN * sumLogLLF2; //newDeltaPhi = max(max((abs(phi-Phi))./(1+abs(phi)))); - double newDeltaPhi = 0.0; + float newDeltaPhi = 0.0; for (int j=0; j<p; j++) { for (int jj=0; jj<m; jj++) { for (int r=0; r<k; r++) { - double tmpDist = fabs(phi[ai(j,jj,r,p,m,k)]-Phi[ai(j,jj,r,p,m,k)]) + float tmpDist = fabs(phi[ai(j,jj,r,p,m,k)]-Phi[ai(j,jj,r,p,m,k)]) / (1.0+fabs(phi[ai(j,jj,r,p,m,k)])); if (tmpDist > newDeltaPhi) newDeltaPhi = tmpDist; diff --git a/src/sources/EMGrank.h b/src/sources/EMGrank.h index 8123e68..92c3f73 100644 --- a/src/sources/EMGrank.h +++ b/src/sources/EMGrank.h @@ -3,17 +3,17 @@ void EMGrank_core( // IN parameters - const double* Pi, - const double* Rho, + const float* Pi, + const float* Rho, int mini, int maxi, - const double* X, - const double* Y, - double tau, + const float* X, + const float* Y, + float tau, const int* rank, // OUT parameters - double* phi, - double* LLF, + float* phi, + float* LLF, // additional size parameters int n, int p, diff --git a/src/sources/constructionModelesLassoMLE.c b/src/sources/constructionModelesLassoMLE.c index 4ab62ad..a48f7d0 100644 --- a/src/sources/constructionModelesLassoMLE.c +++ b/src/sources/constructionModelesLassoMLE.c @@ -7,25 +7,25 @@ // TODO: comment on constructionModelesLassoMLE purpose void constructionModelesLassoMLE_core( // IN parameters - const double* phiInit, // parametre initial de moyenne renormalisé - const double* rhoInit, // parametre initial de variance renormalisé - const double* piInit,// parametre initial des proportions - const double* gamInit, // paramètre initial des probabilités a posteriori de chaque échantillon + const float* phiInit, // parametre initial de moyenne renormalisé + const float* rhoInit, // parametre initial de variance renormalisé + const float* piInit,// parametre initial des proportions + const float* gamInit, // paramètre initial des probabilités a posteriori de chaque échantillon int mini,// nombre minimal d'itérations dans l'algorithme EM int maxi,// nombre maximal d'itérations dans l'algorithme EM - double gamma,// valeur de gamma : puissance des proportions dans la pénalisation pour un Lasso adaptatif - const double* glambda, // valeur des paramètres de régularisation du Lasso - const double* X, // régresseurs - const double* Y, // réponse - double seuil,// seuil pour prendre en compte une variable - double tau,// seuil pour accepter la convergence + float gamma,// valeur de gamma : puissance des proportions dans la pénalisation pour un Lasso adaptatif + const float* glambda, // valeur des paramètres de régularisation du Lasso + const float* X, // régresseurs + const float* Y, // réponse + float seuil,// seuil pour prendre en compte une variable + float tau,// seuil pour accepter la convergence const int* A1, // matrice des coefficients des parametres selectionnes const int* A2, // matrice des coefficients des parametres non selectionnes // OUT parameters - double* phi,// estimateur ainsi calculé par le Lasso - double* rho,// estimateur ainsi calculé par le Lasso - double* pi, // estimateur ainsi calculé par le Lasso - double* lvraisemblance, // estimateur ainsi calculé par le Lasso + float* phi,// estimateur ainsi calculé par le Lasso + float* rho,// estimateur ainsi calculé par le Lasso + float* pi, // estimateur ainsi calculé par le Lasso + float* lvraisemblance, // estimateur ainsi calculé par le Lasso // additional size parameters int n, // taille de l'echantillon int p, // nombre de covariables @@ -58,7 +58,7 @@ void constructionModelesLassoMLE_core( continue; //Xa = X(:,a) - double* Xa = (double*)malloc(n*lengthA*sizeof(double)); + float* Xa = (float*)malloc(n*lengthA*sizeof(float)); for (int i=0; i<n; i++) { for (int j=0; j<lengthA; j++) @@ -66,7 +66,7 @@ void constructionModelesLassoMLE_core( } //phia = phiInit(a,:,:) - double* phia = (double*)malloc(lengthA*m*k*sizeof(double)); + float* phia = (float*)malloc(lengthA*m*k*sizeof(float)); for (int j=0; j<lengthA; j++) { for (int mm=0; mm<m; mm++) @@ -78,11 +78,11 @@ void constructionModelesLassoMLE_core( //[phiLambda,rhoLambda,piLambda,~,~] = EMGLLF(... // phiInit(a,:,:),rhoInit,piInit,gamInit,mini,maxi,gamma,0,X(:,a),Y,tau); - double* phiLambda = (double*)malloc(lengthA*m*k*sizeof(double)); - double* rhoLambda = (double*)malloc(m*m*k*sizeof(double)); - double* piLambda = (double*)malloc(k*sizeof(double)); - double* LLF = (double*)malloc((maxi+1)*sizeof(double)); - double* S = (double*)malloc(lengthA*m*k*sizeof(double)); + float* phiLambda = (float*)malloc(lengthA*m*k*sizeof(float)); + float* rhoLambda = (float*)malloc(m*m*k*sizeof(float)); + float* piLambda = (float*)malloc(k*sizeof(float)); + float* LLF = (float*)malloc((maxi+1)*sizeof(float)); + float* S = (float*)malloc(lengthA*m*k*sizeof(float)); EMGLLF_core(phia,rhoInit,piInit,gamInit,mini,maxi,gamma,0.0,Xa,Y,tau, phiLambda,rhoLambda,piLambda,LLF,S, n,lengthA,m,k); @@ -154,12 +154,12 @@ void constructionModelesLassoMLE_core( free(b); int signum; - double* densite = (double*)calloc(L*n,sizeof(double)); - double sumLogDensit = 0.0; + float* densite = (float*)calloc(L*n,sizeof(float)); + float sumLogDensit = 0.0; gsl_matrix* matrix = gsl_matrix_alloc(m, m); gsl_permutation* permutation = gsl_permutation_alloc(m); - double* YiRhoR = (double*)malloc(m*sizeof(double)); - double* XiPhiR = (double*)malloc(m*sizeof(double)); + float* YiRhoR = (float*)malloc(m*sizeof(float)); + float* XiPhiR = (float*)malloc(m*sizeof(float)); for (int i=0; i<n; i++) { //~ for r=1:k @@ -176,7 +176,7 @@ void constructionModelesLassoMLE_core( matrix->data[u*m+v] = rho[ai4(u,v,r,lambdaIndex,m,m,k,L)]; } gsl_linalg_LU_decomp(matrix, permutation, &signum); - double detRhoR = gsl_linalg_LU_det(matrix, signum); + float detRhoR = gsl_linalg_LU_det(matrix, signum); //compute Y(i,:)*rho(:,:,r,lambdaIndex) for (int u=0; u<m; u++) @@ -196,7 +196,7 @@ void constructionModelesLassoMLE_core( // On peut remplacer X par Xa dans ce dernier calcul, mais je ne sais pas si c'est intéressant ... // compute dotProduct < delta . delta > - double dotProduct = 0.0; + float dotProduct = 0.0; for (int u=0; u<m; u++) dotProduct += (YiRhoR[u]-XiPhiR[u]) * (YiRhoR[u]-XiPhiR[u]); diff --git a/src/sources/constructionModelesLassoMLE.h b/src/sources/constructionModelesLassoMLE.h index 6a20dc7..2058e48 100644 --- a/src/sources/constructionModelesLassoMLE.h +++ b/src/sources/constructionModelesLassoMLE.h @@ -3,25 +3,25 @@ void constructionModelesLassoMLE_core( // IN parameters - const double* phiInit, - const double* rhoInit, - const double* piInit, - const double* gamInit, + const float* phiInit, + const float* rhoInit, + const float* piInit, + const float* gamInit, int mini, int maxi, - double gamma, - const double* glambda, - const double* X, - const double* Y, - double seuil, - double tau, + float gamma, + const float* glambda, + const float* X, + const float* Y, + float seuil, + float tau, const int* A1, const int* A2, // OUT parameters - double* phi, - double* rho, - double* pi, - double* lvraisemblance, + float* phi, + float* rho, + float* pi, + float* lvraisemblance, // additional size parameters int n, int p, diff --git a/src/sources/constructionModelesLassoRank.c b/src/sources/constructionModelesLassoRank.c index e7712a9..031e76c 100644 --- a/src/sources/constructionModelesLassoRank.c +++ b/src/sources/constructionModelesLassoRank.c @@ -7,19 +7,19 @@ // TODO: comment on constructionModelesLassoRank purpose void constructionModelesLassoRank_core( // IN parameters - const double* Pi,// parametre initial des proportions - const double* Rho, // parametre initial de variance renormalisé + const float* Pi,// parametre initial des proportions + const float* Rho, // parametre initial de variance renormalisé int mini, // nombre minimal d'itérations dans l'algorithme EM int maxi, // nombre maximal d'itérations dans l'algorithme EM - const double* X,// régresseurs - const double* Y,// réponse - double tau, // seuil pour accepter la convergence + const float* X,// régresseurs + const float* Y,// réponse + float tau, // seuil pour accepter la convergence const int* A1, // matrice des coefficients des parametres selectionnes int rangmin, //rang minimum autorisé int rangmax, //rang maximum autorisé // OUT parameters (all pointers, to be modified) - double* phi,// estimateur ainsi calculé par le Lasso - double* lvraisemblance,// estimateur ainsi calculé par le Lasso + float* phi,// estimateur ainsi calculé par le Lasso + float* lvraisemblance,// estimateur ainsi calculé par le Lasso // additional size parameters int n,// taille de l'echantillon int p,// nombre de covariables @@ -73,24 +73,24 @@ for (int r=0; r<k; r++) continue; //from now on, longueurActive > 0 - double* phiLambda = (double*)malloc(longueurActive*m*k*sizeof(double)); - double LLF; + float* phiLambda = (float*)malloc(longueurActive*m*k*sizeof(float)); + float LLF; for (int j=0; j<Size; j++) { //[phiLambda,LLF] = EMGrank(Pi(:,lambdaIndex),Rho(:,:,:,lambdaIndex),mini,maxi,X(:,active),Y,tau,Rank(j,:)); int* rank = (int*)malloc(k*sizeof(int)); for (int r=0; r<k; r++) rank[r] = Rank[mi(j,r,Size,k)]; - double* Xactive = (double*)malloc(n*longueurActive*sizeof(double)); + float* Xactive = (float*)malloc(n*longueurActive*sizeof(float)); for (int i=0; i<n; i++) { for (int jj=0; jj<longueurActive; jj++) Xactive[mi(i,jj,n,longueurActive)] = X[mi(i,active[jj],n,p)]; } - double* PiLambda = (double*)malloc(k*sizeof(double)); + float* PiLambda = (float*)malloc(k*sizeof(float)); for (int r=0; r<k; r++) PiLambda[r] = Pi[mi(r,lambdaIndex,k,L)]; - double* RhoLambda = (double*)malloc(m*m*k*sizeof(double)); + float* RhoLambda = (float*)malloc(m*m*k*sizeof(float)); for (int u=0; u<m; u++) { for (int v=0; v<m; v++) @@ -109,7 +109,7 @@ for (int r=0; r<k; r++) //lvraisemblance((lambdaIndex-1)*Size+j,:) = [LLF, dot(Rank(j,:), length(active)-Rank(j,:)+m)]; lvraisemblance[mi(lambdaIndex*Size+j,0,L*Size,2)] = LLF; //dot(Rank(j,:), length(active)-Rank(j,:)+m) - double dotProduct = 0.0; + float dotProduct = 0.0; for (int r=0; r<k; r++) dotProduct += Rank[mi(j,r,Size,k)] * (longueurActive-Rank[mi(j,r,Size,k)]+m); lvraisemblance[mi(lambdaIndex*Size+j,1,Size*L,2)] = dotProduct; diff --git a/src/sources/constructionModelesLassoRank.h b/src/sources/constructionModelesLassoRank.h index 56951d7..60f6623 100644 --- a/src/sources/constructionModelesLassoRank.h +++ b/src/sources/constructionModelesLassoRank.h @@ -4,19 +4,19 @@ // Main job on raw inputs (after transformation from mxArray) void constructionModelesLassoRank_core( // IN parameters - const double* Pi, - const double* Rho, + const float* Pi, + const float* Rho, int mini, int maxi, - const double* X, - const double* Y, - double tau, + const float* X, + const float* Y, + float tau, const int* A1, int rangmin, int rangmax, // OUT parameters - double* phi, - double* lvraisemblance, + float* phi, + float* lvraisemblance, // additional size parameters int n, int p, diff --git a/src/sources/selectiontotale.c b/src/sources/selectiontotale.c index 04ec0a4..3b2e015 100644 --- a/src/sources/selectiontotale.c +++ b/src/sources/selectiontotale.c @@ -7,23 +7,23 @@ // Main job on raw inputs (after transformation from mxArray) void selectiontotale_core( // IN parameters - const double* phiInit, // parametre initial de moyenne renormalisé - const double* rhoInit, // parametre initial de variance renormalisé - const double* piInit,// parametre initial des proportions - const double* gamInit, // paramètre initial des probabilités a posteriori de chaque échantillon + const float* phiInit, // parametre initial de moyenne renormalisé + const float* rhoInit, // parametre initial de variance renormalisé + const float* piInit,// parametre initial des proportions + const float* gamInit, // paramètre initial des probabilités a posteriori de chaque échantillon int mini, // nombre minimal d'itérations dans lambdaIndex'algorithme EM int maxi, // nombre maximal d'itérations dans lambdaIndex'algorithme EM - double gamma, // valeur de gamma : puissance des proportions dans la pénalisation pour un Lasso adaptatif - const double* glambda, // valeur des paramètres de régularisation du Lasso - const double* X,// régresseurs - const double* Y,// réponse - double seuil, // seuil pour prendre en compte une variable - double tau, // seuil pour accepter la convergence + float gamma, // valeur de gamma : puissance des proportions dans la pénalisation pour un Lasso adaptatif + const float* glambda, // valeur des paramètres de régularisation du Lasso + const float* X,// régresseurs + const float* Y,// réponse + float seuil, // seuil pour prendre en compte une variable + float tau, // seuil pour accepter la convergence // OUT parameters (all pointers, to be modified) int* A1, // matrice des coefficients des parametres selectionnes int* A2, // matrice des coefficients des parametres non selectionnes - double* Rho,// estimateur ainsi calculé par le Lasso - double* Pi,// estimateur ainsi calculé par le Lasso + float* Rho,// estimateur ainsi calculé par le Lasso + float* Pi,// estimateur ainsi calculé par le Lasso // additional size parameters int n,// taille de lambdaIndex'echantillon int p,// nombre de covariables @@ -51,11 +51,11 @@ void selectiontotale_core( for (lambdaIndex=0; lambdaIndex<L; lambdaIndex++) { //allocate output variables - double* phi = (double*)malloc(p*m*k*sizeof(double)); - double* rho = (double*)malloc(m*m*k*sizeof(double)); - double* pi = (double*)malloc(k*sizeof(double)); - double* LLF = (double*)malloc(maxi*sizeof(double)); - double* S = (double*)malloc(p*m*k*sizeof(double)); + float* phi = (float*)malloc(p*m*k*sizeof(float)); + float* rho = (float*)malloc(m*m*k*sizeof(float)); + float* pi = (float*)malloc(k*sizeof(float)); + float* LLF = (float*)malloc(maxi*sizeof(float)); + float* S = (float*)malloc(p*m*k*sizeof(float)); EMGLLF_core(phiInit,rhoInit,piInit,gamInit,mini,maxi,gamma,glambda[lambdaIndex],X,Y,tau, phi,rho,pi,LLF,S, n,p,m,k); @@ -72,7 +72,7 @@ void selectiontotale_core( int cpt2 = 0; for (int jj=0; jj<m; jj++) { - double maxPhi = 0.0; + float maxPhi = 0.0; for (int r=0; r<k; r++) { if (fabs(phi[ai(j,jj,r,p,m,k)]) > maxPhi) diff --git a/src/sources/selectiontotale.h b/src/sources/selectiontotale.h index fa2ba84..d225592 100644 --- a/src/sources/selectiontotale.h +++ b/src/sources/selectiontotale.h @@ -4,23 +4,23 @@ // Main job on raw inputs (after transformation from mxArray) void selectiontotale_core( // IN parameters - const double* phiInit, - const double* rhoInit, - const double* piInit, - const double* gamInit, + const float* phiInit, + const float* rhoInit, + const float* piInit, + const float* gamInit, int mini, int maxi, - double gamma, - const double* glambda, - const double* X, - const double* Y, - double seuil, - double tau, + float gamma, + const float* glambda, + const float* X, + const float* Y, + float seuil, + float tau, // OUT parameters int* A1, int* A2, - double* Rho, - double* Pi, + float* Rho, + float* Pi, // additional size parameters int n, int p, diff --git a/src/test/.Makefile.swp b/src/test/.Makefile.swp deleted file mode 100644 index bfa54d3242d716f99d03e59d79aec9385f9d18f4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12288 zcmeI2Pfyf96u{q-ctAvrUObMn2sLSoaDhgQuq<p%7Yqyjxv(kI*=1$uY&u<u(F8w& zUOjmAOX#=I@8CD^W_;5Y5TdN^!Gz>B`R(j<Uf;a^b>`4)x2GQabvElv0UlQYW<Kmc zoxbn`W`+U6UL+E8zR$7qvMZ8~iu;6tyAwrjBDzYuFG8t>s}t^~LZ@y$+!d{k6#X*L zI2j-V0~zS0EqitpW~T3ETYc=-O?Lg-=0K_FA~HY*$N(8217v^<kO4A42F|B}v|EA$ zEPbdbf1+qhr`n=R4H+N<WPl8i0Wv@a$N(8217v^<kO4Aq4h@76z|;u9H^lt^fB5|W z{R+Tm<UO*FaO6HRhKwK=kvEqC4iJg>NDZ-(A*6(S8U=WVyhSupLsk$#zFq?Of_y|? zBd?GI@sS#`fJ`8_ksHVmQbMvi&!J~3nGBEtGC&5%02v?yWPl9(M+1)YsJ6EH%wwUH zj7t&5jAsqNaI(kj7AsE%{-TA=MzyhFK|bo`u}4979K{^R)vA|pp<V1kmc_$}@?@oA zF<Y_n17>qpzK6Lg%fZ4*!({bWE5YVcwPC@yqdYe5@KcwRw@e93M;DkfnumQbZwWhE zNWoKl(Rf3pp%fnb-B~Q@WG#P@n5$T)NiWM?R}oI5gHUU=9>%-HEN6ubGG(>Ck{o9* zdV?hTQ(^U>+NX4k7-T}MH3*iA+<E8MG<qjYL{zMU6Ye2jVxGCr{$g`&@u7w9m`hol zu=3lPXFU3DB;}nme&|0$n_HTPpIS}$=vgdLHqUJTc$Gs@ES}B_Z>(25htE68%7(C; z4efVi#KR;yxj}dqgaO$b?@g`};b;ZL!fu*XZsrTr_H&on@;K@+#EeSZp|Y(de)4S@ zYSUADUC6hWiD)xhr_p>n?#<0H`$??q&R$n`cqg@6y*OLgb|knAlhAA+sF<4DoWoBS CK4?1t diff --git a/src/test/Makefile b/src/test/Makefile index 796b424..459a5cb 100644 --- a/src/test/Makefile +++ b/src/test/Makefile @@ -1,8 +1,8 @@ CC = gcc CFLAGS = -g -std=gnu99 -Wno-implicit-function-declaration LDFLAGS = -lm -lgsl -lcblas -lgomp -LDFLAGS_TEST = -Lobj/ -lvalse_core -LIB = valse_core.so +TEST_LDFLAGS = -L. libvalse_core.so +LIB = libvalse_core.so LIB_SRC = $(wildcard ../sources/*.c) LIB_OBJ = $(LIB_SRC:.c=.o) INCLUDES = -I../sources @@ -12,23 +12,23 @@ all: $(LIB) test.EMGLLF test.EMGrank test.constructionModelesLassoMLE test.EMGra $(LIB): $(LIB_OBJ) $(CC) -shared -o $@ $^ $(LDFLAGS) -test.EMGLLF: test.EMGLLF.o +test.EMGLLF: test.EMGLLF.o utils.o $(CC) -o $@ $^ $(LDFLAGS) $(TEST_LDFLAGS) -test.constructionModelesLassoMLE: test.constructionModelesLassoMLE.o +test.constructionModelesLassoMLE: test.constructionModelesLassoMLE.o utils.o $(CC) -o $@ $^ $(LDFLAGS) $(TEST_LDFLAGS) -test.EMGrank: test.EMGrank.o +test.EMGrank: test.EMGrank.o utils.o $(CC) -o $@ $^ $(LDFLAGS) $(TEST_LDFLAGS) -test.constructionModelesLassoRank: test.constructionModelesLassoRank.o +test.constructionModelesLassoRank: test.constructionModelesLassoRank.o utils.o $(CC) -o $@ $^ $(LDFLAGS) $(TEST_LDFLAGS) -test.selectionTotale: test.selectionTotale.o +test.selectionTotale: test.selectionTotale.o utils.o $(CC) -o $@ $^ $(LDFLAGS) $(TEST_LDFLAGS) %.o: %.c - $(CC) -o $@ -c $< $(CFLAGS) $(INCLUDES) + $(CC) -fPIC -o $@ -c $< $(CFLAGS) $(INCLUDES) clean: rm -f *.o ../sources/*.o diff --git a/src/test/OLD_TEST_MATLAB/TODO b/src/test/OLD_TEST_MATLAB/TODO index d4b05cf..73301dd 100644 --- a/src/test/OLD_TEST_MATLAB/TODO +++ b/src/test/OLD_TEST_MATLAB/TODO @@ -1,4 +1,3 @@ 1) transformer les .m en .R -2) sauvegarder les résultats + entrée/sorties à partir du code R uniquement -3) dans test.Truc.c, prendre en entrée les paramètres de data/ juste sauvegardés, - puis comparer les sorties aux sorties enregistrées +2) sauvegarder les résultats + entrée/sorties à partir du code R uniquement, + dans le dossier src/test/data (** sous forme de vecteurs, sep=" " **) diff --git a/src/test/test.EMGLLF.c b/src/test/test.EMGLLF.c index e938b3a..1720641 100644 --- a/src/test/test.EMGLLF.c +++ b/src/test/test.EMGLLF.c @@ -68,8 +68,8 @@ int main(int argc, char** argv) free(pi); free(ref_pi); - float* ref_LLF = readArray_real("LLF", maxi); - compareArray_real("LLF", LLF, ref_LLF); + float* ref_LLF = readArray_real("LLF"); + compareArray_real("LLF", LLF, ref_LLF, maxi); free(LLF); free(ref_LLF); diff --git a/src/test/utils.c b/src/test/utils.c index 8895cda..a6370b0 100644 --- a/src/test/utils.c +++ b/src/test/utils.c @@ -1,3 +1,8 @@ +#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) @@ -44,7 +49,7 @@ void* readArray(const char* fileName, int isinteger) strcat(command, " | wc -l"); FILE *countSpaces = popen(command, "r"); char* buffer = (char*)calloc(32, sizeof(char)); - fgets(buffer, sizeof(buffer), command); + fgets(buffer, sizeof(buffer), countSpaces); int n = atoi(buffer) + 1; free(buffer); pclose(countSpaces); @@ -92,7 +97,7 @@ int* readArray_int(const char* fileName) float* readArray_real(const char* fileName) { - return (int*)readArray(fileName, 0); + return (float*)readArray(fileName, 0); } int read_int(const char* fileName) -- 2.44.0