| 67 |  | <h1>mex_logger.h</h1><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="preprocessor">#i nclude "<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> |