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.
3b2c6a3db5
...
6adc8d36ba
@ -1,5 +1,4 @@
|
|||||||
**/soil_output
|
**/soil_output
|
||||||
.*
|
.*
|
||||||
**/__pycache__
|
|
||||||
__pycache__
|
__pycache__
|
||||||
*.pyc
|
*.pyc
|
||||||
|
@ -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
|
||||||
|
@ -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)
|
||||||
|
|
||||||
|
@ -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>`_.
|
||||||
|
@ -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
|
||||||
|
@ -1 +1 @@
|
|||||||
0.14.9
|
0.14.7
|
@ -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):
|
||||||
|
@ -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
|
||||||
|
@ -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):
|
||||||
|
Loading…
Reference in New Issue
Block a user