🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

最適化

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

Q&A

解決済

2回答

965閲覧

Pythonにおける変数

ikkun34

総合スコア14

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

最適化

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

0グッド

0クリップ

投稿2019/10/20 02:20

編集2019/10/20 08:56

初めまして。Pythonを用いて最適化を行いたいのですが、普通なら変数を連続変数: x = LpVariable(変数名, lowBound=0)などと指定して解が制約内で帰ってくると思います。しかし今回構造の問題であり使用できる部材の断面積が4つのなかから選択する方式なのですが、変数にこの4つの中から選ぶみたいな指定はできますか?やり方を教えてください。
#pulp

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

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

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

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

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

guest

回答2

0

ベストアンサー

PuLPの変数は連続か離散かバイナリの3種類しかないので一工夫が必要です。

部材の断面積を変数にするのではなく、各部材の数を離散変数に置いて、式の中に定数を埋めてみてはいかがでしょうか:

python:

1import pulp 2 3problem = pulp.LpProblem('test', pulp.LpMaximize) 4parts = pulp.LpVariable.dicts('part', ['A','B','C','D'], 0, 20, "Integer") 5problem += parts['A']*4 + parts['B']*9 + parts['C']*16 + parts['D']*25 # 各部材の断面積 6problem += parts['A'] + parts['B'] + parts['C'] + parts['D'] <= 15 7problem.solve() 8print([parts[key].value() for key in ['A','B','C','D']])

追記 面積を返す式をLpAffineExpression で作ってみました。

python

1import pulp 2 3problem = pulp.LpProblem('test', pulp.LpMaximize) 4parts = pulp.LpVariable.dicts('part_X', ['A','B','C','D'], 0, 1, "Binary") 5part_X_area = pulp.LpAffineExpression(zip(parts.values(), [4, 9, 16, 25])) 6part_X_count = pulp.LpAffineExpression(zip(parts.values(), [1, 1, 1, 1])) 7part_X_constraints = pulp.LpConstraint(part_X_count, 0, 'part_X', 1) 8problem += part_X_area 9problem += part_X_constraints

投稿2019/10/20 06:24

編集2019/10/20 08:03
matobaa

総合スコア2493

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

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

ikkun34

2019/10/20 07:04

解答ありがとうございます。その方法でやろうとも考えたのですが今回、構造物の形及び各部材の長さはあらかじめ決まっており、その長さと断面積に基づいた各部材の制約と、全体としてのたわみの制約に基づいて、コスト最小化の目的関数を解くので、各部材により制約関数の係数がまちまちなのでその方法が適応できない気がするのですが、どうですか?? ちなみに部材は13部材あり、その中に対処なものが12個あります。
matobaa

2019/10/20 08:00

なるほど、それは確かに変数定義でなんとかしたい物量ですね。ちょっと変形してみたので追記しますね。
ikkun34

2019/10/20 08:11

お手数お掛けします。 ありがとうございます!!
guest

0

4つの中から選択するなら、数字入力させて1から4で判断するとか

投稿2019/10/20 04:59

編集2019/10/20 05:00
y_waiwai

総合スコア88038

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

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

ikkun34

2019/10/20 07:06

回答ありがとうございます。今回の問題では変数がかなり多くそれは対応していないので組み合わせが多く途方もない作業となるのでその方法は難しいと思います。
y_waiwai

2019/10/20 07:10

今回の問題とは? あまりにも説明がない/情報が足りないのでなんのことやら。
ikkun34

2019/10/20 08:11

すみません説明不足ですね。今回は構造物の形及び各部材の長さはあらかじめ決まっており、その長さと断面積に基づいた各部材の制約と、全体としてのたわみの制約に基づいて、コスト最小化の目的関数を解くので、各部材により制約関数の係数がまちまちなの対象部材を除いて8種類の断面積にそれぞれ4種類の選択肢与えないといけないのです。
matobaa

2019/10/20 08:16 編集

確かに情報が少ないですね。LpVariable というメソッド名や lowBoundという引数名があるのでなんとか探せるものの、質問に pulp といったタグがついていると、さらに有識者の目にも触れやすいかと思います。
y_waiwai

2019/10/20 08:14

それを質問に追記しましょう #後付けで質問に書かれてないことをなんやかや言われてもねえ。。
ikkun34

2019/10/20 08:46

すみません。最初は変数を4つの選択式にする方法のみを聞こうとしていたもので、それでもpulpのタグぐらいはつけておくべきですね!反省します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問