root/doc/html/itmex_8h-source.html @ 353

Revision 353, 88.6 kB (checked in by smidl, 16 years ago)

doc

Line 
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<!--
10function 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}
22function 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}
46window.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&nbsp;Page</span></a></li>
53      <li><a href="pages.html"><span>Related&nbsp;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&nbsp;List</span></a></li>
62      <li><a href="globals.html"><span>File&nbsp;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 &lt;<a class="code" href="itbase_8h.html" title="Include file for the IT++ base module.">itpp/itbase.h</a>&gt;</span>
70<a name="l00033"></a>00033 <span class="preprocessor">#include &lt;mex.h&gt;</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 -&gt; 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 -&gt; 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&lt;double&gt; <a class="code" href="group__mexfiles.html#g3e58103a674bb9839794b0c4a1f3cada" title="Convert the matlab-format mxArray to complex&amp;lt;double&amp;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++ -&gt; 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 &amp;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> &amp;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> &amp;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> &amp;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&amp;lt;double&amp;gt; to the matlab-format mxArray.">double_complex2mxArray</a>(<span class="keyword">const</span> std::complex&lt;double&gt; &amp;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 &amp;in, mxArray* &amp;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 &amp;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 &amp;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 &amp;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 &amp;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 &amp;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> &amp;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 &amp;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 &amp;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 &amp;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 &amp;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 -&gt; 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 -&gt; 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) &gt; 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&lt;double&gt; <a class="code" href="group__mexfiles.html#g3e58103a674bb9839794b0c4a1f3cada" title="Convert the matlab-format mxArray to complex&amp;lt;double&amp;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) &amp;&amp; (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&lt;double&gt;(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&lt;double&gt;((*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&lt;double&gt;((*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 &lt; size; i++) {
244<a name="l00305"></a>00305     out(i) = (((*temp++) &gt; 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 &lt; 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 &lt; 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 &lt; 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) &amp;&amp; (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 &lt; size; i++) { out(i) = std::complex&lt;double&gt;(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 &lt; size; i++) { out(i) = std::complex&lt;double&gt;((*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 &lt; size; i++) { out(i) = std::complex&lt;double&gt;((*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 &lt; cols; c++) {
354<a name="l00415"></a>00415     <span class="keywordflow">for</span> (r = 0; r &lt; rows; r++) {
355<a name="l00416"></a>00416       out(r, c) = (((*temp++) &gt; 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 &lt; cols; c++) {
378<a name="l00439"></a>00439     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &lt; cols; c++) {
401<a name="l00462"></a>00462     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &lt; cols; c++) {
424<a name="l00485"></a>00485     <span class="keywordflow">for</span> (r = 0; r &lt; 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) &amp;&amp; (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 &lt; cols; c++) { <span class="keywordflow">for</span> (r = 0; r &lt; rows; r++) { out(r, c) = std::complex&lt;double&gt;(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 &lt; cols; c++) { <span class="keywordflow">for</span> (r = 0; r &lt; rows; r++) { out(r, c) = std::complex&lt;double&gt;((*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 &lt; cols; c++) { <span class="keywordflow">for</span> (r = 0; r &lt; rows; r++) { out(r, c) = std::complex&lt;double&gt;((*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> &amp;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&amp;lt;double&amp;gt; to the matlab-format mxArray.">double_complex2mxArray</a>(<span class="keyword">const</span> std::complex&lt;double&gt; &amp;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 &amp;in, mxArray* &amp;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 &amp;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 &lt; 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 &amp;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 &lt; 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 &amp;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 &lt; 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 &amp;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 &lt; 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> &amp;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 &lt; cols; c++) {
552<a name="l00613"></a>00613     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &amp;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 &lt; cols; c++) {
575<a name="l00636"></a>00636     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &amp;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 &lt; cols; c++) {
595<a name="l00656"></a>00656     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &amp;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 &lt; cols; c++) {
615<a name="l00676"></a>00676     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &amp;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 &lt; cols; c++) {
637<a name="l00698"></a>00698     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; cols; c++) {
693<a name="l00754"></a>00754     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &lt; cols; c++) {
709<a name="l00770"></a>00770     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &lt; cols; c++) {
725<a name="l00786"></a>00786     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &lt; cols; c++) {
743<a name="l00804"></a>00804     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; cols; c++) {
798<a name="l00859"></a>00859     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &lt; cols; c++) {
814<a name="l00875"></a>00875     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &lt; cols; c++) {
830<a name="l00891"></a>00891     <span class="keywordflow">for</span> (r = 0; r &lt; 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 &lt; cols; c++) {
848<a name="l00909"></a>00909     <span class="keywordflow">for</span> (r = 0; r &lt; 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&nbsp;
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>
Note: See TracBrowser for help on using the browser.