mirror of
				https://github.com/gsi-upm/soil
				synced 2025-10-22 11:18:25 +00:00 
			
		
		
		
	Compare commits
	
		
			3 Commits
		
	
	
		
			0.14.6
			...
			3b2c6a3db5
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 3b2c6a3db5 | ||
|  | 6118f917ee | ||
|  | 6adc8d36ba | 
| @@ -1,4 +1,5 @@ | ||||
| **/soil_output | ||||
| .* | ||||
| **/__pycache__ | ||||
| __pycache__ | ||||
| *.pyc | ||||
|   | ||||
							
								
								
									
										11
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -3,6 +3,17 @@ 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). | ||||
|  | ||||
| ## [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] | ||||
| ### Changed | ||||
| * Minor change to traceback handling in async simulations | ||||
| ### Fixed | ||||
| * Incomplete example in the docs (example.yml) caused an exception | ||||
| ## [0.14.6] | ||||
| ### Fixed | ||||
| * Bug with newer versions of networkx (0.24) where the Graph.node attribute has been removed. We have updated our calls, but the code in nxsim is not under our control, so we have pinned the networkx version until that issue is solved. | ||||
|   | ||||
| @@ -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 | ||||
|  | ||||
| [](https://www.gsi.dit.upm.es) | ||||
| [](https://www.gsi.upm.es) | ||||
|  | ||||
|   | ||||
| @@ -8,32 +8,8 @@ The advantage of a configuration file is that it is a clean declarative descript | ||||
| Simulation configuration files can be formatted in ``json`` or ``yaml`` and they define all the parameters of a simulation. | ||||
| Here's an example (``example.yml``). | ||||
|  | ||||
| .. code:: yaml | ||||
|            | ||||
|     --- | ||||
|     name: MyExampleSimulation | ||||
|     max_time: 50 | ||||
|     num_trials: 3 | ||||
|     interval: 2 | ||||
|     network_params: | ||||
|         generator: barabasi_albert_graph | ||||
|         n: 100 | ||||
|         m: 2 | ||||
|     network_agents: | ||||
|         - agent_type: SISaModel | ||||
|            weight: 1 | ||||
|             state: | ||||
|             id: content | ||||
|         - agent_type: SISaModel | ||||
|             weight: 1 | ||||
|             state: | ||||
|             id: discontent | ||||
|         - agent_type: SISaModel | ||||
|             weight: 8 | ||||
|             state: | ||||
|             id: neutral | ||||
|     environment_params: | ||||
|         prob_infect: 0.075 | ||||
| .. literalinclude:: example.yml | ||||
|    :language: yaml | ||||
|  | ||||
|  | ||||
| This example configuration will run three trials (``num_trials``) of a simulation containing a randomly generated network (``network_params``). | ||||
|   | ||||
							
								
								
									
										35
									
								
								docs/example.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								docs/example.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | ||||
| --- | ||||
| name: MyExampleSimulation | ||||
| max_time: 50 | ||||
| num_trials: 3 | ||||
| interval: 2 | ||||
| network_params: | ||||
|     generator: barabasi_albert_graph | ||||
|     n: 100 | ||||
|     m: 2 | ||||
| network_agents: | ||||
|     - agent_type: SISaModel | ||||
|       weight: 1 | ||||
|       state: | ||||
|         id: content | ||||
|     - agent_type: SISaModel | ||||
|       weight: 1 | ||||
|       state: | ||||
|         id: discontent | ||||
|     - agent_type: SISaModel | ||||
|       weight: 8 | ||||
|       state: | ||||
|         id: neutral | ||||
| environment_params: | ||||
|     prob_infect: 0.075 | ||||
|     neutral_discontent_spon_prob: 0.1 | ||||
|     neutral_discontent_infected_prob: 0.3 | ||||
|     neutral_content_spon_prob: 0.3 | ||||
|     neutral_content_infected_prob: 0.4 | ||||
|     discontent_neutral: 0.5 | ||||
|     discontent_content: 0.5 | ||||
|     variance_d_c: 0.2 | ||||
|     content_discontent: 0.2 | ||||
|     variance_c_d: 0.2 | ||||
|     content_neutral: 0.2 | ||||
|     standard_variance: 1 | ||||
| @@ -14,11 +14,11 @@ Now test that it worked by running the command line tool | ||||
|  | ||||
|    soil --help | ||||
|  | ||||
| Or using soil programmatically: | ||||
| Or, if you're using using soil programmatically: | ||||
|  | ||||
| .. code:: python | ||||
|  | ||||
|    import soil | ||||
|    print(soil.__version__) | ||||
|  | ||||
| The latest version can be installed through `GitLab <https://lab.cluster.gsi.dit.upm.es/soil/soil.git>`_. | ||||
| The latest version can be installed through `GitLab <https://lab.gsi.upm.es/soil/soil.git>`_ or `GitHub <https://github.com/gsi-upm/soil>`_. | ||||
|   | ||||
| @@ -5,6 +5,6 @@ numpy | ||||
| matplotlib | ||||
| pyyaml>=5.1 | ||||
| pandas>=0.23 | ||||
| scipy==1.2.1 # scipy 1.3.0rc1 is not compatible with salib | ||||
| scipy>=1.3 | ||||
| SALib>=1.3 | ||||
| Jinja2 | ||||
|   | ||||
| @@ -1 +1 @@ | ||||
| 0.14.6 | ||||
| 0.14.9 | ||||
| @@ -44,6 +44,8 @@ class Environment(nxsim.NetworkEnvironment): | ||||
|                  topology=None, | ||||
|                  *args, **kwargs): | ||||
|         self.name = name or 'UnnamedEnvironment' | ||||
|         seed = seed or time.time() | ||||
|         random.seed(seed) | ||||
|         if isinstance(states, list): | ||||
|             states = dict(enumerate(states)) | ||||
|         self.states = deepcopy(states) if states else {} | ||||
| @@ -55,12 +57,11 @@ class Environment(nxsim.NetworkEnvironment): | ||||
|         self.interval = interval | ||||
|         self._history = history.History(name=self.name, | ||||
|                                         backup=True) | ||||
|         self['SEED'] = seed | ||||
|         # Add environment agents first, so their events get | ||||
|         # executed before network agents | ||||
|         self.environment_agents = environment_agents or [] | ||||
|         self.network_agents = network_agents or [] | ||||
|         self['SEED'] = seed or time.time() | ||||
|         random.seed(self['SEED']) | ||||
|  | ||||
|     @property | ||||
|     def agents(self): | ||||
|   | ||||
| @@ -94,7 +94,7 @@ class Simulation(NetworkSimulation): | ||||
|         self.seed = str(seed) or str(time.time()) | ||||
|         self.load_module = load_module | ||||
|         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.num_trials = num_trials | ||||
|         self.max_time = max_time | ||||
| @@ -216,9 +216,10 @@ class Simulation(NetworkSimulation): | ||||
|         try: | ||||
|             return self.run_trial(*args, **kwargs) | ||||
|         except Exception as ex: | ||||
|             c = ex.__cause__ | ||||
|             c.message = ''.join(traceback.format_exception(type(c), c, c.__traceback__)[:]) | ||||
|             return c | ||||
|             if ex.__cause__ is not None: | ||||
|                 ex = ex.__cause__ | ||||
|             ex.message = ''.join(traceback.format_exception(type(ex), ex, ex.__traceback__)[:]) | ||||
|             return ex | ||||
|  | ||||
|     def to_dict(self): | ||||
|         return self.__getstate__() | ||||
|   | ||||
| @@ -31,7 +31,7 @@ def safe_open(path, mode='r', backup=True, **kwargs): | ||||
|         os.makedirs(outdir) | ||||
|     if backup and 'w' in mode and os.path.exists(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) | ||||
|         if not os.path.exists(backup_dir): | ||||
|   | ||||
		Reference in New Issue
	
	Block a user