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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Python

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

Q&A

解決済

1回答

677閲覧

ValueError: cannot reshape array of size 0 into shape (3,2)を解決したい。

nononono1

総合スコア4

Python

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

0グッド

0クリップ

投稿2022/01/14 14:29

ValueError: cannot reshape array of size 0 into shape (3,2)のエラーが発生するのですがどう修正すればいいですか?
エラーが出た行は下のソースです
self.x=np.random.uniform(x_min, x_max, N).reshape(M,N)
self.v=np.random.uniform(x_min, x_max, N).reshape(M,N)

全ソース
import numpy as np
N= 2 # dimension
M= 3 # number of particles
T= 5 # number of iteration
x_min= -10.0
x_max= 10.0
v_min= -10.0
v_max= 10.0
w= 0.4 # parameter for PSO
c1= 2.0 # parameter for PSO
c2= 2.0 # parameter for PSO

def shpere(x):
f= 0
for j in range(x.size): # len(x)
f+= x[j]**2
return(f)

def evaluate(x):
return(shpere(x))

class Pso:
def init(self):
self.fit= np.zeros(M)
self.pbest_fit= np.zeros(M)
self.x=np.random.uniform(x_min, x_max, N).reshape(M,N)
self.v=np.random.uniform(x_min, x_max, N).reshape(M,N)
for i in range(M):
self.fit[i]= evaluate(self.x[i])
self.pbest_fit[i]= self.fit[i]
self.pbest_x= np.copy(self.x)
self.gbest_x= np.copy(self.pbest_x[0])
self.gbest_fit= self.pbest_fit[0]

def update(self): for i in range(M): for j in range(N): self.v[i,j]= w*self.v[i,j] + c1*np.random.uniform(0,

1.0)(self.pbest_x[i,j] - self.x[i,j])+ c2np.random.uniform(0,1.0)*(self.gbest_x[i,j] - self.x[i,j])
self.x[i,j]+= self.v[i,j]
self.fit[i]= evaluate(self.x[i])

def pbest_update(self): for i in range(M): if self.pbest_fit[i]>=self.fit[i]: self.pbest_fit[i]=self.fit[i] self.pbest_x[i]= np.copy(self.x[i]) def gbest_update(self): for i in range(M): if self.gbest_fit>= self.pbest_fit[i]: self.gbest_fit= self.pbest_fit[i] self.gbest_x= np.copy(self.pbest_x[i]) def report_bestfit(self): return(self.gbest_fit)

pso=Pso()
pso.gbest_update()
print(str(0)+ ", " +str(pso.report_bestfit()))
for t in range(1,T+1):
pso.update()
pso.pbest_update()
pso.gbest_update()
print(str(t)+ ", " +str(pso.report_bestfit()))

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

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

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

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

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

guest

回答1

0

ベストアンサー

reshape(M, N) ができる様に M*N 個の乱数を生成します。

python

1self.x=np.random.uniform(x_min, x_max, M*N).reshape(M,N) 2self.v=np.random.uniform(x_min, x_max, M*N).reshape(M,N)

投稿2022/01/14 14:38

編集2022/01/14 14:39
melian

総合スコア19712

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問