質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.31%
最適化

最適化とはメソッドやデザインの最適な処理方法を選択することです。パフォーマンスの向上を目指す為に行われます。プログラミングにおける最適化は、アルゴリズムのスピードアップや、要求されるリソースを減らすことなどを指します。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

11346閲覧

「TypeError: unsupported operand type(s) for」 のエラーの解決方法

退会済みユーザー

退会済みユーザー

総合スコア0

最適化

最適化とはメソッドやデザインの最適な処理方法を選択することです。パフォーマンスの向上を目指す為に行われます。プログラミングにおける最適化は、アルゴリズムのスピードアップや、要求されるリソースを減らすことなどを指します。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2020/01/26 10:44

編集2020/01/26 13:41

前提・実現したいこと

最適化問題の輸送問題を解くプログラムを作っています。
「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

目的関数の式です。
イメージ説明

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

指摘自体は0kaclさんので間違い無いです。プログラムをよく見てみると、

(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) # ここにはforがある (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)) ) # ここにはforがない

以下のように、Cの行はforの中で処理が完結しているのでジェネレータですが、Dの行はfor y in Yのような構文が無いので、(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))の部分で生成されたジェネレータに対して0.5を掛け算してるのでエラーとなります。

gurobipyモジュールを使用したことは無いので、細かい詳細はわかりませんが、この部分が原因だと思われます。for文の抜け忘れなど無いでしょうか?

投稿2020/01/26 12:41

bamboo-nova

総合スコア1408

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/01/26 12:54

ご丁寧な回答ありがとうございます。ご指摘の通りDの行の()が足りなく,エラーが出ていました。
0kcal

2020/01/26 12:56

お疲れ様です。 bamboo-novaさんのご指摘のとおりと想像します。 以下のコードでも同様のエラーが出ます。 num_thing=(num for num in range(1,6)) for num in num_thing: print(type(num_thing)) b = 5.0 * num_thing print(num)
退会済みユーザー

退会済みユーザー

2020/01/26 12:59

先ほどのエラーはなくなったのですが,以下のエラーがまた出てしまいました。。 このプログラムは他の上がっているプログラムをベースに作っているのですが,構文エラーが出てしまっいました。エラーがでた部分は変更を加えていないのですが,使用する関数が間違っているのでしょうか?何度も申し訳ないです。。 ''' File "<ipython-input-8-ee0745b089a7>", line 57 model.optimize() ^ SyntaxError: invalid syntax '''
bamboo-nova

2020/01/26 13:05

多分、model.optimize()が原因ではなく、プログラム上のカッコの対応が何処かで狂っているんだと思います。jupyterならばカッコの対応している部分が分かると思うので、確認してみてください。
0kcal

2020/01/26 13:10

指摘されている部分自体は、SyntaxErrorと言われる内容ではないと思われます。 直前のprint文は、正しく動作していますか。 print('Gurobi Optimizerログ') また、ファイルの文字コードが、shiftJISとかになっていませんか? UTF-8が、単純に、お勧めです。
退会済みユーザー

退会済みユーザー

2020/01/26 13:10

なるほど,ありがとうございます。カッコの対応状況について確認してみます。
退会済みユーザー

退会済みユーザー

2020/01/26 13:17

Print分もエラーが出てしまっています。 初心者なので確認の仕方がわかっていないのですが,コードファイルをUTF-8に変更するということでしょうか?
0kcal

2020/01/26 13:17

