lpsolve
パッケージを使用してR
で線形計画問題を解決しようとしています。私がどのような場合には、小さな問題のために、手動でこの問題を解決することができるよlpsolveを使用したRの線形プログラミング
library("lpSolve")
a <- matrix(c(1,2,5,
1/2,1,3,
1/5,1/3,1),nrow=3,byrow=T)
#
f.obj <- c(1,0,0,0)
f.con <- matrix (c(
1,1,-a[1,2],0, #Contraint 1 for a12
1,-1,a[1,2],0, #Contraint 2 for a12
1,1,0,-a[1,3], #Contraint 1 for a13
1,-1,0,a[1,3], #Contraint 2 for a13
1,0,1,-a[2,3], #Contraint 1 for a23
1,0,-1,a[2,3], #Contraint 2 for a23
0,1,1,1, #Contraint 3
0,1,0,0, #Constraint 4
0,0,1,0, #Constraint 4
0,0,0,1 #Constraint 4
), nrow=10, byrow=TRUE)
f.dir <- c(rep("<=",6), "=",rep(">",3))
f.rhs <- c(rep(1,6),1,rep(0,3))
g <- lp ("max", f.obj, f.con, f.dir, f.rhs)
g$solution
:
が再現例えばRのサンプルである:ここで
が問題です私は7 X 7
または
n x n
行列
a
を持っていました。
1
と
2
という制約をどのように指定するのですか?特に、私は[i、j]に関連する制約を定義するのに苦労していますか?
a = matrix(
c(1,4,9,6,6,5,5,
1/4,1,7,5,5,3,4,
1/9,1/7,1,1/5,1/5,1/7,1/5,
1/6,1/5,5,1,1,1/3,1/3,
1/6,1/5,5,1,1,1/3,1/3,
1/5,1/3,7,3,3,1,2,
1/5,1/4,5,3,3,1/2,1
),nrow = 7,byrow =T)
上記のマトリックスに対する解は、0.986 0.501 0.160 0.043 0.060 0.060 0.1 0.075
です。何か助けがあれば幸いです。
こんにちは、 は、私はあなたがf.conの定義の最後の行が制約4を表していないと思う: 0,1,1,1はW_1 + W_2 + w_3に対応しています。 代わりに0,1,0,0、[w_1> 0] \\ 0,0,1,0 [w_2> 0] \\ 0,0,0,1 [w_3> 0] – Cettt
こんにちは@Cetttはい、私は条件4を間違っています、それを指摘していただきありがとうございます。 – forecaster