67 | | <a name="l00003"></a>00003 <span class="keyword">namespace </span>bdm{ |
68 | | <a name="l00004"></a>00004 <span class="keywordtype">int</span> mxReplaceFieldNM(mxArray *X,<span class="keyword">const</span> <span class="keywordtype">char</span> * fname,mxArray *X1) |
69 | | <a name="l00005"></a>00005 { |
70 | | <a name="l00006"></a>00006 mxArray *Old; |
71 | | <a name="l00007"></a>00007 <span class="keywordtype">int</span> i; |
72 | | <a name="l00008"></a>00008 |
73 | | <a name="l00009"></a>00009 <span class="keywordflow">if</span>((i=mxGetFieldNumber(X,fname))==-1) |
74 | | <a name="l00010"></a>00010 { |
75 | | <a name="l00011"></a>00011 <span class="keywordflow">if</span>((i=mxAddField(X,fname))==-1) <span class="keywordflow">return</span> i; |
| 66 | <a name="l00003"></a>00003 <span class="keyword">namespace </span>bdm { |
| 67 | <a name="l00004"></a>00004 <span class="keywordtype">int</span> mxReplaceFieldNM ( mxArray *X, <span class="keyword">const</span> <span class="keywordtype">char</span> * fname, mxArray *X1 ) { |
| 68 | <a name="l00005"></a>00005 mxArray *Old; |
| 69 | <a name="l00006"></a>00006 <span class="keywordtype">int</span> i; |
| 70 | <a name="l00007"></a>00007 |
| 71 | <a name="l00008"></a>00008 <span class="keywordflow">if</span> ( ( i = mxGetFieldNumber ( X, fname ) ) == -1 ) { |
| 72 | <a name="l00009"></a>00009 <span class="keywordflow">if</span> ( ( i = mxAddField ( X, fname ) ) == -1 ) <span class="keywordflow">return</span> i; |
| 73 | <a name="l00010"></a>00010 |
| 74 | <a name="l00011"></a>00011 } |
96 | | <a name="l00032"></a>00032 rows = in(0).length(); <span class="comment">//length of the first vec</span> |
97 | | <a name="l00033"></a>00033 <span class="keywordflow">if</span> (rows == 0) mexErrMsgTxt(<span class="stringliteral">"mat2mxArray: Data has zero rows"</span>); |
98 | | <a name="l00034"></a>00034 |
99 | | <a name="l00035"></a>00035 <span class="keywordflow">for</span> (c = 0; c < cols; c++) { |
100 | | <a name="l00036"></a>00036 <span class="keywordflow">for</span> (r = 0; r < rows; r++) { |
101 | | <a name="l00037"></a>00037 *temp++ = in(c)(r); |
102 | | <a name="l00038"></a>00038 } |
103 | | <a name="l00039"></a>00039 } |
104 | | <a name="l00040"></a>00040 |
105 | | <a name="l00041"></a>00041 } |
106 | | <a name="l00042"></a>00042 <span class="keyword">class </span>mexlog : <span class="keyword">public</span> memlog { |
107 | | <a name="l00043"></a>00043 <span class="keyword">public</span>: |
108 | | <a name="l00045"></a>00045 mexlog(): <a class="code" href="classbdm_1_1memlog.html#611dda03b3050de2eaa448a59cee9c27" title="Default constructor.">memlog</a>(0,<span class="stringliteral">"mx"</span>){}; |
109 | | <a name="l00047"></a>00047 mxArray* toCell(){ |
110 | | <a name="l00048"></a>00048 mxArray* tmp = mxCreateStructMatrix(1,1,0,NULL); |
111 | | <a name="l00049"></a>00049 |
112 | | <a name="l00050"></a>00050 <span class="comment">//copied from itsave</span> |
113 | | <a name="l00051"></a>00051 <span class="keywordtype">int</span> i; |
114 | | <a name="l00052"></a>00052 <span class="keywordtype">string</span> vec_name=<span class="stringliteral">""</span>; |
115 | | <a name="l00053"></a>00053 <span class="keywordtype">int</span> istart, iend; |
116 | | <a name="l00054"></a>00054 |
117 | | <a name="l00055"></a>00055 mat M; <span class="comment">//temporary matrix</span> |
118 | | <a name="l00056"></a>00056 <span class="keywordflow">for</span> ( i=0; i<<a class="code" href="classbdm_1_1logger.html#c54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a>.length();i++ ) { |
119 | | <a name="l00057"></a>00057 istart=0; |
120 | | <a name="l00058"></a>00058 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> j=0; j<<a class="code" href="classbdm_1_1logger.html#c54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a>(i).length(); j++){ <span class="comment">// same for as in add!!!</span> |
121 | | <a name="l00059"></a>00059 vec_name = <a class="code" href="classbdm_1_1logger.html#68ca1f05cf3d414ba0f39211977b8d02" title="Names of logged quantities, e.g. names of algorithm variants.">names</a>(i) + <a class="code" href="classbdm_1_1logger.html#c54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a>(i).name(j); |
122 | | <a name="l00060"></a>00060 iend=istart+<a class="code" href="classbdm_1_1logger.html#c54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a>(i).size(j)-1; |
123 | | <a name="l00061"></a>00061 M=<a class="code" href="classbdm_1_1memlog.html#1fed143162f2de6ef1c1b6557964f24e" title="Storage.">vectors</a>(i).get_cols(istart,iend); |
124 | | <a name="l00062"></a>00062 istart=iend+1; |
125 | | <a name="l00063"></a>00063 <span class="comment">// copy the selection to mx</span> |
126 | | <a name="l00064"></a>00064 mxArray* fld=mxCreateDoubleMatrix(M.rows(), M.cols(), mxREAL); |
127 | | <a name="l00065"></a>00065 mat2mxArray(M,fld); |
128 | | <a name="l00066"></a>00066 mxReplaceFieldNM(tmp, vec_name.c_str(), fld); |
129 | | <a name="l00067"></a>00067 } |
130 | | <a name="l00068"></a>00068 } |
131 | | <a name="l00069"></a>00069 <span class="keywordflow">return</span> tmp; |
132 | | <a name="l00070"></a>00070 } |
133 | | <a name="l00071"></a>00071 <span class="keywordtype">void</span> from_setting (<span class="keyword">const</span> Setting &root){ |
134 | | <a name="l00072"></a>00072 <a class="code" href="classbdm_1_1memlog.html#a690ebd91430b5973855c9b4c9cf1b1d" title="Maximum length of vectors stored in memory.">maxlen</a>=root[<span class="stringliteral">"maxlen"</span>]; |
135 | | <a name="l00073"></a>00073 } |
136 | | <a name="l00074"></a>00074 }; |
137 | | <a name="l00075"></a>00075 <a class="code" href="user__info_8h.html#4f9de2f17e844047726487b99def99c6" title="Macro for registration of class into map of user-infos, registered class is scriptable...">UIREGISTER</a>(mexlog); |
| 95 | <a name="l00032"></a>00032 <span class="keywordflow">for</span> ( c = 0; c < cols; c++ ) { |
| 96 | <a name="l00033"></a>00033 <span class="keywordflow">for</span> ( r = 0; r < rows; r++ ) { |
| 97 | <a name="l00034"></a>00034 *temp++ = in ( c ) ( r ); |
| 98 | <a name="l00035"></a>00035 } |
| 99 | <a name="l00036"></a>00036 } |
| 100 | <a name="l00037"></a>00037 |
| 101 | <a name="l00038"></a>00038 } |
| 102 | <a name="l00039"></a>00039 |
| 103 | <a name="l00041"></a><a class="code" href="classbdm_1_1mexlog.html">00041</a> <span class="keyword">class </span><a class="code" href="classbdm_1_1mexlog.html" title="Logger storing results into an mxArray.">mexlog</a> : <span class="keyword">public</span> <a class="code" href="classbdm_1_1memlog.html">memlog</a> { |
| 104 | <a name="l00042"></a>00042 <span class="keyword">public</span>: |
| 105 | <a name="l00044"></a><a class="code" href="classbdm_1_1mexlog.html#c458d92bb26518c908521a8c9460a2c1">00044</a> <a class="code" href="classbdm_1_1mexlog.html#c458d92bb26518c908521a8c9460a2c1" title="constructor">mexlog</a>() : <a class="code" href="classbdm_1_1memlog.html">memlog</a> ( 0, <span class="stringliteral">""</span> ) {}; |
| 106 | <a name="l00046"></a>00046 mxArray* toCell() { |
| 107 | <a name="l00047"></a>00047 mxArray* tmp = mxCreateStructMatrix ( 1, 1, 0, NULL ); |
| 108 | <a name="l00048"></a>00048 |
| 109 | <a name="l00049"></a>00049 <span class="comment">//copied from itsave</span> |
| 110 | <a name="l00050"></a>00050 <span class="keywordtype">int</span> i; |
| 111 | <a name="l00051"></a>00051 <span class="keywordtype">string</span> vec_name = <span class="stringliteral">""</span>; |
| 112 | <a name="l00052"></a>00052 <span class="keywordtype">int</span> istart, iend; |
| 113 | <a name="l00053"></a>00053 |
| 114 | <a name="l00054"></a>00054 mat M; <span class="comment">//temporary matrix</span> |
| 115 | <a name="l00055"></a>00055 <span class="keywordflow">for</span> ( i = 0; i < <a class="code" href="classbdm_1_1logger.html#c54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a>.length(); i++ ) { |
| 116 | <a name="l00056"></a>00056 istart = 0; |
| 117 | <a name="l00057"></a>00057 <span class="keywordflow">for</span> ( <span class="keywordtype">int</span> j = 0; j < <a class="code" href="classbdm_1_1logger.html#c54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a> ( i ).length(); j++ ) { <span class="comment">// same for as in add!!!</span> |
| 118 | <a name="l00058"></a>00058 vec_name = <a class="code" href="classbdm_1_1logger.html#68ca1f05cf3d414ba0f39211977b8d02" title="Names of logged quantities, e.g. names of algorithm variants.">names</a> ( i ) + <a class="code" href="classbdm_1_1logger.html#c54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a> ( i ).name ( j ); |
| 119 | <a name="l00059"></a>00059 iend = istart + <a class="code" href="classbdm_1_1logger.html#c54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a> ( i ).size ( j ) - 1; |
| 120 | <a name="l00060"></a>00060 M = <a class="code" href="classbdm_1_1memlog.html#1fed143162f2de6ef1c1b6557964f24e" title="Storage.">vectors</a> ( i ).get_cols ( istart, iend ); |
| 121 | <a name="l00061"></a>00061 istart = iend + 1; |
| 122 | <a name="l00062"></a>00062 <span class="comment">// copy the selection to mx</span> |
| 123 | <a name="l00063"></a>00063 mxArray* fld = mxCreateDoubleMatrix ( M.rows(), M.cols(), mxREAL ); |
| 124 | <a name="l00064"></a>00064 mat2mxArray ( M, fld ); |
| 125 | <a name="l00065"></a>00065 mxReplaceFieldNM ( tmp, vec_name.c_str(), fld ); |
| 126 | <a name="l00066"></a>00066 } |
| 127 | <a name="l00067"></a>00067 } |
| 128 | <a name="l00068"></a>00068 <span class="keywordflow">return</span> tmp; |
| 129 | <a name="l00069"></a>00069 } |
| 130 | <a name="l00070"></a><a class="code" href="classbdm_1_1mexlog.html#39c44b30f201091ab3d287fe5741113e">00070</a> <span class="keywordtype">void</span> <a class="code" href="classbdm_1_1mexlog.html#39c44b30f201091ab3d287fe5741113e" title="UI for memlog.">from_setting</a> ( <span class="keyword">const</span> Setting &<a class="code" href="classbdm_1_1root.html" title="Root class of BDM objects.">root</a> ) { |
| 131 | <a name="l00071"></a>00071 <a class="code" href="classbdm_1_1memlog.html#a690ebd91430b5973855c9b4c9cf1b1d" title="Maximum length of vectors stored in memory.">maxlen</a> = root[<span class="stringliteral">"maxlen"</span>]; |
| 132 | <a name="l00072"></a>00072 } |
| 133 | <a name="l00073"></a>00073 }; |
| 134 | <a name="l00074"></a>00074 <a class="code" href="user__info_8h.html#4f9de2f17e844047726487b99def99c6" title="Macro for registration of class into map of user-infos, registered class is scriptable...">UIREGISTER</a> ( mexlog ); |
| 135 | <a name="l00075"></a>00075 SHAREDPTR ( mexlog ); |