Mercurial > hg > smallbox
comparison DL/RLS-DLA/private/omputils.c @ 60:ad36f80e2ccf
(none)
author | idamnjanovic |
---|---|
date | Tue, 15 Mar 2011 12:20:59 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
59:23f9dd7b9d78 | 60:ad36f80e2ccf |
---|---|
1 /************************************************************************** | |
2 * | |
3 * File name: omputils.c | |
4 * | |
5 * Ron Rubinstein | |
6 * Computer Science Department | |
7 * Technion, Haifa 32000 Israel | |
8 * ronrubin@cs | |
9 * | |
10 * Last Updated: 18.8.2009 | |
11 * | |
12 *************************************************************************/ | |
13 | |
14 #include "omputils.h" | |
15 #include <math.h> | |
16 | |
17 | |
18 const char FULL_GAMMA_STR[] = "full"; | |
19 const char SPARSE_GAMMA_STR[] = "sparse"; | |
20 | |
21 | |
22 /* convert seconds to hours, minutes and seconds */ | |
23 | |
24 void secs2hms(double sectot, int *hrs, int *mins, double *secs) | |
25 { | |
26 *hrs = (int)(floor(sectot/3600)+1e-2); | |
27 sectot = sectot - 3600*(*hrs); | |
28 *mins = (int)(floor(sectot/60)+1e-2); | |
29 *secs = sectot - 60*(*mins); | |
30 } | |
31 | |
32 | |
33 /* quicksort, public-domain C implementation by Darel Rex Finley. */ | |
34 /* modification: sorts the array data[] as well, according to the values in the array vals[] */ | |
35 | |
36 #define MAX_LEVELS 300 | |
37 | |
38 void quicksort(mwIndex vals[], double data[], mwIndex n) { | |
39 | |
40 long piv, beg[MAX_LEVELS], end[MAX_LEVELS], i=0, L, R, swap ; | |
41 double datapiv; | |
42 | |
43 beg[0]=0; | |
44 end[0]=n; | |
45 | |
46 while (i>=0) { | |
47 | |
48 L=beg[i]; | |
49 R=end[i]-1; | |
50 | |
51 if (L<R) { | |
52 | |
53 piv=vals[L]; | |
54 datapiv=data[L]; | |
55 | |
56 while (L<R) | |
57 { | |
58 while (vals[R]>=piv && L<R) | |
59 R--; | |
60 if (L<R) { | |
61 vals[L]=vals[R]; | |
62 data[L++]=data[R]; | |
63 } | |
64 | |
65 while (vals[L]<=piv && L<R) | |
66 L++; | |
67 if (L<R) { | |
68 vals[R]=vals[L]; | |
69 data[R--]=data[L]; | |
70 } | |
71 } | |
72 | |
73 vals[L]=piv; | |
74 data[L]=datapiv; | |
75 | |
76 beg[i+1]=L+1; | |
77 end[i+1]=end[i]; | |
78 end[i++]=L; | |
79 | |
80 if (end[i]-beg[i] > end[i-1]-beg[i-1]) { | |
81 swap=beg[i]; beg[i]=beg[i-1]; beg[i-1]=swap; | |
82 swap=end[i]; end[i]=end[i-1]; end[i-1]=swap; | |
83 } | |
84 } | |
85 else { | |
86 i--; | |
87 } | |
88 } | |
89 } |