Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Platforms: VR/XR issues on some devices (VisionPro, LookingGlass etc.) #17

Open
Aupuma opened this issue Oct 5, 2023 · 26 comments
Open
Labels
bug Something isn't working

Comments

@Aupuma
Copy link

Aupuma commented Oct 5, 2023

Hi, congrats for the effort on the project!
I've been testing it with a VR headset, and I was able to see splats using OpenXR in Multi-Pass mode (Single pass instanced does not work). However, I tried to switch to URP to get some performance benefits but the rendering is reversed, the Left image renders on the right eye and viceversa. Any ideas on how to fix it?

@aras-p
Copy link
Owner

aras-p commented Oct 5, 2023

Since I know nothing about either URP nor VR, and I don't have any VR devices around, then no idea. If someone figures it out, let me know!

@andybak
Copy link

andybak commented Oct 5, 2023

I might take a look at this at some stage as I am particularly interested in Gaussian Splats for VR (seems like the perfect use-case)

In the meantime there is also: /~https://github.com/clarte53/GaussianSplattingVRViewerUnity

@unitycoder
Copy link

Those debug modes seem to render betterr in URP+VR(multipass), compared to splats.

so i'm guessing its something to do with RenderGaussianSplats.shader,
float4 centerClipPos = view.pos; // what is view.pos about?

@gaetanthiesson
Copy link

gaetanthiesson commented Oct 6, 2023

Seems like there is an issue with the camera projection matrix on URP with stereo rendering not exactly sure but seems like the matrix return at this line is wrong or doesn't take into account both eyes.
image

Managed to fix it but using Unity built-in transformations matrices but the result is not exactly the same, looks like the splat scale is slightly smaller but at least it fixed the rendering issue. Here is how SplatUtilities.compute looks like for me now.

Added include for Unity built-in stuff:
#include "UnityCG.cginc"

And changed those 2 lines:
line 81 float4 centerClipPos = mul(UNITY_MATRIX_VP, float4(centerWorldPos, 1));
and 95 float3 cov2d = CalcCovariance2D(splat.pos, cov3d0, cov3d1, _MatrixMV, UNITY_MATRIX_P, _VecScreenParams);

@changruizhu96
Copy link

Hi, congrats for the effort on the project! I've been testing it with a VR headset, and I was able to see splats using OpenXR in Multi-Pass mode (Single pass instanced does not work). However, I tried to switch to URP to get some performance benefits but the rendering is reversed, the Left image renders on the right eye and viceversa. Any ideas on how to fix it?

Hi, could you please share some hints about how to test it with openXR?

@aras-p aras-p added the bug Something isn't working label Oct 18, 2023
@aras-p aras-p changed the title VR rendering reversed in URP Platforms: VR rendering reversed in URP Oct 18, 2023
@Mr-Anderson
Copy link

I have been chasing what I think could be a related issue with #52. In my case, I am trying to get rendering working on a LookingGlass light field display. The issue I believe I found is that if the render target is set to something custom for a camera the render target will be changed to BuiltinRenderTextureType.CameraTarget by GaussianSplatRenderer ignoring the custom target.

Would someone who has this issue be willing to test after commenting out line 190 in GaussiannSplatRendere.cs. This will cause SortAndRenderSplats to render directly to the original render target. This hack skips the compositing step of rendering though so the image will be washed out.
/~https://github.com/aras-p/UnityGaussianSplatting/blob/fded9c09d041e862502acc57d1bbc4c084ae4e6f/package/Runtime/GaussianSplatRenderer.cs#L190C31-L190C31

@vanilla-plus
Copy link

vanilla-plus commented Oct 24, 2023

It's a real long shot but could this theoretically work on stand-alone VR platforms like Quest? It works amazing in the Editor, but several parts of the Compute Shaders fall over when you change the platform to Android.

I wonder if they're minor changes? I had a look at the source but it's black magic to me! It would be life-changing to have splats in stand-alone VR.

@ptc-lexvandersluijs
Copy link

