summaryrefslogtreecommitdiff
path: root/src/c/matrixOperations/interfaces/int_cumprod.h
blob: 722efbbafb08c3887ad25c4eea6e3f9157f45b56 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
// 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


#ifndef __INT_CUMPROD_H__
#define __INT_CUMPROD_H__


#ifdef  __cplusplus
#extern "C" {
#endif

#define d0cumprodd0(in) in
#define s0cumprods0(in) in
#define u80cumprodu80(in) in
#define u160cumprodu160(in) in
#define i80cumprodi80(in) in
#define i160cumprodi160(in) in

#define d2cumprodd2(in1, size1, out) dcumproda(in1, size1[0], size1[1], out)
#define s2cumprods2(in1, size1, out) scumproda(in1, size1[0], size1[1], out)
#define u82cumprodu82(in1, size1, out) u8cumproda(in1, size1[0], size1[1], out)
#define u162cumprodu162(in1, size1, out) u16cumproda(in1, size1[0], size1[1], out)
#define i82cumprodi82(in1, size1, out) i8cumproda(in1, size1[0], size1[1], out)
#define i162cumprodi162(in1, size1, out) i16cumproda(in1, size1[0], size1[1], out)

#define d2g2cumprodd2(in1, size1, in2, size2, out) (in2[0]=='r') ? \
						drowcumproda(in1,size1[0],size1[1],out) : dcolumncumproda(in1,size1[0],size1[1],out)
#define s2g2cumprods2(in1, size1, in2, size2, out) (in2[0]=='r') ? \
						srowcumproda(in1,size1[0],size1[1],out) : scolumncumproda(in1,size1[0],size1[1],out)
#define u82g2cumprodu82(in1, size1, in2, size2, out) (in2[0]=='r') ? \
						u8rowcumproda(in1,size1[0],size1[1],out) : u8columncumproda(in1,size1[0],size1[1],out)
#define i82g2cumprodi82(in1, size1, in2, size2, out) (in2[0]=='r') ? \
						i8rowcumproda(in1,size1[0],size1[1],out) : i8columncumproda(in1,size1[0],size1[1],out)
#define u162g2cumprodu162(in1, size1, in2, size2, out) (in2[0]=='r') ? \
						u16rowcumproda(in1,size1[0],size1[1],out) : u16columncumproda(in1,size1[0],size1[1],out)
#define i162g2cumprodi162(in1, size1, in2, size2, out) (in2[0]=='r') ? \
						i16rowcumproda(in1,size1[0],size1[1],out) : i16columncumproda(in1,size1[0],size1[1],out)



#ifdef  __cplusplus
#} /* extern "C" */
#endif

#endif /*__INT_CUMPROD_H__*/