From 48498431e3e4f649b84953a89ab700e06edea6bb Mon Sep 17 00:00:00 2001 From: alexPatrie Date: Wed, 28 Feb 2024 15:21:52 -0500 Subject: [PATCH] updated process for copasi notebook --- .../processes/copasi_process.py | 64 ++++++++++++++----- notebooks/copasi_process_composer.ipynb | 40 ++++++++---- 2 files changed, 75 insertions(+), 29 deletions(-) diff --git a/biosimulator_processes/processes/copasi_process.py b/biosimulator_processes/processes/copasi_process.py index 326d2813d..383e75e51 100644 --- a/biosimulator_processes/processes/copasi_process.py +++ b/biosimulator_processes/processes/copasi_process.py @@ -26,11 +26,14 @@ run_time_course, get_compartments, new_model, - add_reaction + add_reaction, + T, + set_report_dict ) from process_bigraph import Process, Composite, pf from biosimulator_processes.utils import fetch_biomodel from biosimulator_processes.process_types import MODEL_TYPE +import biosimulator_processes.processes class CopasiProcess(Process): @@ -166,6 +169,7 @@ def __init__(self, config=None, core=None): self.compartments_list = get_compartments(model=self.copasi_model_object).index.tolist() self.method = self.config.get('method') + # set_report_dict('Time-Course', task=T.TIME_COURSE, model=self.copasi_model_object, body=['Time']) def initial_state(self): floating_species_dict = dict( @@ -215,24 +219,12 @@ def update(self, inputs, interval): model=self.copasi_model_object) # run model for "interval" length; we only want the state at the end - timecourse_args = { - 'start_time': inputs['time'], - 'duration': interval, - 'update_model': True, - # 'intervals': 1, - 'model': self.copasi_model_object} - - if self.method is not None: - timecourse_args['method'] = self.method - - # run the time course with given kwargs - # timecourse = run_time_course(**timecourse_args) timecourse = run_time_course( start_time=inputs['time'], duration=interval, update_model=True, - model=self.copasi_model_object - ) + model=self.copasi_model_object, + method=self.method) # extract end values of concentrations from the model and set them in results results = {'time': interval} @@ -284,10 +276,50 @@ def test_process(): } } + instance = { + 'copasi': { + '_type': 'process', + 'address': 'local:copasi', + 'config': { + 'model': { + 'model_source': 'biosimulator_processes/model_files/Caravagna2010.xml' + } + }, + 'inputs': { + 'floating_species': ['floating_species_store'], + 'model_parameters': ['model_parameters_store'], + 'time': ['time_store'], + 'reactions': ['reactions_store'] + }, + 'outputs': { + 'floating_species': ['floating_species_store'], + 'time': ['time_store'], + } + }, + 'emitter': { + '_type': 'step', + 'address': 'local:ram-emitter', + 'config': { + 'emit': { + 'floating_species': 'tree[float]', + 'time': 'float', + }, + }, + 'inputs': { + 'floating_species': ['floating_species_store'], + 'time': ['time_store'], + } + } + } + workflow = Composite({ - 'state': initial_sim_state + 'state': instance # initial_sim_state }) workflow.run(10) results = workflow.gather_results() print(f'RESULTS: {pf(results)}') assert ('emitter',) in results.keys(), "This instance was not properly configured with an emitter." + + +if __name__ == "__main__": + test_process() diff --git a/notebooks/copasi_process_composer.ipynb b/notebooks/copasi_process_composer.ipynb index 44cadc677..f2e4111ba 100644 --- a/notebooks/copasi_process_composer.ipynb +++ b/notebooks/copasi_process_composer.ipynb @@ -174,31 +174,33 @@ "source": [ "workflow = Composite({\n", " 'state': instance\n", - "})" - ] - }, - { - "cell_type": "markdown", - "id": "6a402e48fbc30a5b", - "metadata": { - "collapsed": false - }, - "source": [ - "##### 3. Run the Composite workflow with the Engine" + "})\n", + "\n", + "# basico.set_report_dict('composite_process_model', task=T.TIME_COURSE)\n" ] }, { "cell_type": "code", "outputs": [], "source": [ - "workflow.config_schema" + "basico.T.TIME_COURSE" ], "metadata": { "collapsed": false }, - "id": "9d5477c224adfa39", + "id": "5690cd2793a5a53b", "execution_count": null }, + { + "cell_type": "markdown", + "id": "6a402e48fbc30a5b", + "metadata": { + "collapsed": false + }, + "source": [ + "##### 3. Run the Composite workflow with the Engine" + ] + }, { "cell_type": "code", "execution_count": null, @@ -211,6 +213,18 @@ "workflow.run(10)" ] }, + { + "cell_type": "code", + "outputs": [], + "source": [ + "workflow.process_paths" + ], + "metadata": { + "collapsed": false + }, + "id": "92246d0c4cdc0e51", + "execution_count": null + }, { "cell_type": "markdown", "id": "d0ff3a2822a8fa2c",