Viewer#
Important
This is an experimental tool that is currently under development
The MemryX viewer provides a GUI interface to various SDK tools. This includes the Neural Compile, the Simulator, and the Chip Programmer.
Usage#
To run the viewer you need to run the following command.
mx_viewer
Note
If the GUI fails to start, you may need to install a Qt5 library. On Debian/Ubuntu, you can use sudo apt install libqt5x11extras5
, then try the GUI again.
Compiler#
The compiler tab offers a visual interface to the MemryX neural compiler. It provides basic compiler functionality using a few simple steps.
1. Select the neural network models
data:image/s3,"s3://crabby-images/82f5c/82f5cae6dbdd06df52dae9abfc0c7660624a7371" alt="../_images/model_selector.png"
2. Select the target system
data:image/s3,"s3://crabby-images/25948/259483fd590d3d975506ff4ae3eea8bd28ea2cf7" alt="../_images/chip_selector.png"
(Optional) Select the target performance
data:image/s3,"s3://crabby-images/cbfeb/cbfebb29baa8abf591764b0b4cbc1458112d7ba7" alt="../_images/perf_selector.png"
3. Compile, by clicking the “start” button
data:image/s3,"s3://crabby-images/d1ad2/d1ad29817a6cbe7fa5fa5207a4b331b6ca200430" alt="../_images/compile.png"
The following figure shows the final result after compiling a MobileNet model to a single chip MX3 system. The compiler will also generate the DFP needed to program the accelerator or run the simulator.
data:image/s3,"s3://crabby-images/27aee/27aee4250aa5f62f5c8af4b1683d96ee97c0e733" alt="../_images/compiled_mobilenet.png"
The compiler will show the utilization percentage of the various accelerator resources. The layer distribution view shows how many cores are assigned to each neural network layer. By selecting a cluster of cores additional details including layer mapped to the cores, weight memory assigned to the layer etc. can be obtained. This feature has been demonstrated in the following figure.
data:image/s3,"s3://crabby-images/8c48c/8c48c579e67c0ab2c9de090dc7e2659a60c1a768" alt="../_images/layer.png"
Simulator#
The second tab is the simulator one. It offers a simple interface to the basic simulator features. The user need to select the number of frames they need to simulate and start the simulation.
data:image/s3,"s3://crabby-images/81144/8114427c7f579576ac72c8d86c5ee4157915edeb" alt="../_images/sim_selector.png"
During the simulation, the program previews how data flows through the cores and chips, where it colors each new frame differently.
data:image/s3,"s3://crabby-images/4b970/4b970a1d168a0b9620d997535cdeb1f23aa8a7ce" alt="../_images/sim_running.png"
Finally, the simulated FPS and latency will get reported to the user.
data:image/s3,"s3://crabby-images/91e41/91e41e8bff2903c35902160323fce2a36e1ba38d" alt="../_images/sim_done.png"
Accelerator#
The third tab allows the user to program the chip using the compiled DFP and easily perform inference on the connected MXA and get latency and FPS.