diff options
author | Brijeshcr | 2017-07-06 15:49:18 +0530 |
---|---|---|
committer | GitHub | 2017-07-06 15:49:18 +0530 |
commit | 850c0ff1ca5cd660b76d0568a215bab0547312ad (patch) | |
tree | 26fc9679644561759e8a2c4080059d30b70a3105 /2.3-1/src/c/elementaryFunctions/linspace/slinspacea.c | |
parent | a7eeecce4c7c39ea52a2d434815c574a2c42730d (diff) | |
parent | c600ebcb67961fe6007ba41fd5ad987da3af7f6e (diff) | |
download | Scilab2C-850c0ff1ca5cd660b76d0568a215bab0547312ad.tar.gz Scilab2C-850c0ff1ca5cd660b76d0568a215bab0547312ad.tar.bz2 Scilab2C-850c0ff1ca5cd660b76d0568a215bab0547312ad.zip |
Merge pull request #4 from FOSSEE/revert-3-master
Revert "LinearAlgebra Function Added"
Diffstat (limited to '2.3-1/src/c/elementaryFunctions/linspace/slinspacea.c')
-rw-r--r-- | 2.3-1/src/c/elementaryFunctions/linspace/slinspacea.c | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/2.3-1/src/c/elementaryFunctions/linspace/slinspacea.c b/2.3-1/src/c/elementaryFunctions/linspace/slinspacea.c new file mode 100644 index 00000000..38af3942 --- /dev/null +++ b/2.3-1/src/c/elementaryFunctions/linspace/slinspacea.c @@ -0,0 +1,49 @@ +/* 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: Ukasha Noor + Organization: FOSSEE, IIT Bombay + Email: toolbox@scilab.in +*/ +#include <stdlib.h> +#include "linspace.h" + +void slinspacea(float *low_limit,int _row,float *up_limit,float range_num,float *out) +{ + int i,j,k; + float temp; + float *step_iterate; /* for each row the spacing between two values is different.*/ + step_iterate = (float*) malloc((float)_row*sizeof(float)); + for(i=0;i<_row;i++) + { + + step_iterate[i] = (up_limit[i]-low_limit[i])/(range_num-1); + + } + for(j=0;j < _row;j++) + { + out[j] = low_limit[j]; /* For every row first element is the first value of low_limit array*/ + temp = low_limit[j]; + for(k=1;k < (float)range_num;k++ ) + { + out[(_row*k)+j] = temp + step_iterate[j]; /* Output matrix positions for 3 X 5 matrix are [0 3 6 9 12;1 4 7 10 13;2 5 8 11 14] so (_row*k)+j) used*/ + temp = out[(_row*k)+j]; + if(k == (float)range_num-1 ) + { + out[(_row*k)+j] = (float)up_limit[j]; /* Last value of output is equal to first value of up_limit array*/ + } + + } + + + } + + + + +} + |