help-glpk
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Help-glpk] how to make matrix multiply with mathprog


From: xypron
Subject: Re: [Help-glpk] how to make matrix multiply with mathprog
Date: Tue, 24 Feb 2009 10:29:26 -0800 (PST)

Hello!

hhb83 wrote:
> 
> I still could not work it out. Here, the Up,i is var, so should I take the
> Xp,i as param or var? If param, it always said "expression following :=
> has invalid type". And if I define it as var, and take the formulation as
> constraint like this:
> s.t. position{i in I, j in J, m in K}: X[i,j,m] = if i==1 then X0[j,m]
> else sum{k in K} A[m,k]*X[i-1,j,k] + B[m,k]*U[i-1,j,k];
> 
> 

you can find a working example below.

Best regards

Xypron


# hhb83: how to make matrix multiply with mathprog
set I := {1..9};
set J := {1..3};
set K := {1..3};
set M := {1..3};
param A{j in J, k in K};
param B{j in J, k in K};
param X0{j in J, k in K};
param U{i in I, j in J, k in K};
param X{i in I, j in J, m in M} := 
  if i==1 then X0[j,m] else sum{k in K} ( A[m,k]*X[i-1,j,k] +
B[m,k]*U[i-1,j,k] ); 
display X;
data;
param A: 1 2 3 :=
  1 1 2 3 
  2 4 5 6 
  3 7 8 9;
param B: 1 2 3 :=
  1 1 2 3 
  2 4 5 6 
  3 7 8 9;
param X0: 1 2 3 := 
  1 1 2 3 
  2 4 5 6 
  3 7 8 9;
param U:=
  [1,*,*]: 1 2 3 :=
  1 1 2 3 
  2 4 5 6 
  3 7 8 9
  [2,*,*]: 1 2 3 :=
  1 1 2 3 
  2 4 5 6 
  3 7 8 9
  [3,*,*]: 1 2 3 :=
  1 1 2 3 
  2 4 5 6 
  3 7 8 9
  [4,*,*]: 1 2 3 :=
  1 1 2 3 
  2 4 5 6 
  3 7 8 9
  [5,*,*]: 1 2 3 :=
  1 1 2 3 
  2 4 5 6 
  3 7 8 9
  [6,*,*]: 1 2 3 :=
  1 1 2 3 
  2 4 5 6 
  3 7 8 9
  [7,*,*]: 1 2 3 :=
  1 1 2 3 
  2 4 5 6 
  3 7 8 9
  [8,*,*]: 1 2 3 :=
  1 1 2 3 
  2 4 5 6 
  3 7 8 9
  [9,*,*]: 1 2 3 :=
  1 1 2 3 
  2 4 5 6 
  3 7 8 9;
end;

-- 
View this message in context: 
http://www.nabble.com/how-to-make-matrix-multiply-with-mathprog-tp22077225p22187619.html
Sent from the Gnu - GLPK - Help mailing list archive at Nabble.com.





reply via email to

[Prev in Thread] Current Thread [Next in Thread]