1 | <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> |
---|
2 | <html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> |
---|
3 | <title>mixpp: itmex.h Source File</title> |
---|
4 | <link href="tabs.css" rel="stylesheet" type="text/css"> |
---|
5 | <link href="doxygen.css" rel="stylesheet" type="text/css"> |
---|
6 | </head><body> |
---|
7 | <!-- Generated by Doxygen 1.5.8 --> |
---|
8 | <script type="text/javascript"> |
---|
9 | <!-- |
---|
10 | function changeDisplayState (e){ |
---|
11 | var num=this.id.replace(/[^[0-9]/g,''); |
---|
12 | var button=this.firstChild; |
---|
13 | var sectionDiv=document.getElementById('dynsection'+num); |
---|
14 | if (sectionDiv.style.display=='none'||sectionDiv.style.display==''){ |
---|
15 | sectionDiv.style.display='block'; |
---|
16 | button.src='open.gif'; |
---|
17 | }else{ |
---|
18 | sectionDiv.style.display='none'; |
---|
19 | button.src='closed.gif'; |
---|
20 | } |
---|
21 | } |
---|
22 | function initDynSections(){ |
---|
23 | var divs=document.getElementsByTagName('div'); |
---|
24 | var sectionCounter=1; |
---|
25 | for(var i=0;i<divs.length-1;i++){ |
---|
26 | if(divs[i].className=='dynheader'&&divs[i+1].className=='dynsection'){ |
---|
27 | var header=divs[i]; |
---|
28 | var section=divs[i+1]; |
---|
29 | var button=header.firstChild; |
---|
30 | if (button!='IMG'){ |
---|
31 | divs[i].insertBefore(document.createTextNode(' '),divs[i].firstChild); |
---|
32 | button=document.createElement('img'); |
---|
33 | divs[i].insertBefore(button,divs[i].firstChild); |
---|
34 | } |
---|
35 | header.style.cursor='pointer'; |
---|
36 | header.onclick=changeDisplayState; |
---|
37 | header.id='dynheader'+sectionCounter; |
---|
38 | button.src='closed.gif'; |
---|
39 | section.id='dynsection'+sectionCounter; |
---|
40 | section.style.display='none'; |
---|
41 | section.style.marginLeft='14px'; |
---|
42 | sectionCounter++; |
---|
43 | } |
---|
44 | } |
---|
45 | } |
---|
46 | window.onload = initDynSections; |
---|
47 | --> |
---|
48 | </script> |
---|
49 | <div class="navigation" id="top"> |
---|
50 | <div class="tabs"> |
---|
51 | <ul> |
---|
52 | <li><a href="main.html"><span>Main Page</span></a></li> |
---|
53 | <li><a href="pages.html"><span>Related Pages</span></a></li> |
---|
54 | <li><a href="modules.html"><span>Modules</span></a></li> |
---|
55 | <li><a href="annotated.html"><span>Classes</span></a></li> |
---|
56 | <li class="current"><a href="files.html"><span>Files</span></a></li> |
---|
57 | </ul> |
---|
58 | </div> |
---|
59 | <div class="tabs"> |
---|
60 | <ul> |
---|
61 | <li><a href="files.html"><span>File List</span></a></li> |
---|
62 | <li><a href="globals.html"><span>File Members</span></a></li> |
---|
63 | </ul> |
---|
64 | </div> |
---|
65 | <h1>itmex.h</h1><a href="itmex_8h.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 |
---|
66 | <a name="l00029"></a>00029 <span class="preprocessor">#ifndef ITMEX_H</span> |
---|
67 | <a name="l00030"></a>00030 <span class="preprocessor"></span><span class="preprocessor">#define ITMEX_H</span> |
---|
68 | <a name="l00031"></a>00031 <span class="preprocessor"></span> |
---|
69 | <a name="l00032"></a>00032 <span class="preprocessor">#include <<a class="code" href="itbase_8h.html" title="Include file for the IT++ base module.">itpp/itbase.h</a>></span> |
---|
70 | <a name="l00033"></a>00033 <span class="preprocessor">#include <mex.h></span> |
---|
71 | <a name="l00034"></a>00034 |
---|
72 | <a name="l00035"></a>00035 |
---|
73 | <a name="l00036"></a>00036 <span class="keyword">namespace </span>itpp |
---|
74 | <a name="l00037"></a>00037 { |
---|
75 | <a name="l00038"></a>00038 |
---|
76 | <a name="l00039"></a>00039 <span class="comment">//--------------------------------------------------------</span> |
---|
77 | <a name="l00040"></a>00040 <span class="comment">// mex -> it++</span> |
---|
78 | <a name="l00041"></a>00041 <span class="comment">//--------------------------------------------------------</span> |
---|
79 | <a name="l00042"></a>00042 |
---|
80 | <a name="l00088"></a>00088 <span class="comment">// --------------------------------------------------------</span> |
---|
81 | <a name="l00089"></a>00089 <span class="comment">// mex -> IT++</span> |
---|
82 | <a name="l00090"></a>00090 <span class="comment">// --------------------------------------------------------</span> |
---|
83 | <a name="l00091"></a>00091 |
---|
84 | <a name="l00093"></a>00093 bin <a class="code" href="group__mexfiles.html#gc78ba4be4a066402f96e511adeabc9b6" title="Convert the matlab-format mxArray to bin.">mxArray2bin</a>(<span class="keyword">const</span> mxArray *in); |
---|
85 | <a name="l00095"></a>00095 <span class="keywordtype">short</span> <a class="code" href="group__mexfiles.html#gfc3458b6a75fd121fe8ce2afa708408d" title="Convert the matlab-format mxArray to short.">mxArray2short</a>(<span class="keyword">const</span> mxArray *in); |
---|
86 | <a name="l00097"></a>00097 <span class="keywordtype">int</span> <a class="code" href="group__mexfiles.html#gc0d9ead5b652d552a51129bfa29f0aea" title="Convert the matlab-format mxArray to int.">mxArray2int</a>(<span class="keyword">const</span> mxArray *in); |
---|
87 | <a name="l00099"></a>00099 <span class="keywordtype">double</span> <a class="code" href="group__mexfiles.html#g68e9d2587f3e0e37c89940e0e7cb8153" title="Convert the matlab-format mxArray to double.">mxArray2double</a>(<span class="keyword">const</span> mxArray *in); |
---|
88 | <a name="l00101"></a>00101 std::complex<double> <a class="code" href="group__mexfiles.html#g3e58103a674bb9839794b0c4a1f3cada" title="Convert the matlab-format mxArray to complex&lt;double&gt;.">mxArray2double_complex</a>(<span class="keyword">const</span> mxArray *in); |
---|
89 | <a name="l00103"></a>00103 std::string <a class="code" href="group__mexfiles.html#ga7d28675ac76cb6b100f27801c5d8787" title="Convert the matlab-format mxArray to string.">mxArray2string</a>(<span class="keyword">const</span> mxArray *in); |
---|
90 | <a name="l00104"></a>00104 |
---|
91 | <a name="l00106"></a>00106 bvec <a class="code" href="group__mexfiles.html#g397d757bf73eaa16b1aebd67b95a4d8f" title="Convert the matlab-format mxArray to bvec.">mxArray2bvec</a>(<span class="keyword">const</span> mxArray *in); |
---|
92 | <a name="l00108"></a>00108 svec <a class="code" href="group__mexfiles.html#gf003d047a1a757ef5648a4ea7bc6113c" title="Convert the matlab-format mxArray to svec.">mxArray2svec</a>(<span class="keyword">const</span> mxArray *in); |
---|
93 | <a name="l00110"></a>00110 ivec <a class="code" href="group__mexfiles.html#g731f7774860420a05421d750670cb291" title="Convert the matlab-format mxArray to ivec.">mxArray2ivec</a>(<span class="keyword">const</span> mxArray *in); |
---|
94 | <a name="l00112"></a>00112 vec <a class="code" href="group__mexfiles.html#g808dd4e9161849d15f885fc86c5454e5" title="Convert the matlab-format mxArray to vec.">mxArray2vec</a>(<span class="keyword">const</span> mxArray *in); |
---|
95 | <a name="l00114"></a>00114 cvec <a class="code" href="group__mexfiles.html#g3dc0c8a0aff8d5a79633e9a3db603976" title="Convert the matlab-format mxArray to cvec.">mxArray2cvec</a>(<span class="keyword">const</span> mxArray *in); |
---|
96 | <a name="l00115"></a>00115 |
---|
97 | <a name="l00117"></a>00117 <a class="code" href="mat_8h.html#f90acd1af41bf2d1d8a4bb23662fff69" title="bin matrix">bmat</a> <a class="code" href="group__mexfiles.html#g4cf7ac093d387fbc02e454642c18ddff" title="Convert the matlab-format mxArray to bmat.">mxArray2bmat</a>(<span class="keyword">const</span> mxArray *in); |
---|
98 | <a name="l00119"></a>00119 smat <a class="code" href="group__mexfiles.html#g575ddd65f32c826ff412c7eb7a98994c" title="Convert the matlab-format mxArray to smat.">mxArray2smat</a>(<span class="keyword">const</span> mxArray *in); |
---|
99 | <a name="l00121"></a>00121 imat <a class="code" href="group__mexfiles.html#g9672b0ae7328382bbf43850d60ad23d0" title="Convert the matlab-format mxArray to imat.">mxArray2imat</a>(<span class="keyword">const</span> mxArray *in); |
---|
100 | <a name="l00123"></a>00123 mat <a class="code" href="group__mexfiles.html#g2adb0970c31c7febf62850fabed65c5c" title="Convert the matlab-format mxArray to mat.">mxArray2mat</a>(<span class="keyword">const</span> mxArray *in); |
---|
101 | <a name="l00125"></a>00125 cmat <a class="code" href="group__mexfiles.html#gf21de941d8ecde5fd50bd53ac96c405e" title="Convert the matlab-format mxArray to cmat.">mxArray2cmat</a>(<span class="keyword">const</span> mxArray *in); |
---|
102 | <a name="l00126"></a>00126 |
---|
103 | <a name="l00127"></a>00127 <span class="comment">// --------------------------------------------------------</span> |
---|
104 | <a name="l00128"></a>00128 <span class="comment">// IT++ -> mex</span> |
---|
105 | <a name="l00129"></a>00129 <span class="comment">// --------------------------------------------------------</span> |
---|
106 | <a name="l00130"></a>00130 |
---|
107 | <a name="l00132"></a>00132 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#ge017e7ba24ff5296669c99fdc2aed0ff" title="Convert bin to the matlab-format mxArray.">bin2mxArray</a>(<span class="keyword">const</span> bin &in, mxArray *out); |
---|
108 | <a name="l00134"></a>00134 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g910673a250a28c2359c29f1f84ad68c9" title="Convert short to the matlab-format mxArray.">short2mxArray</a>(<span class="keyword">const</span> <span class="keywordtype">short</span> &in, mxArray *out); |
---|
109 | <a name="l00136"></a>00136 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gabcf89548804db251ff413c3d0057527" title="Convert int to the matlab-format mxArray.">int2mxArray</a>(<span class="keyword">const</span> <span class="keywordtype">int</span> &in, mxArray *out); |
---|
110 | <a name="l00138"></a>00138 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g75ed25c51a4943584b6e2fcf8e6bb720" title="Convert double to the matlab-format mxArray.">double2mxArray</a>(<span class="keyword">const</span> <span class="keywordtype">double</span> &in, mxArray *out); |
---|
111 | <a name="l00140"></a>00140 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g16bc1d8cd7516a74aa37e29826c75f38" title="Convert complex&lt;double&gt; to the matlab-format mxArray.">double_complex2mxArray</a>(<span class="keyword">const</span> std::complex<double> &in, mxArray *out); |
---|
112 | <a name="l00142"></a>00142 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gf072ee06b8ae430cc5b8b6868f51702e" title="Convert string to the matlab-format mxArray.">string2mxArray</a>(<span class="keyword">const</span> std::string &in, mxArray* &out); |
---|
113 | <a name="l00143"></a>00143 |
---|
114 | <a name="l00145"></a>00145 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gc97de915a25eac08caca7c8ef5fc9058" title="Convert bvec to the matlab-format mxArray.">bvec2mxArray</a>(<span class="keyword">const</span> bvec &in, mxArray *out); |
---|
115 | <a name="l00147"></a>00147 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g08d7d878248ef3d5f31b721cbc9b0d14" title="Convert svec to the matlab-format mxArray.">svec2mxArray</a>(<span class="keyword">const</span> svec &in, mxArray *out); |
---|
116 | <a name="l00149"></a>00149 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g62fcc542613bc7a0613427ecb877a0a0" title="Convert ivec to the matlab-format mxArray.">ivec2mxArray</a>(<span class="keyword">const</span> ivec &in, mxArray *out); |
---|
117 | <a name="l00151"></a>00151 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gd1f0678a5b5a93a20c50aef0bf7bf211" title="Convert vec to the matlab-format mxArray.">vec2mxArray</a>(<span class="keyword">const</span> vec &in, mxArray *out); |
---|
118 | <a name="l00153"></a>00153 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gd1a7f07847740d4dc813a4785b73ba44" title="Convert cvec to the matlab-format mxArray.">cvec2mxArray</a>(<span class="keyword">const</span> cvec &in, mxArray *out); |
---|
119 | <a name="l00154"></a>00154 |
---|
120 | <a name="l00156"></a>00156 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gf9524573874f8e6314cb02837d7ede3a" title="Convert bmat to the matlab-format mxArray.">bmat2mxArray</a>(<span class="keyword">const</span> <a class="code" href="mat_8h.html#f90acd1af41bf2d1d8a4bb23662fff69" title="bin matrix">bmat</a> &in, mxArray *out); |
---|
121 | <a name="l00158"></a>00158 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g2686ae6b181d6b1490916d68d0f28ed1" title="Convert smat to the matlab-format mxArray.">smat2mxArray</a>(<span class="keyword">const</span> smat &in, mxArray *out); |
---|
122 | <a name="l00160"></a>00160 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gd1871047cece783b84d6ec3472778d15" title="Convert imat to the matlab-format mxArray.">imat2mxArray</a>(<span class="keyword">const</span> imat &in, mxArray *out); |
---|
123 | <a name="l00162"></a>00162 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g662aa389e9c98b92a4880e2ab1241779" title="Convert mat to the matlab-format mxArray.">mat2mxArray</a>(<span class="keyword">const</span> mat &in, mxArray *out); |
---|
124 | <a name="l00164"></a>00164 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g57c21d0729a206659cdff4eafb397bd2" title="Convert cmat to the matlab-format mxArray.">cmat2mxArray</a>(<span class="keyword">const</span> cmat &in, mxArray *out); |
---|
125 | <a name="l00165"></a>00165 |
---|
126 | <a name="l00166"></a>00166 <span class="comment">// --------------------------------------------------------</span> |
---|
127 | <a name="l00167"></a>00167 <span class="comment">// mex -> C</span> |
---|
128 | <a name="l00168"></a>00168 <span class="comment">// --------------------------------------------------------</span> |
---|
129 | <a name="l00169"></a>00169 |
---|
130 | <a name="l00171"></a>00171 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g2fb857731c56da75778f3b9ff4a2ab26" title="Convert the matlab-format mxArray to C-format pointer to short.">mxArray2Csvec</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">short</span> *out); |
---|
131 | <a name="l00173"></a>00173 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gafc87420b618496149acd189c0a125d6" title="Convert the matlab-format mxArray to C-format pointer to int.">mxArray2Civec</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">int</span> *out); |
---|
132 | <a name="l00175"></a>00175 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gfda111aa6e327339d771fa6456695475" title="Convert the matlab-format mxArray to C-format pointer to double.">mxArray2Cvec</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">double</span> *out); |
---|
133 | <a name="l00177"></a>00177 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g32173752abe2bcbdd698377ebbef660f" title="Convert the matlab-format mxArray to C-format pointers to double (real and imaginary...">mxArray2Ccvec</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">double</span> *out_real, <span class="keywordtype">double</span> *out_imag); |
---|
134 | <a name="l00178"></a>00178 |
---|
135 | <a name="l00180"></a>00180 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gac0f1fe44f6e61a72621bcdc3ae35dbc" title="Convert the matlab-format mxArray to C-format pointer to pointer to short.">mxArray2Csmat</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">short</span> **out); |
---|
136 | <a name="l00182"></a>00182 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g856cf3cd63fc72836ca8f2007fdcc42c" title="Convert the matlab-format mxArray to C-format pointer to pointer to int.">mxArray2Cimat</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">int</span> **out); |
---|
137 | <a name="l00184"></a>00184 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g52a848d56a73ea66e5130bb58e061a51" title="Convert the matlab-format mxArray to C-format pointer to pointer to double.">mxArray2Cmat</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">double</span> **out); |
---|
138 | <a name="l00186"></a>00186 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gf8dffb515e935d83a980c79ff61a270f" title="Convert the matlab-format mxArray to C-format pointer to pointer to double (real...">mxArray2Ccmat</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">double</span> **out_real, <span class="keywordtype">double</span> **out_imag); |
---|
139 | <a name="l00187"></a>00187 |
---|
140 | <a name="l00188"></a>00188 <span class="comment">// --------------------------------------------------------</span> |
---|
141 | <a name="l00189"></a>00189 <span class="comment">// C -> mex</span> |
---|
142 | <a name="l00190"></a>00190 <span class="comment">// --------------------------------------------------------</span> |
---|
143 | <a name="l00191"></a>00191 |
---|
144 | <a name="l00193"></a>00193 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gcc7700ff9ee3a2d8d434534c4519a833" title="Convert C-format pointer to short to matlab-format mxArray.">Csvec2mxArray</a>(<span class="keywordtype">short</span> *in, mxArray *out); |
---|
145 | <a name="l00195"></a>00195 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gcece7ce3e6101d8f3094b61be90a4de4" title="Convert C-format pointer to int to matlab-format mxArray.">Civec2mxArray</a>(<span class="keywordtype">int</span> *in, mxArray *out); |
---|
146 | <a name="l00197"></a>00197 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gb9bd9c76e9eddb4ac9b84268d660fe3e" title="Convert C-format pointer to double to matlab-format mxArray.">Cvec2mxArray</a>(<span class="keywordtype">double</span> *in, mxArray *out); |
---|
147 | <a name="l00199"></a>00199 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g157b049f32c1ae57dad33803932d5884" title="Convert C-format pointers to double (real and imaginary parts) to matlab-format mxArray...">Ccvec2mxArray</a>(<span class="keywordtype">double</span> *in_real, <span class="keywordtype">double</span> *in_imag, mxArray *out); |
---|
148 | <a name="l00200"></a>00200 |
---|
149 | <a name="l00202"></a>00202 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gffcc3047b69811b179eac1f5918a2eb0" title="Convert C-format pointer to pointer to short to matlab-format mxArray.">Csmat2mxArray</a>(<span class="keywordtype">short</span> **in, mxArray *out); |
---|
150 | <a name="l00204"></a>00204 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g30559d4f2e3376c4370b81f3450cbb50" title="Convert C-format pointer to pointer to int to matlab-format mxArray.">Cimat2mxArray</a>(<span class="keywordtype">int</span> **in, mxArray *out); |
---|
151 | <a name="l00206"></a>00206 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gb3154ff3fb563011aee4e9b206b09c1d" title="Convert C-format pointer to pointer to double to matlab-format mxArray.">Cmat2mxArray</a>(<span class="keywordtype">double</span> **in, mxArray *out); |
---|
152 | <a name="l00208"></a>00208 <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gaa443bad4a1c6b53ca10c5442a82afc4" title="Convert C-format pointer to pointer to double (real and imaginary parts) to matlab-format...">Ccmat2mxArray</a>(<span class="keywordtype">double</span> **in_real, <span class="keywordtype">double</span> **in_imag, mxArray *out); |
---|
153 | <a name="l00209"></a>00209 |
---|
154 | <a name="l00215"></a><a class="code" href="group__mexfiles.html#gc78ba4be4a066402f96e511adeabc9b6">00215</a> <a class="code" href="classitpp_1_1bin.html" title="Binary arithmetic (boolean) class.">bin</a> <a class="code" href="group__mexfiles.html#gc78ba4be4a066402f96e511adeabc9b6" title="Convert the matlab-format mxArray to bin.">mxArray2bin</a>(<span class="keyword">const</span> mxArray *in) |
---|
155 | <a name="l00216"></a>00216 { |
---|
156 | <a name="l00217"></a>00217 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a>; |
---|
157 | <a name="l00218"></a>00218 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
158 | <a name="l00219"></a>00219 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2bin: Pointer to data is NULL"</span>); |
---|
159 | <a name="l00220"></a>00220 size = mxGetNumberOfElements(in); |
---|
160 | <a name="l00221"></a>00221 <span class="keywordflow">if</span> (size != 1) mexErrMsgTxt(<span class="stringliteral">"mxArray2bin: Size of data is not equal to one"</span>); |
---|
161 | <a name="l00222"></a>00222 |
---|
162 | <a name="l00223"></a>00223 <span class="keywordflow">return</span> (((*temp) > 0.0) ? <a class="code" href="classitpp_1_1bin.html" title="Binary arithmetic (boolean) class.">bin</a>(1) : <a class="code" href="classitpp_1_1bin.html" title="Binary arithmetic (boolean) class.">bin</a>(0)); |
---|
163 | <a name="l00224"></a>00224 } |
---|
164 | <a name="l00225"></a>00225 |
---|
165 | <a name="l00226"></a><a class="code" href="group__mexfiles.html#gfc3458b6a75fd121fe8ce2afa708408d">00226</a> <span class="keywordtype">short</span> <a class="code" href="group__mexfiles.html#gfc3458b6a75fd121fe8ce2afa708408d" title="Convert the matlab-format mxArray to short.">mxArray2short</a>(<span class="keyword">const</span> mxArray *in) |
---|
166 | <a name="l00227"></a>00227 { |
---|
167 | <a name="l00228"></a>00228 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a>; |
---|
168 | <a name="l00229"></a>00229 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
169 | <a name="l00230"></a>00230 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2short: Pointer to data is NULL"</span>); |
---|
170 | <a name="l00231"></a>00231 size = mxGetNumberOfElements(in); |
---|
171 | <a name="l00232"></a>00232 <span class="keywordflow">if</span> (size != 1) mexErrMsgTxt(<span class="stringliteral">"mxArray2short: Size of data is not equal to one"</span>); |
---|
172 | <a name="l00233"></a>00233 |
---|
173 | <a name="l00234"></a>00234 <span class="keywordflow">return</span> (<span class="keywordtype">short</span>)(*temp); |
---|
174 | <a name="l00235"></a>00235 } |
---|
175 | <a name="l00236"></a>00236 |
---|
176 | <a name="l00237"></a><a class="code" href="group__mexfiles.html#gc0d9ead5b652d552a51129bfa29f0aea">00237</a> <span class="keywordtype">int</span> <a class="code" href="group__mexfiles.html#gc0d9ead5b652d552a51129bfa29f0aea" title="Convert the matlab-format mxArray to int.">mxArray2int</a>(<span class="keyword">const</span> mxArray *in) |
---|
177 | <a name="l00238"></a>00238 { |
---|
178 | <a name="l00239"></a>00239 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a>; |
---|
179 | <a name="l00240"></a>00240 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
180 | <a name="l00241"></a>00241 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2int: Pointer to data is NULL"</span>); |
---|
181 | <a name="l00242"></a>00242 size = mxGetNumberOfElements(in); |
---|
182 | <a name="l00243"></a>00243 <span class="keywordflow">if</span> (size != 1) mexErrMsgTxt(<span class="stringliteral">"mxArray2int: Size of data is not equal to one"</span>); |
---|
183 | <a name="l00244"></a>00244 |
---|
184 | <a name="l00245"></a>00245 <span class="keywordflow">return</span> (<span class="keywordtype">int</span>)(*temp); |
---|
185 | <a name="l00246"></a>00246 } |
---|
186 | <a name="l00247"></a>00247 |
---|
187 | <a name="l00248"></a><a class="code" href="group__mexfiles.html#g68e9d2587f3e0e37c89940e0e7cb8153">00248</a> <span class="keywordtype">double</span> <a class="code" href="group__mexfiles.html#g68e9d2587f3e0e37c89940e0e7cb8153" title="Convert the matlab-format mxArray to double.">mxArray2double</a>(<span class="keyword">const</span> mxArray *in) |
---|
188 | <a name="l00249"></a>00249 { |
---|
189 | <a name="l00250"></a>00250 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a>; |
---|
190 | <a name="l00251"></a>00251 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
191 | <a name="l00252"></a>00252 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2double: Pointer to data is NULL"</span>); |
---|
192 | <a name="l00253"></a>00253 size = mxGetNumberOfElements(in); |
---|
193 | <a name="l00254"></a>00254 <span class="keywordflow">if</span> (size != 1) mexErrMsgTxt(<span class="stringliteral">"mxArray2double: Size of data is not equal to one"</span>); |
---|
194 | <a name="l00255"></a>00255 |
---|
195 | <a name="l00256"></a>00256 <span class="keywordflow">return</span> (*temp); |
---|
196 | <a name="l00257"></a>00257 } |
---|
197 | <a name="l00258"></a>00258 |
---|
198 | <a name="l00259"></a><a class="code" href="group__mexfiles.html#g3e58103a674bb9839794b0c4a1f3cada">00259</a> std::complex<double> <a class="code" href="group__mexfiles.html#g3e58103a674bb9839794b0c4a1f3cada" title="Convert the matlab-format mxArray to complex&lt;double&gt;.">mxArray2double_complex</a>(<span class="keyword">const</span> mxArray *in) |
---|
199 | <a name="l00260"></a>00260 { |
---|
200 | <a name="l00261"></a>00261 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a>; |
---|
201 | <a name="l00262"></a>00262 <span class="keywordtype">double</span>* tempR = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
202 | <a name="l00263"></a>00263 <span class="keywordtype">double</span>* tempI = (<span class="keywordtype">double</span>*) mxGetPi(in); |
---|
203 | <a name="l00264"></a>00264 |
---|
204 | <a name="l00265"></a>00265 <span class="keywordflow">if</span> ((tempR == 0) && (tempI == 0)) mexErrMsgTxt(<span class="stringliteral">"mxArray2double_complex: Pointer to data is NULL"</span>); |
---|
205 | <a name="l00266"></a>00266 |
---|
206 | <a name="l00267"></a>00267 size = mxGetNumberOfElements(in); |
---|
207 | <a name="l00268"></a>00268 <span class="keywordflow">if</span> (size != 1) mexErrMsgTxt(<span class="stringliteral">"mxArray2double_complex: Size of data is not equal to one"</span>); |
---|
208 | <a name="l00269"></a>00269 |
---|
209 | <a name="l00270"></a>00270 <span class="keywordflow">if</span> (tempR == 0) { |
---|
210 | <a name="l00271"></a>00271 <span class="keywordflow">return</span> std::complex<double>(0.0 , (*tempI)); |
---|
211 | <a name="l00272"></a>00272 } |
---|
212 | <a name="l00273"></a>00273 <span class="keywordflow">else</span> <span class="keywordflow">if</span> (tempI == 0) { |
---|
213 | <a name="l00274"></a>00274 <span class="keywordflow">return</span> std::complex<double>((*tempR), 0.0); |
---|
214 | <a name="l00275"></a>00275 } |
---|
215 | <a name="l00276"></a>00276 <span class="keywordflow">else</span> { |
---|
216 | <a name="l00277"></a>00277 <span class="keywordflow">return</span> std::complex<double>((*tempR), (*tempI)); |
---|
217 | <a name="l00278"></a>00278 } |
---|
218 | <a name="l00279"></a>00279 |
---|
219 | <a name="l00280"></a>00280 } |
---|
220 | <a name="l00281"></a>00281 |
---|
221 | <a name="l00282"></a><a class="code" href="group__mexfiles.html#ga7d28675ac76cb6b100f27801c5d8787">00282</a> std::string <a class="code" href="group__mexfiles.html#ga7d28675ac76cb6b100f27801c5d8787" title="Convert the matlab-format mxArray to string.">mxArray2string</a>(<span class="keyword">const</span> mxArray *in) |
---|
222 | <a name="l00283"></a>00283 { |
---|
223 | <a name="l00284"></a>00284 <span class="keywordflow">if</span> (in == 0) |
---|
224 | <a name="l00285"></a>00285 mexErrMsgTxt(<span class="stringliteral">"mxArray2string: Pointer to data is NULL"</span>); |
---|
225 | <a name="l00286"></a>00286 std::string str = mxArrayToString(in); |
---|
226 | <a name="l00287"></a>00287 <span class="keywordflow">if</span> (str.data() == 0) |
---|
227 | <a name="l00288"></a>00288 mexErrMsgTxt(<span class="stringliteral">"mxArray2string: Could not convert mxArray to string"</span>); |
---|
228 | <a name="l00289"></a>00289 <span class="keywordflow">return</span> str; |
---|
229 | <a name="l00290"></a>00290 } |
---|
230 | <a name="l00291"></a>00291 |
---|
231 | <a name="l00292"></a><a class="code" href="group__mexfiles.html#g397d757bf73eaa16b1aebd67b95a4d8f">00292</a> bvec <a class="code" href="group__mexfiles.html#g397d757bf73eaa16b1aebd67b95a4d8f" title="Convert the matlab-format mxArray to bvec.">mxArray2bvec</a>(<span class="keyword">const</span> mxArray *in) |
---|
232 | <a name="l00293"></a>00293 { |
---|
233 | <a name="l00294"></a>00294 bvec out; |
---|
234 | <a name="l00295"></a>00295 <span class="keywordtype">int</span> i, <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a>; |
---|
235 | <a name="l00296"></a>00296 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
236 | <a name="l00297"></a>00297 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2bvec: Pointer to data is NULL"</span>); |
---|
237 | <a name="l00298"></a>00298 |
---|
238 | <a name="l00299"></a>00299 size = mxGetNumberOfElements(in); |
---|
239 | <a name="l00300"></a>00300 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2bvec: Size of data is zero"</span>); |
---|
240 | <a name="l00301"></a>00301 |
---|
241 | <a name="l00302"></a>00302 out.set_size(size, <span class="keyword">false</span>); |
---|
242 | <a name="l00303"></a>00303 |
---|
243 | <a name="l00304"></a>00304 <span class="keywordflow">for</span> (i = 0; i < size; i++) { |
---|
244 | <a name="l00305"></a>00305 out(i) = (((*temp++) > 1e-5) ? <a class="code" href="classitpp_1_1bin.html" title="Binary arithmetic (boolean) class.">bin</a>(1) : <a class="code" href="classitpp_1_1bin.html" title="Binary arithmetic (boolean) class.">bin</a>(0)); |
---|
245 | <a name="l00306"></a>00306 } |
---|
246 | <a name="l00307"></a>00307 |
---|
247 | <a name="l00308"></a>00308 <span class="keywordflow">return</span> out; |
---|
248 | <a name="l00309"></a>00309 |
---|
249 | <a name="l00310"></a>00310 } |
---|
250 | <a name="l00311"></a>00311 |
---|
251 | <a name="l00312"></a><a class="code" href="group__mexfiles.html#gf003d047a1a757ef5648a4ea7bc6113c">00312</a> svec <a class="code" href="group__mexfiles.html#gf003d047a1a757ef5648a4ea7bc6113c" title="Convert the matlab-format mxArray to svec.">mxArray2svec</a>(<span class="keyword">const</span> mxArray *in) |
---|
252 | <a name="l00313"></a>00313 { |
---|
253 | <a name="l00314"></a>00314 svec out; |
---|
254 | <a name="l00315"></a>00315 <span class="keywordtype">int</span> i, <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a>; |
---|
255 | <a name="l00316"></a>00316 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
256 | <a name="l00317"></a>00317 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2svec: Pointer to data is NULL"</span>); |
---|
257 | <a name="l00318"></a>00318 |
---|
258 | <a name="l00319"></a>00319 size = mxGetNumberOfElements(in); |
---|
259 | <a name="l00320"></a>00320 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2svec: Size of data is zero"</span>); |
---|
260 | <a name="l00321"></a>00321 |
---|
261 | <a name="l00322"></a>00322 out.set_size(size, <span class="keyword">false</span>); |
---|
262 | <a name="l00323"></a>00323 |
---|
263 | <a name="l00324"></a>00324 <span class="keywordflow">for</span> (i = 0; i < size; i++) { |
---|
264 | <a name="l00325"></a>00325 out(i) = (short)(*temp++); |
---|
265 | <a name="l00326"></a>00326 } |
---|
266 | <a name="l00327"></a>00327 |
---|
267 | <a name="l00328"></a>00328 <span class="keywordflow">return</span> out; |
---|
268 | <a name="l00329"></a>00329 |
---|
269 | <a name="l00330"></a>00330 } |
---|
270 | <a name="l00331"></a>00331 |
---|
271 | <a name="l00332"></a><a class="code" href="group__mexfiles.html#g731f7774860420a05421d750670cb291">00332</a> ivec <a class="code" href="group__mexfiles.html#g731f7774860420a05421d750670cb291" title="Convert the matlab-format mxArray to ivec.">mxArray2ivec</a>(<span class="keyword">const</span> mxArray *in) |
---|
272 | <a name="l00333"></a>00333 { |
---|
273 | <a name="l00334"></a>00334 ivec out; |
---|
274 | <a name="l00335"></a>00335 <span class="keywordtype">int</span> i, <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a>; |
---|
275 | <a name="l00336"></a>00336 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
276 | <a name="l00337"></a>00337 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2ivec: Pointer to data is NULL"</span>); |
---|
277 | <a name="l00338"></a>00338 |
---|
278 | <a name="l00339"></a>00339 size = mxGetNumberOfElements(in); |
---|
279 | <a name="l00340"></a>00340 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2ivec: Size of data is zero"</span>); |
---|
280 | <a name="l00341"></a>00341 |
---|
281 | <a name="l00342"></a>00342 out.set_size(size, <span class="keyword">false</span>); |
---|
282 | <a name="l00343"></a>00343 |
---|
283 | <a name="l00344"></a>00344 <span class="keywordflow">for</span> (i = 0; i < size; i++) { |
---|
284 | <a name="l00345"></a>00345 out(i) = (int)(*temp++); |
---|
285 | <a name="l00346"></a>00346 } |
---|
286 | <a name="l00347"></a>00347 |
---|
287 | <a name="l00348"></a>00348 <span class="keywordflow">return</span> out; |
---|
288 | <a name="l00349"></a>00349 |
---|
289 | <a name="l00350"></a>00350 } |
---|
290 | <a name="l00351"></a>00351 |
---|
291 | <a name="l00352"></a><a class="code" href="group__mexfiles.html#g808dd4e9161849d15f885fc86c5454e5">00352</a> vec <a class="code" href="group__mexfiles.html#g808dd4e9161849d15f885fc86c5454e5" title="Convert the matlab-format mxArray to vec.">mxArray2vec</a>(<span class="keyword">const</span> mxArray *in) |
---|
292 | <a name="l00353"></a>00353 { |
---|
293 | <a name="l00354"></a>00354 vec out; |
---|
294 | <a name="l00355"></a>00355 <span class="keywordtype">int</span> i, <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a>; |
---|
295 | <a name="l00356"></a>00356 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
296 | <a name="l00357"></a>00357 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2vec: Pointer to data is NULL"</span>); |
---|
297 | <a name="l00358"></a>00358 |
---|
298 | <a name="l00359"></a>00359 size = mxGetNumberOfElements(in); |
---|
299 | <a name="l00360"></a>00360 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2vec: Size of data is zero"</span>); |
---|
300 | <a name="l00361"></a>00361 |
---|
301 | <a name="l00362"></a>00362 out.set_size(size, <span class="keyword">false</span>); |
---|
302 | <a name="l00363"></a>00363 |
---|
303 | <a name="l00364"></a>00364 <span class="keywordflow">for</span> (i = 0; i < size; i++) { |
---|
304 | <a name="l00365"></a>00365 out(i) = (*temp++); |
---|
305 | <a name="l00366"></a>00366 } |
---|
306 | <a name="l00367"></a>00367 |
---|
307 | <a name="l00368"></a>00368 <span class="keywordflow">return</span> out; |
---|
308 | <a name="l00369"></a>00369 |
---|
309 | <a name="l00370"></a>00370 } |
---|
310 | <a name="l00371"></a>00371 |
---|
311 | <a name="l00372"></a><a class="code" href="group__mexfiles.html#g3dc0c8a0aff8d5a79633e9a3db603976">00372</a> cvec <a class="code" href="group__mexfiles.html#g3dc0c8a0aff8d5a79633e9a3db603976" title="Convert the matlab-format mxArray to cvec.">mxArray2cvec</a>(<span class="keyword">const</span> mxArray *in) |
---|
312 | <a name="l00373"></a>00373 { |
---|
313 | <a name="l00374"></a>00374 cvec out; |
---|
314 | <a name="l00375"></a>00375 <span class="keywordtype">int</span> i, <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a>; |
---|
315 | <a name="l00376"></a>00376 <span class="keywordtype">double</span>* tempR = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
316 | <a name="l00377"></a>00377 <span class="keywordtype">double</span>* tempI = (<span class="keywordtype">double</span>*) mxGetPi(in); |
---|
317 | <a name="l00378"></a>00378 |
---|
318 | <a name="l00379"></a>00379 <span class="keywordflow">if</span> ((tempR == 0) && (tempI == 0)) mexErrMsgTxt(<span class="stringliteral">"mxArray2cvec: Pointer data is NULL"</span>); |
---|
319 | <a name="l00380"></a>00380 |
---|
320 | <a name="l00381"></a>00381 size = mxGetNumberOfElements(in); |
---|
321 | <a name="l00382"></a>00382 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2cvec: Size of data is zero"</span>); |
---|
322 | <a name="l00383"></a>00383 |
---|
323 | <a name="l00384"></a>00384 out.set_size(size, <span class="keyword">false</span>); |
---|
324 | <a name="l00385"></a>00385 |
---|
325 | <a name="l00386"></a>00386 <span class="keywordflow">if</span> (tempR == 0) { |
---|
326 | <a name="l00387"></a>00387 <span class="keywordflow">for</span> (i = 0; i < size; i++) { out(i) = std::complex<double>(0.0, (*tempI++)); } |
---|
327 | <a name="l00388"></a>00388 } |
---|
328 | <a name="l00389"></a>00389 <span class="keywordflow">else</span> <span class="keywordflow">if</span> (tempI == 0) { |
---|
329 | <a name="l00390"></a>00390 <span class="keywordflow">for</span> (i = 0; i < size; i++) { out(i) = std::complex<double>((*tempR++), 0.0); } |
---|
330 | <a name="l00391"></a>00391 } |
---|
331 | <a name="l00392"></a>00392 <span class="keywordflow">else</span> { |
---|
332 | <a name="l00393"></a>00393 <span class="keywordflow">for</span> (i = 0; i < size; i++) { out(i) = std::complex<double>((*tempR++), (*tempI++)); } |
---|
333 | <a name="l00394"></a>00394 } |
---|
334 | <a name="l00395"></a>00395 |
---|
335 | <a name="l00396"></a>00396 <span class="keywordflow">return</span> out; |
---|
336 | <a name="l00397"></a>00397 |
---|
337 | <a name="l00398"></a>00398 } |
---|
338 | <a name="l00399"></a>00399 |
---|
339 | <a name="l00400"></a><a class="code" href="group__mexfiles.html#g4cf7ac093d387fbc02e454642c18ddff">00400</a> <a class="code" href="mat_8h.html#f90acd1af41bf2d1d8a4bb23662fff69" title="bin matrix">bmat</a> <a class="code" href="group__mexfiles.html#g4cf7ac093d387fbc02e454642c18ddff" title="Convert the matlab-format mxArray to bmat.">mxArray2bmat</a>(<span class="keyword">const</span> mxArray *in) |
---|
340 | <a name="l00401"></a>00401 { |
---|
341 | <a name="l00402"></a>00402 <a class="code" href="mat_8h.html#f90acd1af41bf2d1d8a4bb23662fff69" title="bin matrix">bmat</a> out; |
---|
342 | <a name="l00403"></a>00403 <span class="keywordtype">int</span> r, c, rows, cols; |
---|
343 | <a name="l00404"></a>00404 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
344 | <a name="l00405"></a>00405 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2bmat: Pointer to data is NULL"</span>); |
---|
345 | <a name="l00406"></a>00406 |
---|
346 | <a name="l00407"></a>00407 rows = mxGetM(in); |
---|
347 | <a name="l00408"></a>00408 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2bmat: Data has zero rows"</span>); |
---|
348 | <a name="l00409"></a>00409 cols = mxGetN(in); |
---|
349 | <a name="l00410"></a>00410 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2bmat: Data has zero columns"</span>); |
---|
350 | <a name="l00411"></a>00411 |
---|
351 | <a name="l00412"></a>00412 out.set_size(rows, cols, <span class="keyword">false</span>); |
---|
352 | <a name="l00413"></a>00413 |
---|
353 | <a name="l00414"></a>00414 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
354 | <a name="l00415"></a>00415 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
355 | <a name="l00416"></a>00416 out(r, c) = (((*temp++) > 0.0) ? <a class="code" href="classitpp_1_1bin.html" title="Binary arithmetic (boolean) class.">bin</a>(1) : <a class="code" href="classitpp_1_1bin.html" title="Binary arithmetic (boolean) class.">bin</a>(0)); |
---|
356 | <a name="l00417"></a>00417 } |
---|
357 | <a name="l00418"></a>00418 } |
---|
358 | <a name="l00419"></a>00419 |
---|
359 | <a name="l00420"></a>00420 <span class="keywordflow">return</span> out; |
---|
360 | <a name="l00421"></a>00421 |
---|
361 | <a name="l00422"></a>00422 } |
---|
362 | <a name="l00423"></a>00423 |
---|
363 | <a name="l00424"></a><a class="code" href="group__mexfiles.html#g575ddd65f32c826ff412c7eb7a98994c">00424</a> smat <a class="code" href="group__mexfiles.html#g575ddd65f32c826ff412c7eb7a98994c" title="Convert the matlab-format mxArray to smat.">mxArray2smat</a>(<span class="keyword">const</span> mxArray *in) |
---|
364 | <a name="l00425"></a>00425 { |
---|
365 | <a name="l00426"></a>00426 smat out; |
---|
366 | <a name="l00427"></a>00427 <span class="keywordtype">int</span> r, c, rows, cols; |
---|
367 | <a name="l00428"></a>00428 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
368 | <a name="l00429"></a>00429 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2smat: Pointer to data is NULL"</span>); |
---|
369 | <a name="l00430"></a>00430 |
---|
370 | <a name="l00431"></a>00431 rows = mxGetM(in); |
---|
371 | <a name="l00432"></a>00432 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2smat: Data has zero rows"</span>); |
---|
372 | <a name="l00433"></a>00433 cols = mxGetN(in); |
---|
373 | <a name="l00434"></a>00434 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2smat: Data has zero columns"</span>); |
---|
374 | <a name="l00435"></a>00435 |
---|
375 | <a name="l00436"></a>00436 out.set_size(rows, cols, <span class="keyword">false</span>); |
---|
376 | <a name="l00437"></a>00437 |
---|
377 | <a name="l00438"></a>00438 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
378 | <a name="l00439"></a>00439 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
379 | <a name="l00440"></a>00440 out(r, c) = (short)(*temp++); |
---|
380 | <a name="l00441"></a>00441 } |
---|
381 | <a name="l00442"></a>00442 } |
---|
382 | <a name="l00443"></a>00443 |
---|
383 | <a name="l00444"></a>00444 <span class="keywordflow">return</span> out; |
---|
384 | <a name="l00445"></a>00445 |
---|
385 | <a name="l00446"></a>00446 } |
---|
386 | <a name="l00447"></a>00447 |
---|
387 | <a name="l00448"></a><a class="code" href="group__mexfiles.html#g9672b0ae7328382bbf43850d60ad23d0">00448</a> imat <a class="code" href="group__mexfiles.html#g9672b0ae7328382bbf43850d60ad23d0" title="Convert the matlab-format mxArray to imat.">mxArray2imat</a>(<span class="keyword">const</span> mxArray *in) |
---|
388 | <a name="l00449"></a>00449 { |
---|
389 | <a name="l00450"></a>00450 imat out; |
---|
390 | <a name="l00451"></a>00451 <span class="keywordtype">int</span> r, c, rows, cols; |
---|
391 | <a name="l00452"></a>00452 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
392 | <a name="l00453"></a>00453 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2imat: Pointer to data is NULL"</span>); |
---|
393 | <a name="l00454"></a>00454 |
---|
394 | <a name="l00455"></a>00455 rows = mxGetM(in); |
---|
395 | <a name="l00456"></a>00456 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2imat: Data has zero rows"</span>); |
---|
396 | <a name="l00457"></a>00457 cols = mxGetN(in); |
---|
397 | <a name="l00458"></a>00458 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2imat: Data has zero columns"</span>); |
---|
398 | <a name="l00459"></a>00459 out.set_size(rows, cols, <span class="keyword">false</span>); |
---|
399 | <a name="l00460"></a>00460 |
---|
400 | <a name="l00461"></a>00461 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
401 | <a name="l00462"></a>00462 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
402 | <a name="l00463"></a>00463 out(r, c) = (int)(*temp++); |
---|
403 | <a name="l00464"></a>00464 } |
---|
404 | <a name="l00465"></a>00465 } |
---|
405 | <a name="l00466"></a>00466 |
---|
406 | <a name="l00467"></a>00467 <span class="keywordflow">return</span> out; |
---|
407 | <a name="l00468"></a>00468 |
---|
408 | <a name="l00469"></a>00469 } |
---|
409 | <a name="l00470"></a>00470 |
---|
410 | <a name="l00471"></a><a class="code" href="group__mexfiles.html#g2adb0970c31c7febf62850fabed65c5c">00471</a> mat <a class="code" href="group__mexfiles.html#g2adb0970c31c7febf62850fabed65c5c" title="Convert the matlab-format mxArray to mat.">mxArray2mat</a>(<span class="keyword">const</span> mxArray *in) |
---|
411 | <a name="l00472"></a>00472 { |
---|
412 | <a name="l00473"></a>00473 mat out; |
---|
413 | <a name="l00474"></a>00474 <span class="keywordtype">int</span> r, c, rows, cols; |
---|
414 | <a name="l00475"></a>00475 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
415 | <a name="l00476"></a>00476 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2mat: Pointer to data is NULL"</span>); |
---|
416 | <a name="l00477"></a>00477 |
---|
417 | <a name="l00478"></a>00478 rows = mxGetM(in); |
---|
418 | <a name="l00479"></a>00479 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2mat: Data has zero rows"</span>); |
---|
419 | <a name="l00480"></a>00480 cols = mxGetN(in); |
---|
420 | <a name="l00481"></a>00481 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2mat: Data has zero columns"</span>); |
---|
421 | <a name="l00482"></a>00482 out.set_size(rows, cols, <span class="keyword">false</span>); |
---|
422 | <a name="l00483"></a>00483 |
---|
423 | <a name="l00484"></a>00484 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
424 | <a name="l00485"></a>00485 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
425 | <a name="l00486"></a>00486 out(r, c) = (*temp++); |
---|
426 | <a name="l00487"></a>00487 } |
---|
427 | <a name="l00488"></a>00488 } |
---|
428 | <a name="l00489"></a>00489 |
---|
429 | <a name="l00490"></a>00490 <span class="keywordflow">return</span> out; |
---|
430 | <a name="l00491"></a>00491 |
---|
431 | <a name="l00492"></a>00492 } |
---|
432 | <a name="l00493"></a>00493 |
---|
433 | <a name="l00494"></a><a class="code" href="group__mexfiles.html#gf21de941d8ecde5fd50bd53ac96c405e">00494</a> cmat <a class="code" href="group__mexfiles.html#gf21de941d8ecde5fd50bd53ac96c405e" title="Convert the matlab-format mxArray to cmat.">mxArray2cmat</a>(<span class="keyword">const</span> mxArray *in) |
---|
434 | <a name="l00495"></a>00495 { |
---|
435 | <a name="l00496"></a>00496 cmat out; |
---|
436 | <a name="l00497"></a>00497 <span class="keywordtype">int</span> r, c, rows, cols; |
---|
437 | <a name="l00498"></a>00498 <span class="keywordtype">double</span>* tempR = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
438 | <a name="l00499"></a>00499 <span class="keywordtype">double</span>* tempI = (<span class="keywordtype">double</span>*) mxGetPi(in); |
---|
439 | <a name="l00500"></a>00500 |
---|
440 | <a name="l00501"></a>00501 <span class="keywordflow">if</span> ((tempR == 0) && (tempI == 0)) mexErrMsgTxt(<span class="stringliteral">"mxArray2cmat: Pointer to data is NULL"</span>); |
---|
441 | <a name="l00502"></a>00502 |
---|
442 | <a name="l00503"></a>00503 rows = mxGetM(in); |
---|
443 | <a name="l00504"></a>00504 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2cmat: Data has zero rows"</span>); |
---|
444 | <a name="l00505"></a>00505 cols = mxGetN(in); |
---|
445 | <a name="l00506"></a>00506 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2cmat: Data has zero columns"</span>); |
---|
446 | <a name="l00507"></a>00507 out.set_size(rows, cols, <span class="keyword">false</span>); |
---|
447 | <a name="l00508"></a>00508 |
---|
448 | <a name="l00509"></a>00509 <span class="keywordflow">if</span> (tempR == 0) { |
---|
449 | <a name="l00510"></a>00510 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { <span class="keywordflow">for</span> (r = 0; r < rows; r++) { out(r, c) = std::complex<double>(0.0 , (*tempI++)); } } |
---|
450 | <a name="l00511"></a>00511 } |
---|
451 | <a name="l00512"></a>00512 <span class="keywordflow">else</span> <span class="keywordflow">if</span> (tempI == 0) { |
---|
452 | <a name="l00513"></a>00513 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { <span class="keywordflow">for</span> (r = 0; r < rows; r++) { out(r, c) = std::complex<double>((*tempR++), 0.0); } } |
---|
453 | <a name="l00514"></a>00514 } |
---|
454 | <a name="l00515"></a>00515 <span class="keywordflow">else</span> { |
---|
455 | <a name="l00516"></a>00516 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { <span class="keywordflow">for</span> (r = 0; r < rows; r++) { out(r, c) = std::complex<double>((*tempR++), (*tempI++)); } } |
---|
456 | <a name="l00517"></a>00517 } |
---|
457 | <a name="l00518"></a>00518 |
---|
458 | <a name="l00519"></a>00519 <span class="keywordflow">return</span> out; |
---|
459 | <a name="l00520"></a>00520 |
---|
460 | <a name="l00521"></a>00521 } |
---|
461 | <a name="l00522"></a>00522 |
---|
462 | <a name="l00523"></a><a class="code" href="group__mexfiles.html#g75ed25c51a4943584b6e2fcf8e6bb720">00523</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g75ed25c51a4943584b6e2fcf8e6bb720" title="Convert double to the matlab-format mxArray.">double2mxArray</a>(<span class="keyword">const</span> <span class="keywordtype">double</span> &in, mxArray *out) |
---|
463 | <a name="l00524"></a>00524 { |
---|
464 | <a name="l00525"></a>00525 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
465 | <a name="l00526"></a>00526 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"double2mxArray: Pointer to data is NULL"</span>); |
---|
466 | <a name="l00527"></a>00527 |
---|
467 | <a name="l00528"></a>00528 *temp = (double) in; |
---|
468 | <a name="l00529"></a>00529 } |
---|
469 | <a name="l00530"></a>00530 |
---|
470 | <a name="l00531"></a><a class="code" href="group__mexfiles.html#g16bc1d8cd7516a74aa37e29826c75f38">00531</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g16bc1d8cd7516a74aa37e29826c75f38" title="Convert complex&lt;double&gt; to the matlab-format mxArray.">double_complex2mxArray</a>(<span class="keyword">const</span> std::complex<double> &in, mxArray *out) |
---|
471 | <a name="l00532"></a>00532 { |
---|
472 | <a name="l00533"></a>00533 <span class="keywordtype">double</span>* tempR = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
473 | <a name="l00534"></a>00534 <span class="keywordtype">double</span>* tempI = (<span class="keywordtype">double</span> *) mxGetPi(out); |
---|
474 | <a name="l00535"></a>00535 <span class="keywordflow">if</span> (tempR == 0) mexErrMsgTxt(<span class="stringliteral">"double_complex2mxArray: Pointer to real valued part is NULL"</span>); |
---|
475 | <a name="l00536"></a>00536 <span class="keywordflow">if</span> (tempI == 0) mexErrMsgTxt(<span class="stringliteral">"double_complex2mxArray: Pointer to imaginary valued part is NULL"</span>); |
---|
476 | <a name="l00537"></a>00537 |
---|
477 | <a name="l00538"></a>00538 *tempR = (double) in.real(); |
---|
478 | <a name="l00539"></a>00539 *tempI = (double) in.imag(); |
---|
479 | <a name="l00540"></a>00540 } |
---|
480 | <a name="l00541"></a>00541 |
---|
481 | <a name="l00542"></a><a class="code" href="group__mexfiles.html#gf072ee06b8ae430cc5b8b6868f51702e">00542</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gf072ee06b8ae430cc5b8b6868f51702e" title="Convert string to the matlab-format mxArray.">string2mxArray</a>(<span class="keyword">const</span> std::string &in, mxArray* &out) |
---|
482 | <a name="l00543"></a>00543 { |
---|
483 | <a name="l00544"></a>00544 <span class="keywordflow">if</span> (in.data() == 0) |
---|
484 | <a name="l00545"></a>00545 mexErrMsgTxt(<span class="stringliteral">"string2mxArray: Pointer to string is NULL"</span>); |
---|
485 | <a name="l00546"></a>00546 out = mxCreateString(in.data()); |
---|
486 | <a name="l00547"></a>00547 <span class="keywordflow">if</span> (out == 0) |
---|
487 | <a name="l00548"></a>00548 mexErrMsgTxt(<span class="stringliteral">"string2mxArray: Could not convert string to mxArray"</span>); |
---|
488 | <a name="l00549"></a>00549 } |
---|
489 | <a name="l00550"></a>00550 |
---|
490 | <a name="l00551"></a><a class="code" href="group__mexfiles.html#gc97de915a25eac08caca7c8ef5fc9058">00551</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gc97de915a25eac08caca7c8ef5fc9058" title="Convert bvec to the matlab-format mxArray.">bvec2mxArray</a>(<span class="keyword">const</span> bvec &in, mxArray *out) |
---|
491 | <a name="l00552"></a>00552 { |
---|
492 | <a name="l00553"></a>00553 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
493 | <a name="l00554"></a>00554 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"bvec2mxArray: Pointer to data is NULL"</span>); |
---|
494 | <a name="l00555"></a>00555 <span class="keywordflow">if</span> (in.size() == 0) mexErrMsgTxt(<span class="stringliteral">"bvec2mxArray: Size of data is zero"</span>); |
---|
495 | <a name="l00556"></a>00556 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < in.size(); i++) { |
---|
496 | <a name="l00557"></a>00557 <span class="keywordflow">if</span> (in(i)) |
---|
497 | <a name="l00558"></a>00558 *temp++ = 1.0; |
---|
498 | <a name="l00559"></a>00559 <span class="keywordflow">else</span> |
---|
499 | <a name="l00560"></a>00560 *temp++ = 0.0; |
---|
500 | <a name="l00561"></a>00561 } |
---|
501 | <a name="l00562"></a>00562 } |
---|
502 | <a name="l00563"></a>00563 |
---|
503 | <a name="l00564"></a><a class="code" href="group__mexfiles.html#g62fcc542613bc7a0613427ecb877a0a0">00564</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g62fcc542613bc7a0613427ecb877a0a0" title="Convert ivec to the matlab-format mxArray.">ivec2mxArray</a>(<span class="keyword">const</span> ivec &in, mxArray *out) |
---|
504 | <a name="l00565"></a>00565 { |
---|
505 | <a name="l00566"></a>00566 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
506 | <a name="l00567"></a>00567 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"ivec2mxArray: Pointer to data is NULL"</span>); |
---|
507 | <a name="l00568"></a>00568 <span class="keywordflow">if</span> (in.size() == 0) mexErrMsgTxt(<span class="stringliteral">"ivec2mxArray: Size of data is zero"</span>); |
---|
508 | <a name="l00569"></a>00569 |
---|
509 | <a name="l00570"></a>00570 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < in.size(); i++) { |
---|
510 | <a name="l00571"></a>00571 *temp++ = (double) in(i); |
---|
511 | <a name="l00572"></a>00572 } |
---|
512 | <a name="l00573"></a>00573 } |
---|
513 | <a name="l00574"></a>00574 |
---|
514 | <a name="l00575"></a><a class="code" href="group__mexfiles.html#gd1f0678a5b5a93a20c50aef0bf7bf211">00575</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gd1f0678a5b5a93a20c50aef0bf7bf211" title="Convert vec to the matlab-format mxArray.">vec2mxArray</a>(<span class="keyword">const</span> vec &in, mxArray *out) |
---|
515 | <a name="l00576"></a>00576 { |
---|
516 | <a name="l00577"></a>00577 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
517 | <a name="l00578"></a>00578 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"vec2mxArray: Pointer to data is NULL"</span>); |
---|
518 | <a name="l00579"></a>00579 <span class="keywordflow">if</span> (in.size() == 0) mexErrMsgTxt(<span class="stringliteral">"vec2mxArray: Size of data is zero"</span>); |
---|
519 | <a name="l00580"></a>00580 |
---|
520 | <a name="l00581"></a>00581 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < in.size(); i++) { |
---|
521 | <a name="l00582"></a>00582 *temp++ = (double) in(i); |
---|
522 | <a name="l00583"></a>00583 } |
---|
523 | <a name="l00584"></a>00584 } |
---|
524 | <a name="l00585"></a>00585 |
---|
525 | <a name="l00586"></a><a class="code" href="group__mexfiles.html#gd1a7f07847740d4dc813a4785b73ba44">00586</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gd1a7f07847740d4dc813a4785b73ba44" title="Convert cvec to the matlab-format mxArray.">cvec2mxArray</a>(<span class="keyword">const</span> cvec &in, mxArray *out) |
---|
526 | <a name="l00587"></a>00587 { |
---|
527 | <a name="l00588"></a>00588 <span class="keywordtype">double</span>* tempR = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
528 | <a name="l00589"></a>00589 <span class="keywordtype">double</span>* tempI = (<span class="keywordtype">double</span> *) mxGetPi(out); |
---|
529 | <a name="l00590"></a>00590 <span class="keywordflow">if</span> (tempR == 0) mexErrMsgTxt(<span class="stringliteral">"cvec2mxArray: Pointer to real valued part is NULL"</span>); |
---|
530 | <a name="l00591"></a>00591 <span class="keywordflow">if</span> (tempI == 0) mexErrMsgTxt(<span class="stringliteral">"cvec2mxArray: Pointer to imaginary valued part is NULL"</span>); |
---|
531 | <a name="l00592"></a>00592 <span class="keywordflow">if</span> (in.size() == 0) mexErrMsgTxt(<span class="stringliteral">"cvec2mxArray: Size of data is zero"</span>); |
---|
532 | <a name="l00593"></a>00593 |
---|
533 | <a name="l00594"></a>00594 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < in.size(); i++) { |
---|
534 | <a name="l00595"></a>00595 *tempR++ = (double) in(i).real(); |
---|
535 | <a name="l00596"></a>00596 *tempI++ = (double) in(i).imag(); |
---|
536 | <a name="l00597"></a>00597 } |
---|
537 | <a name="l00598"></a>00598 } |
---|
538 | <a name="l00599"></a>00599 |
---|
539 | <a name="l00600"></a><a class="code" href="group__mexfiles.html#gf9524573874f8e6314cb02837d7ede3a">00600</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gf9524573874f8e6314cb02837d7ede3a" title="Convert bmat to the matlab-format mxArray.">bmat2mxArray</a>(<span class="keyword">const</span> <a class="code" href="mat_8h.html#f90acd1af41bf2d1d8a4bb23662fff69" title="bin matrix">bmat</a> &in, mxArray *out) |
---|
540 | <a name="l00601"></a>00601 { |
---|
541 | <a name="l00602"></a>00602 <span class="keywordtype">int</span> rows, cols, r, c; |
---|
542 | <a name="l00603"></a>00603 |
---|
543 | <a name="l00604"></a>00604 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
544 | <a name="l00605"></a>00605 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"bmat2mxArray: Pointer to data is NULL"</span>); |
---|
545 | <a name="l00606"></a>00606 |
---|
546 | <a name="l00607"></a>00607 rows = in.rows(); |
---|
547 | <a name="l00608"></a>00608 cols = in.cols(); |
---|
548 | <a name="l00609"></a>00609 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"bmat2mxArray: Data has zero rows"</span>); |
---|
549 | <a name="l00610"></a>00610 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"bmat2mxArray: Data has zero columns"</span>); |
---|
550 | <a name="l00611"></a>00611 |
---|
551 | <a name="l00612"></a>00612 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
552 | <a name="l00613"></a>00613 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
553 | <a name="l00614"></a>00614 <span class="keywordflow">if</span> (in(r, c)) |
---|
554 | <a name="l00615"></a>00615 *temp++ = 1.0; |
---|
555 | <a name="l00616"></a>00616 <span class="keywordflow">else</span> |
---|
556 | <a name="l00617"></a>00617 *temp++ = 0.0; |
---|
557 | <a name="l00618"></a>00618 } |
---|
558 | <a name="l00619"></a>00619 } |
---|
559 | <a name="l00620"></a>00620 |
---|
560 | <a name="l00621"></a>00621 } |
---|
561 | <a name="l00622"></a>00622 |
---|
562 | <a name="l00623"></a><a class="code" href="group__mexfiles.html#g2686ae6b181d6b1490916d68d0f28ed1">00623</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g2686ae6b181d6b1490916d68d0f28ed1" title="Convert smat to the matlab-format mxArray.">smat2mxArray</a>(<span class="keyword">const</span> smat &in, mxArray *out) |
---|
563 | <a name="l00624"></a>00624 { |
---|
564 | <a name="l00625"></a>00625 <span class="keywordtype">int</span> rows, cols, r, c; |
---|
565 | <a name="l00626"></a>00626 |
---|
566 | <a name="l00627"></a>00627 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
567 | <a name="l00628"></a>00628 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"smat2mxArray: Pointer to data is NULL"</span>); |
---|
568 | <a name="l00629"></a>00629 |
---|
569 | <a name="l00630"></a>00630 rows = in.rows(); |
---|
570 | <a name="l00631"></a>00631 cols = in.cols(); |
---|
571 | <a name="l00632"></a>00632 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"smat2mxArray: Data has zero rows"</span>); |
---|
572 | <a name="l00633"></a>00633 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"smat2mxArray: Data has zero columns"</span>); |
---|
573 | <a name="l00634"></a>00634 |
---|
574 | <a name="l00635"></a>00635 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
575 | <a name="l00636"></a>00636 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
576 | <a name="l00637"></a>00637 *temp++ = (double) in(r, c); |
---|
577 | <a name="l00638"></a>00638 } |
---|
578 | <a name="l00639"></a>00639 } |
---|
579 | <a name="l00640"></a>00640 |
---|
580 | <a name="l00641"></a>00641 } |
---|
581 | <a name="l00642"></a>00642 |
---|
582 | <a name="l00643"></a><a class="code" href="group__mexfiles.html#gd1871047cece783b84d6ec3472778d15">00643</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gd1871047cece783b84d6ec3472778d15" title="Convert imat to the matlab-format mxArray.">imat2mxArray</a>(<span class="keyword">const</span> imat &in, mxArray *out) |
---|
583 | <a name="l00644"></a>00644 { |
---|
584 | <a name="l00645"></a>00645 <span class="keywordtype">int</span> rows, cols, r, c; |
---|
585 | <a name="l00646"></a>00646 |
---|
586 | <a name="l00647"></a>00647 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
587 | <a name="l00648"></a>00648 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"imat2mxArray: Pointer to data is NULL"</span>); |
---|
588 | <a name="l00649"></a>00649 |
---|
589 | <a name="l00650"></a>00650 rows = in.rows(); |
---|
590 | <a name="l00651"></a>00651 cols = in.cols(); |
---|
591 | <a name="l00652"></a>00652 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"imat2mxArray: Data has zero rows"</span>); |
---|
592 | <a name="l00653"></a>00653 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"imat2mxArray: Data has zero columns"</span>); |
---|
593 | <a name="l00654"></a>00654 |
---|
594 | <a name="l00655"></a>00655 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
595 | <a name="l00656"></a>00656 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
596 | <a name="l00657"></a>00657 *temp++ = (double) in(r, c); |
---|
597 | <a name="l00658"></a>00658 } |
---|
598 | <a name="l00659"></a>00659 } |
---|
599 | <a name="l00660"></a>00660 |
---|
600 | <a name="l00661"></a>00661 } |
---|
601 | <a name="l00662"></a>00662 |
---|
602 | <a name="l00663"></a><a class="code" href="group__mexfiles.html#g662aa389e9c98b92a4880e2ab1241779">00663</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g662aa389e9c98b92a4880e2ab1241779" title="Convert mat to the matlab-format mxArray.">mat2mxArray</a>(<span class="keyword">const</span> mat &in, mxArray *out) |
---|
603 | <a name="l00664"></a>00664 { |
---|
604 | <a name="l00665"></a>00665 <span class="keywordtype">int</span> rows, cols, r, c; |
---|
605 | <a name="l00666"></a>00666 |
---|
606 | <a name="l00667"></a>00667 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
607 | <a name="l00668"></a>00668 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mat2mxArray: Pointer to data is NULL"</span>); |
---|
608 | <a name="l00669"></a>00669 |
---|
609 | <a name="l00670"></a>00670 rows = in.rows(); |
---|
610 | <a name="l00671"></a>00671 cols = in.cols(); |
---|
611 | <a name="l00672"></a>00672 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"mat2mxArray: Data has zero rows"</span>); |
---|
612 | <a name="l00673"></a>00673 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"mat2mxArray: Data has zero columns"</span>); |
---|
613 | <a name="l00674"></a>00674 |
---|
614 | <a name="l00675"></a>00675 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
615 | <a name="l00676"></a>00676 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
616 | <a name="l00677"></a>00677 *temp++ = in(r, c); |
---|
617 | <a name="l00678"></a>00678 } |
---|
618 | <a name="l00679"></a>00679 } |
---|
619 | <a name="l00680"></a>00680 |
---|
620 | <a name="l00681"></a>00681 } |
---|
621 | <a name="l00682"></a>00682 |
---|
622 | <a name="l00683"></a><a class="code" href="group__mexfiles.html#g57c21d0729a206659cdff4eafb397bd2">00683</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g57c21d0729a206659cdff4eafb397bd2" title="Convert cmat to the matlab-format mxArray.">cmat2mxArray</a>(<span class="keyword">const</span> cmat &in, mxArray *out) |
---|
623 | <a name="l00684"></a>00684 { |
---|
624 | <a name="l00685"></a>00685 <span class="keywordtype">int</span> rows, cols, r, c; |
---|
625 | <a name="l00686"></a>00686 |
---|
626 | <a name="l00687"></a>00687 <span class="keywordtype">double</span>* tempR = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
627 | <a name="l00688"></a>00688 <span class="keywordtype">double</span>* tempI = (<span class="keywordtype">double</span> *) mxGetPi(out); |
---|
628 | <a name="l00689"></a>00689 <span class="keywordflow">if</span> (tempR == 0) mexErrMsgTxt(<span class="stringliteral">"cvec2mxArray: Pointer to real valued part is NULL"</span>); |
---|
629 | <a name="l00690"></a>00690 <span class="keywordflow">if</span> (tempI == 0) mexErrMsgTxt(<span class="stringliteral">"cvec2mxArray: Pointer to imaginary valued part is NULL"</span>); |
---|
630 | <a name="l00691"></a>00691 |
---|
631 | <a name="l00692"></a>00692 rows = in.rows(); |
---|
632 | <a name="l00693"></a>00693 cols = in.cols(); |
---|
633 | <a name="l00694"></a>00694 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"cvec2mxArray: Data has zero rows"</span>); |
---|
634 | <a name="l00695"></a>00695 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"cvec2mxArray: Data has zero columns"</span>); |
---|
635 | <a name="l00696"></a>00696 |
---|
636 | <a name="l00697"></a>00697 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
637 | <a name="l00698"></a>00698 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
638 | <a name="l00699"></a>00699 *tempR++ = (double) in(r, c).real(); |
---|
639 | <a name="l00700"></a>00700 *tempI++ = (double) in(r, c).imag(); |
---|
640 | <a name="l00701"></a>00701 } |
---|
641 | <a name="l00702"></a>00702 } |
---|
642 | <a name="l00703"></a>00703 |
---|
643 | <a name="l00704"></a>00704 } |
---|
644 | <a name="l00705"></a>00705 |
---|
645 | <a name="l00706"></a><a class="code" href="group__mexfiles.html#g2fb857731c56da75778f3b9ff4a2ab26">00706</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g2fb857731c56da75778f3b9ff4a2ab26" title="Convert the matlab-format mxArray to C-format pointer to short.">mxArray2Csvec</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">short</span> *out) |
---|
646 | <a name="l00707"></a>00707 { |
---|
647 | <a name="l00708"></a>00708 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
648 | <a name="l00709"></a>00709 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Csvec: Pointer to data is NULL"</span>); |
---|
649 | <a name="l00710"></a>00710 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a> = mxGetNumberOfElements(in); |
---|
650 | <a name="l00711"></a>00711 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Csvec: Size of data is zero"</span>); |
---|
651 | <a name="l00712"></a>00712 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < size; i++) { out[i] = (short)(*temp++); } |
---|
652 | <a name="l00713"></a>00713 } |
---|
653 | <a name="l00714"></a>00714 |
---|
654 | <a name="l00715"></a><a class="code" href="group__mexfiles.html#gafc87420b618496149acd189c0a125d6">00715</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gafc87420b618496149acd189c0a125d6" title="Convert the matlab-format mxArray to C-format pointer to int.">mxArray2Civec</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">int</span> *out) |
---|
655 | <a name="l00716"></a>00716 { |
---|
656 | <a name="l00717"></a>00717 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
657 | <a name="l00718"></a>00718 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Civec: Pointer to data is NULL"</span>); |
---|
658 | <a name="l00719"></a>00719 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a> = mxGetNumberOfElements(in); |
---|
659 | <a name="l00720"></a>00720 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Civec: Size of data is zero"</span>); |
---|
660 | <a name="l00721"></a>00721 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < size; i++) { out[i] = (int)(*temp++); } |
---|
661 | <a name="l00722"></a>00722 } |
---|
662 | <a name="l00723"></a>00723 |
---|
663 | <a name="l00724"></a><a class="code" href="group__mexfiles.html#gfda111aa6e327339d771fa6456695475">00724</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gfda111aa6e327339d771fa6456695475" title="Convert the matlab-format mxArray to C-format pointer to double.">mxArray2Cvec</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">double</span> *out) |
---|
664 | <a name="l00725"></a>00725 { |
---|
665 | <a name="l00726"></a>00726 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
666 | <a name="l00727"></a>00727 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Cvec: Pointer to data is NULL"</span>); |
---|
667 | <a name="l00728"></a>00728 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a> = mxGetNumberOfElements(in); |
---|
668 | <a name="l00729"></a>00729 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Cvec: Size of data is zero"</span>); |
---|
669 | <a name="l00730"></a>00730 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < size; i++) { out[i] = (*temp++); } |
---|
670 | <a name="l00731"></a>00731 } |
---|
671 | <a name="l00732"></a>00732 |
---|
672 | <a name="l00733"></a><a class="code" href="group__mexfiles.html#g32173752abe2bcbdd698377ebbef660f">00733</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g32173752abe2bcbdd698377ebbef660f" title="Convert the matlab-format mxArray to C-format pointers to double (real and imaginary...">mxArray2Ccvec</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">double</span> *out_real, <span class="keywordtype">double</span> *out_imag) |
---|
673 | <a name="l00734"></a>00734 { |
---|
674 | <a name="l00735"></a>00735 <span class="keywordtype">double</span>* tempR = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
675 | <a name="l00736"></a>00736 <span class="keywordtype">double</span>* tempI = (<span class="keywordtype">double</span>*) mxGetPi(in); |
---|
676 | <a name="l00737"></a>00737 <span class="keywordflow">if</span> (tempR == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Ccvec: Pointer to real valued part is NULL"</span>); |
---|
677 | <a name="l00738"></a>00738 <span class="keywordflow">if</span> (tempI == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Ccvec: Pointer to imaginary valued part is NULL"</span>); |
---|
678 | <a name="l00739"></a>00739 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a> = mxGetNumberOfElements(in); |
---|
679 | <a name="l00740"></a>00740 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Ccvec: Size of data is zero"</span>); |
---|
680 | <a name="l00741"></a>00741 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < size; i++) { out_real[i] = (*tempR++); out_imag[i] = (*tempI++); } |
---|
681 | <a name="l00742"></a>00742 } |
---|
682 | <a name="l00743"></a>00743 |
---|
683 | <a name="l00744"></a><a class="code" href="group__mexfiles.html#gac0f1fe44f6e61a72621bcdc3ae35dbc">00744</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gac0f1fe44f6e61a72621bcdc3ae35dbc" title="Convert the matlab-format mxArray to C-format pointer to pointer to short.">mxArray2Csmat</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">short</span> **out) |
---|
684 | <a name="l00745"></a>00745 { |
---|
685 | <a name="l00746"></a>00746 <span class="keywordtype">int</span> r, c; |
---|
686 | <a name="l00747"></a>00747 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
687 | <a name="l00748"></a>00748 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Csmat: Pointer to data is NULL"</span>); |
---|
688 | <a name="l00749"></a>00749 <span class="keywordtype">int</span> rows = mxGetM(in); |
---|
689 | <a name="l00750"></a>00750 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Csmat: Data has zero rows"</span>); |
---|
690 | <a name="l00751"></a>00751 <span class="keywordtype">int</span> cols = mxGetN(in); |
---|
691 | <a name="l00752"></a>00752 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Csmat: Data has zero columns"</span>); |
---|
692 | <a name="l00753"></a>00753 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
693 | <a name="l00754"></a>00754 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
694 | <a name="l00755"></a>00755 out[r][c] = (short)(*temp++); |
---|
695 | <a name="l00756"></a>00756 } |
---|
696 | <a name="l00757"></a>00757 } |
---|
697 | <a name="l00758"></a>00758 } |
---|
698 | <a name="l00759"></a>00759 |
---|
699 | <a name="l00760"></a><a class="code" href="group__mexfiles.html#g856cf3cd63fc72836ca8f2007fdcc42c">00760</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g856cf3cd63fc72836ca8f2007fdcc42c" title="Convert the matlab-format mxArray to C-format pointer to pointer to int.">mxArray2Cimat</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">int</span> **out) |
---|
700 | <a name="l00761"></a>00761 { |
---|
701 | <a name="l00762"></a>00762 <span class="keywordtype">int</span> r, c; |
---|
702 | <a name="l00763"></a>00763 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
703 | <a name="l00764"></a>00764 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Cimat: Pointer to data is NULL"</span>); |
---|
704 | <a name="l00765"></a>00765 <span class="keywordtype">int</span> rows = mxGetM(in); |
---|
705 | <a name="l00766"></a>00766 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Cimat: Data has zero rows"</span>); |
---|
706 | <a name="l00767"></a>00767 <span class="keywordtype">int</span> cols = mxGetN(in); |
---|
707 | <a name="l00768"></a>00768 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Cimat: Data has zero columns"</span>); |
---|
708 | <a name="l00769"></a>00769 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
709 | <a name="l00770"></a>00770 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
710 | <a name="l00771"></a>00771 out[r][c] = (int)(*temp++); |
---|
711 | <a name="l00772"></a>00772 } |
---|
712 | <a name="l00773"></a>00773 } |
---|
713 | <a name="l00774"></a>00774 } |
---|
714 | <a name="l00775"></a>00775 |
---|
715 | <a name="l00776"></a><a class="code" href="group__mexfiles.html#g52a848d56a73ea66e5130bb58e061a51">00776</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g52a848d56a73ea66e5130bb58e061a51" title="Convert the matlab-format mxArray to C-format pointer to pointer to double.">mxArray2Cmat</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">double</span> **out) |
---|
716 | <a name="l00777"></a>00777 { |
---|
717 | <a name="l00778"></a>00778 <span class="keywordtype">int</span> r, c; |
---|
718 | <a name="l00779"></a>00779 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
719 | <a name="l00780"></a>00780 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Cmat: Pointer to data is NULL"</span>); |
---|
720 | <a name="l00781"></a>00781 <span class="keywordtype">int</span> rows = mxGetM(in); |
---|
721 | <a name="l00782"></a>00782 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Cmat: Data has zero rows"</span>); |
---|
722 | <a name="l00783"></a>00783 <span class="keywordtype">int</span> cols = mxGetN(in); |
---|
723 | <a name="l00784"></a>00784 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Cmat: Data has zero columns"</span>); |
---|
724 | <a name="l00785"></a>00785 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
725 | <a name="l00786"></a>00786 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
726 | <a name="l00787"></a>00787 out[r][c] = (*temp++); |
---|
727 | <a name="l00788"></a>00788 } |
---|
728 | <a name="l00789"></a>00789 } |
---|
729 | <a name="l00790"></a>00790 } |
---|
730 | <a name="l00791"></a>00791 |
---|
731 | <a name="l00792"></a><a class="code" href="group__mexfiles.html#gf8dffb515e935d83a980c79ff61a270f">00792</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gf8dffb515e935d83a980c79ff61a270f" title="Convert the matlab-format mxArray to C-format pointer to pointer to double (real...">mxArray2Ccmat</a>(<span class="keyword">const</span> mxArray *in, <span class="keywordtype">double</span> **out_real, <span class="keywordtype">double</span> **out_imag) |
---|
732 | <a name="l00793"></a>00793 { |
---|
733 | <a name="l00794"></a>00794 <span class="keywordtype">int</span> r, c; |
---|
734 | <a name="l00795"></a>00795 <span class="keywordtype">double</span>* tempR = (<span class="keywordtype">double</span>*) mxGetPr(in); |
---|
735 | <a name="l00796"></a>00796 <span class="keywordtype">double</span>* tempI = (<span class="keywordtype">double</span>*) mxGetPi(in); |
---|
736 | <a name="l00797"></a>00797 <span class="keywordflow">if</span> (tempR == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Cmat: Pointer to real valued part is NULL"</span>); |
---|
737 | <a name="l00798"></a>00798 <span class="keywordflow">if</span> (tempI == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Cmat: Pointer to imaginary valued part is NULL"</span>); |
---|
738 | <a name="l00799"></a>00799 <span class="keywordtype">int</span> rows = mxGetM(in); |
---|
739 | <a name="l00800"></a>00800 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Cmat: Data has zero rows"</span>); |
---|
740 | <a name="l00801"></a>00801 <span class="keywordtype">int</span> cols = mxGetN(in); |
---|
741 | <a name="l00802"></a>00802 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"mxArray2Cmat: Data has zero columns"</span>); |
---|
742 | <a name="l00803"></a>00803 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
743 | <a name="l00804"></a>00804 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
744 | <a name="l00805"></a>00805 out_real[r][c] = (*tempR++); |
---|
745 | <a name="l00806"></a>00806 out_imag[r][c] = (*tempI++); |
---|
746 | <a name="l00807"></a>00807 } |
---|
747 | <a name="l00808"></a>00808 } |
---|
748 | <a name="l00809"></a>00809 } |
---|
749 | <a name="l00810"></a>00810 |
---|
750 | <a name="l00811"></a><a class="code" href="group__mexfiles.html#gcc7700ff9ee3a2d8d434534c4519a833">00811</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gcc7700ff9ee3a2d8d434534c4519a833" title="Convert C-format pointer to short to matlab-format mxArray.">Csvec2mxArray</a>(<span class="keywordtype">short</span> *in, mxArray *out) |
---|
751 | <a name="l00812"></a>00812 { |
---|
752 | <a name="l00813"></a>00813 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
753 | <a name="l00814"></a>00814 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"Csvec2mxArray: Pointer to data is NULL"</span>); |
---|
754 | <a name="l00815"></a>00815 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a> = mxGetNumberOfElements(out); |
---|
755 | <a name="l00816"></a>00816 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"Csvec2mxArray: Size of data is zero"</span>); |
---|
756 | <a name="l00817"></a>00817 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < size; i++) { *temp++ = (double) in[i]; } |
---|
757 | <a name="l00818"></a>00818 } |
---|
758 | <a name="l00819"></a>00819 |
---|
759 | <a name="l00820"></a><a class="code" href="group__mexfiles.html#gcece7ce3e6101d8f3094b61be90a4de4">00820</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gcece7ce3e6101d8f3094b61be90a4de4" title="Convert C-format pointer to int to matlab-format mxArray.">Civec2mxArray</a>(<span class="keywordtype">int</span> *in, mxArray *out) |
---|
760 | <a name="l00821"></a>00821 { |
---|
761 | <a name="l00822"></a>00822 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
762 | <a name="l00823"></a>00823 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"Civec2mxArray: Pointer to data is NULL"</span>); |
---|
763 | <a name="l00824"></a>00824 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a> = mxGetNumberOfElements(out); |
---|
764 | <a name="l00825"></a>00825 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"Civec2mxArray: Size of data is zero"</span>); |
---|
765 | <a name="l00826"></a>00826 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < size; i++) { *temp++ = (double) in[i]; } |
---|
766 | <a name="l00827"></a>00827 } |
---|
767 | <a name="l00828"></a>00828 |
---|
768 | <a name="l00829"></a><a class="code" href="group__mexfiles.html#gb9bd9c76e9eddb4ac9b84268d660fe3e">00829</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gb9bd9c76e9eddb4ac9b84268d660fe3e" title="Convert C-format pointer to double to matlab-format mxArray.">Cvec2mxArray</a>(<span class="keywordtype">double</span> *in, mxArray *out) |
---|
769 | <a name="l00830"></a>00830 { |
---|
770 | <a name="l00831"></a>00831 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
771 | <a name="l00832"></a>00832 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"Cvec2mxArray: Pointer to data is NULL"</span>); |
---|
772 | <a name="l00833"></a>00833 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a> = mxGetNumberOfElements(out); |
---|
773 | <a name="l00834"></a>00834 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"Cvec2mxArray: Size of data is zero"</span>); |
---|
774 | <a name="l00835"></a>00835 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < size; i++) { *temp++ = in[i]; } |
---|
775 | <a name="l00836"></a>00836 } |
---|
776 | <a name="l00837"></a>00837 |
---|
777 | <a name="l00838"></a><a class="code" href="group__mexfiles.html#g157b049f32c1ae57dad33803932d5884">00838</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g157b049f32c1ae57dad33803932d5884" title="Convert C-format pointers to double (real and imaginary parts) to matlab-format mxArray...">Ccvec2mxArray</a>(<span class="keywordtype">double</span> *in_real, <span class="keywordtype">double</span> *in_imag, mxArray *out) |
---|
778 | <a name="l00839"></a>00839 { |
---|
779 | <a name="l00840"></a>00840 <span class="keywordtype">double</span>* tempR = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
780 | <a name="l00841"></a>00841 <span class="keywordtype">double</span>* tempI = (<span class="keywordtype">double</span> *) mxGetPi(out); |
---|
781 | <a name="l00842"></a>00842 <span class="keywordflow">if</span> (tempR == 0) mexErrMsgTxt(<span class="stringliteral">"Ccvec2mxArray: Pointer to real valued part is NULL"</span>); |
---|
782 | <a name="l00843"></a>00843 <span class="keywordflow">if</span> (tempI == 0) mexErrMsgTxt(<span class="stringliteral">"Ccvec2mxArray: Pointer to imaginary valued part is NULL"</span>); |
---|
783 | <a name="l00844"></a>00844 <span class="keywordtype">int</span> <a class="code" href="group__matrix__functions.html#g3c1a2b0972c6a8e1215eb3f76d7c7512" title="Length of vector.">size</a> = mxGetNumberOfElements(out); |
---|
784 | <a name="l00845"></a>00845 <span class="keywordflow">if</span> (size == 0) mexErrMsgTxt(<span class="stringliteral">"Ccvec2mxArray: Size of data is zero"</span>); |
---|
785 | <a name="l00846"></a>00846 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < size; i++) { *tempR++ = in_real[i]; *tempI++ = in_imag[i]; } |
---|
786 | <a name="l00847"></a>00847 } |
---|
787 | <a name="l00848"></a>00848 |
---|
788 | <a name="l00849"></a><a class="code" href="group__mexfiles.html#gffcc3047b69811b179eac1f5918a2eb0">00849</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gffcc3047b69811b179eac1f5918a2eb0" title="Convert C-format pointer to pointer to short to matlab-format mxArray.">Csmat2mxArray</a>(<span class="keywordtype">short</span> **in, mxArray *out) |
---|
789 | <a name="l00850"></a>00850 { |
---|
790 | <a name="l00851"></a>00851 <span class="keywordtype">int</span> r, c; |
---|
791 | <a name="l00852"></a>00852 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
792 | <a name="l00853"></a>00853 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"Csmat2mxArray: Pointer to data is NULL"</span>); |
---|
793 | <a name="l00854"></a>00854 <span class="keywordtype">int</span> rows = mxGetM(out); |
---|
794 | <a name="l00855"></a>00855 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"Csmat2mxArray: Data has zero rows"</span>); |
---|
795 | <a name="l00856"></a>00856 <span class="keywordtype">int</span> cols = mxGetN(out); |
---|
796 | <a name="l00857"></a>00857 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"Csmat2mxArray: Data has zero columns"</span>); |
---|
797 | <a name="l00858"></a>00858 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
798 | <a name="l00859"></a>00859 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
799 | <a name="l00860"></a>00860 *temp++ = (short) in[r][c]; |
---|
800 | <a name="l00861"></a>00861 } |
---|
801 | <a name="l00862"></a>00862 } |
---|
802 | <a name="l00863"></a>00863 } |
---|
803 | <a name="l00864"></a>00864 |
---|
804 | <a name="l00865"></a><a class="code" href="group__mexfiles.html#g30559d4f2e3376c4370b81f3450cbb50">00865</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#g30559d4f2e3376c4370b81f3450cbb50" title="Convert C-format pointer to pointer to int to matlab-format mxArray.">Cimat2mxArray</a>(<span class="keywordtype">int</span> **in, mxArray *out) |
---|
805 | <a name="l00866"></a>00866 { |
---|
806 | <a name="l00867"></a>00867 <span class="keywordtype">int</span> r, c; |
---|
807 | <a name="l00868"></a>00868 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
808 | <a name="l00869"></a>00869 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"Cimat2mxArray: Pointer to data is NULL"</span>); |
---|
809 | <a name="l00870"></a>00870 <span class="keywordtype">int</span> rows = mxGetM(out); |
---|
810 | <a name="l00871"></a>00871 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"Cimat2mxArray: Data has zero rows"</span>); |
---|
811 | <a name="l00872"></a>00872 <span class="keywordtype">int</span> cols = mxGetN(out); |
---|
812 | <a name="l00873"></a>00873 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"Cimat2mxArray: Data has zero columns"</span>); |
---|
813 | <a name="l00874"></a>00874 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
814 | <a name="l00875"></a>00875 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
815 | <a name="l00876"></a>00876 *temp++ = (int) in[r][c]; |
---|
816 | <a name="l00877"></a>00877 } |
---|
817 | <a name="l00878"></a>00878 } |
---|
818 | <a name="l00879"></a>00879 } |
---|
819 | <a name="l00880"></a>00880 |
---|
820 | <a name="l00881"></a><a class="code" href="group__mexfiles.html#gb3154ff3fb563011aee4e9b206b09c1d">00881</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gb3154ff3fb563011aee4e9b206b09c1d" title="Convert C-format pointer to pointer to double to matlab-format mxArray.">Cmat2mxArray</a>(<span class="keywordtype">double</span> **in, mxArray *out) |
---|
821 | <a name="l00882"></a>00882 { |
---|
822 | <a name="l00883"></a>00883 <span class="keywordtype">int</span> r, c; |
---|
823 | <a name="l00884"></a>00884 <span class="keywordtype">double</span>* temp = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
824 | <a name="l00885"></a>00885 <span class="keywordflow">if</span> (temp == 0) mexErrMsgTxt(<span class="stringliteral">"Cmat2mxArray: Pointer to data is NULL"</span>); |
---|
825 | <a name="l00886"></a>00886 <span class="keywordtype">int</span> rows = mxGetM(out); |
---|
826 | <a name="l00887"></a>00887 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"Cmat2mxArray: Data has zero rows"</span>); |
---|
827 | <a name="l00888"></a>00888 <span class="keywordtype">int</span> cols = mxGetN(out); |
---|
828 | <a name="l00889"></a>00889 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"Cmat2mxArray: Data has zero columns"</span>); |
---|
829 | <a name="l00890"></a>00890 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
830 | <a name="l00891"></a>00891 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
831 | <a name="l00892"></a>00892 *temp++ = in[r][c]; |
---|
832 | <a name="l00893"></a>00893 } |
---|
833 | <a name="l00894"></a>00894 } |
---|
834 | <a name="l00895"></a>00895 } |
---|
835 | <a name="l00896"></a>00896 |
---|
836 | <a name="l00897"></a><a class="code" href="group__mexfiles.html#gaa443bad4a1c6b53ca10c5442a82afc4">00897</a> <span class="keywordtype">void</span> <a class="code" href="group__mexfiles.html#gaa443bad4a1c6b53ca10c5442a82afc4" title="Convert C-format pointer to pointer to double (real and imaginary parts) to matlab-format...">Ccmat2mxArray</a>(<span class="keywordtype">double</span> **in_real, <span class="keywordtype">double</span> **in_imag, mxArray *out) |
---|
837 | <a name="l00898"></a>00898 { |
---|
838 | <a name="l00899"></a>00899 <span class="keywordtype">int</span> r, c; |
---|
839 | <a name="l00900"></a>00900 <span class="keywordtype">double</span>* tempR = (<span class="keywordtype">double</span> *) mxGetPr(out); |
---|
840 | <a name="l00901"></a>00901 <span class="keywordtype">double</span>* tempI = (<span class="keywordtype">double</span> *) mxGetPi(out); |
---|
841 | <a name="l00902"></a>00902 <span class="keywordflow">if</span> (tempR == 0) mexErrMsgTxt(<span class="stringliteral">"Ccmat2mxArray: Pointer to real valued part is NULL"</span>); |
---|
842 | <a name="l00903"></a>00903 <span class="keywordflow">if</span> (tempI == 0) mexErrMsgTxt(<span class="stringliteral">"Ccmat2mxArray: Pointer to imaginary valued part is NULL"</span>); |
---|
843 | <a name="l00904"></a>00904 <span class="keywordtype">int</span> rows = mxGetM(out); |
---|
844 | <a name="l00905"></a>00905 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"Ccmat2mxArray: Data has zero rows"</span>); |
---|
845 | <a name="l00906"></a>00906 <span class="keywordtype">int</span> cols = mxGetN(out); |
---|
846 | <a name="l00907"></a>00907 <span class="keywordflow">if</span> (cols == 0) mexErrMsgTxt(<span class="stringliteral">"Ccmat2mxArray: Data has zero columns"</span>); |
---|
847 | <a name="l00908"></a>00908 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
---|
848 | <a name="l00909"></a>00909 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
---|
849 | <a name="l00910"></a>00910 *tempR++ = in_real[r][c]; |
---|
850 | <a name="l00911"></a>00911 *tempI++ = in_imag[r][c]; |
---|
851 | <a name="l00912"></a>00912 } |
---|
852 | <a name="l00913"></a>00913 } |
---|
853 | <a name="l00914"></a>00914 } |
---|
854 | <a name="l00915"></a>00915 |
---|
855 | <a name="l00916"></a>00916 } <span class="comment">// namespace itpp</span> |
---|
856 | <a name="l00917"></a>00917 |
---|
857 | <a name="l00918"></a>00918 <span class="preprocessor">#endif // #ifndef ITMEX_H</span> |
---|
858 | </pre></div></div> |
---|
859 | <hr size="1"><address style="text-align: right;"><small>Generated on Tue Jun 2 10:02:11 2009 for mixpp by |
---|
860 | <a href="http://www.doxygen.org/index.html"> |
---|
861 | <img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.8 </small></address> |
---|
862 | </body> |
---|
863 | </html> |
---|