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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
|
/****************************************
Author: Sridhar Reddy
*****************************************/
#include <numeric>
#include "opencv2/core/core.hpp"
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/opencv.hpp"
#include <iostream>
using namespace cv;
using namespace std;
extern "C"
{
#include "api_scilab.h"
#include "Scierror.h"
#include "BOOL.h"
#include <localization.h>
#include "sciprint.h"
#include "../common.h"
int opencv_fftnew(char *fname, unsigned long fname_len)
{
SciErr sciErr;
int intErr=0;
int iRows=0,iCols=0,i,j;
int *piAddr1=NULL;
double *ipReal=NULL;
double *ipImg=NULL;
double *rsltReal=NULL;
double *rsltImg=NULL;
vector<complex<double> > vec_out;
vector<double> vec_in;
CheckInputArgument(pvApiCtx, 1, 1);
CheckOutputArgument(pvApiCtx, 1, 1) ;
sciErr = getVarAddressFromPosition(pvApiCtx, 1, &piAddr1);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return 0;
}
sciErr = getMatrixOfDouble(pvApiCtx, piAddr1, &iRows, &iCols, &ipReal);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return 0;
}
ipImg = (double*)malloc(sizeof(double) * iRows * iCols);
if(iRows==1){
for(i = 0 ; i <iCols ; i++)
vec_in.push_back(ipReal[i]);
dft(vec_in,vec_out, DFT_COMPLEX_OUTPUT);
for(i = 0 ; i < iCols ; i++){
ipReal[i]=real(vec_out[i]);
ipImg[i]=imag(vec_out[i]);
}
vec_in.clear();
vec_out.clear();
}
else{
for(i = 0 ; i < iCols ; i++){
for(j = 0 ; j < iRows ; j++)
vec_in.push_back(ipReal[j+iCols*i]);
dft(vec_in,vec_out,DFT_COMPLEX_OUTPUT);
for(j = 0 ; j < iRows ; j++){
ipReal[j+iCols*i]=real(vec_out[j]);
ipImg[j+iCols*i]=imag(vec_out[j]);
}
vec_in.clear();
vec_out.clear();
}
}
sciErr = allocComplexMatrixOfDouble(pvApiCtx, nbInputArgument(pvApiCtx) + 1, iRows, iCols, &rsltReal, &rsltImg);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return 0;
}
for(i = 0 ; i < iRows * iCols; i++)
{
rsltReal[i]=ipReal[i];
rsltImg[i]=ipImg[i];
}
AssignOutputVariable(pvApiCtx, 1) = nbInputArgument(pvApiCtx) + 1;
ReturnArguments(pvApiCtx);
return 0;
}
}
|