diff options
author | Brijeshcr | 2017-08-10 19:38:31 +0530 |
---|---|---|
committer | Brijeshcr | 2017-08-10 19:38:31 +0530 |
commit | 4bc007e5b44a13b582b0275bf7fc6693942ba2ac (patch) | |
tree | 85bbdf6358c3c8eb5dd5dfaeb63029808f06ae3e /src/c/linearAlgebra/range | |
parent | 14fc3be8d95da244daa1fa12d519ceee8fb97eae (diff) | |
download | Scilab2C_fossee_old-4bc007e5b44a13b582b0275bf7fc6693942ba2ac.tar.gz Scilab2C_fossee_old-4bc007e5b44a13b582b0275bf7fc6693942ba2ac.tar.bz2 Scilab2C_fossee_old-4bc007e5b44a13b582b0275bf7fc6693942ba2ac.zip |
Added Gamma, gammaln, beta, isinf, ndgrid and range
Diffstat (limited to 'src/c/linearAlgebra/range')
-rw-r--r-- | src/c/linearAlgebra/range/drangea.c | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/src/c/linearAlgebra/range/drangea.c b/src/c/linearAlgebra/range/drangea.c new file mode 100644 index 0000000..7627f24 --- /dev/null +++ b/src/c/linearAlgebra/range/drangea.c @@ -0,0 +1,78 @@ +/* Copyright (C) 2016 - IIT Bombay - FOSSEE + + This file must be used under the terms of the CeCILL. + This source file is licensed as described in the file COPYING, which + you should have received as part of this distribution. The terms + are also available at + http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt + Author: Brijesh Gupta C R + Organization: FOSSEE, IIT Bombay + Email: toolbox@scilab.in +*/ + +#include <stdio.h> +#include <stdlib.h> +#include <math.h> +#include "range.h" + +double drangea(double* inp1, int row, int col, double inp2, double* out1) +{ + double a[row*col], aprod[row*col], dim = 0, u[row*row], utrans[row*row], o[row*row], unew[row*col], otemp[row*col]; + if (inp2 == 0) + { + deyea(out1, row, col); + return row; + + } + + dim = drowcompa(1,inp1,row,col,NULL,0,u); + + + for(int i = 0; i < row*row; i++) + o[i] = u[i]; + + for(int i = 0; i < row*col; i++) + a[i] = inp1[i]; + + dtransposea(u,row,row, utrans); + + + for(int i = 2; i <= inp2; i++) + { + + dmulma(a, row, col, utrans, row, row, aprod); + + for(int i = 0; i < row*col; i++) + a[i] = aprod[i]; + + + double acut[row*(int)dim]; + + for(int i = 0; i < row*dim; i++) + acut[i] = a[i]; + + + + dim = drowcompa(1,acut,row,(int)dim,NULL,0,unew); + + for(int i = 0; i < row*col; i++) + u[i] = unew[i]; + + + + dmulma(u, row, row, o, row, col, otemp); + + for(int i = 0; i < row*col; i++) + o[i] = otemp[i]; + + + } + + + + for(int i = 0; i < row*col; i++) + out1[i] = o[i]; + + return dim; + +} |