<br><font size=2 face="sans-serif">Francois,</font>
<br>
<br><font size=2 face="sans-serif">I will look at it next week - maybe
just a tolerance issue.</font>
<br>
<br><font size=2 face="sans-serif">John Forrest</font>
<br>
<br>
<br>
<table width=100%>
<tr valign=top>
<td width=40%><font size=1 face="sans-serif"><b>Francois Margot <fmargot@andrew.cmu.edu></b>
</font>
<br><font size=1 face="sans-serif">Sent by: coin-lpsolver-bounces@list.coin-or.org</font>
<p><font size=1 face="sans-serif">04/10/2006 10:19 AM</font>
<td width=59%>
<table width=100%>
<tr valign=top>
<td>
<div align=right><font size=1 face="sans-serif">To</font></div>
<td><font size=1 face="sans-serif">coin-lpsolver@list.coin-or.org</font>
<tr valign=top>
<td>
<div align=right><font size=1 face="sans-serif">cc</font></div>
<td>
<tr valign=top>
<td>
<div align=right><font size=1 face="sans-serif">Subject</font></div>
<td><font size=1 face="sans-serif">[Coin-lpsolver] Precision for Clp solution</font></table>
<br>
<table>
<tr valign=top>
<td>
<td></table>
<br></table>
<br>
<br>
<br><tt><font size=2><br>
What precision can we expect for the results obtained from Clp, using<br>
Lapack and Blas libraries on a Linux machine? Is 10e-3 too much to<br>
expect? (I just updated my copy of COIN this morning.)<br>
<br>
I am solving an LP (admittedly with a numerically suspect formulation,<br>
with some coefficients smaller than 10e-10) using:<br>
<br>
OsiClpSolverInterface *clp = new OsiClpSolverInterface;<br>
clp->readMps("bc1.mps");<br>
clp->initialSolve();<br>
<br>
const double *lb = clp->getColLower();<br>
const double *ub = clp->getColUpper();<br>
const double *rc = clp->getReducedCost();<br>
<br>
int ncol = clp->getNumCols();<br>
int nrow = clp->getNumRows();<br>
<br>
for(int i=0; i<ncol; i++) {<br>
if((rc[i] > 1e-4) && (ub[i] - lb[i] > 1e-4)
&& (x[i] > lb[i] + 1e-4)) {<br>
printf("### ERROR: var: %d rc: %f
lb: %f ub: %f x: %f\n",<br>
i, rc[i], lb[i], ub[i], x[i]);<br>
exit(1);<br>
}<br>
if((rc[i] < -1e-4) && (ub[i] - lb[i] > 1e-4)
&& (x[i] < ub[i] - 1e-4)) {<br>
printf("### ERROR: var: %d rc: %f
lb: %f ub: %f x: %f\n",<br>
i, rc[i], lb[i], ub[i], x[i]);<br>
exit(1);<br>
}<br>
}<br>
<br>
<br>
I get:<br>
<br>
### ERROR: var: 8 rc: -0.002807 lb: 0.000000 ub: 10.000000
x: 0.000000<br>
<br>
Regardless of the initial formulation, the precision of the result seems<br>
to be at most 10e-2. The mps file bc1.mps is available from<br>
<br>
http://plato.asu.edu/ftp/milp/<br>
<br>
Francois<br>
<br>
_______________________________________________<br>
Coin-lpsolver mailing list<br>
Coin-lpsolver@list.coin-or.org<br>
http://list.coin-or.org/mailman/listinfo/coin-lpsolver<br>
</font></tt>
<br>