For those looking for a VR implementation with the Built-In Render Pipeline (BIRP), I have just put the code for my project online here: /~https://github.com/ptc-lexvandersluijs/Unity3DGS_VR . This is made with multi-pass rendering, Unity 2023.1.14f and tested with OpenXR / HTC Vive.

@bmegli
Copy link

bmegli commented Mar 19, 2024

The hack to make URP VR left eye left, right eye right mentioned in:

With current 08a270a codebase is more like this:

  • around line 197
  • around line 233
  • and include at the beginning
diff --git a/package/Shaders/SplatUtilities.compute b/package/Shaders/SplatUtilities.compute
index a23a282..718d63d 100644
--- a/package/Shaders/SplatUtilities.compute
+++ b/package/Shaders/SplatUtilities.compute
@@ -30,6 +30,7 @@

 #include "DeviceRadixSort.hlsl"
 #include "GaussianSplatting.hlsl"
+#include "UnityCG.cginc"

 float4x4 _MatrixObjectToWorld;
 float4x4 _MatrixWorldToObject;
@@ -193,7 +194,8 @@ void CSCalcViewData (uint3 id : SV_DispatchThreadID)
     SplatViewData view = (SplatViewData)0;

     float3 centerWorldPos = mul(_MatrixObjectToWorld, float4(splat.pos,1)).xyz;
-    float4 centerClipPos = mul(_MatrixVP, float4(centerWorldPos, 1));
+    //float4 centerClipPos = mul(_MatrixVP, float4(centerWorldPos, 1));
+    float4 centerClipPos = mul(UNITY_MATRIX_VP, float4(centerWorldPos, 1));
     half opacityScale = _SplatOpacityScale;
     float splatScale = _SplatScale;

@@ -229,7 +231,8 @@ void CSCalcViewData (uint3 id : SV_DispatchThreadID)
         float splatScale2 = splatScale * splatScale;
         cov3d0 *= splatScale2;
         cov3d1 *= splatScale2;
-        float3 cov2d = CalcCovariance2D(splat.pos, cov3d0, cov3d1, _MatrixMV, _MatrixP, _VecScreenParams);
+        float3 cov2d = CalcCovariance2D(splat.pos, cov3d0, cov3d1, _MatrixMV, UNITY_MATRIX_P, _VecScreenParams);
+        //float3 cov2d = CalcCovariance2D(splat.pos, cov3d0, cov3d1, _MatrixMV, _MatrixP, _VecScreenParams);

         DecomposeCovariance(cov2d, view.axis1, view.axis2);

Another thing that seems necessary is setting Unity editor game view resolution to match VR single eye resolution.


Reversing eyes is new funny way to get headache.

@aras-p aras-p changed the title Platforms: VR rendering reversed in URP Platforms: VR/XR issues (reversed rendering in URP etc.) May 20, 2024
@aras-p aras-p changed the title Platforms: VR/XR issues (reversed rendering in URP etc.) Platforms: VR/XR issues (Quest, OpenXR, VisionPro, LookingGlass etc.) Jun 2, 2024
@AndreCorreaSantos
Copy link

For those looking for a VR implementation with the Built-In Render Pipeline (BIRP), I have just put the code for my project online here: /~https://github.com/ptc-lexvandersluijs/Unity3DGS_VR . This is made with multi-pass rendering, Unity 2023.1.14f and tested with OpenXR / HTC Vive.

Hello, sorry to bother, but I was trying to get the current repo working with quest 3 and for some reason the rendered models seem to follow the headset around, instead of remaining fixed in the desired positions. This seems to be an issue with how the XR package sets the axis of the projection or the view matrices ( I'm not sure), but I was wondering if you ran into any issues when porting the project to work with HTC vive, and I couldn't quite figure out what you changed from the original code. Could you please tell me exactly what you changed to make it work?

@ptc-lexvandersluijs
Copy link

ptc-lexvandersluijs commented Jul 9, 2024

Hello, sorry to bother, but I was trying to get the current repo working with quest 3 and for some reason the rendered models seem to follow the headset around, instead of remaining fixed in the desired positions. This seems to be an issue with how the XR package sets the axis of the projection or the view matrices ( I'm not sure), but I was wondering if you ran into any issues when porting the project to work with HTC vive, and I couldn't quite figure out what you changed from the original code. Could you please tell me exactly what you changed to make it work?

If the models follow you around, the first thing that comes to mind is that the 6DOF tracking of the headset isn't working at all / isn't coming through to the rendering software. It has been a while since I last worked on anything VR-related, so I'm afraid I can't give very specific advice. There is an elaborate controller framework in Unity that deals with mapping all of the various input device-types and -manufacturers to specific control operations, so that's something you could look into.

Although the very first thing that I would do in your situation is to try to find a 'known good' Unity example that works with your hardware, and -if that works- then perhaps try to find the differences between both implementations.

@AndreCorreaSantos
Copy link

Hello, sorry to bother, but I was trying to get the current repo working with quest 3 and for some reason the rendered models seem to follow the headset around, instead of remaining fixed in the desired positions. This seems to be an issue with how the XR package sets the axis of the projection or the view matrices ( I'm not sure), but I was wondering if you ran into any issues when porting the project to work with HTC vive, and I couldn't quite figure out what you changed from the original code. Could you please tell me exactly what you changed to make it work?

If the models follow you around, the first thing that comes to mind is that the 6DOF tracking of the headset isn't working at all / isn't coming through to the rendering software. It has been a while since I last worked on anything VR-related, so I'm afraid I can't give very specific advice. There is an elaborate controller framework in Unity that deals with mapping all of the various input device-types and -manufacturers to specific control operations, so that's something you could look into.

Although the very first thing that I would do in your situation is to try to find a 'known good' Unity example that works with your hardware, and -if that works- then perhaps try to find the differences between both implementations.

Your implementation works on my Quest, but I can't seem to find anything different from the base version of the repository. Do you remember which Unity settings you changed to make it work?

When I try to set it up with the base version of the repository, I get a very weird behavior where the model follows the head movement (it doesn't stay fixed in place in the scene). This seems to be caused by incorrect matrices being sent to the shader. I tried to fix this error by getting the view and projection matrices for each eye in the multi-pass and setting these directly to the shader, but nothing changed.

Thank you for your previous response. Having it rendered on my headset is already very nice.

@alkastrinogiannis
Copy link

Thanks for this awesome package, for us researchers its a great step forward into the psychological research!

This might be a very specific question for the VR-related people but I will try my luck:

I am using the Varjo Aero (Varjo Base Version 4.3.0.14) with Unity (Version 2022.3.12f1) to implement some examples. However, I’ve encountered an issue where the scene only renders correctly in multi-pass mode. In this mode though, I see unwanted "reflections" of my splats on the left and right edges of the display (see Picture 1). I not using any of the URP or HDRP render modes, I run the simple GaussianExample Scene.

I suspect this may be due to Varjo's focus rendering in multi-pass mode, as explained in the documentation:

“VarjoStereoRenderingMode.Multipass — The scene is rendered in four separate passes: one for each view (left context, right context, left focus, right focus).”

To work around this, I attempted using other rendering modes, ideally the stereo mode where focus views aren't rendered. Unfortunately, this approach leads to errors (see Picture 2), and I haven’t been able to run the scene in two-pass or stereo rendering modes.

Has anyone encountered similar issues with non-multi-pass modes or know why this might be happening?

Thank you very much in advance for any advice!

stereo_erros multi_pass

@ninjamode
Copy link
Contributor

ninjamode commented Oct 31, 2024

I have worked on VR support for Gaussian Splatting for a recent publication. Feel free to use the code from here: /~https://github.com/ninjamode/Unity-VR-Gaussian-Splatting

Tested to work on Vive / Varjo / Quest headsets. Change a bunch of things for better VR support, including not strictly needed things like sorting only once for the center point between both eyes. It's a little messy, I probably also broke some stuff while working on it. There is also a .apk file to download and try on Quest headsets.

@aras-p I could create a merge request if you are still interested in this repository to bring at least the basic functionality over to make vive and quest work?

@aras-p
Copy link
Owner

aras-p commented Nov 4, 2024

I could create a merge request if you are still interested in this repository to bring at least the basic functionality over to make vive and quest work?

@ninjamode yes that would be most excellent!

@ninjamode ninjamode mentioned this issue Nov 27, 2024
@ninjamode
Copy link
Contributor

I have opened a pull request adding VR support in case anyone wants to try it. See #146

@aras-p aras-p changed the title Platforms: VR/XR issues (Quest, OpenXR, VisionPro, LookingGlass etc.) Platforms: VR/XR issues on some devices (VisionPro, LookingGlass etc.) Nov 28, 2024
@aras-p
Copy link
Owner

aras-p commented Nov 28, 2024

Just merged @ninjamode's PR #146 which reportedly makes it work on Quest 3, Quest Pro, HTC Vive, Varjo Aero. Some other VR/XR/MR issues might still remain; I have not tested anything VR related whatsoever.

@SaadMirzaBaig
Copy link

Like in the example from @ninjamode I don't see the option to optimize it for Quest. Is it something not added in the latest version?
image
image

@ninjamode
Copy link
Contributor

Optimize in this version doesn't really optimize anything, it's a flag to read Gaussian positions inline in the splat shader. I don't remember what exactly caused positioning problems on the Quest, however it is not needed in this repository. It might have been some older Unity or Quest version or any of the other changes I introduced that made this hack necessary.

Relevant lines are /~https://github.com/ninjamode/Unity-VR-Gaussian-Splatting/blob/599aa75ab713b797b7531db96f9f15c0bff298c6/package/Shaders/RenderGaussianSplats.shader#L47-L50

Similarly, the ffx sort backport has not been brought over, as the newer device radix version now supports all the devices I cared about.

@SaadMirzaBaig
Copy link

I have been recieving these errors as soon as I imported Meta All in one SDK in the project.
SplatUtilities.compute: Kernel at index (1) requires features which are unavailable on the current platform - 'wavebasic' 'waveballot'. Make sure '#pragma require' is used correctly as unnecessary arguments can restrict platform reach.
Also

AssertionException: Assertion failure. Value was False
Expected: True
package/Runtime/GpuSorting.cs:144)

@aras-p
Copy link
Owner

aras-p commented Dec 12, 2024

@SaadMirzaBaig I have no idea what "Meta All" does. Maybe it switches the editor to some platform and/or graphics emulation that pretends it does not support modern compute shaders? (e.g. WebGL, or Android with OpenGL ES instead of Vulkan)

@SaadMirzaBaig
Copy link

Can you mention what sdk you used to test it in VR? The issue only occurs when I try to build it for VR (Quest 3) standalone.

@ninjamode
Copy link
Contributor

You dont need any 3rd party SDK to use this project with VR. Unity with URP and OpenXR should be fine. It's what I used so far.
That said, I might get around to trying out the Meta SDK in a week or so to see why it breaks the GS rendering.

@fx-lange
Copy link

fx-lange commented Dec 13, 2024

I'm actually using the Meta Interaction SDK (using the OVRCameraRig) and GS rendering works (URP, Unity6, Quest3). One pitfall might be that the OVRManager in the Rig prefab has "use recommended MSAA Level" enabled by default which has to be turned of - GS rendering is not compatible with MSAA afaik.

@Aresnan
Copy link

Aresnan commented Jan 8, 2025

I solved this exellent problem, quite easy!!!

@fx-lange
Copy link

Due to other tech in our project relying on multiview/singlepass I wanted to ask how feasible it would be to change/migrate the GS rendering to singlepass. A rough estimation between not possible at all and super easy just have a look at xyz would be appreciated :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests