- 
                Notifications
    You must be signed in to change notification settings 
- Fork 73
SCIRun Python API 0.2
The API contains global functions for network editing, file management, module state modification, and data object extraction and insertion.
- 
scirun_add_module("ModuleName")- Adds a new instance of a module to the network. Returns the module ID as a string.
 
- 
scirun_remove_module("ModuleID")- Removes the module specified by the ID string.
 
- 
scirun_execute_all()- Executes the entire current network.
 
- 
scirun_module_ids()- Returns a list of all module ID strings in the current network.
 
- 
scirun_connect_modules("ModuleIDFrom", fromIndex, "ModuleIDTo", toIndex)- Connects ports between two modules by index. From is the output, To is the input.
 
- 
scirun_disconnect_modules("ModuleIDFrom", fromIndex, "ModuleIDTo", toIndex)- Used to disconnect two modules, with the same syntax as connecting.
 
- 
scirun_save_network("Filename.srn5")- Saves the current network file.
 
- 
scirun_load_network("Filename.srn5")- Loads the specified network file.
 
- 
scirun_import_network("Filename.srn")- Imports the specified v4 network file.
 
- 
scirun_quit()- Enables quitting SCIRun after the next network execution is complete.
 
- 
scirun_force_quit()- Quits SCIRun immediately.
 
- 
scirun_get_module_state("ModuleID", "StateVariableName")- Returns the value of a the specified module state variable.
 
- 
scirun_set_module_state("ModuleID", "StateVariableName", value)- Sets the specified module state variable's value.
 
- 
scirun_dump_module_state("ModuleID")- Returns a dictionary with the entire state of the specified module.
 
- 
scirun_get_module_transient_state("ModuleID", "StateVariableName")- Returns the value of a the specified module transient state variable.
 
- 
scirun_set_module_transient_state("ModuleID", "StateVariableName", value)- Sets the specified module transient state variable's value. Used to pass data values (strings, matrices, fields [coming soon]) back to modules.
 
- 
scirun_get_module_input_type("ModuleID", portIndex)- Returns the type of the input data object on the specified port.
 
- 
scirun_get_module_input_object("ModuleID", "PortName")- Returns a special PyDatatypewrapper object containing a copy of the data on the specified input port, by name.
 
- Returns a special 
- 
scirun_get_module_input_value("ModuleID", "PortName")- Returns a Python object containing a copy of the data on the specified input port.
 
- 
scirun_get_module_input_object_by_index("ModuleID", portIndex)- Returns a special PyDatatypewrapper object containing a copy of the data on the specified input port, by port index.
 
- Returns a special 
- 
scirun_get_module_input_value_by_index("ModuleID", portIndex)- Returns a Python object containing a copy of the data on the specified input port, by index.
 
- If there is an installation of the packages with other python builds on the machine, the system path can be used to use those packages.
There are many ways to install packages in python. pip is an easy way that is usually included with python.
if pip is not installed, follow these directions: https://pip.pypa.io/en/stable/installing/
*make sure that pip is installed *in the terminal:
- cd "scirun_root"/bin/Externals/Install/Python_external/bin/
- ./python3 -m pip install numpy
in the terminal:
- cd "matlab_root"/extern/engines/python
- "scirun_root"/bin/Externals/Install/Python_external/bin/python3.4 setup.py build --build-base="builddir" install --prefix="installdir"
Full instructions are located at http://www.mathworks.com/help/matlab/matlab_external/install-the-matlab-engine-for-python.html
In SCIRun 5, Matlab code and functions can be run using the matlab engine for python in the python console or python interface. To do so, make sure that the matlab engine is installed (previous section). Full documentation found at http://www.mathworks.com/help/matlab/matlab-engine-for-python.html