Discussion:
[osg-users] osg apps on gpu cluster
Trajce Nikolov NICK
2018-10-01 18:42:39 UTC
Permalink
Hi Community,

I am totally new to this topic and that is the reason I am pinging you this
time. Anyone with some experience or hints? I am after running (Linux) osg
app N times so each app to have dedicated GPU, something in this fashion.

I will investigate this too, but any word from you is highly appreciated.

Thanks a bunch as always!

Cheers,
Nick
--
trajce nikolov nick
Chris Hanson
2018-10-01 19:22:12 UTC
Permalink
I think Robert advised me on tweaking this probably 4 years ago for a
Windows system with 16 display outputs all running from one EXE, ensuring
there were the proper number of contexts and threads all playing nicely so
as not to jam up the bus.

What's your hardware profile look like? Which Linux OS? What CPUs and how
many, what display cards, and how many, how many outputs, etc. The exact
best mechanism may not be invariant across all situations.

On Mon, Oct 1, 2018 at 7:43 PM Trajce Nikolov NICK <
Post by Trajce Nikolov NICK
Hi Community,
I am totally new to this topic and that is the reason I am pinging you
this time. Anyone with some experience or hints? I am after running (Linux)
osg app N times so each app to have dedicated GPU, something in this
fashion.
I will investigate this too, but any word from you is highly appreciated.
Thanks a bunch as always!
Cheers,
Nick
--
trajce nikolov nick
_______________________________________________
osg-users mailing list
http://lists.openscenegraph.org/listinfo.cgi/osg-users-openscenegraph.org
--
Chris 'Xenon' Hanson, omo sanza lettere. ***@AlphaPixel.com
http://www.alphapixel.com/
Training • Consulting • Contracting
3D • Scene Graphs (Open Scene Graph/OSG) • OpenGL 2 • OpenGL 3 • OpenGL 4 •
GLSL • OpenGL ES 1 • OpenGL ES 2 • OpenCL
Legal/IP • Forensics • Imaging • UAVs • GIS • GPS •
osgEarth • Terrain • Telemetry • Cryptography • LIDAR • Embedded • Mobile •
iPhone/iPad/iOS • Android
@alphapixel <https://twitter.com/alphapixel> facebook.com/alphapixel (775)
623-PIXL [7495]
Per Nordqvist
2018-10-02 05:12:12 UTC
Permalink
Hello Chris, thanks for chipping in.

I and Nick are working to utilize as much of the GPUs as possible, either
on single machine or cluster.
So hardware is not yet decided, but let's assume ubuntu 16+, multiple
modern Nvidia gaming cards, but still single screen.

Cheers
Per
Post by Chris Hanson
I think Robert advised me on tweaking this probably 4 years ago for a
Windows system with 16 display outputs all running from one EXE, ensuring
there were the proper number of contexts and threads all playing nicely so
as not to jam up the bus.
What's your hardware profile look like? Which Linux OS? What CPUs and how
many, what display cards, and how many, how many outputs, etc. The exact
best mechanism may not be invariant across all situations.
On Mon, Oct 1, 2018 at 7:43 PM Trajce Nikolov NICK <
Post by Trajce Nikolov NICK
Hi Community,
I am totally new to this topic and that is the reason I am pinging you
this time. Anyone with some experience or hints? I am after running (Linux)
osg app N times so each app to have dedicated GPU, something in this
fashion.
I will investigate this too, but any word from you is highly appreciated.
Thanks a bunch as always!
Cheers,
Nick
--
trajce nikolov nick
_______________________________________________
osg-users mailing list
http://lists.openscenegraph.org/listinfo.cgi/osg-users-openscenegraph.org
--
http://www.alphapixel.com/
Training • Consulting • Contracting
3D • Scene Graphs (Open Scene Graph/OSG) • OpenGL 2 • OpenGL 3 • OpenGL 4
• GLSL • OpenGL ES 1 • OpenGL ES 2 • OpenCL
Legal/IP • Forensics • Imaging • UAVs • GIS • GPS •
osgEarth • Terrain • Telemetry • Cryptography • LIDAR • Embedded • Mobile •
iPhone/iPad/iOS • Android
@alphapixel <https://twitter.com/alphapixel> facebook.com/alphapixel (775)
623-PIXL [7495]
_______________________________________________
osg-users mailing list
http://lists.openscenegraph.org/listinfo.cgi/osg-users-openscenegraph.org
Robert Osfield
2018-10-02 07:53:45 UTC
Permalink
Hi Nick & Per,
I and Nick are working to utilize as much of the GPUs as possible, either on single machine or cluster.
So hardware is not yet decided, but let's assume ubuntu 16+, multiple modern Nvidia gaming cards, but still single screen.
osgViewer has been written from the ground up to support multiple GPUs
on a single machine with a single application.

The basic concept is the View's master Camera controls the overall
view, and a series of slave Camera's assign to the View handle the
rendering for each graphics card/display. The osgwindow example is
the simplistic example of this in action. A search for addSlave in
the OSG codebase will reveal lots of other examples of it in action -
it can be used for a wide range of tasks.

The OSG out of the box will default to DrawThreadPerContext
ThreadingModel on modern machines, you might find
CullDrawThreadPerContext more appropriate, you could even try
CullThreadPerCameraDrawThreadPerContext if you have plenty of cores to
throw at it.

In 3.6.x you also have support for explicitly controlling Affinity so
you can lock various threads to particular cores.

