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: itpp::Sort< T > Class Template Reference</title> |
---|
4 | <link href="tabs.css" rel="stylesheet" type="text/css"> |
---|
5 | <link href="doxygen.css" rel="stylesheet" type="text/css"> |
---|
6 | </head><body> |
---|
7 | <!-- Generated by Doxygen 1.5.8 --> |
---|
8 | <script type="text/javascript"> |
---|
9 | <!-- |
---|
10 | function changeDisplayState (e){ |
---|
11 | var num=this.id.replace(/[^[0-9]/g,''); |
---|
12 | var button=this.firstChild; |
---|
13 | var sectionDiv=document.getElementById('dynsection'+num); |
---|
14 | if (sectionDiv.style.display=='none'||sectionDiv.style.display==''){ |
---|
15 | sectionDiv.style.display='block'; |
---|
16 | button.src='open.gif'; |
---|
17 | }else{ |
---|
18 | sectionDiv.style.display='none'; |
---|
19 | button.src='closed.gif'; |
---|
20 | } |
---|
21 | } |
---|
22 | function initDynSections(){ |
---|
23 | var divs=document.getElementsByTagName('div'); |
---|
24 | var sectionCounter=1; |
---|
25 | for(var i=0;i<divs.length-1;i++){ |
---|
26 | if(divs[i].className=='dynheader'&&divs[i+1].className=='dynsection'){ |
---|
27 | var header=divs[i]; |
---|
28 | var section=divs[i+1]; |
---|
29 | var button=header.firstChild; |
---|
30 | if (button!='IMG'){ |
---|
31 | divs[i].insertBefore(document.createTextNode(' '),divs[i].firstChild); |
---|
32 | button=document.createElement('img'); |
---|
33 | divs[i].insertBefore(button,divs[i].firstChild); |
---|
34 | } |
---|
35 | header.style.cursor='pointer'; |
---|
36 | header.onclick=changeDisplayState; |
---|
37 | header.id='dynheader'+sectionCounter; |
---|
38 | button.src='closed.gif'; |
---|
39 | section.id='dynsection'+sectionCounter; |
---|
40 | section.style.display='none'; |
---|
41 | section.style.marginLeft='14px'; |
---|
42 | sectionCounter++; |
---|
43 | } |
---|
44 | } |
---|
45 | } |
---|
46 | window.onload = initDynSections; |
---|
47 | --> |
---|
48 | </script> |
---|
49 | <div class="navigation" id="top"> |
---|
50 | <div class="tabs"> |
---|
51 | <ul> |
---|
52 | <li><a href="main.html"><span>Main Page</span></a></li> |
---|
53 | <li><a href="pages.html"><span>Related Pages</span></a></li> |
---|
54 | <li><a href="modules.html"><span>Modules</span></a></li> |
---|
55 | <li class="current"><a href="annotated.html"><span>Classes</span></a></li> |
---|
56 | <li><a href="files.html"><span>Files</span></a></li> |
---|
57 | </ul> |
---|
58 | </div> |
---|
59 | <div class="tabs"> |
---|
60 | <ul> |
---|
61 | <li><a href="annotated.html"><span>Class List</span></a></li> |
---|
62 | <li><a href="classes.html"><span>Class Index</span></a></li> |
---|
63 | <li><a href="hierarchy.html"><span>Class Hierarchy</span></a></li> |
---|
64 | <li><a href="functions.html"><span>Class Members</span></a></li> |
---|
65 | </ul> |
---|
66 | </div> |
---|
67 | <div class="navpath"><b>itpp</b>::<a class="el" href="classitpp_1_1Sort.html">Sort</a> |
---|
68 | </div> |
---|
69 | </div> |
---|
70 | <div class="contents"> |
---|
71 | <h1>itpp::Sort< T > Class Template Reference</h1><!-- doxytag: class="itpp::Sort" -->Class for sorting of vectors. |
---|
72 | <a href="#_details">More...</a> |
---|
73 | <p> |
---|
74 | <code>#include <<a class="el" href="sort_8h-source.html">sort.h</a>></code> |
---|
75 | <p> |
---|
76 | |
---|
77 | <p> |
---|
78 | <a href="classitpp_1_1Sort-members.html">List of all members.</a><table border="0" cellpadding="0" cellspacing="0"> |
---|
79 | <tr><td></td></tr> |
---|
80 | <tr><td colspan="2"><br><h2>Public Member Functions</h2></td></tr> |
---|
81 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="e89f0cdcd430af54b41520385b06c9b9"></a><!-- doxytag: member="itpp::Sort::Sort" ref="e89f0cdcd430af54b41520385b06c9b9" args="(SORTING_METHOD method=INTROSORT)" --> |
---|
82 | </td><td class="memItemRight" valign="bottom"><a class="el" href="classitpp_1_1Sort.html#e89f0cdcd430af54b41520385b06c9b9">Sort</a> (SORTING_METHOD method=INTROSORT)</td></tr> |
---|
83 | |
---|
84 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Constructor that sets Intro <a class="el" href="classitpp_1_1Sort.html" title="Class for sorting of vectors.">Sort</a> method by default. <br></td></tr> |
---|
85 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="0fe6dbe275ae1eb38d34e0bea3604044"></a><!-- doxytag: member="itpp::Sort::set_method" ref="0fe6dbe275ae1eb38d34e0bea3604044" args="(SORTING_METHOD method)" --> |
---|
86 | void </td><td class="memItemRight" valign="bottom"><a class="el" href="classitpp_1_1Sort.html#0fe6dbe275ae1eb38d34e0bea3604044">set_method</a> (SORTING_METHOD method)</td></tr> |
---|
87 | |
---|
88 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Set sorting method. <br></td></tr> |
---|
89 | <tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="17222b0f57479cf93632b0caabbe6abc"></a><!-- doxytag: member="itpp::Sort::get_method" ref="17222b0f57479cf93632b0caabbe6abc" args="() const " --> |
---|
90 | SORTING_METHOD </td><td class="memItemRight" valign="bottom"><a class="el" href="classitpp_1_1Sort.html#17222b0f57479cf93632b0caabbe6abc">get_method</a> () const </td></tr> |
---|
91 | |
---|
92 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Get current sorting method. <br></td></tr> |
---|
93 | <tr><td class="memItemLeft" nowrap align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classitpp_1_1Sort.html#0ccff5c48c69b4680347935039a0d3f1">sort</a> (int low, int high, <a class="el" href="classitpp_1_1Vec.html">Vec</a>< T > &data)</td></tr> |
---|
94 | |
---|
95 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Sorting function of a subset of a vector <em>data</em>. <a href="#0ccff5c48c69b4680347935039a0d3f1"></a><br></td></tr> |
---|
96 | <tr><td class="memItemLeft" nowrap align="right" valign="top">ivec </td><td class="memItemRight" valign="bottom"><a class="el" href="classitpp_1_1Sort.html#5eefe31327b1987cf9799562333ebccb">sort_index</a> (int low, int high, const <a class="el" href="classitpp_1_1Vec.html">Vec</a>< T > &data)</td></tr> |
---|
97 | |
---|
98 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Sorting function that returns a sorted index vector. <a href="#5eefe31327b1987cf9799562333ebccb"></a><br></td></tr> |
---|
99 | <tr><td class="memItemLeft" nowrap align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classitpp_1_1Sort.html#5730b92e4812e1cd376619c16cda36d8">intro_sort</a> (int low, int high, int max_depth, <a class="el" href="classitpp_1_1Vec.html">Vec</a>< T > &data)</td></tr> |
---|
100 | |
---|
101 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Introsort function of a subset of a vector <code>data</code>. <a href="#5730b92e4812e1cd376619c16cda36d8"></a><br></td></tr> |
---|
102 | <tr><td class="memItemLeft" nowrap align="right" valign="top">ivec </td><td class="memItemRight" valign="bottom"><a class="el" href="classitpp_1_1Sort.html#b738462d713bcdb42d758e730819b499">intro_sort_index</a> (int low, int high, int max_depth, const <a class="el" href="classitpp_1_1Vec.html">Vec</a>< T > &data)</td></tr> |
---|
103 | |
---|
104 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Introsort function, which returns a sorted index vector. <a href="#b738462d713bcdb42d758e730819b499"></a><br></td></tr> |
---|
105 | </table> |
---|
106 | <hr><a name="_details"></a><h2>Detailed Description</h2> |
---|
107 | <h3>template<class T><br> |
---|
108 | class itpp::Sort< T ></h3> |
---|
109 | |
---|
110 | Class for sorting of vectors. |
---|
111 | <p> |
---|
112 | A class which takes a vector, and sorts its values descending. There are two types of sort: a normal sort (accessed via the <a class="el" href="classitpp_1_1Sort.html#0ccff5c48c69b4680347935039a0d3f1" title="Sorting function of a subset of a vector data.">Sort::sort()</a> function) which sorts the vector passed in the argument, and an index sort (accessed via the <a class="el" href="classitpp_1_1Sort.html#5eefe31327b1987cf9799562333ebccb" title="Sorting function that returns a sorted index vector.">Sort::sort_index()</a> function) which leaves the passed vector intact, but returns an index vector describing the sorted order.<p> |
---|
113 | The <a class="el" href="classitpp_1_1Sort.html" title="Class for sorting of vectors.">Sort</a> class has four sorting methods implemented:<ul> |
---|
114 | <li>Introsort [1,2]: It is a sorting algorithm developed by David Musser. I starts as a quicksort, but switches to a heapsort in cases where the recursion becomes too deep. Additionally, when sub vectors become smaller than 16 elements, it switches to an insertion sort. Introsort has a worst-case of <img class="formulaInl" alt="$\Theta(n\log n)$" src="form_186.png"> comparisons, bu has the efficiency of the quick sort algorithm in cases where the data is well conditioned for quicksort.</li><li>Quicksort [3]: It is a comparison sorting algorithm that has an average complexity of <img class="formulaInl" alt="$\Theta(n\log n)$" src="form_186.png"> comparisons. For most data sets, the quicksort will be significantly more efficient than this average. However for data sets not well suited to it, quicksort may require as many as <img class="formulaInl" alt="$\Theta(n^2)$" src="form_187.png"> comparisons. Example of such ill-suited data sets are those which are nearly in order, and data sets with multiple elements of the same value.</li><li>Heapsort [4]: It is a comparison sorting algorithm. While it is usually seen to be slower than quicksort routines, its worst-case requires only <img class="formulaInl" alt="$\Theta(n\log n)$" src="form_186.png"> comparisons. This makes it an ideal quicksort replacement for data sets that that are ill-conditioned for quicksorting.</li><li>Insertion sort [5]: An insertion sort is a simple comparison sort, which is widely considered to be one of the most efficient algorithms for very small data sets (10-20 elements). <a href="http://en.wikipedia.org/wiki/Insertion_sort">http://en.wikipedia.org/wiki/Insertion_sort</a></li></ul> |
---|
115 | <p> |
---|
116 | References:<ul> |
---|
117 | <li>[1] <a href="http://en.wikipedia.org/wiki/Introsort">http://en.wikipedia.org/wiki/Introsort</a></li><li>[2] <a href="http://www.cs.rpi.edu/~musser/gp/introsort.ps">http://www.cs.rpi.edu/~musser/gp/introsort.ps</a></li><li>[3] <a href="http://en.wikipedia.org/wiki/Quicksort">http://en.wikipedia.org/wiki/Quicksort</a></li><li>[4] <a href="http://en.wikipedia.org/wiki/Heapsort">http://en.wikipedia.org/wiki/Heapsort</a></li><li>[5] <a href="http://en.wikipedia.org/wiki/Insertion_sort">http://en.wikipedia.org/wiki/Insertion_sort</a></li></ul> |
---|
118 | <p> |
---|
119 | <dl class="author" compact><dt><b>Author:</b></dt><dd>Tony Ottosson (Quicksort), Mark Dobossy (Introsort, Heapsort and Insertion <a class="el" href="classitpp_1_1Sort.html" title="Class for sorting of vectors.">Sort</a>) and Adam Piatyszek (<a class="el" href="classitpp_1_1Sort.html" title="Class for sorting of vectors.">Sort</a> class design, code clean-up) </dd></dl> |
---|
120 | <hr><h2>Member Function Documentation</h2> |
---|
121 | <a class="anchor" name="5730b92e4812e1cd376619c16cda36d8"></a><!-- doxytag: member="itpp::Sort::intro_sort" ref="5730b92e4812e1cd376619c16cda36d8" args="(int low, int high, int max_depth, Vec< T > &data)" --> |
---|
122 | <div class="memitem"> |
---|
123 | <div class="memproto"> |
---|
124 | <div class="memtemplate"> |
---|
125 | template<class T > </div> |
---|
126 | <table class="memname"> |
---|
127 | <tr> |
---|
128 | <td class="memname">void <a class="el" href="classitpp_1_1Sort.html">itpp::Sort</a>< T >::intro_sort </td> |
---|
129 | <td>(</td> |
---|
130 | <td class="paramtype">int </td> |
---|
131 | <td class="paramname"> <em>low</em>, </td> |
---|
132 | </tr> |
---|
133 | <tr> |
---|
134 | <td class="paramkey"></td> |
---|
135 | <td></td> |
---|
136 | <td class="paramtype">int </td> |
---|
137 | <td class="paramname"> <em>high</em>, </td> |
---|
138 | </tr> |
---|
139 | <tr> |
---|
140 | <td class="paramkey"></td> |
---|
141 | <td></td> |
---|
142 | <td class="paramtype">int </td> |
---|
143 | <td class="paramname"> <em>max_depth</em>, </td> |
---|
144 | </tr> |
---|
145 | <tr> |
---|
146 | <td class="paramkey"></td> |
---|
147 | <td></td> |
---|
148 | <td class="paramtype"><a class="el" href="classitpp_1_1Vec.html">Vec</a>< T > & </td> |
---|
149 | <td class="paramname"> <em>data</em></td><td> </td> |
---|
150 | </tr> |
---|
151 | <tr> |
---|
152 | <td></td> |
---|
153 | <td>)</td> |
---|
154 | <td></td><td></td><td><code> [inline]</code></td> |
---|
155 | </tr> |
---|
156 | </table> |
---|
157 | </div> |
---|
158 | <div class="memdoc"> |
---|
159 | |
---|
160 | <p> |
---|
161 | Introsort function of a subset of a vector <code>data</code>. |
---|
162 | <p> |
---|
163 | <dl compact><dt><b>Parameters:</b></dt><dd> |
---|
164 | <table border="0" cellspacing="2" cellpadding="0"> |
---|
165 | <tr><td valign="top"></td><td valign="top"><em>low</em> </td><td>Start index of a subvector to be sorted </td></tr> |
---|
166 | <tr><td valign="top"></td><td valign="top"><em>high</em> </td><td>End index of a subvector to be sorted </td></tr> |
---|
167 | <tr><td valign="top"></td><td valign="top"><em>max_depth</em> </td><td>Maximum recursion depth before switching to heap sort recommended value: log2 of the length of the data vector </td></tr> |
---|
168 | <tr><td valign="top"></td><td valign="top"><em>data</em> </td><td>Data vector, in which a part of it is to be sorted</td></tr> |
---|
169 | </table> |
---|
170 | </dl> |
---|
171 | <dl class="note" compact><dt><b>Note:</b></dt><dd>An introsort is not a stable sort (i.e. it may not maintain the relative order of elements with equal value.) <p> |
---|
172 | This function uses recurrence. </dd></dl> |
---|
173 | |
---|
174 | <p>References <a class="el" href="vec_8h-source.html#l00505">itpp::Vec< Num_T >::_data()</a>, <a class="el" href="itassert_8h-source.html#l00094">it_assert</a>, and <a class="el" href="vec_8h-source.html#l00277">itpp::Vec< Num_T >::size()</a>.</p> |
---|
175 | |
---|
176 | </div> |
---|
177 | </div><p> |
---|
178 | <a class="anchor" name="b738462d713bcdb42d758e730819b499"></a><!-- doxytag: member="itpp::Sort::intro_sort_index" ref="b738462d713bcdb42d758e730819b499" args="(int low, int high, int max_depth, const Vec< T > &data)" --> |
---|
179 | <div class="memitem"> |
---|
180 | <div class="memproto"> |
---|
181 | <div class="memtemplate"> |
---|
182 | template<class T > </div> |
---|
183 | <table class="memname"> |
---|
184 | <tr> |
---|
185 | <td class="memname">ivec <a class="el" href="classitpp_1_1Sort.html">itpp::Sort</a>< T >::intro_sort_index </td> |
---|
186 | <td>(</td> |
---|
187 | <td class="paramtype">int </td> |
---|
188 | <td class="paramname"> <em>low</em>, </td> |
---|
189 | </tr> |
---|
190 | <tr> |
---|
191 | <td class="paramkey"></td> |
---|
192 | <td></td> |
---|
193 | <td class="paramtype">int </td> |
---|
194 | <td class="paramname"> <em>high</em>, </td> |
---|
195 | </tr> |
---|
196 | <tr> |
---|
197 | <td class="paramkey"></td> |
---|
198 | <td></td> |
---|
199 | <td class="paramtype">int </td> |
---|
200 | <td class="paramname"> <em>max_depth</em>, </td> |
---|
201 | </tr> |
---|
202 | <tr> |
---|
203 | <td class="paramkey"></td> |
---|
204 | <td></td> |
---|
205 | <td class="paramtype">const <a class="el" href="classitpp_1_1Vec.html">Vec</a>< T > & </td> |
---|
206 | <td class="paramname"> <em>data</em></td><td> </td> |
---|
207 | </tr> |
---|
208 | <tr> |
---|
209 | <td></td> |
---|
210 | <td>)</td> |
---|
211 | <td></td><td></td><td><code> [inline]</code></td> |
---|
212 | </tr> |
---|
213 | </table> |
---|
214 | </div> |
---|
215 | <div class="memdoc"> |
---|
216 | |
---|
217 | <p> |
---|
218 | Introsort function, which returns a sorted index vector. |
---|
219 | <p> |
---|
220 | <dl compact><dt><b>Parameters:</b></dt><dd> |
---|
221 | <table border="0" cellspacing="2" cellpadding="0"> |
---|
222 | <tr><td valign="top"></td><td valign="top"><em>low</em> </td><td>Start index of a subvector to be sorted </td></tr> |
---|
223 | <tr><td valign="top"></td><td valign="top"><em>high</em> </td><td>End index of a subvector to be sorted </td></tr> |
---|
224 | <tr><td valign="top"></td><td valign="top"><em>max_depth</em> </td><td>Maximum recursion depth before switching to heap sort recommended value: log2 of the length of the data vector </td></tr> |
---|
225 | <tr><td valign="top"></td><td valign="top"><em>data</em> </td><td>Data vector, in which a part of it is to be sorted</td></tr> |
---|
226 | </table> |
---|
227 | </dl> |
---|
228 | <dl class="note" compact><dt><b>Note:</b></dt><dd>An Introsort is not a stable sort (i.e. it may not maintain the relative order of elements with equal value.) <p> |
---|
229 | This function uses recurrence. </dd></dl> |
---|
230 | |
---|
231 | <p>References <a class="el" href="vec_8h-source.html#l00505">itpp::Vec< Num_T >::_data()</a>, <a class="el" href="itassert_8h-source.html#l00094">it_assert</a>, and <a class="el" href="vec_8h-source.html#l00277">itpp::Vec< Num_T >::size()</a>.</p> |
---|
232 | |
---|
233 | </div> |
---|
234 | </div><p> |
---|
235 | <a class="anchor" name="0ccff5c48c69b4680347935039a0d3f1"></a><!-- doxytag: member="itpp::Sort::sort" ref="0ccff5c48c69b4680347935039a0d3f1" args="(int low, int high, Vec< T > &data)" --> |
---|
236 | <div class="memitem"> |
---|
237 | <div class="memproto"> |
---|
238 | <div class="memtemplate"> |
---|
239 | template<class T > </div> |
---|
240 | <table class="memname"> |
---|
241 | <tr> |
---|
242 | <td class="memname">void <a class="el" href="classitpp_1_1Sort.html">itpp::Sort</a>< T >::sort </td> |
---|
243 | <td>(</td> |
---|
244 | <td class="paramtype">int </td> |
---|
245 | <td class="paramname"> <em>low</em>, </td> |
---|
246 | </tr> |
---|
247 | <tr> |
---|
248 | <td class="paramkey"></td> |
---|
249 | <td></td> |
---|
250 | <td class="paramtype">int </td> |
---|
251 | <td class="paramname"> <em>high</em>, </td> |
---|
252 | </tr> |
---|
253 | <tr> |
---|
254 | <td class="paramkey"></td> |
---|
255 | <td></td> |
---|
256 | <td class="paramtype"><a class="el" href="classitpp_1_1Vec.html">Vec</a>< T > & </td> |
---|
257 | <td class="paramname"> <em>data</em></td><td> </td> |
---|
258 | </tr> |
---|
259 | <tr> |
---|
260 | <td></td> |
---|
261 | <td>)</td> |
---|
262 | <td></td><td></td><td><code> [inline]</code></td> |
---|
263 | </tr> |
---|
264 | </table> |
---|
265 | </div> |
---|
266 | <div class="memdoc"> |
---|
267 | |
---|
268 | <p> |
---|
269 | Sorting function of a subset of a vector <em>data</em>. |
---|
270 | <p> |
---|
271 | <dl compact><dt><b>Parameters:</b></dt><dd> |
---|
272 | <table border="0" cellspacing="2" cellpadding="0"> |
---|
273 | <tr><td valign="top"></td><td valign="top"><em>low</em> </td><td>Start index of a subvector to be sorted </td></tr> |
---|
274 | <tr><td valign="top"></td><td valign="top"><em>high</em> </td><td>End index of a subvector to be sorted </td></tr> |
---|
275 | <tr><td valign="top"></td><td valign="top"><em>data</em> </td><td>Data vector, in which a part of it is to be sorted </td></tr> |
---|
276 | </table> |
---|
277 | </dl> |
---|
278 | |
---|
279 | <p>References <a class="el" href="vec_8h-source.html#l00505">itpp::Vec< Num_T >::_data()</a>, <a class="el" href="itassert_8h-source.html#l00094">it_assert</a>, <a class="el" href="itassert_8h-source.html#l00126">it_error</a>, <a class="el" href="log__exp_8h-source.html#l00303">itpp::levels2bits()</a>, and <a class="el" href="vec_8h-source.html#l00277">itpp::Vec< Num_T >::size()</a>.</p> |
---|
280 | |
---|
281 | <p>Referenced by <a class="el" href="sort_8h-source.html#l00187">itpp::Vec< Num_T >::sort()</a>.</p> |
---|
282 | |
---|
283 | </div> |
---|
284 | </div><p> |
---|
285 | <a class="anchor" name="5eefe31327b1987cf9799562333ebccb"></a><!-- doxytag: member="itpp::Sort::sort_index" ref="5eefe31327b1987cf9799562333ebccb" args="(int low, int high, const Vec< T > &data)" --> |
---|
286 | <div class="memitem"> |
---|
287 | <div class="memproto"> |
---|
288 | <div class="memtemplate"> |
---|
289 | template<class T > </div> |
---|
290 | <table class="memname"> |
---|
291 | <tr> |
---|
292 | <td class="memname">ivec <a class="el" href="classitpp_1_1Sort.html">itpp::Sort</a>< T >::sort_index </td> |
---|
293 | <td>(</td> |
---|
294 | <td class="paramtype">int </td> |
---|
295 | <td class="paramname"> <em>low</em>, </td> |
---|
296 | </tr> |
---|
297 | <tr> |
---|
298 | <td class="paramkey"></td> |
---|
299 | <td></td> |
---|
300 | <td class="paramtype">int </td> |
---|
301 | <td class="paramname"> <em>high</em>, </td> |
---|
302 | </tr> |
---|
303 | <tr> |
---|
304 | <td class="paramkey"></td> |
---|
305 | <td></td> |
---|
306 | <td class="paramtype">const <a class="el" href="classitpp_1_1Vec.html">Vec</a>< T > & </td> |
---|
307 | <td class="paramname"> <em>data</em></td><td> </td> |
---|
308 | </tr> |
---|
309 | <tr> |
---|
310 | <td></td> |
---|
311 | <td>)</td> |
---|
312 | <td></td><td></td><td><code> [inline]</code></td> |
---|
313 | </tr> |
---|
314 | </table> |
---|
315 | </div> |
---|
316 | <div class="memdoc"> |
---|
317 | |
---|
318 | <p> |
---|
319 | Sorting function that returns a sorted index vector. |
---|
320 | <p> |
---|
321 | <dl compact><dt><b>Parameters:</b></dt><dd> |
---|
322 | <table border="0" cellspacing="2" cellpadding="0"> |
---|
323 | <tr><td valign="top"></td><td valign="top"><em>low</em> </td><td>Start index of a subvector to be sorted </td></tr> |
---|
324 | <tr><td valign="top"></td><td valign="top"><em>high</em> </td><td>End index of a subvector to be sorted </td></tr> |
---|
325 | <tr><td valign="top"></td><td valign="top"><em>data</em> </td><td>Data vector, in which a part of it is to be sorted </td></tr> |
---|
326 | </table> |
---|
327 | </dl> |
---|
328 | |
---|
329 | <p>References <a class="el" href="vec_8h-source.html#l00505">itpp::Vec< Num_T >::_data()</a>, <a class="el" href="itassert_8h-source.html#l00094">it_assert</a>, <a class="el" href="itassert_8h-source.html#l00126">it_error</a>, <a class="el" href="log__exp_8h-source.html#l00303">itpp::levels2bits()</a>, and <a class="el" href="vec_8h-source.html#l00277">itpp::Vec< Num_T >::size()</a>.</p> |
---|
330 | |
---|
331 | <p>Referenced by <a class="el" href="sort_8h-source.html#l00203">itpp::Vec< Num_T >::sort_index()</a>.</p> |
---|
332 | |
---|
333 | </div> |
---|
334 | </div><p> |
---|
335 | <hr>The documentation for this class was generated from the following file:<ul> |
---|
336 | <li><a class="el" href="sort_8h-source.html">sort.h</a></ul> |
---|
337 | </div> |
---|
338 | <hr size="1"><address style="text-align: right;"><small>Generated on Tue Jun 2 10:02:19 2009 for mixpp by |
---|
339 | <a href="http://www.doxygen.org/index.html"> |
---|
340 | <img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.8 </small></address> |
---|
341 | </body> |
---|
342 | </html> |
---|