cc_staff
295
edits
(→Visualization on new Compute Canada systems: Started adding material to Cedar/Graham visualization section.) Tags: Mobile edit Mobile web edit |
(→Visualization on new Compute Canada systems: Finished adding material to Cedar/Graham visualization section.) Tags: Mobile edit Mobile web edit |
||
Line 27: | Line 27: | ||
= Visualization on new Compute Canada systems = <!--T:6--> | = Visualization on new Compute Canada systems = <!--T:6--> | ||
== Client-server visualization on Cedar and Graham == | |||
Currently, we are working to bring GPU rendering to [[Cedar]] (SFU) and [[Graham]] (Waterloo). In the meantime, you can do client-server ParaView rendering on cluster CPUs. To get started, install ParaView 5.3.x (where "x" could be anything) on your laptop as you need the same version as on the cluster. Log in to Cedar or Graham and start a serial non-GPU interactive job: | Currently, we are working to bring GPU rendering to [[Cedar]] (SFU) and [[Graham]] (Waterloo). In the meantime, you can do client-server ParaView rendering on cluster CPUs. To get started, install ParaView 5.3.x (where "x" could be anything) on your laptop as you need the same version as on the cluster. Log in to Cedar or Graham and start a serial non-GPU interactive job: | ||
Line 46: | Line 48: | ||
ssh cedar.computecanada.ca -L 11111:cdr774:11111 | ssh cedar.computecanada.ca -L 11111:cdr774:11111 | ||
Start ParaView on your laptop, go to File -> Connect (or click on the green Connect button in the toolbar) and then click Add Server. You'll need to point ParaView to your local port 11111, so you can do something like name = cedar, server type = Client/Server, host = localhost, port = 11111, then click Configure, then select Manual and click Save. Once the remote is added to the configuration, simply select the server from the list and click Connect. The first terminal window that was saying "Accepting connection ..." will now say "Client connected" and possibly "SWR detected AVX2" (or it may confirm AVX2 support when you start rendering). | |||
Then open a file in ParaView (it'll point you to the remote filesystem) and visualize it as usual. An important setting in ParaView's preferences is Render View -> Remote/Parallel Rendering Options -> Remote Render Threshold. If you set it to default (20MB) or similar, small rendering will be done on your laptop's GPU, the rotation with a mouse will be fast, but anything modestly intensive (under 20MB) will be shipped to your laptop and -- depending on your connection -- visualization might be slow. If you set it to 0MB, all rendering will be remote including rotation, so you'll be really using the cluster's CPU for everything, good for large data processing but not so good for interactivity. You'll need to play with this setting to see what works best for you. | |||
If you want to do parallel rendering on multiple CPUs, start a parallel job (don't forget to specify the correct maximum walltime limit): | |||
salloc --time=0:30:0 --ntasks=8 --account=xwp-462-aa | |||
and then start ParaView server with "srun": | |||
module load paraview-offscreen/5.3.0 | |||
srun pvserver --mesa | |||
The flag "--mesa-swr-avx2" does not seem to have any effect when in parallel so we replaced it with the more generic "--mesa" to (hopefully) enable automatic detection of the best software rendering option. | |||
To check that you are doing parallel rendering, you can pass your visualization through the Process Id Scalars filter and then colour it by "process id". | |||
== Client-server visualization in a cloud VM == <!--T:20--> | == Client-server visualization in a cloud VM == <!--T:20--> |