Another variable you could play with is that you can set up the
OS/desktop so that one single graphics context can span multiple
cards.

Modern graphics cards are beast so you might well be able to handle
quite a few displays just from one card.

Robert.
Per Nordqvist
2018-10-03 14:26:45 UTC
Permalink
Thank you Robert, these are great leads, will check them out.

There is one more variant I wonder about:
If I run two osg apps on one screen, with multiple graphics cards,
can I then share the loads between the GPUs?
Something like "GPU Affinity"?

Kind regards
Per
Post by Robert Osfield
Hi Nick & Per,
Post by Per Nordqvist
I and Nick are working to utilize as much of the GPUs as possible,
either on single machine or cluster.
Post by Per Nordqvist
So hardware is not yet decided, but let's assume ubuntu 16+, multiple
modern Nvidia gaming cards, but still single screen.
osgViewer has been written from the ground up to support multiple GPUs
on a single machine with a single application.
The basic concept is the View's master Camera controls the overall
view, and a series of slave Camera's assign to the View handle the
rendering for each graphics card/display. The osgwindow example is
the simplistic example of this in action. A search for addSlave in
the OSG codebase will reveal lots of other examples of it in action -
it can be used for a wide range of tasks.
The OSG out of the box will default to DrawThreadPerContext
ThreadingModel on modern machines, you might find
CullDrawThreadPerContext more appropriate, you could even try
CullThreadPerCameraDrawThreadPerContext if you have plenty of cores to
throw at it.
In 3.6.x you also have support for explicitly controlling Affinity so
you can lock various threads to particular cores.
Another variable you could play with is that you can set up the
OS/desktop so that one single graphics context can span multiple
cards.
Modern graphics cards are beast so you might well be able to handle
quite a few displays just from one card.
Robert.
_______________________________________________
osg-users mailing list
http://lists.openscenegraph.org/listinfo.cgi/osg-users-openscenegraph.org
Robert Osfield
2018-10-03 14:56:49 UTC
Permalink
Hi Per,
Post by Per Nordqvist
If I run two osg apps on one screen, with multiple graphics cards,
can I then share the loads between the GPUs?
Something like "GPU Affinity"?
There are various implementation of doing this, with varying levels of
hardware/driver support. This is historical known as SLI.

Personally, I double avoid the complexity as I doubt for vis-sim use
case it's going to help too much.

Robert.
David Heitbrink
2018-10-04 20:42:03 UTC
Permalink
GPU affinity is really only available with Quadro cards. AMD has there own system that is a little more complicated, and has a few more features....but I am not really experienced with those, and I believe they are only usable on the FirePro/Radeon Pro cards.

We have found setting the GPU affinity is an absolute must for multi GPU systems on windows.

Basically from what I understand, windows will by default dispatch the OpenGL commands to what it thinks is the fastest GPU in the system, then copies the result to the other GPU(s). Linux by default dispatches the commands to the GPU attached to the display the window is on......so setting the GPU affinity is most likely only worth while if you are using windows.

FYI I think this was the talk I sat through on the subject:
https://docplayer.net/29825650-Programming-multi-gpus-for-scalable-rendering-shalini-venkataraman-senior-applied-engineer-nvidia.html

I do have an modification of OSG I could share that sets the GPU affinity mask.....but its ugly.

You might also have to think about synchronization if you are driving multiple projectors that are blended to form a single image...and if you have a decent amount of motion, you can get noticeable tearing in the blend regions.

------------------
Read this topic online here:
http://forum.openscenegraph.org/viewtopic.php?p=75038#75038
Trajce Nikolov NICK
2018-10-05 06:45:00 UTC
Permalink
Thanks David,
Post by David Heitbrink
You might also have to think about synchronization if you are driving
multiple projectors that are blended to form a single image...and if you
have a decent amount of motion, you can get noticeable tearing in the blend
regions.

The output is not that much important in our case and there are no blending
or such (projectors etc). Anyway, this is the info I believe we need to
start investigate ...

Thanks again !

Cheers,
Nick

p.s.
Post by David Heitbrink
I do have an modification of OSG I could share that sets the GPU affinity
mask.....but its ugly.
Anything will help at this point :-)
Post by David Heitbrink
GPU affinity is really only available with Quadro cards. AMD has there own
system that is a little more complicated, and has a few more
features....but I am not really experienced with those, and I believe they
are only usable on the FirePro/Radeon Pro cards.
We have found setting the GPU affinity is an absolute must for multi GPU
systems on windows.
Basically from what I understand, windows will by default dispatch the
OpenGL commands to what it thinks is the fastest GPU in the system, then
copies the result to the other GPU(s). Linux by default dispatches the
commands to the GPU attached to the display the window is on......so
setting the GPU affinity is most likely only worth while if you are using
windows.
https://docplayer.net/29825650-Programming-multi-gpus-for-scalable-rendering-shalini-venkataraman-senior-applied-engineer-nvidia.html
I do have an modification of OSG I could share that sets the GPU affinity
mask.....but its ugly.
You might also have to think about synchronization if you are driving
multiple projectors that are blended to form a single image...and if you
have a decent amount of motion, you can get noticeable tearing in the blend
regions.
------------------
http://forum.openscenegraph.org/viewtopic.php?p=75038#75038
_______________________________________________
osg-users mailing list
http://lists.openscenegraph.org/listinfo.cgi/osg-users-openscenegraph.org
--
trajce nikolov nick
Loading...