mexopencv  3.4.1
MEX interface for OpenCV library
getGaborKernel.cpp
Go to the documentation of this file.
1 
8 #include "mexopencv.hpp"
9 #include "opencv2/imgproc.hpp"
10 using namespace std;
11 using namespace cv;
12 
20 void mexFunction(int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[])
21 {
22  // Check the number of arguments
23  nargchk((nrhs%2)==0 && nlhs<=1);
24 
25  // Argument vector
26  vector<MxArray> rhs(prhs, prhs+nrhs);
27 
28  // Option processing
29  Size ksize(21,21);
30  double sigma = 5.0;
31  double theta = CV_PI*0.25;
32  double lambd = 10.0;
33  double gamma = 0.75;
34  double psi = CV_PI*0.5;
35  int ktype = CV_64F;
36  for (int i=0; i<nrhs; i+=2) {
37  string key(rhs[i].toString());
38  if (key == "KSize")
39  ksize = rhs[i+1].toSize();
40  else if (key == "Sigma")
41  sigma = rhs[i+1].toDouble();
42  else if (key == "Theta")
43  theta = rhs[i+1].toDouble();
44  else if (key == "Lambda")
45  lambd = rhs[i+1].toDouble();
46  else if (key == "Gamma")
47  gamma = rhs[i+1].toDouble();
48  else if (key == "Psi")
49  psi = rhs[i+1].toDouble();
50  else if (key == "KType")
51  ktype = (rhs[i+1].isChar()) ?
52  ClassNameMap[rhs[i+1].toString()] : rhs[i+1].toInt();
53  else
54  mexErrMsgIdAndTxt("mexopencv:error",
55  "Unrecognized option %s", key.c_str());
56  }
57 
58  // Process
59  Mat kernel = getGaborKernel(ksize, sigma, theta, lambd, gamma, psi, ktype);
60  plhs[0] = MxArray(kernel);
61 }
#define CV_PI
const ConstMap< std::string, int > ClassNameMap
Translates class name used in MATLAB to equivalent OpenCV depth.
Definition: mexopencv.hpp:27
void mexFunction(int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[])
Main entry called from Matlab.
Mat getGaborKernel(Size ksize, double sigma, double theta, double lambd, double gamma, double psi=CV_PI *0.5, int ktype=CV_64F)
STL namespace.
struct mxArray_tag mxArray
Forward declaration for mxArray.
Definition: matrix.h:259
#define CV_64F
LIBMWMEX_API_EXTERN_C void mexErrMsgIdAndTxt(const char *identifier, const char *err_msg,...)
Issue formatted error message with corresponding error identifier and return to MATLAB prompt...
mxArray object wrapper for data conversion and manipulation.
Definition: MxArray.hpp:123
void nargchk(bool cond)
Alias for input/output arguments number check.
Definition: mexopencv.hpp:181
STL class.
Global constant definitions.
T c_str(T... args)