Class OVRPerfStatsPerCompositorFrame
- java.lang.Object
-
- org.lwjgl.system.Pointer.Default
-
- org.lwjgl.system.Struct
-
- org.lwjgl.ovr.OVRPerfStatsPerCompositorFrame
-
- All Implemented Interfaces:
- org.lwjgl.system.Pointer
public class OVRPerfStatsPerCompositorFrame extends org.lwjgl.system.StructContains the performance stats for a given SDK compositor frame.All of the int fields can be reset via the
ResetPerfStatscall.Member documentation
HmdVsyncIndex– Vsync Frame Index - increments with each HMD vertical synchronization signal (i.e. vsync or refresh rate).If the compositor drops a frame, expect this value to increment more than 1 at a time.
AppFrameIndex– index that increments with each successiveSubmitFramecallAppDroppedFrameCount– if the app fails to callSubmitFrameon time, then expect this value to increment with each missed frameAppMotionToPhotonLatency– motion-to-photon latency for the applicationThis value is calculated by either using the
SensorSampleTimeprovided for theOVRLayerEyeFovor if that is not available, then the call toGetTrackingStatewhich haslatencyMarkerset toTrue.AppQueueAheadTime– amount of queue-ahead in seconds provided to the app based on performance and overlap of CPU and GPU utilization.A value of 0.0 would mean the CPU & GPU workload is being completed in 1 frame's worth of time, while 11 ms (on the CV1) of queue ahead would indicate that the app's CPU workload for the next frame is overlapping the app's GPU workload for the current frame.
AppCpuElapsedTime– amount of time in seconds spent on the CPU by the app's render-thread that callsSubmitFrame.Measured as elapsed time between from when app regains control from
SubmitFrameto the next time the app callsSubmitFrame.AppGpuElapsedTime– amount of time in seconds spent on the GPU by the app.Measured as elapsed time between each
SubmitFramecall using GPU timing queries.CompositorFrameIndex– index that increments each time the SDK compositor completes a distortion and timewarp pass.Since the compositor operates asynchronously, even if the app calls
SubmitFrametoo late, the compositor will kick off for each vsync.CompositorDroppedFrameCount– increments each time the SDK compositor fails to complete in time.This is not tied to the app's performance, but failure to complete can be related to other factors such as OS capabilities, overall available hardware cycles to execute the compositor in time and other factors outside of the app's control.
CompositorLatency– motion-to-photon latency of the SDK compositor in seconds.This is the latency of timewarp which corrects the higher app latency as well as dropped app frames.
CompositorCpuElapsedTime– the amount of time in seconds spent on the CPU by the SDK compositor.Unless the VR app is utilizing all of the CPU cores at their peak performance, there is a good chance the compositor CPU times will not affect the app's CPU performance in a major way.
CompositorGpuElapsedTime– the amount of time in seconds spent on the GPU by the SDK compositor. Any time spent on the compositor will eat away from the available GPU time for the app.CompositorCpuStartToGpuEndElapsedTime– the amount of time in seconds spent from the point the CPU kicks off the compositor to the point in time the compositor completes the distortion & timewarp on the GPU.In the event the GPU time is not available, expect this value to be -1.0f.
CompositorGpuEndToVsyncElapsedTime– the amount of time in seconds left after the compositor is done on the GPU to the associated V-Sync time.In the event the GPU time is not available, expect this value to be -1.0f.
AswIsActive– Will be true if ASW is active for the given frame such that the application is being forced into half the frame-rate while the compositor continues to run at full frame-rate.AswActivatedToggleCount– Increments each time ASW it activated where the app was forced in and out of half-rate rendering.AswPresentedFrameCount– Accumulates the number of frames presented by the compositor which had extrapolated ASW frames presentedAswFailedFrameCount– Accumulates the number of frames that the compositor tried to present when ASW is active but failed
Layout
struct ovrPerfStatsPerCompositorFrame { int HmdVsyncIndex; int AppFrameIndex; int AppDroppedFrameCount; float AppMotionToPhotonLatency; float AppQueueAheadTime; float AppCpuElapsedTime; float AppGpuElapsedTime; int CompositorFrameIndex; int CompositorDroppedFrameCount; float CompositorLatency; float CompositorCpuElapsedTime; float CompositorGpuElapsedTime; float CompositorCpuStartToGpuEndElapsedTime; float CompositorGpuEndToVsyncElapsedTime; ovrBool AswIsActive; int AswActivatedToggleCount; int AswPresentedFrameCount; int AswFailedFrameCount; }
-
-
Nested Class Summary
Nested Classes Modifier and Type Class and Description static classOVRPerfStatsPerCompositorFrame.BufferAn array ofOVRPerfStatsPerCompositorFramestructs.
-
Field Summary
Fields Modifier and Type Field and Description static intSIZEOFThe struct size in bytes.
-
Constructor Summary
Constructors Constructor and Description OVRPerfStatsPerCompositorFrame(java.nio.ByteBuffer container)Creates aOVRPerfStatsPerCompositorFrameinstance at the current position of the specifiedByteBuffercontainer.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method and Description floatAppCpuElapsedTime()Returns the value of theAppCpuElapsedTimefield.intAppDroppedFrameCount()Returns the value of theAppDroppedFrameCountfield.intAppFrameIndex()Returns the value of theAppFrameIndexfield.floatAppGpuElapsedTime()Returns the value of theAppGpuElapsedTimefield.floatAppMotionToPhotonLatency()Returns the value of theAppMotionToPhotonLatencyfield.floatAppQueueAheadTime()Returns the value of theAppQueueAheadTimefield.intAswActivatedToggleCount()Returns the value of theAswActivatedToggleCountfield.intAswFailedFrameCount()Returns the value of theAswFailedFrameCountfield.booleanAswIsActive()Returns the value of theAswIsActivefield.intAswPresentedFrameCount()Returns the value of theAswPresentedFrameCountfield.floatCompositorCpuElapsedTime()Returns the value of theCompositorCpuElapsedTimefield.floatCompositorCpuStartToGpuEndElapsedTime()Returns the value of theCompositorCpuStartToGpuEndElapsedTimefield.intCompositorDroppedFrameCount()Returns the value of theCompositorDroppedFrameCountfield.intCompositorFrameIndex()Returns the value of theCompositorFrameIndexfield.floatCompositorGpuElapsedTime()Returns the value of theCompositorGpuElapsedTimefield.floatCompositorGpuEndToVsyncElapsedTime()Returns the value of theCompositorGpuEndToVsyncElapsedTimefield.floatCompositorLatency()Returns the value of theCompositorLatencyfield.static OVRPerfStatsPerCompositorFramecreate(long address)Returns a newOVRPerfStatsPerCompositorFrameinstance for the specified memory address.static OVRPerfStatsPerCompositorFrame.Buffercreate(long address, int capacity)Create aOVRPerfStatsPerCompositorFrame.Bufferinstance at the specified memory.static OVRPerfStatsPerCompositorFramecreateSafe(long address)static OVRPerfStatsPerCompositorFrame.BuffercreateSafe(long address, int capacity)intHmdVsyncIndex()Returns the value of theHmdVsyncIndexfield.intsizeof()
-
-
-
Constructor Detail
-
OVRPerfStatsPerCompositorFrame
public OVRPerfStatsPerCompositorFrame(java.nio.ByteBuffer container)
Creates aOVRPerfStatsPerCompositorFrameinstance at the current position of the specifiedByteBuffercontainer. Changes to the buffer's content will be visible to the struct instance and vice versa.The created instance holds a strong reference to the container object.
-
-
Method Detail
-
sizeof
public int sizeof()
- Specified by:
sizeofin classorg.lwjgl.system.Struct
-
HmdVsyncIndex
public int HmdVsyncIndex()
Returns the value of theHmdVsyncIndexfield.
-
AppFrameIndex
public int AppFrameIndex()
Returns the value of theAppFrameIndexfield.
-
AppDroppedFrameCount
public int AppDroppedFrameCount()
Returns the value of theAppDroppedFrameCountfield.
-
AppMotionToPhotonLatency
public float AppMotionToPhotonLatency()
Returns the value of theAppMotionToPhotonLatencyfield.
-
AppQueueAheadTime
public float AppQueueAheadTime()
Returns the value of theAppQueueAheadTimefield.
-
AppCpuElapsedTime
public float AppCpuElapsedTime()
Returns the value of theAppCpuElapsedTimefield.
-
AppGpuElapsedTime
public float AppGpuElapsedTime()
Returns the value of theAppGpuElapsedTimefield.
-
CompositorFrameIndex
public int CompositorFrameIndex()
Returns the value of theCompositorFrameIndexfield.
-
CompositorDroppedFrameCount
public int CompositorDroppedFrameCount()
Returns the value of theCompositorDroppedFrameCountfield.
-
CompositorLatency
public float CompositorLatency()
Returns the value of theCompositorLatencyfield.
-
CompositorCpuElapsedTime
public float CompositorCpuElapsedTime()
Returns the value of theCompositorCpuElapsedTimefield.
-
CompositorGpuElapsedTime
public float CompositorGpuElapsedTime()
Returns the value of theCompositorGpuElapsedTimefield.
-
CompositorCpuStartToGpuEndElapsedTime
public float CompositorCpuStartToGpuEndElapsedTime()
Returns the value of theCompositorCpuStartToGpuEndElapsedTimefield.
-
CompositorGpuEndToVsyncElapsedTime
public float CompositorGpuEndToVsyncElapsedTime()
Returns the value of theCompositorGpuEndToVsyncElapsedTimefield.
-
AswIsActive
public boolean AswIsActive()
Returns the value of theAswIsActivefield.
-
AswActivatedToggleCount
public int AswActivatedToggleCount()
Returns the value of theAswActivatedToggleCountfield.
-
AswPresentedFrameCount
public int AswPresentedFrameCount()
Returns the value of theAswPresentedFrameCountfield.
-
AswFailedFrameCount
public int AswFailedFrameCount()
Returns the value of theAswFailedFrameCountfield.
-
create
public static OVRPerfStatsPerCompositorFrame create(long address)
Returns a newOVRPerfStatsPerCompositorFrameinstance for the specified memory address.
-
createSafe
@Nullable public static OVRPerfStatsPerCompositorFrame createSafe(long address)
-
create
public static OVRPerfStatsPerCompositorFrame.Buffer create(long address, int capacity)
Create aOVRPerfStatsPerCompositorFrame.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
@Nullable public static OVRPerfStatsPerCompositorFrame.Buffer createSafe(long address, int capacity)
-
-