PsyNeuLinkView (PNLV) is an application that provides a graphical user interface to the PsyNeuLink (PNL) Python library. This allows users to visualize and edit PNL compositions in a drag-and-drop format on a native desktop app. An open source project, PNLV is built with an Electron frontend that uses gRPC to interact with a Python server running a PNL script.
PNLV currently supports the following features:
- View PNL compositions where the PNL script contains only one composition within its namespace.
- Edit layout of mechanisms within PNL compositions with drag-and-drop. User defined layout of nodes is autosaved into the PNL script so the arrangement is saved for future use.
- Run select PNL compositions with custom input.
- Monitor and plot the values of any parameter of the composition on configurable, tileable line plots.
Future planned features include:
- Run any PNL composition.
- Construct and modify PNL composition topology within the app.
- Additional output visualization types (heatmaps, multidimensional output, etc.).
- Double click node for more information (parameter values, etc).
(NOTE: See #10 for important usage information)
-
Download code. Git clone these two repositories into the same directory.
-
Install dependencies
- Node.js (Must be on PATH)
- Yarn (Must be on PATH)
- Python3 (latest version recommended)
- PsyNeuLink
- $ pip install psyneulink
- RedBaron
- $ pip install redbaron
-
Set up dependencies. Navigate to top level PNLV directory and run:
- $ yarn
-
Run application
- To run:
- $ yarn electron-dev
- NOTE: a number of errors may be thrown due to internal electron errors or lint warnings. This should not affect functionality.
- To run:
-
Initial setup
- Navigate to Preferences menu (cmd/ctrl + , or Edit>Preferences)
- Under “Interpreter Path”, enter the path to your Python executable. You should see a green check icon if the interpreter is validated.
-
Load a composition
- Open a composition (cmd/ctrl + O or File>Open)
- Select pnlv-plotting-test.py from PsyNeuLinkView/examples/working-test/basic
- For pnlv-plotting-test.py, a simple 3 node graph should be rendered in the Construct tab. For Rumelhart Semantic Network.py, a more complex graph should load (will take a few seconds)
- Nodes can be dragged and repositioned
- NOTE: Opening devtools (cmd/ctrl + I) while viewing the Construct tab may crash the app. Dragging nodes while the window is not at fullscreen may also cause this. When this error occurs, you may need to manually edit the PNL python script that was previously loaded such that the pnl_graphics_spec dictionary is initialized as an empty dict. Code to reposition nodes on window size change needs work. However, you can open devtools while viewing the Monitor tab.
-
Add and configure plots
- Switch to Monitor tab
- Drag and drop desired number of plots from the Line Plot option in the sidebar into the main window
- In the configuration panel at the bottom of the window, select the Line-Plot-1 tab (default plot name)
- Scroll down and select a component and a port within that component to be plotted
- Select the default color to change
-
Provide input to composition
- In the bottom configuration panel, select the Composition tab
- Click the upload button and upload the file input.json from PsyNeuLinkView/examples/working-test/basic
-
Run composition
- Click green play icon in the control strip at the top of the window
-
Quit app
- First, Cmd-Q or Electron>Quit psyneulinkview. Then Keyboard Interrupt at the terminal.
- NOTE: Do not use Keyboard Interrupt without quitting Electron first. Keyboard Interrupt at the terminal will only kill the Electron client process, and it will not kill the Python server process. This will result in the old Python process remaining alive when attempting to reopen the app, leading to PNL registry side-effects and bugs.
- First, Cmd-Q or Electron>Quit psyneulinkview. Then Keyboard Interrupt at the terminal.