optimizationjulia-jumpinteger-programming

Julia-Jump Integer Programming Optimization model: issue with multiplying matrix by vector


I have written an optimization model that has 3 binary decision variables that are all in matrix form (X[p,s], Y[a,s], and Z[a,p]). a=associate, p=process, and s=station.

I have encountered an issue with coding a constraint for my Z variable. Z is a decision variable = 1 if associate assigned process; = 0 otherwise.

I want to write a constraint that ensures no associate is assigned more process time than they can handle. I've attempted this by writing: @constraint(m, associate_takt[a in A, p in P], sum(Z[a, p]*Pt[p] for p in P) <= takt_lim)

This is supposed to multiply every value in a row of Z by their corresponding times stored in the vector Pt. This would give a sum of process time for that row (associate) which is then checked to ensure it is less than some value "takt_lim" (process time restriction). I would like to do this for all rows (associates) in matrix Z.

I tried updating the constraint to: @constraint(m, associate_takt[a in A, p in P], sum(value.(Z[a, p])*Pt[p] for p in P) <= takt_lim) but this creates an error as the Z variables have not been optimized yet: "OptimizeNotCalled()"


Solution

  • Isn't it just:

    @constraint(
        m, 
        associate_takt[a in A],
        sum(Z[a, p]*Pt[p] for p in P) <= takt_lim,
    )
    

    I don't see why you need to loop over all p in P for the constraint.