20面体ダイスの期待値についてシミュレーションするプログラムを作りました。期待値の収束とダイスの出目の頻度をグラフとして表示させたいのですが、分かりませんでした。以下、コードとエラー文です。
解答よろしくお願いします。
python
1import matplotlib.pyplot as plt 2import random 3 4appearances = [] #出目を記録 5count_num = [] #出た回数を記録 6exp_val = [] #期待値を記録 7try_num = 100000 #試行回数 8 9x = 0 10i = 1 11j = 1 12y = 0 13a = range(1, 20) #グラフの横軸 14 15while i <= try_num: 16 x=random.randint(1,20) 17 appearances.append(x) 18 if i==50: 19 #各要素が何回出たか 20 while j <= 20: 21 y=appearances.count(j) 22 count_num.append(y) 23 #出目を棒グラフで表示&期待値の計算 24 if j==20: 25 plt.bar(a, count_num) 26 average = sum(appearances) / len(appearances) 27 exp_val.append(average) 28 j+=1 29 elif i==100: 30 while j <= 20: 31 y=appearances.count(j) 32 count_num.append(y) 33 if j==20: 34 plt.bar(a, count_num) 35 average = sum(appearances) / len(appearances) 36 exp_val.append(average) 37 j+=1 38 elif i==1000: 39 while j <= 20: 40 y=appearances.count(j) 41 count_num.append(y) 42 if j==20: 43 plt.bar(a, count_num) 44 average = sum(appearances) / len(appearances) 45 exp_val.append(average) 46 j+=1 47 elif i==10000: 48 while j <= 20: 49 y=appearances.count(j) 50 count_num.append(y) 51 if j==20: 52 plt.bar(a, count_num) 53 average = sum(appearances) / len(appearances) 54 exp_val.append(average) 55 j+=1 56 elif i==100000: 57 while j <= 20: 58 y=appearances.count(j) 59 count_num.append(y) 60 if j==20: 61 plt.bar(a, count_num) 62 average = sum(appearances) / len(appearances) 63 exp_val.append(average) 64 j+=1 65 i+=1 66 67#期待値の収束 68fig, ax = plt.subplots() 69ax.plot(try_num, exp_val) 70 71plt.show()
python
1ValueError: shape mismatch: objects cannot be broadcast to a single shape
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。