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

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

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

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

Q&A

解決済

1回答

2292閲覧

感染症のセルオートマトンモデル

suugaku_nyumon

総合スコア37

Python

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

0グッド

0クリップ

投稿2018/12/05 00:35

質問

続けての質問を申し訳ございません。これで一旦最後となります。左右の影響のみを受ける1列のセルオートマトンにおいてコードを書いていたのですが、エラーの対処が出来ず質問させていただきました。

B[i1][i][15]の値が未定義な状態らしく、エラーメッセージが出てしまいます。これはどうすれば直せるのでしょうか?

内容(必要であれば読んでください)

1列に続く30枚のマスの連続の中に牛かクマがいます。そして、感染した牛のセルと感染したクマのセルを紫色にします。ただし、A[i1][i][15]値は1と3と分けています。さらに非感染の牛のセルを値を2にして赤色のセルに、非感染のアナグマのセルの値を4にして青色のセルに設定します。

また、動物の感染度をBとして表していますが、これをi番目のセルの感染度としてB[i1][i][15]と定義しています。そして、これが0.4以上ならば感染しているとみなし、0.4未満なら非感染とみなします。また、Bは0以上1以下の数です。なので、B[i2][1][15]>1ならばB[i2][i][15]=1に訂正しています。

そして、自分自身の感染度と両隣のセルの感染度から次の時間での自分自身の感染度を導出して、感染度から感染しているか判別しセルの色を変えるというプログラムを組んでいます。

また、動物-動物間の感染率も定義して、クマからクマ:0.6、クマから牛:0.75、牛からクマ:0.1、牛から牛:0.25として、これを感染度と掛け合わせることで、その動物が感染させる確率を導出しています。また、両隣のセルから感染する確率は、それぞれ出した確率の和で計算してます。

今回は死亡しないケースを考えて、回復については、感染したセルの値が徐々に小さくなるように式を定義して、治るようにしています。今回は回復率は0.3です。0.7という数字は1-0.3で出しています。

python3

