summaryrefslogtreecommitdiff
path: root/src/c
diff options
context:
space:
mode:
Diffstat (limited to 'src/c')
-rw-r--r--src/c/differential_calculus/diff/u16dissca.c203
1 files changed, 0 insertions, 203 deletions
diff --git a/src/c/differential_calculus/diff/u16dissca.c b/src/c/differential_calculus/diff/u16dissca.c
deleted file mode 100644
index d83a9e6..0000000
--- a/src/c/differential_calculus/diff/u16dissca.c
+++ /dev/null
@@ -1,203 +0,0 @@
-/* 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: Siddhesh Wani
- Organization: FOSSEE, IIT Bombay
- Email: toolbox@scilab.in
-*/
-
- /* This function calculates difference between adjacent members of given
- input array/matrix */
-
-#include "diffc.h"
-
-
-void u16diffca(uint16 *in, int row, int col, int depth, int dim, uint16 *out)
-{
- int counter, depth_count;
- int row_count, col_count;
- uint16 *buffer; /*To store intermediate results*/
-
- depth_count = 1;
-
- if(dim == 0)
- { /*For dim = 0, we calculate difference between adjacent elements
- in case of arrays. In case of matrices, we calculate difference along
- first column, and then continue to second (diff between first element
- of second column and last element of first column, then third etc.*/
- if(depth == 1)
- {/*for depth=1, a buffer is not needed. Directly write result in
- out buffer*/
- for(counter = 0; counter < row*col - depth_count; counter++)
- {
- out[counter] = in[counter+1] - in[counter];
- }
- }
- else
- { /*define buffer for storing intermediate results*/
-
- buffer = (uint16 *) malloc (sizeof(uint16)*(row*col-1));
-
- while(depth_count <= depth)
- {
- if(depth_count == 1)
- {
- /*calculate diff and store in buffer*/
- for(counter = 0; counter < row*col - depth_count; counter++)
- {
- buffer[counter] = in[counter+1] - in[counter];
- }
- }
- else if(depth_count < depth)
- {
- for(counter = 0; counter <= row*col - depth_count ; counter++)
- {
- buffer[counter] = buffer[counter+1] - buffer[counter];
- }
- }
- /*For last step use output buffer to store result*/
- else
- {
- for(counter = 0; counter < row*col - depth_count; counter++)
- {
- out[counter] = buffer[counter+1] - buffer[counter];
- }
- }
- depth_count += 1;
- }
- }
-
- }
- else if(dim == 1)
- {
- /*For dim = 1, difference is calculated along rows. Each element of
- first row is subtracted from corresponding element of second row and
- result is stored in first row. Same thing is repeated till last row. */
-
- if (depth == 1)
- {
- /*If depth is 1, store result directly in out buffer*/
- for(col_count = 0; col_count < col; col_count++)
- {
- for(row_count = 0; row_count < row - 1; row_count++)
- {
- out[col_count*(row-1)+row_count] = in[col_count*row + row_count+1] \
- - in[col_count*row + row_count];
- }
- }
- }
- else
- {
- /*If depth is not 1, declare a buffer to store intermediate
- results. At last step store result into out buffer*/
- buffer = (uint16 *) malloc (sizeof(uint16)*((row-1)*col));
-
- while(depth_count <= depth)
- {
- if(depth_count == 1)
- {
- /*For first step, use in buffer and store results in buffer*/
- for(col_count = 0; col_count < col; col_count++)
- {
- for(row_count = 0; row_count < row - 1; row_count++)
- {
- buffer[col_count*row+row_count] = in[col_count*row + row_count + 1] \
- - in[col_count*row + row_count];
- }
-
- }
- }
- else if(depth_count < depth)
- {
- for(col_count = 0; col_count < col; col_count++)
- {
- for(row_count = 0; row_count < row - depth_count; row_count++)
- {
- buffer[col_count*row+row_count] = buffer[col_count*row + row_count + 1] \
- - buffer[col_count*row + row_count];
- }
-
- }
- }
- else
- {
- for(col_count = 0; col_count < col; col_count++)
- {
- for(row_count = 0; row_count < row - depth_count; row_count++)
- {
- out[col_count*(row-depth_count)+row_count] = buffer[col_count*row + row_count+1] \
- - buffer[col_count*row + row_count];
- }
- }
- }
- depth_count +=1;
- }
- }
- }
- else if(dim == 2)
- {
- /*For dim = 2, difference is calculated along columns. Each element of
- first column is subtracted from corresponding element of second column
- and result is stored in first column. Same thing is repeated till last
- column. */
- if(depth == 1)
- {
- for(row_count = 0; row_count < row; row_count++)
- {
- for(col_count = 0; col_count < col - 1; col_count++)
- {
- out[col_count*row+row_count] = in[(col_count+1)*row + row_count] \
- - in[col_count*row + row_count];
- }
- }
- }
- else
- {
- /*If depth is not 1, declare a buffer to store intermediate
- results. At last step store result into out buffer*/
- buffer = (uint16 *) malloc (sizeof(uint16)*(row*(col-1)));
-
- while(depth_count <= depth)
- {
- if(depth_count == 1)
- {
- for(row_count = 0; row_count < row; row_count++)
- {
- for(col_count = 0; col_count < col - 1; col_count++)
- {
- buffer[col_count*row+row_count] = in[(col_count+1)*row + row_count] \
- - in[col_count*row + row_count];
- }
- }
- }
- else if(depth_count < depth)
- {
- for(row_count = 0; row_count < row; row_count++)
- {
- for(col_count = 0; col_count < col - depth_count; col_count++)
- {
- buffer[col_count*row+row_count] = buffer[(col_count+1)*row + row_count] \
- - buffer[col_count*row + row_count];
- }
- }
- }
- else
- {
- for(row_count = 0; row_count < row; row_count++)
- {
- for(col_count = 0; col_count < col - depth_count; col_count++)
- {
- out[col_count*row+row_count] = buffer[(col_count+1)*row + row_count] \
- - buffer[col_count*row + row_count];
- }
- }
- }
- depth_count += 1;
- }
- }
- }
-}