1
0
mirror of https://github.com/gsi-upm/soil synced 2025-01-10 00:31:27 +00:00

Compare commits

..

No commits in common. "3b2c6a3db5a4362c575d229271a3f331766a9309" and "6adc8d36ba705da322435b231e2b923a2c574bd1" have entirely different histories.

9 changed files with 9 additions and 17 deletions

View File

@ -1,5 +1,4 @@
**/soil_output **/soil_output
.* .*
**/__pycache__
__pycache__ __pycache__
*.pyc *.pyc

View File

@ -3,12 +3,6 @@ All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
## [0.14.9]
### Changed
* Seed random before environment initialization
## [0.14.8]
### Fixed
* Invalid directory names in Windows gsi-upm/soil#5
## [0.14.7] ## [0.14.7]
### Changed ### Changed
* Minor change to traceback handling in async simulations * Minor change to traceback handling in async simulations

View File

@ -30,5 +30,5 @@ If you use Soil in your research, don't forget to cite this paper:
@Copyright GSI - Universidad Politécnica de Madrid 2017 @Copyright GSI - Universidad Politécnica de Madrid 2017
[![SOIL](logo_gsi.png)](https://www.gsi.upm.es) [![SOIL](logo_gsi.png)](https://www.gsi.dit.upm.es)

View File

@ -14,11 +14,11 @@ Now test that it worked by running the command line tool
soil --help soil --help
Or, if you're using using soil programmatically: Or using soil programmatically:
.. code:: python .. code:: python
import soil import soil
print(soil.__version__) print(soil.__version__)
The latest version can be installed through `GitLab <https://lab.gsi.upm.es/soil/soil.git>`_ or `GitHub <https://github.com/gsi-upm/soil>`_. The latest version can be installed through `GitLab <https://lab.cluster.gsi.dit.upm.es/soil/soil.git>`_.

View File

@ -5,6 +5,6 @@ numpy
matplotlib matplotlib
pyyaml>=5.1 pyyaml>=5.1
pandas>=0.23 pandas>=0.23
scipy>=1.3 scipy==1.2.1 # scipy 1.3.0rc1 is not compatible with salib
SALib>=1.3 SALib>=1.3
Jinja2 Jinja2

View File

@ -1 +1 @@
0.14.9 0.14.7

View File

@ -44,8 +44,6 @@ class Environment(nxsim.NetworkEnvironment):
topology=None, topology=None,
*args, **kwargs): *args, **kwargs):
self.name = name or 'UnnamedEnvironment' self.name = name or 'UnnamedEnvironment'
seed = seed or time.time()
random.seed(seed)
if isinstance(states, list): if isinstance(states, list):
states = dict(enumerate(states)) states = dict(enumerate(states))
self.states = deepcopy(states) if states else {} self.states = deepcopy(states) if states else {}
@ -57,11 +55,12 @@ class Environment(nxsim.NetworkEnvironment):
self.interval = interval self.interval = interval
self._history = history.History(name=self.name, self._history = history.History(name=self.name,
backup=True) backup=True)
self['SEED'] = seed
# Add environment agents first, so their events get # Add environment agents first, so their events get
# executed before network agents # executed before network agents
self.environment_agents = environment_agents or [] self.environment_agents = environment_agents or []
self.network_agents = network_agents or [] self.network_agents = network_agents or []
self['SEED'] = seed or time.time()
random.seed(self['SEED'])
@property @property
def agents(self): def agents(self):

View File

@ -94,7 +94,7 @@ class Simulation(NetworkSimulation):
self.seed = str(seed) or str(time.time()) self.seed = str(seed) or str(time.time())
self.load_module = load_module self.load_module = load_module
self.network_params = network_params self.network_params = network_params
self.name = name or 'Unnamed_' + time.strftime("%Y-%m-%d_%H.%M.%S") self.name = name or 'Unnamed_' + time.strftime("%Y-%m-%d_%H:%M:%S")
self.group = group or None self.group = group or None
self.num_trials = num_trials self.num_trials = num_trials
self.max_time = max_time self.max_time = max_time

View File

@ -31,7 +31,7 @@ def safe_open(path, mode='r', backup=True, **kwargs):
os.makedirs(outdir) os.makedirs(outdir)
if backup and 'w' in mode and os.path.exists(path): if backup and 'w' in mode and os.path.exists(path):
creation = os.path.getctime(path) creation = os.path.getctime(path)
stamp = time.strftime('%Y-%m-%d_%H.%M', time.localtime(creation)) stamp = time.strftime('%Y-%m-%d_%H:%M', time.localtime(creation))
backup_dir = os.path.join(outdir, stamp) backup_dir = os.path.join(outdir, stamp)
if not os.path.exists(backup_dir): if not os.path.exists(backup_dir):