bamboo-novaさんのご意見に賛成です。 SyntaxError: invalid syntaxの例を示します。 ( にやさしいというか。。。。別の行で、エラーがでます。 a = 1.0 b = ( 2.0 * a c = 3.0
bamboo-nova

2020/01/26 13:19

直したプログラムのソースコードを質問文に「改訂版」とかでいいので追記して頂けませんか?
0kcal

2020/01/26 13:20

回答が入れ子になってますが、 まず、()の対応、ご確認下さい。
退会済みユーザー

退会済みユーザー

2020/01/26 13:30

改訂版コードです。 ’’’ from gurobipy import * #from mypulp import * d= multidict({1:2, 2:7, 3:3 , 4:2, 5:4}) # 工場の需要量Demand S= multidict({1:5, 2:3, 3:4, 4:6}) # 倉庫の部品数Supply Y = [1,2,3,4,5] X = [1,2,3,4] q = [1,2,3,4,5,6,7,8,9] Y,d = multidict({1:2, 2:7, 3:3 , 4:2, 5:4}) X,S = multidict({1:5, 2:3, 3:4, 4:6}) c = {(1,1):5, (1,2):2, (1,3):6, (1,4):3, # 費用Cost (2,1):1, (2,2):3, (2,3):4, (2,4):2, (3,1):7, (3,2):6, (3,3):8, (3,4):2, (4,1):3, (4,2):9, (4,3):1, (4,4):2, (5,1):3, (5,2):5, (5,3):4, (5,4):4, } #重み係数 A=29 B=80 C=80 D=0.55 #問題を設定 model= Model(name="Hitchcock") Vxyi={} for i in q: #指定回数繰り返す(D回) #インデントの開始(半角空白4個下げ) for y in Y: for x in X: #変数を設定(変数単体にかかる制約を含む) Vxyi[x,y,i] = model.addVar(vtype='C', name = 'Vxyi(%s, %s, %s)' % (x ,y ,i)) model.update()#モデルの一括更新 #インデントの終了(for文の終了) arcs = tuplelist([(x,y,i) for (x,y,i) in Vxyi]) #制約条件の設定 for x in X: #(model.addConstr():モデルに複数の制約を追加 model.addConstr(quicksum(Vxyi[x,y,i] for (x,y,i) in arcs.select('*',Y,q)) == S[x]) for y in Y: model.addConstr(quicksum(Vxyi[x,y,i] for (x,y,i) in arcs.select(X,'*',q))==d[y]) #目的関数を設定 model.setObjective((-0.5 * A * quicksum((1 - 2 * Vxyi[x,y,i]) * (1 - 2 * Vxyi[x,y,i])) for (x,y,i) in Vxyi) + (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)) + (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) + (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) #解を求める計算 print('Gurobi Optimizerログ') model.optimize() print('Optimal value:', model.ObjVal) print() #最適解が得られた場合,結果を出力 print('[解]') if model.Status == GRB.OPTIMAL: Vxyi_opt=x.X # 目的関数の値 val_opt = model.ObjVal print('最適値は{val_opt}') ’’’
退会済みユーザー

退会済みユーザー

2020/01/26 13:30

このコードのエラーはいかの状態です。 ’’’ File "<ipython-input-13-fabd52b828d5>", line 55 print('Gurobi Optimizerログ') ^ SyntaxError: invalid syntax ’’’
bamboo-nova

2020/01/26 13:39

Dの行のカッコが適切に対応してないですね。また、この部分の行ですが、おそらく行いたいのは以下のように纏められませんか?forを二回も使って掛け算するのはきついと思ったのですが...汗 + (0.5 * D * ((quicksum(c[x,y] * Vxyi[x,y,i])) * (quicksum(c[x,y] * Vxyi[x,y,i])) for x in X for y in Y for i in q)),GRB.MINIMIZE)
退会済みユーザー

退会済みユーザー

2020/01/26 13:44

forの使い方がわかっていなくてすいません。まとめてみます。 表したい式としては,補足情報に載せた式になっています。
bamboo-nova

2020/01/26 13:47

だとすれば、こんな感じです。GRB .MINIMIZEの隣のカッコはmodel.setObjective(のカッコに対応しています。 + (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)
退会済みユーザー

退会済みユーザー

2020/01/26 13:55

’’’ #目的関数を設定 model.setObjective((-0.5 * A * quicksum((1 - 2 * Vxyi[x,y,i]) * (1 - 2 * Vxyi[x,y,i])) for (x,y,i) in Vxyi) + (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)) + (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) + (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) ’’’ これでやってみたのですが,同じようなエラーが出てしまいました。。確認してカッコは対応していると思うのですが, 以下エラー文 ’’’ TypeError Traceback (most recent call last) <ipython-input-24-c2b4275e282c> 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' ’’’
bamboo-nova

2020/01/26 14:08

すみません、自分自身も混乱してきたんですが、 v1 = (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)) + (0.5 * D * vv for vv in v1),GRB.MINIMIZE) のようにして、一度ジェネレータ部分のみを切り分けるのはいかがでしょうか。
退会済みユーザー

退会済みユーザー

2020/01/26 14:19

ややこしくてすいません。いろいろ提案していただき感謝です。。 試してみます。
退会済みユーザー

退会済みユーザー

2020/01/27 04:53

切り分けるとエラーが消えました!ありがとうございます。
guest

0

お疲れ様です。

TypeError: unsupported operand type(s) for *: 'float' and 'generator'

に示されているように、「generator自体」に、「実数(float)」を掛け算しているので、
処理できないというエラーだと思います。

どれがgeneratorになっているのか、よく知らないのですが、
ちょっと、ミスってませんか?

以下は、同じエラーが出るコードの例です。

python

1def my_gen1(): 2 yield 1 3 4print("1111111111111") 5gen = my_gen1() 6CC = 2.0 7gengen = CC * gen

投稿2020/01/26 11:05

編集2020/01/26 11:25
0kcal

総合スコア275

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/01/26 12:10 編集

generatorとして定義したものに実数を直接掛け算しまっているという理解で間違いないですか? このプログラムでいうと「Vxyi」か「S[x]とD[x]」がgeneratorになっているのでしょうか? あまりgeneratorに関して知識がなく申し訳ないです,,
0kcal

2020/01/26 12:22

ワタシも知識が足りてないのと、提示のプログラムは、なんかインストールしないと動作しないので、こちらでは動かせていないのですが、 ご指摘正しいと思います。 print(type(何か))で、generatorと出れば、それは、genratorだと思います。 すみません、中途半端な回答で。 (求む!!素敵な回答)
退会済みユーザー

退会済みユーザー

2020/01/26 12:53

ありがとうございます!なんとなく理解できました。 Dの行の()が足りなかったためにgeneratorに実数をかけてしまいエラーが出ている状態でした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.31%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問