annotate clustalomega/clustal-omega-1.0.2/src/squid/vectorops.c @ 1:bc707542e5de

Uploaded
author clustalomega
date Thu, 21 Jul 2011 13:35:08 -0400
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
1 /* vectorops.c
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
2 * Operations on vectors of floats or doubles.
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
3 *
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
4 * DSet(), FSet() - set all items in vector to value.
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
5 * DScale(), FScale() - multiply all items in vector by scale
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
6 * DSum(), FSum() - return sum of values in vector
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
7 * DAdd(), FAdd() - add vec2 to vec1.
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
8 * DCopy(), FCopy() - set vec1 to be same as vec2.
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
9 * DDot(), FDot() - return dot product of two vectors.
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
10 * DMax(), FMax() - return value of maximum element in vector
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
11 * DMin(), FMin() - return value of minimum element in vector
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
12 * DArgMax(), FArgMax() - return index of maximum element in vector
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
13 * DArgMin(), FArgMin() - return index of minimum element in vector
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
14 *
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
15 * DNorm(), FNorm() - normalize a probability vector of length n.
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
16 * DLog(), FLog() - convert to log probabilities
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
17 * DExp(), FExp() - convert log p's back to probabilities
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
18 * DLogSum(), FLogSum() - given vector of log p's; return log of summed p's.
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
19 *
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
20 * SRE, Tue Oct 1 15:23:25 2002 [St. Louis]
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
21 * CVS $Id: vectorops.c,v 1.1 2002/10/09 14:26:09 eddy Exp)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
22 */
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
23
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
24 #include <stdlib.h>
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
25 #include <math.h>
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
26 #include <float.h>
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
27 #include "vectorops.h"
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
28
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
29 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
30 DSet(double *vec, int n, double value)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
31 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
32 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
33 for (x = 0; x < n; x++) vec[x] = value;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
34 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
35
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
36 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
37 FSet(float *vec, int n, float value)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
38 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
39 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
40 for (x = 0; x < n; x++) vec[x] = value;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
41 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
42
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
43 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
44 DScale(double *vec, int n, double scale)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
45 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
46 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
47 for (x = 0; x < n; x++) vec[x] *= scale;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
48 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
49
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
50 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
51 FScale(float *vec, int n, float scale)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
52 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
53 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
54 for (x = 0; x < n; x++) vec[x] *= scale;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
55 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
56
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
57 double
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
58 DSum(double *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
59 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
60 double sum = 0.;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
61 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
62 for (x = 0; x < n; x++) sum += vec[x];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
63 return sum;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
64 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
65
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
66 float
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
67 FSum(float *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
68 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
69 float sum = 0.;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
70 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
71 for (x = 0; x < n; x++) sum += vec[x];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
72 return sum;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
73 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
74
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
75 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
76 DAdd(double *vec1, double *vec2, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
77 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
78 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
79 for (x = 0; x < n; x++) vec1[x] += vec2[x];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
80 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
81
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
82 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
83 FAdd(float *vec1, float *vec2, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
84 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
85 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
86 for (x = 0; x < n; x++) vec1[x] += vec2[x];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
87 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
88
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
89 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
90 DCopy(double *vec1, double *vec2, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
91 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
92 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
93 for (x = 0; x < n; x++) vec1[x] = vec2[x];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
94 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
95
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
96 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
97 FCopy(float *vec1, float *vec2, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
98 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
99 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
100 for (x = 0; x < n; x++) vec1[x] = vec2[x];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
101 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
102
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
103 double
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
104 DDot(double *vec1, double *vec2, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
105 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
106 double result = 0.;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
107 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
108 for (x = 0; x < n; x++) result += vec1[x] * vec2[x];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
109 return result;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
110 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
111
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
112 float
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
113 FDot(float *vec1, float *vec2, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
114 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
115 float result = 0.;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
116 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
117 for (x = 0; x < n; x++) result += vec1[x] * vec2[x];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
118 return result;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
119 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
120
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
121 double
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
122 DMax(double *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
123 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
124 int i;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
125 double best;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
126
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
127 best = vec[0];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
128 for (i = 1; i < n; i++)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
129 if (vec[i] > best) best = vec[i];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
130 return best;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
131 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
132
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
133 float
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
134 FMax(float *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
135 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
136 int i;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
137 float best;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
138
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
139 best = vec[0];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
140 for (i = 1; i < n; i++)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
141 if (vec[i] > best) best = vec[i];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
142 return best;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
143 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
144
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
145 double
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
146 DMin(double *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
147 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
148 int i;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
149 double best;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
150
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
151 best = vec[0];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
152 for (i = 1; i < n; i++)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
153 if (vec[i] < best) best = vec[i];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
154 return best;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
155 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
156
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
157 float
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
158 FMin(float *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
159 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
160 int i;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
161 float best;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
162
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
163 best = vec[0];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
164 for (i = 1; i < n; i++)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
165 if (vec[i] < best) best = vec[i];
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
166 return best;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
167 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
168
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
169 double
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
170 DArgMax(double *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
171 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
172 int i;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
173 int best = 0;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
174
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
175 for (i = 1; i < n; i++)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
176 if (vec[i] > vec[best]) best = i;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
177 return best;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
178 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
179
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
180 float
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
181 FArgMax(float *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
182 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
183 int i;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
184 int best = 0;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
185
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
186 for (i = 1; i < n; i++)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
187 if (vec[i] > vec[best]) best = i;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
188 return best;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
189 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
190
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
191 double
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
192 DArgMin(double *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
193 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
194 int i;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
195 int best = 0;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
196 for (i = 1; i < n; i++)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
197 if (vec[i] < vec[best]) best = i;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
198 return best;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
199 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
200
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
201 float
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
202 FArgMin(float *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
203 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
204 int i;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
205 int best = 0;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
206
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
207 for (i = 1; i < n; i++)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
208 if (vec[i] < vec[best]) best = i;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
209 return best;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
210 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
211
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
212 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
213 DNorm(double *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
214 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
215 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
216 double sum;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
217
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
218 sum = DSum(vec, n);
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
219 if (sum != 0.0) for (x = 0; x < n; x++) vec[x] /= sum;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
220 else for (x = 0; x < n; x++) vec[x] = 1. / (double) n;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
221 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
222
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
223 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
224 FNorm(float *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
225 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
226 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
227 float sum;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
228
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
229 sum = FSum(vec, n);
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
230 if (sum != 0.0) for (x = 0; x < n; x++) vec[x] /= sum;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
231 else for (x = 0; x < n; x++) vec[x] = 1. / (float) n;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
232 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
233
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
234 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
235 DLog(double *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
236 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
237 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
238 for (x = 0; x < n; x++)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
239 if (vec[x] > 0.) vec[x] = log(vec[x]);
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
240 else vec[x] = -DBL_MAX;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
241 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
242
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
243 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
244 FLog(float *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
245 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
246 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
247 for (x = 0; x < n; x++)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
248 if (vec[x] > 0.) vec[x] = log(vec[x]);
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
249 else vec[x] = -FLT_MAX;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
250 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
251
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
252 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
253 DExp(double *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
254 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
255 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
256 for (x = 0; x < n; x++) vec[x] = exp(vec[x]);
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
257 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
258
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
259 void
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
260 FExp(float *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
261 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
262 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
263 for (x = 0; x < n; x++) vec[x] = exp(vec[x]);
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
264 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
265
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
266 float
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
267 DLogSum(double *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
268 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
269 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
270 double max, sum;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
271
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
272 max = DMax(vec, n);
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
273 sum = 0.0;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
274 for (x = 0; x < n; x++)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
275 if (vec[x] > max - 50.)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
276 sum += exp(vec[x] - max);
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
277 sum = log(sum) + max;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
278 return sum;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
279 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
280
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
281 float
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
282 FLogSum(float *vec, int n)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
283 {
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
284 int x;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
285 float max, sum;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
286
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
287 max = FMax(vec, n);
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
288 sum = 0.0;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
289 for (x = 0; x < n; x++)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
290 if (vec[x] > max - 50.)
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
291 sum += exp(vec[x] - max);
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
292 sum = log(sum) + max;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
293 return sum;
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
294 }
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
295
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
296
bc707542e5de Uploaded
clustalomega
parents:
diff changeset
297