1
0
mirror of https://github.com/gsi-upm/soil synced 2024-11-22 19:22:29 +00:00
soil/examples/programmatic/programmatic_sim.py

54 lines
1.2 KiB
Python
Raw Normal View History

2022-10-17 18:23:57 +00:00
"""
Example of a fully programmatic simulation, without definition files.
2022-10-17 18:23:57 +00:00
"""
from soil import Simulation, Environment, agents
from networkx import Graph
import logging
def mygenerator():
# Add only a node
G = Graph()
G.add_node(1)
G.add_node(2)
return G
class MyAgent(agents.NetworkAgent, agents.FSM):
times_run = 0
@agents.default_state
@agents.state
def neutral(self):
2022-10-17 18:23:57 +00:00
self.debug("I am running")
if self.prob(0.2):
self.times_run += 1
2022-10-17 18:23:57 +00:00
self.info("This runs 2/10 times on average")
class ProgrammaticEnv(Environment):
def init(self):
self.create_network(generator=mygenerator)
assert len(self.G)
self.populate_network(agent_class=MyAgent)
self.add_agent_reporter('times_run')
simulation = Simulation(
2022-10-17 18:23:57 +00:00
name="Programmatic",
model=ProgrammaticEnv,
seed='Program',
2023-04-20 15:56:44 +00:00
iterations=1,
2022-10-17 18:23:57 +00:00
max_time=100,
dump=False,
2022-10-17 18:23:57 +00:00
)
if __name__ == "__main__":
# By default, logging will only print WARNING logs (and above).
# You need to choose a lower logging level to get INFO/DEBUG traces
logging.basicConfig(level=logging.INFO)
envs = simulation.run()
for agent in envs[0].agents:
print(agent.times_run)