- Infos im HLRS Wiki sind nicht rechtsverbindlich und ohne Gewähr -
- Information contained in the HLRS Wiki is not legally binding and HLRS is not responsible for any damages that might result from its use -
CRAY XC40 Graphic Environment
To use the graphic hardware for remote rendering there are currently two ways tested. The first is via TurboVNC the second one is directly via VirtualGL.
Visualisation Software
To use the installed visualisation software please follow the steps described below.
Covise
ParaView
Building Paraview
To build ParaView on hww machines first of all download the source package of the version to be build from http://www.paraview.org/download and extract it to your home directory.
The second step would be to create an empty build directory outside the source directory since an out of source build is the recomended way to compile ParaView.
To build ParaView certain recent dependencies have to be satisfied. For an OpenGL build these are:
- Autotools
- Cmake
- Qt 4
If you plan to build a ParaView server suitable for the Hornet compute nodes also recent versions of
- LLVM with CLang
- libclc and
- Mesa
have to be available.
All of these dependencies are installed on Hornet. Currently the following versions are available:
- m4-1.4.17
- autoconf-2.69
- automake-1.14
- libtool-2.4.2
- pkg-config-0.28
- llvm-3.4.2
- libclc-0.1.5
- Mesa-10.2.2
- Qt-4.8.6
- Cmake-3.0.2
Environment setup
To modify your environment in a way that the dependencies of the OpenGL-Client are usable, source the following bash-script.
setenv-gl.sh
#!/bin/bash # # Setup modules ####################################### module load tools/autotools module load tools/cmake module unload PrgEnv-cray module load PrgEnv-gnu module swap gcc/4.9.1 gcc/4.8.1 # # QT ################################################# export LD_LIBRARY_PATH=/sw/hornet/hlrs/tools/paraview/4.1.0/aux/qt/lib:$LD_LIBRARY_PATH export PATH=/sw/hornet/hlrs/tools/paraview/4.1.0/aux/qt/bin:$PATH #
To modify your environment in a way that the dependencies of the Mesa-Server are usable, source the following bash-script.
setenv-mesa.sh
#!/bin/bash # # Setup modules ####################################### module load tools/autotools module load tools/cmake module unload PrgEnv-cray module load PrgEnv-gnu module swap gcc/4.9.1 gcc/4.8.1 # # LLVM ############################################### export LD_LIBRARY_PATH=/sw/hornet/hlrs/tools/paraview/4.1.0/aux/llvm/lib:$LD_LIBRARY_PATH export PATH=/sw/hornet/hlrs/tools/paraview/4.1.0/aux/llvm/bin:$PATH # # MESA ############################################### export LD_LIBRARY_PATH=/sw/hornet/hlrs/tools/paraview/4.1.0/aux/mesa/lib:$LD_LIBRARY_PATH # # QT ################################################# export LD_LIBRARY_PATH=/sw/hornet/hlrs/tools/paraview/4.1.0/aux/qt/lib:$LD_LIBRARY_PATH export PATH=/sw/hornet/hlrs/tools/paraview/4.1.0/aux/qt/bin:$PATH #
This means, copying one of the statement-sets above to a file e.g. named setenv-pv.sh and executing
source setenv-pv.sh
will make your environment ready to build ParaView.
Source code patches
If you want to use your installation to build custom plugins, you have to patch one of VTK's source to enable the dynamic load of shared libraries during runtime. The file to patch is located in the VTK part of the ParaView source tree.
ParaView-vx.x.x/VTK/Utilities/KWSys/vtksys/DynamicLoader.cxx
The patch is basically disabling the #ifdef section for systems without shared library support. In Paraview version 4.1.0 this can be done by commenting out lines 380 - 422 as stated below.
374 return retval; 375 } 376 377 } // namespace KWSYS_NAMESPACE 378 #endif 379 380 // // --------------------------------------------------------------- 381 // // 5. Implementation for systems without dynamic libs 382 // // __gnu_blrts__ is IBM BlueGene/L 383 // // __LIBCATAMOUNT__ is defined on Catamount on Cray compute nodes 384 // #if defined(__gnu_blrts__) || defined(__LIBCATAMOUNT__) || defined(__CRAYXT_COMPUTE_LINUX_TARGET) 385 // #include <string.h> // for strerror() 386 // #define DYNAMICLOADER_DEFINED 1 387 388 // namespace KWSYS_NAMESPACE 389 // { 390 391 // //---------------------------------------------------------------------------- 392 // DynamicLoader::LibraryHandle DynamicLoader::OpenLibrary(const char* libname ) 393 // { 394 // return 0; 395 // } 396 397 // //---------------------------------------------------------------------------- 398 // int DynamicLoader::CloseLibrary(DynamicLoader::LibraryHandle lib) 399 // { 400 // if (!lib) 401 // { 402 // return 0; 403 // } 404 405 // return 1; 406 // } 407 408 // //---------------------------------------------------------------------------- 409 // DynamicLoader::SymbolPointer DynamicLoader::GetSymbolAddress( 410 // DynamicLoader::LibraryHandle lib, const char* sym) 411 // { 412 // return 0; 413 // } 414 415 // //---------------------------------------------------------------------------- 416 // const char* DynamicLoader::LastError() 417 // { 418 // return "General error"; 419 // } 420 421 // } // namespace KWSYS_NAMESPACE 422 // #endif 423 424 #ifdef __MINT__ 425 #define DYNAMICLOADER_DEFINED 1 426 #define _GNU_SOURCE /* for program_invocation_name */
Configuration
To configure and afterwards build ParaView enter your empty build directory and execute ccmake
cd <your_build_directory> ccmake -Wno-dev <paraview_source_directory>
Press c for intial configuration. After cmake has done the initial configuration change the build parameters according to your needs. For the installation
BUILD_DOCUMENTATION : OFF BUILD_EXAMPLES : OFF BUILD_SHARED_LIBS : ON BUILD_TESTING : OFF CMAKE_BUILD_TYPE : Release PARAVIEW_ENABLE_PYTHON : ON PARAVIEW_INSTALL_DEVELOPMENT_F : ON PARAVIEW_USE_MPI : ON
Depending whether the OpenGL-Client or the Mesa-Server should be build the prefix is:
CMAKE_INSTALL_PREFIX : /opt/hlrs/tools/paraview/4.1.0/OpenGL
or
CMAKE_INSTALL_PREFIX : /opt/hlrs/tools/paraview/4.1.0/Mesa
Press c for configuration. After the configuration has finished you should encounter the following error:
CMake Error at VTK/CMake/vtkTestingMPISupport.cmake:31 (message): MPIEXEC was empty. Call Stack (most recent call first): VTK/Parallel/MPI/CMakeLists.txt:4 (include)
Press e to exit the error display, press t to toogle advanced options and change the following build parameters.
MPIEXEC : aprun MPIEXEC_MAX_NUMPROCS : 24 MPI_Fortran_COMPILER : /opt/cray/craype/2.2.0/bin/ftn Module_vtkFiltersParallelGeome : ON Module_vtkFiltersSelection : ON Module_vtkIOMPIParallel : ON Module_vtkImagingMath : ON Module_vtkImagingStatistics : ON Module_vtkImagingStencil : ON VTK_Group_Imaging : ON VTK_Group_MPI : ON CMAKE_SHARED_LINKER_FLAGS : -z muldefs
After changing these parameters you have to press c two times. After two configuration runs you will get a new option [g] to generate.
Press g to generate the makefiles an exit cmake.
If you want to build the Mesa-Server another non interactive configuration has to be done by executing the following command.
To build the OpenGL-Client you have to skip this step.
cmake \ <paraview_source_directory> \ -DPARAVIEW_BUILD_QT_GUI=OFF \ -DVTK_USE_X=OFF \ -DOPENGL_INCLUDE_DIR=/sw/hornet/hlrs/tools/paraview/4.1.0/aux/mesa/include \ -DOPENGL_gl_LIBRARY=/sw/hornet/hlrs/tools/paraview/4.1.0/aux/mesa/lib/libOSMesa.so \ -DOPENGL_glu_LIBRARY=/usr/lib/libGLU.so \ -DVTK_OPENGL_HAS_OSMESA=ON \ -DOSMESA_INCLUDE_DIR=/sw/hornet/hlrs/tools/paraview/4.1.0/aux/mesa/include \ -DOSMESA_LIBRARY=/sw/hornet/hlrs/tools/paraview/4.1.0/aux/mesa/lib/libOSMesa.so
Build
To build, login to a mom node e.g.
ssh mom12
Then compile and install with
make make install
Using Paraview
Serial client on pre-/postprocessing nodes
Allocate a pre-/postprocesisng node with the vis_via_vnc.sh script provided by the tools/VirtualGL module. On an eslogin node execute:
module laod tools/VirtualGL vis_via_vnc.sh [walltime] [geometry]
Connect to the VNC-session by one of the methodes issued by the script. Within the VNC-session open a terminal and execute:
module laod tools/VirtualGL module load tools/paraview/4.1.0-Pre vglrun paraview
Launch parallel server on compute nodes
In order to launch a parallel pvserver on the Hornet compute nodes, request the number of compute nodes you need
qsub -I -lnodes=XX:ppn=YY -lwalltime=hh:mm:ss -N PVServer
On the mom node do:
module load tools/paraview/4.1.0-parallel-Mesa aprun -n XX*YY -N YY pvserver
Once the server is running it should respond with something like:
Waiting for client... Connection URL: cs://nidxxxxx:11111 Accepting connection(s): nidxxxxx:11111