1from tkinter import * 2import time 3import tkinter as tk 4import random 5import math 6#配列の宣言 7def array2(N1,N2): 8 return [[0 for j in range(N2)]for k in range(N1)] 9def array3(N1,N2,N3): 10 return [array2(N2,N3)for k in range(N1)] 11#セルの初期設定 12def initdt(): 13 A=array3(1000,31,31) 14 B=array3(1000,31,31) 15 for i in range(1,31): 16 if (1 <= i <= 4 or 6 <= i <= 14 or 16 <= i <= 19 or 21 <= i <= 24 or 26 <= i <= 30): 17 r_0=random.random() 18 if (r_0 <= 0.50): 19 A[0][i][15]=2 20 B[0][i][15]=0 21 if (r_0 > 0.50): 22 A[0][i][15]=4 23 B[0][i][15]=0 24 if (i == 5 or 25): 25 A[0][i][15]=1 26 B[0][i][15]=1 27 if (i == 15 or 20): 28 A[0][i][15]=3 29 B[0][i][15]=1 30 return A 31 return B 32#セルオートマトンの実行 33def execCell(A,i1): 34 i2 = 1 + i1 35 for i in range(1,30): 36 if A[i1][i][15] == 1: 37 B[i2][i][15] = 0.7 * B[i1][i][15] 38 if (0 <= B[i2][i][15] < 0.4): 39 A[i2][i][15] = 2 40 if (0.4 <= B[i2][i][15] <= 1): 41 A[i2][i][15] = 1 42 if A[i1][i][15] == 2: 43 if (A[i1][i-1][15] == 1 or 2) and (A[i1][i+1][15] == 1 or 2): 44 B[i2][i][15] = 0.7 * B[i1][i][15] + 0.25 * B[i1][i+1][15] + 0.25 * B[i1][i-1][15] 45 if (A[i1][i-1][15] == 3 or 4) and (A[i1][i+1][15] == 1 or 2): 46 B[i2][i][15] = 0.7 * B[i1][i][15] + 0.75 * B[i1][i-1][15] + 0.25 * B[i1][i+1][15] 47 if (A[i1][i-1][15] == 1 or 2) and (A[i1][i+1][15] == 3 or 4): 48 B[i2][i][15] = 0.7 * B[i1][i][15] + 0.25 * B[i1][i-1][15] + 0.75 * B[i1][i+1][15] 49 if (A[i1][i-1][15] == 3 or 4) and (A[i1][i+1][15] == 3 or 4): 50 B[i2][i][15] = 0.7 * B[i1][i][15] + 0.75 * B[i1][i-1][15] + 0.75 * B[i1][i+1][15] 51 if (0 <= B[i2][i][15] < 0.4): 52 A[i2][i][15] = 2 53 if (0.4 <= B[i2][i][15] <= 1): 54 A[i2][i][15] = 1 55 if (1.0 < B[i2][i][15]): 56 A[i2][i][15] = 1 57 B[i2][i][15] = 1.0 58 if A[i1][i][15] == 3: 59 B[i2][i][15] = 0.7 * B[i1][i][15] 60 if (0 <= B[i2][i][15] < 0.4): 61 A[i2][i][15] = 4 62 if (0.4 <= B[i2][i][15] <= 1): 63 A[i2][i][15] = 3 64 if A[i1][i][15] == 4: 65 if (A[i1][i-1][15] == 1 or 2) and (A[i1][i+1][15] == 1 or 2): 66 B[i2][i][15] = 0.7 * B[i1][i][15] + 0.10 * B[i1][i+1][15] + 0.10 * B[i1][i-1][15] 67 if (A[i1][i-1][15] == 3 or 4) and (A[i1][i+1][15] == 1 or 2): 68 B[i2][i][15] = 0.7 * B[i1][i][15] + 0.40 * B[i1][i-1][15] + 0.10 * B[i1][i+1][15] 69 if (A[i1][i-1][15] == 1 or 2) and (A[i1][i+1][15] == 3 or 4): 70 B[i2][i][15] = 0.7 * B[i1][i][15] + 0.10 * B[i1][i-1][15] + 0.40 * B[i1][i+1][15] 71 if (A[i1][i-1][15] == 3 or 4) and (A[i1][i+1][15] == 3 or 4): 72 B[i2][i][15] = 0.7 * B[i1][i][15] + 0.40 * B[i1][i-1][15] + 0.40 * B[i1][i+1][15] 73 if (0 <= B[i2][i][15] < 0.4): 74 A[i2][i][15] = 4 75 if (0.4 <= B[i2][i][15] <= 1): 76 A[i2][i][15] = 3 77 if (1.0 < B[i2][i][15]): 78 A[i2][i][15] = 3 79 B[i2][i][15] = 1.0 80#セルの位置決めとIDの設定 81def drawCell(canvas,A,k): 82 x2=0 83 CID=array2(31,31) 84 for i in range(1,30): 85 x1=x2 86 x2=x1+10 87 y2=0 88 for j in range(1,30): 89 y1=y2 90 y2=y1+10 91 CID[i][j]=canvas.create_rectangle(x1,y1,x2,y2,fill='black') 92 return CID 93#セルの色設定 94def modifyCell(canvas,A,k,CID): 95 CL=['black','#800080','#ff0000','#800080','#0000ff'] 96 for i in range(1,30): 97 for j in range(1,30): 98 canvas.itemconfig(CID[i][j],fill=CL[A[k][i][j]]) 99 canvas.itemconfig(CID[i][j],outline=CL[A[k][i][j]]) 100#Tk初期設定 101def initTk(): 102 tk=Tk(); tk.title("2D Cell Automaton"); tk.resizable(0,0) 103 return tk 104#画面キャプチャ用 105def leftMouseDown(event): 106 global canvas, A,k,CID 107 modifyCell(canvas,A,k,CID) 108 execCell(A,k) 109#実行メイン 110A=initdt() 111root=initTk() 112canvas=Canvas(root,width=290,height=290,highlightthickness=0) 113canvas.pack() 114CID=drawCell(canvas,A,0) 115k=0 116 117def animate(): 118 global k 119 modifyCell(canvas, A, k, CID) 120 execCell(A,k) 121 k = 1 + k 122 root.after(200, animate) 123 124root.after(200, animate) 125root.mainloop()

エラー

Exception in Tkinter callback Traceback (most recent call last): File "C:\Python37\lib\tkinter\__init__.py", line 1705, in __call__ return self.func(*args) File "C:\Python37\lib\tkinter\__init__.py", line 749, in callit func(*args) File "2direc_main3.py", line 120, in animate execCell(A,k) File "2direc_main3.py", line 59, in execCell B[i2][i][15] = 0.7 * B[i1][i][15] NameError: name 'B' is not defined

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

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

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

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

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

guest

回答1

0

ベストアンサー

提示エラーが発生する直接の原因はdef execCell(A,i1):内にてBが定義されていないためです。
initdt(においてreturn文を2行書いていますが、それでは最初のreturn文しか実行されませんし、Bはどこからも参照できません。
さらに、呼出元にてBを受け取っておらず、execCell(にも渡していないためBは利用できません。
以下のように修正が必要です。

Python

1# 略 2def initdt(): 3 # 略 4 return A,B # Bも返す 5# 略 6#実行メイン 7A,B=initdt() # Bも受け取る

投稿2018/12/05 00:53

編集2018/12/05 01:16
can110

総合スコア38262

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

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

suugaku_nyumon

2018/12/05 03:57

ありがとうございました。Bが定義されていない問題は解決しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問