Don't want to see articles from a certain category? When logged in, go to your User Settings and adjust your feed in the Content Preferences section where you can block tags!
We do often include affiliate links to earn us some pennies. See more here.

Ray tracing seems to be all the rage at GDC this year, so AMD has announced Radeon-Rays, an open source ray tracing SDK. From what I understand, it's basically them making a big splash over a re-named and updated AMD FireRays with Vulkan support.

Here's what they said about it:

Radeon-Rays is a GPU intersection acceleration library with basic support for heterogeneous systems. AMD developed Radeon-Rays to help developers get the most out of AMD GPUs and CPU or APUs, as well as save them from maintaining hardware-dependent code. Radeon-Rays exposes a well-defined C++ API for scene construction and performing asynchronous ray intersection queries. The current implementation is based on OpenCL, which means Radeon-Rays supports execution on all platforms conforming to the OpenCL 1.2 standard. It is not limited to AMD hardware or a specific operating system. Radeon-Rays can be easily distributed and through its API helps assure compatibility and best performance across a wide range of hardware platforms.

YouTube Thumbnail
YouTube videos require cookies, you must accept their cookies to view. View cookie preferences.
Accept Cookies & Show   Direct Link

It's nice to see AMD continue to put their stuff out in the open, with it not being tied to their hardware and available for anyone to use.  You can find it on GitHub with some other info available in this post on the GPUOpen site.

They also have the "Baikal initiative", an open source (MIT license) GPU-based global illumination renderer that initially started as a sample application for showing off Radeon-Rays, which has since evolved into a fully functional rendering engine.

Thanks for the tip, mirv!

Article taken from GamingOnLinux.com.
18 Likes
About the author -
author picture
I am the owner of GamingOnLinux. After discovering Linux back in the days of Mandrake in 2003, I constantly came back to check on the progress of Linux until Ubuntu appeared on the scene and it helped me to really love it. You can reach me easily by emailing GamingOnLinux directly.
See more from me
The comments on this article are closed.
30 comments
Page: «3/3
  Go to:

etonbears Apr 6, 2018
Quoting: elmapulUWP isnt compatible with Vulkan nor any program with opengl above 1.0
that means that vulkan apps cant run on xbox, hololens and whatever else microsoft put on the market.

currently lose the xbox market would do more harm to the pockets of the developers than losing mac/linux.

The XBOX is locked hardware with a restricted set of APIs. You would get better performance on XBOX by using the lowest level APIs rather than UWP.

Windows 10 is a general purpose computer OS, not locked to hardware. Both the CPU and GPU can be accessed through non-Microsoft APIs, even from within UWP programs; Vulkan APIs and drivers are supplied by the hardware manufacturers, not Microsoft.

I would not expect game makers to switch to UPW from XBOX low-level APIs, as it would reduce performance. If they want their game to support UWP on Windows 10, they will probably make the minimum changes necessary to existing DirectX code.

If they want to support additional platforms, they might do so by writing a Vulkan implementation, which could also be made to run on Windows 10 UWP. Whether that is a good idea or not depends on the game.
elmapul Apr 15, 2018
"Windows 10 is a general purpose computer OS, not locked to hardware. Both the CPU and GPU can be accessed through non-Microsoft APIs, even from within UWP programs; Vulkan APIs and drivers are supplied by the hardware manufacturers, not Microsoft."

i think that UWP is a sub set of apis, sandboxed and with some libraries.

it help to ensure either compatibility (you will not try to acess any hardware feature that is x86 exclusive), security (sandboxed)
subset (it wont support vulkan because it dont allow direct gpu acess to sendo vk commands)
but with some libraries to save developers time/money convincing then to use it and to make some effects without too much cpu/gpu usage.

example, you can use nvidia hair works to make hair, instead of coding it your self, it will save you time/money, at the cost of this single feature only working on nvidia hardware.
and since they know their hardare better than anyone else, they can optimize this feature better than you could if you try to do it by your self.
maybe they even have an asic on their gpu on part of it is only acessible if you use their api, so you cant compete in performance with ther oficial api.

