pragathichi
2009-Sep-22 10:34 UTC
[R] Semi continous variable- define bounds using lpsolve
How to define bounds for a semi continous variable in lp_solve. Min 5x1 +9x2 +7.15x3 +0.1x4 subject to x1+x2+x3+x4=6.7 x1+x4 <= 6.5 And x3 can be 0 or greater than 3.6 hence x3 is a semi continous variable how to define bounds as well as semicontinous function because using set.semicont and set. bound simantaneously doesn't seem to work.Thanks in advance for the help -- View this message in context: http://www.nabble.com/Semi-continous-variable--define-bounds-using-lpsolve-tp25530668p25530668.html Sent from the R help mailing list archive at Nabble.com.
Hans W. Borchers
2009-Sep-22 20:56 UTC
[R] Semi continous variable- define bounds using lpsolve
I played around a bit with the original 'lp-solve' program --- i.e., not the R package but the program to be downloaded from Sourceforge ---, at least version 5.5.0.15 through its IDE. I was not even able to reproduce the example on semi-continuous variables in the reference documentation at <http://lpsolve.sourceforge.net/5.5/>. It appears as if a bug has been introduced in newer versions of 'lp-solve' that prevent these semi-continuous variables from being handled correctly. So maybe it's not the fault of the R package 'lpsolve' and can only be amended by the 'lp-solve' team itself. Hans Werner pragathichi wrote:> > How to define bounds for a semi continous variable in lp_solve. > Min 5x1 +9x2 +7.15x3 +0.1x4 > subject to > x1+x2+x3+x4=6.7 > x1+x4 <= 6.5 > And x3 can be 0 or greater than 3.6 > hence x3 is a semi continous variable > how to define bounds as well as semicontinous function because using > set.semicont and set. bound simantaneously doesn't seem to work.Thanks in > advance for the help >-- View this message in context: http://www.nabble.com/Semi-continous-variable--define-bounds-using-lpsolve-tp25530668p25530901.html Sent from the R help mailing list archive at Nabble.com.
Hans W. Borchers
2009-Sep-22 22:57 UTC
[R] Semi continous variable- define bounds using lpsolve
But of course, it is always possible to emulate a semi-continuous variable by introducing a binary variable and use some "big-M" trick. That is, with a new binary variable b we add the following two conditions: x3 - 3.6 * b >= 0 and x3 - 10 * b <= 0 # Big-M trick, here M >= 10 (If b = 0, then x3 = 0, and if b = 1, then x3 >= 3.6 !) As I do not trust 'lpSolve' too much anymore I used package 'Rglpk' with the following code: #-- snip --- library(Rglpk) obj<- c(5, 9, 7.15, 0.1, 0) mat <- matrix(c(1,1,1,1,0, 1,0,0,1,0, 0,0,1,0,-3.6, 0,0,1,0,-10, 0,0,0,0,1), byrow=TRUE, ncol=5) dir <- c("==", "<=", ">=", "<=", "<=") rhs <- c(9, 6.55, 0, 0, 1) types <- c("C", "C", "C", "C", "I") max <- FALSE Rglpk_solve_LP(obj, mat, dir, rhs, types, max = max) # $optimum # [1] 22.705 # # $solution # [1] 0.00 2.45 0.00 6.55 0.00 # # $status # [1] 0 #-- snap --- Semi-continuous variables are sometimes preferred as with a good implementation the solution is reached much faster (that's why I suggested them), but they can always be modelled with binary variables. Hans Werner pragathichi wrote:> > How to define bounds for a semi continous variable in lp_solve. > Min 5x1 +9x2 +7.15x3 +0.1x4 > subject to > x1+x2+x3+x4=6.7 > x1+x4 <= 6.5 > And x3 can be 0 or greater than 3.6 > hence x3 is a semi continous variable > how to define bounds as well as semicontinous function because using > set.semicont and set. bound simantaneously doesn't seem to work.Thanks in > advance for the help >-- View this message in context: http://www.nabble.com/Semi-continous-variable--define-bounds-using-lpsolve-tp25530668p25530929.html Sent from the R help mailing list archive at Nabble.com.
Apparently Analagous Threads
- semi-continuous variables in lpSolve package
- R and marine protected areas: algorithms for site selection
- lpSolve doesn't compile because of a malloc.h error
- Solve linear program without objective function
- Package Installation produces "linux/limits.h: No such file or directory" error when installing the lpSolve package