mirror of
https://github.com/balkian/gists.git
synced 2024-09-27 15:51:42 +00:00
15 lines
500 B
Python
15 lines
500 B
Python
class ControlModelM2(BaseBehaviour):
|
|
NEUTRAL = 0
|
|
INFECTED = 1
|
|
def step(self, now):
|
|
if self.state['id'] == self.NEUTRAL: #Neutral
|
|
self.neutral_behaviour()
|
|
elif self.state['id'] == self.INFECTED: #Infected
|
|
self.infected_behaviour()
|
|
…
|
|
def infected_behaviour(self):
|
|
neutral_neighbors = self.get_neighboring_agents(state_id=self.NEUTRAL)
|
|
for neighbor in neutral_neighbors:
|
|
if random.random() < self.prob_infect:
|
|
neighbor.state['id'] = self.INFECTED
|