i think that is what ms is trying to do here, but i'm not sure, i didnt read the documentation.

also i dont think xbox has even drivers to run vulkan or will ever have.
etonbears Apr 15, 2018
Quoting: elmapul"Windows 10 is a general purpose computer OS, not locked to hardware. Both the CPU and GPU can be accessed through non-Microsoft APIs, even from within UWP programs; Vulkan APIs and drivers are supplied by the hardware manufacturers, not Microsoft."

i think that UWP is a sub set of apis, sandboxed and with some libraries.

it help to ensure either compatibility (you will not try to acess any hardware feature that is x86 exclusive), security (sandboxed)
subset (it wont support vulkan because it dont allow direct gpu acess to sendo vk commands)
but with some libraries to save developers time/money convincing then to use it and to make some effects without too much cpu/gpu usage.

example, you can use nvidia hair works to make hair, instead of coding it your self, it will save you time/money, at the cost of this single feature only working on nvidia hardware.
and since they know their hardare better than anyone else, they can optimize this feature better than you could if you try to do it by your self.
maybe they even have an asic on their gpu on part of it is only acessible if you use their api, so you cant compete in performance with ther oficial api.

i think that is what ms is trying to do here, but i'm not sure, i didnt read the documentation.

also i dont think xbox has even drivers to run vulkan or will ever have.

Yes, UWP is a subset - a very large subset - of the existing windows APIs. Most of the dropped APIs are to do with screen presentation in some way. The sandbox is limited in scope; while it does prevent a UWP application from invoking a device IOCTL directly, UWP has the "Device Access API" that a hardware manufacturer can use to provide a UWP application with access to their device.

