mcutil.c
Go to the documentation of this file.
1 /*
2  * mutil.c
3  *
4  * This file contains various utility functions for the MOC portion of the
5  * code
6  *
7  * Started 2/15/98
8  * George
9  *
10  * $Id: mcutil.c 13901 2013-03-24 16:17:03Z karypis $
11  *
12  */
13 
14 #include "metislib.h"
15 
16 
17 /*************************************************************************/
21 /**************************************************************************/
23 {
24  for (n--; n>=0; n--) {
25  if (x[n] > y[n])
26  return 0;
27  }
28 
29  return 1;
30 }
31 
32 
33 /*************************************************************************/
37 /**************************************************************************/
39 {
40  for (n--; n>=0; n--) {
41  if (x[n] < y[n])
42  return 0;
43  }
44 
45  return 1;
46 }
47 
48 
49 /*************************************************************************/
53 /**************************************************************************/
55 {
56  for (n--; n>=0; n--) {
57  if (x1[n]+x2[n] > y[n])
58  return 0;
59  }
60 
61  return 1;
62 }
63 
64 
65 /*************************************************************************/
67 /**************************************************************************/
69 {
70  real_t max;
71 
72  max = x[0]-y[0];
73 
74  for (n--; n>0; n--) {
75  if (max < x[n]-y[n])
76  max = x[n]-y[n];
77  }
78 
79  return max;
80 }
81 
82 
83 /*************************************************************************/
85 /**************************************************************************/
87 {
88  for (n--; n>=0; n--) {
89  if (x[n] > z[n])
90  return 0;
91  }
92 
93  return 1;
94 }
95 
96 
97 /*************************************************************************/
99 /**************************************************************************/
101 {
102  for (n--; n>=0; n--) {
103  if (x[n] < z[n])
104  return 0;
105  }
106 
107  return 1;
108 }
109 
110 
111 /*************************************************************************/
113 /**************************************************************************/
115 {
116  for (n--; n>=0; n--) {
117  if (a*x[n]+y[n] > z[n])
118  return 0;
119  }
120 
121  return 1;
122 }
123 
124 
125 /*************************************************************************/
127 /**************************************************************************/
129 {
130  for (n--; n>=0; n--) {
131  if (a*x[n]+y[n] < z[n])
132  return 0;
133  }
134 
135  return 1;
136 }
137 
138 
139 /*************************************************************************/
142 /*************************************************************************/
143 int BetterVBalance(idx_t ncon, real_t *invtvwgt, idx_t *v_vwgt, idx_t *u1_vwgt,
144  idx_t *u2_vwgt)
145 {
146  idx_t i;
147  real_t sum1=0.0, sum2=0.0, diff1=0.0, diff2=0.0;
148 
149  for (i=0; i<ncon; i++) {
150  sum1 += (v_vwgt[i]+u1_vwgt[i])*invtvwgt[i];
151  sum2 += (v_vwgt[i]+u2_vwgt[i])*invtvwgt[i];
152  }
153  sum1 = sum1/ncon;
154  sum2 = sum2/ncon;
155 
156  for (i=0; i<ncon; i++) {
157  diff1 += rabs(sum1 - (v_vwgt[i]+u1_vwgt[i])*invtvwgt[i]);
158  diff2 += rabs(sum2 - (v_vwgt[i]+u2_vwgt[i])*invtvwgt[i]);
159  }
160 
161  return (diff1 - diff2 >= 0);
162 }
163 
164 
165 /*************************************************************************/
168 /*************************************************************************/
170 {
171  real_t nrm1=0.0, nrm2=0.0;
172 
173  for (--n; n>=0; n--) {
174  if (x[n] > 0) nrm1 += x[n]*x[n];
175  if (y[n] > 0) nrm2 += y[n]*y[n];
176  }
177  return nrm2 < nrm1;
178 }
179 
180 
181 /*************************************************************************/
188 /*************************************************************************/
190  idx_t a1, idx_t *pt1, real_t *bm1,
191  idx_t a2, idx_t *pt2, real_t *bm2)
192 {
193  idx_t i;
194  real_t tmp, nrm1=0.0, nrm2=0.0, max1=0.0, max2=0.0;
195 
196  for (i=0; i<ncon; i++) {
197  tmp = bm1[i]*(pt1[i]+a1*vwgt[i]) - ubvec[i];
198  //printf("BB: %d %+.4f ", (int)i, (float)tmp);
199  nrm1 += tmp*tmp;
200  max1 = (tmp > max1 ? tmp : max1);
201 
202  tmp = bm2[i]*(pt2[i]+a2*vwgt[i]) - ubvec[i];
203  //printf("%+.4f ", (float)tmp);
204  nrm2 += tmp*tmp;
205  max2 = (tmp > max2 ? tmp : max2);
206 
207  //printf("%4d %4d %4d %4d %4d %4d %4d %.2f\n",
208  // (int)vwgt[i],
209  // (int)a1, (int)pt1[i], (int)tpt1[i],
210  // (int)a2, (int)pt2[i], (int)tpt2[i], ubvec[i]);
211  }
212  //printf(" %.3f %.3f %.3f %.3f\n", (float)max1, (float)nrm1, (float)max2, (float)nrm2);
213 
214  if (max2 < max1)
215  return 1;
216 
217  if (max2 == max1 && nrm2 < nrm1)
218  return 1;
219 
220  return 0;
221 }
222 
223 
224 /*************************************************************************/
227 /**************************************************************************/
229 {
230  idx_t i, j, ncon, *pwgts;
231  real_t max, cur;
232 
233  ncon = graph->ncon;
234  pwgts = graph->pwgts;
235 
236  max = 1.0;
237  for (i=0; i<ncon; i++) {
238  for (j=0; j<nparts; j++) {
239  cur = pwgts[j*ncon+i]*pijbm[j*ncon+i];
240  if (cur > max)
241  max = cur;
242  }
243  }
244 
245  return max;
246 }
247 
248 
249 /*************************************************************************/
255 /**************************************************************************/
257  real_t *ubvec)
258 {
259  idx_t i, j, ncon, *pwgts;
260  real_t max, cur;
261 
262  ncon = graph->ncon;
263  pwgts = graph->pwgts;
264 
265  max = -1.0;
266  for (i=0; i<ncon; i++) {
267  for (j=0; j<nparts; j++) {
268  cur = pwgts[j*ncon+i]*pijbm[j*ncon+i] - ubvec[i];
269  if (cur > max)
270  max = cur;
271  }
272  }
273 
274  return max;
275 }
276 
277 
278 /*************************************************************************/
283 /**************************************************************************/
285  real_t *ubfactors, real_t *diffvec)
286 {
287  idx_t i, j, ncon, *pwgts;
288  real_t cur, max;
289 
290  ncon = graph->ncon;
291  pwgts = graph->pwgts;
292 
293  for (max=-1.0, i=0; i<ncon; i++) {
294  diffvec[i] = pwgts[i]*pijbm[i] - ubfactors[i];
295  for (j=1; j<nparts; j++) {
296  cur = pwgts[j*ncon+i]*pijbm[j*ncon+i] - ubfactors[i];
297  if (cur > diffvec[i])
298  diffvec[i] = cur;
299  }
300  if (max < diffvec[i])
301  max = diffvec[i];
302  }
303 
304  return max;
305 }
306 
307 
308 /*************************************************************************/
310 /**************************************************************************/
312  real_t *lbvec)
313 {
314  idx_t i, j, ncon, *pwgts;
315  real_t cur;
316 
317  ncon = graph->ncon;
318  pwgts = graph->pwgts;
319 
320  for (i=0; i<ncon; i++) {
321  lbvec[i] = pwgts[i]*pijbm[i];
322  for (j=1; j<nparts; j++) {
323  cur = pwgts[j*ncon+i]*pijbm[j*ncon+i];
324  if (cur > lbvec[i])
325  lbvec[i] = cur;
326  }
327  }
328 }
329 
330 
rvecmaxdiff
real_t rvecmaxdiff(idx_t n, real_t *x, real_t *y)
Definition: mcutil.c:68
rvecsumle
int rvecsumle(idx_t n, real_t *x1, real_t *x2, real_t *y)
Definition: mcutil.c:54
ubvec
idx_t idx_t idx_t idx_t idx_t idx_t idx_t real_t real_t * ubvec
Definition: include/metis.h:199
rvecle
int rvecle(idx_t n, real_t *x, real_t *y)
Definition: mcutil.c:22
x
set noclip points set clip one set noclip two set bar set border lt lw set xdata set ydata set zdata set x2data set y2data set boxwidth set dummy x
Definition: gnuplot_common_settings.hh:12
ivecle
int ivecle(idx_t n, idx_t *x, idx_t *z)
Definition: mcutil.c:86
ComputeLoadImbalanceVec
void ComputeLoadImbalanceVec(graph_t *graph, idx_t nparts, real_t *pijbm, real_t *lbvec)
Definition: mcutil.c:311
n
int n
Definition: BiCGSTAB_simple.cpp:1
align_3::a1
Point2 a1
Definition: testPose2.cpp:769
ncon
idx_t * ncon
Definition: include/metis.h:197
nparts
idx_t idx_t idx_t idx_t idx_t idx_t idx_t * nparts
Definition: include/metis.h:199
j
std::ptrdiff_t j
Definition: tut_arithmetic_redux_minmax.cpp:2
ivecaxpylez
int ivecaxpylez(idx_t n, idx_t a, idx_t *x, idx_t *y, idx_t *z)
Definition: mcutil.c:114
x1
Pose3 x1
Definition: testPose3.cpp:663
rvecge
int rvecge(idx_t n, real_t *x, real_t *y)
Definition: mcutil.c:38
ivecaxpygez
int ivecaxpygez(idx_t n, idx_t a, idx_t *x, idx_t *y, idx_t *z)
Definition: mcutil.c:128
pybind_wrapper_test_script.z
z
Definition: pybind_wrapper_test_script.py:61
vwgt
idx_t idx_t idx_t idx_t * vwgt
Definition: include/metis.h:198
nrm2
Scalar EIGEN_BLAS_FUNC() nrm2(int *n, RealScalar *px, int *incx)
Definition: level1_real_impl.h:68
rabs
#define rabs
Definition: include/metis.h:140
y
Scalar * y
Definition: level1_cplx_impl.h:124
ComputeLoadImbalance
real_t ComputeLoadImbalance(graph_t *graph, idx_t nparts, real_t *pijbm)
Definition: mcutil.c:228
a
ArrayXXi a
Definition: Array_initializer_list_23_cxx11.cpp:1
align_3::a2
Point2 a2
Definition: testPose2.cpp:770
BetterBalance2Way
int BetterBalance2Way(idx_t n, real_t *x, real_t *y)
Definition: mcutil.c:169
BetterVBalance
int BetterVBalance(idx_t ncon, real_t *invtvwgt, idx_t *v_vwgt, idx_t *u1_vwgt, idx_t *u2_vwgt)
Definition: mcutil.c:143
ComputeLoadImbalanceDiff
real_t ComputeLoadImbalanceDiff(graph_t *graph, idx_t nparts, real_t *pijbm, real_t *ubvec)
Definition: mcutil.c:256
real_t
float real_t
Definition: include/metis.h:132
ComputeLoadImbalanceDiffVec
real_t ComputeLoadImbalanceDiffVec(graph_t *graph, idx_t nparts, real_t *pijbm, real_t *ubfactors, real_t *diffvec)
Definition: mcutil.c:284
metislib.h
BetterBalanceKWay
int BetterBalanceKWay(idx_t ncon, idx_t *vwgt, real_t *ubvec, idx_t a1, idx_t *pt1, real_t *bm1, idx_t a2, idx_t *pt2, real_t *bm2)
Definition: mcutil.c:189
graph
NonlinearFactorGraph graph
Definition: doc/Code/OdometryExample.cpp:2
max
#define max(a, b)
Definition: datatypes.h:20
x2
Pose3 x2(Rot3::Ypr(0.0, 0.0, 0.0), l2)
i
int i
Definition: BiCGSTAB_step_by_step.cpp:9
ivecge
int ivecge(idx_t n, idx_t *x, idx_t *z)
Definition: mcutil.c:100
graph_t
Definition: libmetis/struct.h:82
idx_t
int32_t idx_t
Definition: include/metis.h:101


gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:03:05