
前提・実現したいこと
最適化問題の輸送問題を解くプログラムを作っています。
「TypeError: unsupported operand type(s) for : 'float' and 'generator'」というエラーが出てしまっています。
「」やfloatを使わずに他の方法を使えばいいのでしょうか。
詳しい方ご教授おねがいしたいです。
発生している問題・エラーメッセージ
--------------------------------------------------------------------------- TypeError Traceback (most recent call last) <ipython-input-10-ea3930e004ae> in <module> 50 + (0.5 * B * (quicksum((S[x]-quicksum(Vxyi[x,y,i] for y in Y for i in q)) * (S[x]-quicksum(Vxyi[x,y,i] for y in Y for i in q))) for x in X)) 51 + (0.5 * C * (quicksum(D[y]-quicksum(Vxyi[x,y,i] for x in X for i in q)) * (D[y]-quicksum(Vxyi[x,y,i] for x in X for i in q))) for y in Y) ---> 52 + (0.5 * D * (quicksum(c[x,y] * Vxyi[x,y,i] for x in X for y in Y for i in q)) * (quicksum(c[x,y] * Vxyi[x,y,i] for x in X for y in Y for i in q))),GRB.MINIMIZE) 53 54 #解を求める計算 TypeError: unsupported operand type(s) for *: 'float' and 'generator'
該当のソースコード
python3
1 2from gurobipy import * 3#from mypulp import * 4 5d= multidict({1:2, 2:7, 3:3 , 4:2, 5:4}) # 工場の需要量Demand 6S= multidict({1:5, 2:3, 3:4, 4:6}) # 倉庫の部品数Supply 7 8Y = [1,2,3,4,5] 9X = [1,2,3,4] 10q = [1,2,3,4,5,6,7,8,9] 11 12Y,d = multidict({1:2, 2:7, 3:3 , 4:2, 5:4}) 13X,S = multidict({1:5, 2:3, 3:4, 4:6}) 14 15c = {(1,1):5, (1,2):2, (1,3):6, (1,4):3, # 費用Cost 16 (2,1):1, (2,2):3, (2,3):4, (2,4):2, 17 (3,1):7, (3,2):6, (3,3):8, (3,4):2, 18 (4,1):3, (4,2):9, (4,3):1, (4,4):2, 19 (5,1):3, (5,2):5, (5,3):4, (5,4):4, 20 } 21 22#重み係数 23A=29 24B=80 25C=80 26D=0.55 27 28#問題を設定 29model= Model(name="Hitchcock") 30 31Vxyi={} 32for i in q: #指定回数繰り返す(D回) 33#インデントの開始(半角空白4個下げ) 34 for y in Y: 35 for x in X: 36 #変数を設定(変数単体にかかる制約を含む) 37 Vxyi[x,y,i] = model.addVar(vtype='C', name = 'Vxyi(%s, %s, %s)' % (x ,y ,i)) 38model.update()#モデルの一括更新 39#インデントの終了(for文の終了) 40arcs = tuplelist([(x,y,i) for (x,y,i) in Vxyi]) 41#制約条件の設定 42for x in X: 43 #(model.addConstr():モデルに複数の制約を追加 44 model.addConstr(quicksum(Vxyi[x,y,i] for (x,y,i) in arcs.select('*',Y,q)) == S[x]) 45 46for y in Y: 47 model.addConstr(quicksum(Vxyi[x,y,i] for (x,y,i) in arcs.select(X,'*',q))==d[y]) 48 49#目的関数を設定 50model.setObjective((-0.5 * A * quicksum((1 - 2 * Vxyi[x,y,i]) * (1 - 2 * Vxyi[x,y,i])) for (x,y,i) in Vxyi) 51 + (0.5 * B * (quicksum((S[x]-quicksum(Vxyi[x,y,i] for y in Y for i in q)) * (S[x]-quicksum(Vxyi[x,y,i] for y in Y for i in q))) for x in X)) 52 + (0.5 * C * (quicksum(D[y]-quicksum(Vxyi[x,y,i] for x in X for i in q)) * (D[y]-quicksum(Vxyi[x,y,i] for x in X for i in q))) for y in Y) 53 + (0.5 * D * (quicksum(c[x,y] * Vxyi[x,y,i] for x in X for y in Y for i in q)) * (quicksum(c[x,y] * Vxyi[x,y,i] for x in X for y in Y for i in q))),GRB.MINIMIZE) 54 55#解を求める計算 56print('Gurobi Optimizerログ') 57 58model.optimize() 59print( 'Optimal value:', model.ObjVal) 60print() 61 62#最適解が得られた場合,結果を出力 63print('[解]') 64if model.Status == gp.GRB.OPTIMAL: 65 Vxyi_opt=x.X 66 # 目的関数の値 67 val_opt = model.ObjVal 68 69 print('最適値は{val_opt}')
補足情報(FW/ツールのバージョンなど)
Anaconda Jupyter notebook
Python3.7.0
Gurobi
を使っています。
参考にしているサイト
https://qiita.com/keisukesato-ac/items/a3c284aedb2ca8550238

回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2020/01/26 12:54
2020/01/26 12:56
退会済みユーザー
2020/01/26 12:59
2020/01/26 13:05
2020/01/26 13:10
退会済みユーザー
2020/01/26 13:10
退会済みユーザー
2020/01/26 13:17
2020/01/26 13:17
2020/01/26 13:19
2020/01/26 13:20
退会済みユーザー
2020/01/26 13:30
退会済みユーザー
2020/01/26 13:30
2020/01/26 13:39
退会済みユーザー
2020/01/26 13:44
2020/01/26 13:47
退会済みユーザー
2020/01/26 13:55
2020/01/26 14:08
退会済みユーザー
2020/01/26 14:19
退会済みユーザー
2020/01/27 04:53