If a GPU manufacturer wanted to provide a custom graphics API ( like Vulkan ) they would write a UWP device app ( which has special permissions ) and the graphics API would be implemented against this device access app as a static library to be bound into any client UWP app ( UWP apps can't bind libraries dynamically other than the windows libraries ).

What the performance would be like is anyone's guess, probably poor, since the entire idea of UWP is of questionable value to anyone but Microsoft; but it doesn't mean you can provide alternative graphics APIs if you really want to.

XBox, as I mentioned before, is a different case altogether.
tuubi Apr 16, 2018
View PC info
  • Supporter Plus
Quoting: etonbearsIf a GPU manufacturer wanted to provide a custom graphics API ( like Vulkan ) they would write a UWP device app ( which has special permissions ) and the graphics API would be implemented against this device access app as a static library to be bound into any client UWP app ( UWP apps can't bind libraries dynamically other than the windows libraries ).
There's no whitelisting or enforced driver signing by Microsoft? I'd be very surprised. UWP is all about control after all. They want to be Apple so hard it hurts.
etonbears Apr 18, 2018
Quoting: tuubi
Quoting: etonbearsIf a GPU manufacturer wanted to provide a custom graphics API ( like Vulkan ) they would write a UWP device app ( which has special permissions ) and the graphics API would be implemented against this device access app as a static library to be bound into any client UWP app ( UWP apps can't bind libraries dynamically other than the windows libraries ).
There's no whitelisting or enforced driver signing by Microsoft? I'd be very surprised. UWP is all about control after all. They want to be Apple so hard it hurts.
True, they do want control, but if a device manufacturer submits a UWP device app to allow direct hardware use they would risk regulatory scrutiny if they refuse to sign it. Usually they use commercial pressure with big companies.

Best not to use UWP at all. Neither the architecture nor the market seem compelling to me.
elmapul Apr 19, 2018
Quoting: etonbearsBest not to use UWP at all. Neither the architecture nor the market seem compelling to me.

we can avoid UWP all as we want, but how to convince developers to not use it?
etonbears Apr 20, 2018
Quoting: elmapul
Quoting: etonbearsBest not to use UWP at all. Neither the architecture nor the market seem compelling to me.

we can avoid UWP all as we want, but how to convince developers to not use it?

Actually, I meant that comment from a developer perspective. The UWP development model is inferior to the Win32/64 model for desktop and laptop computers, where Microsoft are still reasonably strong. The whole point of UWP is to provide an equivalent to the iOS development model for tablets and phones, but that is a market in which Microsoft is almost invisible.

I'm not sure that Microsoft have yet realised that they are no longer important enough to enforce market adoption in all segments. It is quite possible that UWP will go the same way as Silverlight and countless other "innovative" technologies that were introduced more for Microsoft's benefit than for users or developers.
Purple Library Guy Apr 21, 2018
Quoting: etonbears
Quoting: elmapul
Quoting: etonbearsBest not to use UWP at all. Neither the architecture nor the market seem compelling to me.

we can avoid UWP all as we want, but how to convince developers to not use it?

Actually, I meant that comment from a developer perspective. The UWP development model is inferior to the Win32/64 model for desktop and laptop computers, where Microsoft are still reasonably strong. The whole point of UWP is to provide an equivalent to the iOS development model for tablets and phones, but that is a market in which Microsoft is almost invisible.

I'm not sure that Microsoft have yet realised that they are no longer important enough to enforce market adoption in all segments. It is quite possible that UWP will go the same way as Silverlight and countless other "innovative" technologies that were introduced more for Microsoft's benefit than for users or developers.

I certainly hope so. From your lips to the tech gods' ears, old bean.
elmapul Apr 29, 2018
Quoting: etonbears
Quoting: elmapul
Quoting: etonbearsBest not to use UWP at all. Neither the architecture nor the market seem compelling to me.

we can avoid UWP all as we want, but how to convince developers to not use it?

Actually, I meant that comment from a developer perspective. The UWP development model is inferior to the Win32/64 model for desktop and laptop computers, where Microsoft are still reasonably strong. The whole point of UWP is to provide an equivalent to the iOS development model for tablets and phones, but that is a market in which Microsoft is almost invisible.

UWP also works on xbox
etonbears Apr 29, 2018
Quoting: elmapul
Quoting: etonbears
Quoting: elmapul
Quoting: etonbearsBest not to use UWP at all. Neither the architecture nor the market seem compelling to me.

we can avoid UWP all as we want, but how to convince developers to not use it?

Actually, I meant that comment from a developer perspective. The UWP development model is inferior to the Win32/64 model for desktop and laptop computers, where Microsoft are still reasonably strong. The whole point of UWP is to provide an equivalent to the iOS development model for tablets and phones, but that is a market in which Microsoft is almost invisible.

UWP also works on xbox

That's true. But XBox is a games console, and also has a better development model than UWP for developing games; I am not clear why one would want to develop anything much else for an XBox.

I understand the logic of UWP for Microsoft; they can market a single development environment and pretend it makes development everywhere easier. But I really don't think it does, any more that the Java slogan of "write once, run everywhere" was ever true. The range of devices for which UWP is proposed comprise quite different sets of capabilities; if a UWP app in the Microsoft store runs on all platforms, a developer would feel obliged to write and test additional code to handle them all, even if they make no sense.

I am not suggesting that UWP is of no value to any anyone, or that no developers will find it helpful. There are probably classes of utility applications that can find common ground on multiple Windows 10 platforms, and if you want to link together multiple Microsoft-only web and Windows 10 services, you can probably benefit from UWP.

However, if you are a platform neutral developer, UWP makes sharing code between platforms far more difficult, which may be to Microsoft's benefit, but is certainly not helpful to the developer.


Last edited by etonbears on 29 April 2018 at 8:35 pm UTC
While you're here, please consider supporting GamingOnLinux on:

Reward Tiers: Patreon. Plain Donations: PayPal.

This ensures all of our main content remains totally free for everyone! Patreon supporters can also remove all adverts and sponsors! Supporting us helps bring good, fresh content. Without your continued support, we simply could not continue!

You can find even more ways to support us on this dedicated page any time. If you already are, thank you!
The comments on this article are closed.
Buy Games
Buy games with our affiliate / partner links: