67 | | <h1>mex_logger.h</h1><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="preprocessor">#include "<a class="code" href="loggers_8h.html" title="Loggers for storing results of experiments.">base/loggers.h</a>"</span> |
68 | | <a name="l00002"></a>00002 |
69 | | <a name="l00003"></a>00003 <span class="keyword">namespace </span>bdm { |
70 | | <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 ) { |
71 | | <a name="l00005"></a>00005 mxArray *Old; |
72 | | <a name="l00006"></a>00006 <span class="keywordtype">int</span> i; |
73 | | <a name="l00007"></a>00007 |
74 | | <a name="l00008"></a>00008 <span class="keywordflow">if</span> ( ( i = mxGetFieldNumber ( X, fname ) ) == -1 ) { |
75 | | <a name="l00009"></a>00009 <span class="keywordflow">if</span> ( ( i = mxAddField ( X, fname ) ) == -1 ) <span class="keywordflow">return</span> i; |
| 67 | <h1>mex_logger.h</h1><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="preprocessor">#ifndef MXLOG_H</span> |
| 68 | <a name="l00002"></a>00002 <span class="preprocessor"></span><span class="preprocessor">#define MXLOG_H</span> |
| 69 | <a name="l00003"></a>00003 <span class="preprocessor"></span> |
| 70 | <a name="l00004"></a>00004 <span class="preprocessor">#include "<a class="code" href="loggers_8h.html" title="Loggers for storing results of experiments.">base/loggers.h</a>"</span> |
| 71 | <a name="l00005"></a>00005 |
| 72 | <a name="l00006"></a>00006 <span class="keyword">namespace </span>bdm { |
| 73 | <a name="l00007"></a>00007 <span class="keywordtype">int</span> mxReplaceFieldNM ( mxArray *X, <span class="keyword">const</span> <span class="keywordtype">char</span> * fname, mxArray *X1 ) { |
| 74 | <a name="l00008"></a>00008 mxArray *Old; |
| 75 | <a name="l00009"></a>00009 <span class="keywordtype">int</span> i; |
77 | | <a name="l00011"></a>00011 } |
78 | | <a name="l00012"></a>00012 |
79 | | <a name="l00013"></a>00013 Old = mxGetFieldByNumber ( X, 0, i ); |
80 | | <a name="l00014"></a>00014 <span class="keywordflow">if</span> ( Old ) mxDestroyArray ( Old ); |
81 | | <a name="l00015"></a>00015 mxSetFieldByNumber ( X, 0, i, X1 ); |
82 | | <a name="l00016"></a>00016 <span class="keywordflow">return</span> i; |
83 | | <a name="l00017"></a>00017 |
84 | | <a name="l00018"></a>00018 }; |
85 | | <a name="l00019"></a>00019 |
86 | | <a name="l00020"></a>00020 <span class="keywordtype">void</span> Arrayvec2mxArray ( <span class="keyword">const</span> Array<vec> &in, mxArray *out ) { |
87 | | <a name="l00021"></a>00021 <span class="keywordtype">int</span> rows, cols, r, c; |
| 77 | <a name="l00011"></a>00011 <span class="keywordflow">if</span> ( ( i = mxGetFieldNumber ( X, fname ) ) == -1 ) { |
| 78 | <a name="l00012"></a>00012 <span class="keywordflow">if</span> ( ( i = mxAddField ( X, fname ) ) == -1 ) <span class="keywordflow">return</span> i; |
| 79 | <a name="l00013"></a>00013 |
| 80 | <a name="l00014"></a>00014 } |
| 81 | <a name="l00015"></a>00015 |
| 82 | <a name="l00016"></a>00016 Old = mxGetFieldByNumber ( X, 0, i ); |
| 83 | <a name="l00017"></a>00017 <span class="keywordflow">if</span> ( Old ) mxDestroyArray ( Old ); |
| 84 | <a name="l00018"></a>00018 mxSetFieldByNumber ( X, 0, i, X1 ); |
| 85 | <a name="l00019"></a>00019 <span class="keywordflow">return</span> i; |
| 86 | <a name="l00020"></a>00020 |
| 87 | <a name="l00021"></a>00021 }; |
98 | | <a name="l00032"></a>00032 <span class="keywordflow">for</span> ( c = 0; c < cols; c++ ) { |
99 | | <a name="l00033"></a>00033 <span class="keywordflow">for</span> ( r = 0; r < rows; r++ ) { |
100 | | <a name="l00034"></a>00034 *temp++ = in ( c ) ( r ); |
101 | | <a name="l00035"></a>00035 } |
102 | | <a name="l00036"></a>00036 } |
103 | | <a name="l00037"></a>00037 |
104 | | <a name="l00038"></a>00038 } |
105 | | <a name="l00039"></a>00039 |
106 | | <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> { |
107 | | <a name="l00042"></a>00042 <span class="keyword">public</span>: |
108 | | <a name="l00044"></a><a class="code" href="classbdm_1_1mexlog.html#ac458d92bb26518c908521a8c9460a2c1">00044</a> <a class="code" href="classbdm_1_1mexlog.html#ac458d92bb26518c908521a8c9460a2c1" title="constructor">mexlog</a>() : <a class="code" href="classbdm_1_1memlog.html">memlog</a> ( 0, <span class="stringliteral">""</span> ) {}; |
109 | | <a name="l00046"></a>00046 mxArray* toCell() { |
110 | | <a name="l00047"></a>00047 mxArray* tmp = mxCreateStructMatrix ( 1, 1, 0, NULL ); |
111 | | <a name="l00048"></a>00048 |
112 | | <a name="l00049"></a>00049 <span class="comment">//copied from itsave</span> |
113 | | <a name="l00050"></a>00050 <span class="keywordtype">int</span> i; |
114 | | <a name="l00051"></a>00051 <span class="keywordtype">string</span> vec_name = <span class="stringliteral">""</span>; |
115 | | <a name="l00052"></a>00052 <span class="keywordtype">int</span> istart, iend; |
116 | | <a name="l00053"></a>00053 |
117 | | <a name="l00054"></a>00054 mat M; <span class="comment">//temporary matrix</span> |
118 | | <a name="l00055"></a>00055 <span class="keywordflow">for</span> ( i = 0; i < <a class="code" href="classbdm_1_1logger.html#ac54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a>.length(); i++ ) { |
119 | | <a name="l00056"></a>00056 istart = 0; |
120 | | <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#ac54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a> ( i ).length(); j++ ) { <span class="comment">// same for as in add!!!</span> |
121 | | <a name="l00058"></a>00058 vec_name = <a class="code" href="classbdm_1_1logger.html#a68ca1f05cf3d414ba0f39211977b8d02" title="Names of logged quantities, e.g. names of algorithm variants.">names</a> ( i ) + <a class="code" href="classbdm_1_1logger.html#ac54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a> ( i ).name ( j ); |
122 | | <a name="l00059"></a>00059 iend = istart + <a class="code" href="classbdm_1_1logger.html#ac54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a> ( i ).size ( j ) - 1; |
123 | | <a name="l00060"></a>00060 M = <a class="code" href="classbdm_1_1memlog.html#a1fed143162f2de6ef1c1b6557964f24e" title="Storage.">vectors</a> ( i ).get_cols ( istart, iend ); |
124 | | <a name="l00061"></a>00061 istart = iend + 1; |
125 | | <a name="l00062"></a>00062 <span class="comment">// copy the selection to mx</span> |
126 | | <a name="l00063"></a>00063 mxArray* fld = mxCreateDoubleMatrix ( M.rows(), M.cols(), mxREAL ); |
127 | | <a name="l00064"></a>00064 mat2mxArray ( M, fld ); |
128 | | <a name="l00065"></a>00065 mxReplaceFieldNM ( tmp, vec_name.c_str(), fld ); |
129 | | <a name="l00066"></a>00066 } |
130 | | <a name="l00067"></a>00067 } |
131 | | <a name="l00068"></a>00068 <span class="keywordflow">return</span> tmp; |
132 | | <a name="l00069"></a>00069 } |
133 | | <a name="l00070"></a><a class="code" href="classbdm_1_1mexlog.html#a39c44b30f201091ab3d287fe5741113e">00070</a> <span class="keywordtype">void</span> <a class="code" href="classbdm_1_1mexlog.html#a39c44b30f201091ab3d287fe5741113e" 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> ) { |
134 | | <a name="l00071"></a>00071 <a class="code" href="classbdm_1_1memlog.html#aa690ebd91430b5973855c9b4c9cf1b1d" title="Maximum length of vectors stored in memory.">maxlen</a> = root[<span class="stringliteral">"maxlen"</span>]; |
135 | | <a name="l00072"></a>00072 } |
136 | | <a name="l00073"></a>00073 }; |
137 | | <a name="l00074"></a>00074 <a class="code" href="user__info_8h.html#a4f9de2f17e844047726487b99def99c6" title="Macro for registration of class into map of user-infos, registered class is scriptable...">UIREGISTER</a> ( mexlog ); |
138 | | <a name="l00075"></a>00075 SHAREDPTR ( mexlog ); |
139 | | <a name="l00076"></a>00076 } |
| 98 | <a name="l00032"></a>00032 rows = in ( 0 ).length(); <span class="comment">//length of the first vec</span> |
| 99 | <a name="l00033"></a>00033 <span class="keywordflow">if</span> ( rows == 0 ) mexErrMsgTxt ( <span class="stringliteral">"mat2mxArray: Data has zero rows"</span> ); |
| 100 | <a name="l00034"></a>00034 |
| 101 | <a name="l00035"></a>00035 <span class="keywordflow">for</span> ( c = 0; c < cols; c++ ) { |
| 102 | <a name="l00036"></a>00036 <span class="keywordflow">for</span> ( r = 0; r < rows; r++ ) { |
| 103 | <a name="l00037"></a>00037 *temp++ = in ( c ) ( r ); |
| 104 | <a name="l00038"></a>00038 |
| 105 | <a name="l00039"></a>00039 } |
| 106 | <a name="l00040"></a>00040 } |
| 107 | <a name="l00041"></a>00041 |
| 108 | <a name="l00042"></a>00042 } |
| 109 | <a name="l00043"></a>00043 |
| 110 | <a name="l00045"></a><a class="code" href="classbdm_1_1mexlog.html">00045</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> { |
| 111 | <a name="l00046"></a>00046 <span class="keyword">public</span>: |
| 112 | <a name="l00048"></a><a class="code" href="classbdm_1_1mexlog.html#ac458d92bb26518c908521a8c9460a2c1">00048</a> <a class="code" href="classbdm_1_1mexlog.html#ac458d92bb26518c908521a8c9460a2c1" title="constructor">mexlog</a>() : <a class="code" href="classbdm_1_1memlog.html">memlog</a> ( 0, <span class="stringliteral">""</span> ) {}; |
| 113 | <a name="l00050"></a>00050 mxArray* toCell() { |
| 114 | <a name="l00051"></a>00051 mxArray* tmp = mxCreateStructMatrix ( 1, 1, 0, NULL ); |
| 115 | <a name="l00052"></a>00052 |
| 116 | <a name="l00053"></a>00053 <span class="comment">//copied from itsave</span> |
| 117 | <a name="l00054"></a>00054 <span class="keywordtype">int</span> i; |
| 118 | <a name="l00055"></a>00055 <span class="keywordtype">string</span> vec_name = <span class="stringliteral">""</span>; |
| 119 | <a name="l00056"></a>00056 <span class="keywordtype">int</span> istart, iend; |
| 120 | <a name="l00057"></a>00057 |
| 121 | <a name="l00058"></a>00058 mat M; <span class="comment">//temporary matrix</span> |
| 122 | <a name="l00059"></a>00059 <span class="keywordflow">for</span> ( i = 0; i < <a class="code" href="classbdm_1_1logger.html#ac54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a>.length(); i++ ) { |
| 123 | <a name="l00060"></a>00060 istart = 0; |
| 124 | <a name="l00061"></a>00061 <span class="keywordflow">for</span> ( <span class="keywordtype">int</span> j = 0; j < <a class="code" href="classbdm_1_1logger.html#ac54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a> ( i ).length(); j++ ) { <span class="comment">// same for as in add!!!</span> |
| 125 | <a name="l00062"></a>00062 vec_name = <a class="code" href="classbdm_1_1logger.html#a68ca1f05cf3d414ba0f39211977b8d02" title="Names of logged quantities, e.g. names of algorithm variants.">names</a> ( i ) + <a class="code" href="classbdm_1_1logger.html#ac54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a> ( i ).name ( j ); |
| 126 | <a name="l00063"></a>00063 iend = istart + <a class="code" href="classbdm_1_1logger.html#ac54566a4554089443a20b2a49ed1a61f" title="RVs of all logged variables.">entries</a> ( i ).size ( j ) - 1; |
| 127 | <a name="l00064"></a>00064 M = <a class="code" href="classbdm_1_1memlog.html#a1fed143162f2de6ef1c1b6557964f24e" title="Storage.">vectors</a> ( i ).get_cols ( istart, iend ); |
| 128 | <a name="l00065"></a>00065 istart = iend + 1; |
| 129 | <a name="l00066"></a>00066 <span class="comment">// copy the selection to mx</span> |
| 130 | <a name="l00067"></a>00067 mxArray* fld = mxCreateDoubleMatrix ( M.rows(), M.cols(), mxREAL ); |
| 131 | <a name="l00068"></a>00068 mat2mxArray ( M, fld ); |
| 132 | <a name="l00069"></a>00069 mxReplaceFieldNM ( tmp, vec_name.c_str(), fld ); |
| 133 | <a name="l00070"></a>00070 } |
| 134 | <a name="l00071"></a>00071 } |
| 135 | <a name="l00072"></a>00072 <span class="keywordflow">return</span> tmp; |
| 136 | <a name="l00073"></a>00073 } |
| 137 | <a name="l00074"></a><a class="code" href="classbdm_1_1mexlog.html#a39c44b30f201091ab3d287fe5741113e">00074</a> <span class="keywordtype">void</span> <a class="code" href="classbdm_1_1mexlog.html#a39c44b30f201091ab3d287fe5741113e" 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> ) { |
| 138 | <a name="l00075"></a>00075 <a class="code" href="classbdm_1_1memlog.html#aa690ebd91430b5973855c9b4c9cf1b1d" title="Maximum length of vectors stored in memory.">maxlen</a> = root[<span class="stringliteral">"maxlen"</span>]; |
| 139 | <a name="l00076"></a>00076 } |
| 140 | <a name="l00077"></a>00077 }; |
| 141 | <a name="l00078"></a>00078 <a class="code" href="user__info_8h.html#a4f9de2f17e844047726487b99def99c6" title="Macro for registration of class into map of user-infos, registered class is scriptable...">UIREGISTER</a> ( mexlog ); |
| 142 | <a name="l00079"></a>00079 SHAREDPTR ( mexlog ); |
| 143 | <a name="l00080"></a>00080 } |
| 144 | <a name="l00081"></a>00081 |
| 145 | <a name="l00082"></a>00082 <span class="preprocessor">#endif //MXLOG_H</span> |