Class VkVideoEncodeRateControlInfoKHR
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
Description
If layerCount is zero then the values of virtualBufferSizeInMs and initialVirtualBufferSizeInMs are ignored.
This structure can be specified in the following places:
- In the
pNextchain ofVkVideoBeginCodingInfoKHRto specify the current rate control state expected to be configured when beginning a video coding scope. - In the
pNextchain ofVkVideoCodingControlInfoKHRto change the rate control configuration of the bound video session.
Including this structure in the pNext chain of VkVideoCodingControlInfoKHR and including VIDEO_CODING_CONTROL_ENCODE_RATE_CONTROL_BIT_KHR in VkVideoCodingControlInfoKHR::flags enables updating the rate control configuration of the bound video session. This replaces the entire rate control configuration of the bound video session and may reset the state of all enabled rate control layers to an initial state according to the codec-specific rate control semantics defined in the corresponding sections listed below.
When layerCount is greater than one, multiple rate control layers are configured, and each rate control layer is applied to the corresponding video coding layer identified by the index of the corresponding element of pLayer.
- If the video session was created with the video codec operation
VIDEO_CODEC_OPERATION_ENCODE_H264_BIT_KHR, then this index specifies the H.264 temporal layer ID of the video coding layer the rate control layer is applied to. - If the video session was created with the video codec operation
VIDEO_CODEC_OPERATION_ENCODE_H265_BIT_KHR, then this index specifies the H.265 temporal ID of the video coding layer the rate control layer is applied to. - If the video session was created with the video codec operation
VIDEO_CODEC_OPERATION_ENCODE_AV1_BIT_KHR, then this index specifies the AV1 temporal ID of the temporal layer the rate control layer is applied to.
Additional structures providing codec-specific rate control parameters can be included in the pNext chain of VkVideoCodingControlInfoKHR depending on the video profile the bound video session was created. For further details see:
The new rate control configuration takes effect when the corresponding CmdControlVideoCodingKHR is executed on the device, and only impacts video encode operations that follow in execution order.
Valid Usage
- If
rateControlModeisVIDEO_ENCODE_RATE_CONTROL_MODE_DEFAULT_KHRorVIDEO_ENCODE_RATE_CONTROL_MODE_DISABLED_BIT_KHR, thenlayerCountmust be 0 - If
rateControlModeisVIDEO_ENCODE_RATE_CONTROL_MODE_CBR_BIT_KHRorVIDEO_ENCODE_RATE_CONTROL_MODE_VBR_BIT_KHR, thenlayerCountmust be greater than 0 - If
rateControlModeis notVIDEO_ENCODE_RATE_CONTROL_MODE_DEFAULT_KHR, then it must specify one of the bits included inVkVideoEncodeCapabilitiesKHR::rateControlModes, as returned byGetPhysicalDeviceVideoCapabilitiesKHRfor the used video profile layerCountmember must be less than or equal toVkVideoEncodeCapabilitiesKHR::maxRateControlLayers, as returned byGetPhysicalDeviceVideoCapabilitiesKHRfor the used video profile- For each element of
pLayers, itsaverageBitratemember must be between 1 andVkVideoEncodeCapabilitiesKHR::maxBitrate, as returned byGetPhysicalDeviceVideoCapabilitiesKHRfor the used video profile - For each element of
pLayers, itsmaxBitratemember must be between 1 andVkVideoEncodeCapabilitiesKHR::maxBitrate, as returned byGetPhysicalDeviceVideoCapabilitiesKHRfor the used video profile - If
rateControlModeisVIDEO_ENCODE_RATE_CONTROL_MODE_CBR_BIT_KHR, then for each element ofpLayers, itsaverageBitratemember must equal itsmaxBitratemember - If
rateControlModeisVIDEO_ENCODE_RATE_CONTROL_MODE_VBR_BIT_KHR, then for each element ofpLayers, itsaverageBitratemember must be less than or equal to itsmaxBitratemember - If
layerCountis not zero, thenvirtualBufferSizeInMsmust be greater than zero - If
layerCountis not zero, theninitialVirtualBufferSizeInMsmust be less than or equal tovirtualBufferSizeInMs - If the
videoCodecOperationof the used video profile isVIDEO_CODEC_OPERATION_ENCODE_H264_BIT_KHR, thepNextchain this structure is included in also includes an instance of theVkVideoEncodeH264RateControlInfoKHRstructure, andlayerCountis greater than 1, thenlayerCountmust equalVkVideoEncodeH264RateControlInfoKHR::temporalLayerCount - If the
videoCodecOperationof the used video profile isVIDEO_CODEC_OPERATION_ENCODE_H265_BIT_KHR, thepNextchain this structure is included in also includes an instance of theVkVideoEncodeH265RateControlInfoKHRstructure, andlayerCountis greater than 1, thenlayerCountmust equalVkVideoEncodeH265RateControlInfoKHR::subLayerCount - If the
videoCodecOperationof the used video profile isVIDEO_CODEC_OPERATION_ENCODE_AV1_BIT_KHR, thepNextchain this structure is included in also includes an instance of theVkVideoEncodeAV1RateControlInfoKHRstructure, andlayerCountis greater than 1, thenlayerCountmust equalVkVideoEncodeAV1RateControlInfoKHR::temporalLayerCount
Valid Usage (Implicit)
sTypemust beSTRUCTURE_TYPE_VIDEO_ENCODE_RATE_CONTROL_INFO_KHRflagsmust be 0- If
rateControlModeis not 0,rateControlModemust be a validVkVideoEncodeRateControlModeFlagBitsKHRvalue - If
layerCountis not 0,pLayersmust be a valid pointer to an array oflayerCountvalidVkVideoEncodeRateControlLayerInfoKHRstructures
See Also
VkVideoEncodeRateControlLayerInfoKHR
Layout
struct VkVideoEncodeRateControlInfoKHR {
VkStructureType sType();
void const * pNext();
VkVideoEncodeRateControlFlagsKHR flags();
VkVideoEncodeRateControlModeFlagBitsKHR rateControlMode();
uint32_t layerCount();
VkVideoEncodeRateControlLayerInfoKHR const * pLayers();
uint32_t virtualBufferSizeInMs();
uint32_t initialVirtualBufferSizeInMs();
}-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classAn array ofVkVideoEncodeRateControlInfoKHRstructs.Nested classes/interfaces inherited from class org.lwjgl.system.Struct
org.lwjgl.system.Struct.StructValidationNested classes/interfaces inherited from interface org.lwjgl.system.Pointer
org.lwjgl.system.Pointer.Default -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intThe struct alignment in bytes.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct size in bytes.static final intThe struct member offsets.static final intThe struct member offsets.Fields inherited from interface org.lwjgl.system.Pointer
BITS32, BITS64, CLONG_SHIFT, CLONG_SIZE, POINTER_SHIFT, POINTER_SIZE -
Constructor Summary
ConstructorsConstructorDescriptionVkVideoEncodeRateControlInfoKHR(ByteBuffer container) Creates aVkVideoEncodeRateControlInfoKHRinstance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptioncalloc()Returns a newVkVideoEncodeRateControlInfoKHRinstance allocated withmemCalloc.calloc(int capacity) Returns a newVkVideoEncodeRateControlInfoKHR.Bufferinstance allocated withmemCalloc.calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkVideoEncodeRateControlInfoKHR.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.calloc(org.lwjgl.system.MemoryStack stack) Returns a newVkVideoEncodeRateControlInfoKHRinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.create()Returns a newVkVideoEncodeRateControlInfoKHRinstance allocated withBufferUtils.create(int capacity) Returns a newVkVideoEncodeRateControlInfoKHR.Bufferinstance allocated withBufferUtils.create(long address) Returns a newVkVideoEncodeRateControlInfoKHRinstance for the specified memory address.create(long address, int capacity) Create aVkVideoEncodeRateControlInfoKHR.Bufferinstance at the specified memory.static @Nullable VkVideoEncodeRateControlInfoKHRcreateSafe(long address) static @Nullable VkVideoEncodeRateControlInfoKHR.BuffercreateSafe(long address, int capacity) intflags()reserved for future use.flags(int value) Sets the specified value to theflags()field.intthe initial occupancy in milliseconds of the virtual buffer used by the implementation’s rate control algorithm for the leaky bucket model.initialVirtualBufferSizeInMs(int value) Sets the specified value to theinitialVirtualBufferSizeInMs()field.intspecifies the number of rate control layers to use.malloc()Returns a newVkVideoEncodeRateControlInfoKHRinstance allocated withmemAlloc.malloc(int capacity) Returns a newVkVideoEncodeRateControlInfoKHR.Bufferinstance allocated withmemAlloc.malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkVideoEncodeRateControlInfoKHR.Bufferinstance allocated on the specifiedMemoryStack.malloc(org.lwjgl.system.MemoryStack stack) Returns a newVkVideoEncodeRateControlInfoKHRinstance allocated on the specifiedMemoryStack.static intnflags(long struct) Unsafe version offlags().static voidnflags(long struct, int value) Unsafe version offlags.static intninitialVirtualBufferSizeInMs(long struct) Unsafe version ofinitialVirtualBufferSizeInMs().static voidninitialVirtualBufferSizeInMs(long struct, int value) Unsafe version ofinitialVirtualBufferSizeInMs.static intnlayerCount(long struct) Unsafe version oflayerCount().static voidnlayerCount(long struct, int value) Sets the specified value to thelayerCountfield of the specifiedstruct.static @Nullable VkVideoEncodeRateControlLayerInfoKHR.BuffernpLayers(long struct) Unsafe version ofpLayers().static voidnpLayers(long struct, @Nullable VkVideoEncodeRateControlLayerInfoKHR.Buffer value) Unsafe version ofpLayers.static longnpNext(long struct) Unsafe version ofpNext().static voidnpNext(long struct, long value) Unsafe version ofpNext.static intnrateControlMode(long struct) Unsafe version ofrateControlMode().static voidnrateControlMode(long struct, int value) Unsafe version ofrateControlMode.static intnsType(long struct) Unsafe version ofsType().static voidnsType(long struct, int value) Unsafe version ofsType.static intnvirtualBufferSizeInMs(long struct) Unsafe version ofvirtualBufferSizeInMs().static voidnvirtualBufferSizeInMs(long struct, int value) Unsafe version ofvirtualBufferSizeInMs.pLayers()a pointer to an array oflayerCountVkVideoEncodeRateControlLayerInfoKHRstructures, each specifying the rate control configuration of the corresponding rate control layer.pLayers(@Nullable VkVideoEncodeRateControlLayerInfoKHR.Buffer value) Sets the address of the specifiedVkVideoEncodeRateControlLayerInfoKHR.Bufferto thepLayers()field.longpNext()NULLor a pointer to a structure extending this structure.pNext(long value) Sets the specified value to thepNext()field.intaVkVideoEncodeRateControlModeFlagBitsKHRvalue specifying the rate control mode.rateControlMode(int value) Sets the specified value to therateControlMode()field.set(int sType, long pNext, int flags, int rateControlMode, @Nullable VkVideoEncodeRateControlLayerInfoKHR.Buffer pLayers, int virtualBufferSizeInMs, int initialVirtualBufferSizeInMs) Initializes this struct with the specified values.Copies the specified struct data to this struct.intsizeof()intsType()aVkStructureTypevalue identifying this structure.sType(int value) Sets the specified value to thesType()field.Sets theSTRUCTURE_TYPE_VIDEO_ENCODE_RATE_CONTROL_INFO_KHRvalue to thesType()field.static voidvalidate(long struct) Validates pointer members that should not beNULL.intthe size in milliseconds of the virtual buffer used by the implementation’s rate control algorithm for the leaky bucket model, with respect to the average bitrate of the stream calculated by summing the values of theaverageBitratemembers of the elements of thepLayersarray.virtualBufferSizeInMs(int value) Sets the specified value to thevirtualBufferSizeInMs()field.Methods inherited from class org.lwjgl.system.Struct
clear, free, isNull, validate, validateMethods inherited from class org.lwjgl.system.Pointer.Default
address, equals, hashCode, toStringMethods inherited from interface org.lwjgl.system.NativeResource
close, free
-
Field Details
-
SIZEOF
public static final int SIZEOFThe struct size in bytes. -
ALIGNOF
public static final int ALIGNOFThe struct alignment in bytes. -
STYPE
public static final int STYPEThe struct member offsets. -
PNEXT
public static final int PNEXTThe struct member offsets. -
FLAGS
public static final int FLAGSThe struct member offsets. -
RATECONTROLMODE
public static final int RATECONTROLMODEThe struct member offsets. -
LAYERCOUNT
public static final int LAYERCOUNTThe struct member offsets. -
PLAYERS
public static final int PLAYERSThe struct member offsets. -
VIRTUALBUFFERSIZEINMS
public static final int VIRTUALBUFFERSIZEINMSThe struct member offsets. -
INITIALVIRTUALBUFFERSIZEINMS
public static final int INITIALVIRTUALBUFFERSIZEINMSThe struct member offsets.
-
-
Constructor Details
-
VkVideoEncodeRateControlInfoKHR
Creates aVkVideoEncodeRateControlInfoKHRinstance 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 Details
-
sizeof
public int sizeof()- Specified by:
sizeofin classorg.lwjgl.system.Struct<VkVideoEncodeRateControlInfoKHR>
-
sType
public int sType()aVkStructureTypevalue identifying this structure. -
pNext
public long pNext()NULLor a pointer to a structure extending this structure. -
flags
public int flags()reserved for future use. -
rateControlMode
public int rateControlMode()aVkVideoEncodeRateControlModeFlagBitsKHRvalue specifying the rate control mode. -
layerCount
public int layerCount()specifies the number of rate control layers to use. -
pLayers
a pointer to an array oflayerCountVkVideoEncodeRateControlLayerInfoKHRstructures, each specifying the rate control configuration of the corresponding rate control layer. -
virtualBufferSizeInMs
public int virtualBufferSizeInMs()the size in milliseconds of the virtual buffer used by the implementation’s rate control algorithm for the leaky bucket model, with respect to the average bitrate of the stream calculated by summing the values of theaverageBitratemembers of the elements of thepLayersarray. -
initialVirtualBufferSizeInMs
public int initialVirtualBufferSizeInMs()the initial occupancy in milliseconds of the virtual buffer used by the implementation’s rate control algorithm for the leaky bucket model. -
sType
Sets the specified value to thesType()field. -
sType$Default
Sets theSTRUCTURE_TYPE_VIDEO_ENCODE_RATE_CONTROL_INFO_KHRvalue to thesType()field. -
pNext
Sets the specified value to thepNext()field. -
flags
Sets the specified value to theflags()field. -
rateControlMode
Sets the specified value to therateControlMode()field. -
pLayers
public VkVideoEncodeRateControlInfoKHR pLayers(@Nullable VkVideoEncodeRateControlLayerInfoKHR.Buffer value) Sets the address of the specifiedVkVideoEncodeRateControlLayerInfoKHR.Bufferto thepLayers()field. -
virtualBufferSizeInMs
Sets the specified value to thevirtualBufferSizeInMs()field. -
initialVirtualBufferSizeInMs
Sets the specified value to theinitialVirtualBufferSizeInMs()field. -
set
public VkVideoEncodeRateControlInfoKHR set(int sType, long pNext, int flags, int rateControlMode, @Nullable VkVideoEncodeRateControlLayerInfoKHR.Buffer pLayers, int virtualBufferSizeInMs, int initialVirtualBufferSizeInMs) Initializes this struct with the specified values. -
set
Copies the specified struct data to this struct.- Parameters:
src- the source struct- Returns:
- this struct
-
malloc
Returns a newVkVideoEncodeRateControlInfoKHRinstance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newVkVideoEncodeRateControlInfoKHRinstance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newVkVideoEncodeRateControlInfoKHRinstance allocated withBufferUtils. -
create
Returns a newVkVideoEncodeRateControlInfoKHRinstance for the specified memory address. -
createSafe
-
malloc
Returns a newVkVideoEncodeRateControlInfoKHR.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newVkVideoEncodeRateControlInfoKHR.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newVkVideoEncodeRateControlInfoKHR.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aVkVideoEncodeRateControlInfoKHR.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
public static @Nullable VkVideoEncodeRateControlInfoKHR.Buffer createSafe(long address, int capacity) -
malloc
Returns a newVkVideoEncodeRateControlInfoKHRinstance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
Returns a newVkVideoEncodeRateControlInfoKHRinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
public static VkVideoEncodeRateControlInfoKHR.Buffer malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkVideoEncodeRateControlInfoKHR.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
public static VkVideoEncodeRateControlInfoKHR.Buffer calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkVideoEncodeRateControlInfoKHR.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
nsType
public static int nsType(long struct) Unsafe version ofsType(). -
npNext
public static long npNext(long struct) Unsafe version ofpNext(). -
nflags
public static int nflags(long struct) Unsafe version offlags(). -
nrateControlMode
public static int nrateControlMode(long struct) Unsafe version ofrateControlMode(). -
nlayerCount
public static int nlayerCount(long struct) Unsafe version oflayerCount(). -
npLayers
Unsafe version ofpLayers(). -
nvirtualBufferSizeInMs
public static int nvirtualBufferSizeInMs(long struct) Unsafe version ofvirtualBufferSizeInMs(). -
ninitialVirtualBufferSizeInMs
public static int ninitialVirtualBufferSizeInMs(long struct) Unsafe version ofinitialVirtualBufferSizeInMs(). -
nsType
public static void nsType(long struct, int value) Unsafe version ofsType. -
npNext
public static void npNext(long struct, long value) Unsafe version ofpNext. -
nflags
public static void nflags(long struct, int value) Unsafe version offlags. -
nrateControlMode
public static void nrateControlMode(long struct, int value) Unsafe version ofrateControlMode. -
nlayerCount
public static void nlayerCount(long struct, int value) Sets the specified value to thelayerCountfield of the specifiedstruct. -
npLayers
public static void npLayers(long struct, @Nullable VkVideoEncodeRateControlLayerInfoKHR.Buffer value) Unsafe version ofpLayers. -
nvirtualBufferSizeInMs
public static void nvirtualBufferSizeInMs(long struct, int value) Unsafe version ofvirtualBufferSizeInMs. -
ninitialVirtualBufferSizeInMs
public static void ninitialVirtualBufferSizeInMs(long struct, int value) Unsafe version ofinitialVirtualBufferSizeInMs. -
validate
public static void validate(long struct) Validates pointer members that should not beNULL.- Parameters:
struct- the struct to validate
-