OWL
OptiX7 Wrapper Library
|
#include <cuda.h>
#include <driver_types.h>
#include <optix.h>
#include <sys/types.h>
#include <stdint.h>
Go to the source code of this file.
Classes | |
struct | _OWL_int2 |
struct | _OWL_uint2 |
struct | _OWL_long2 |
struct | _OWL_ulong2 |
struct | _OWL_float2 |
struct | _OWL_double2 |
struct | _OWL_int3 |
struct | _OWL_uint3 |
struct | _OWL_long3 |
struct | _OWL_ulong3 |
struct | _OWL_float3 |
struct | _OWL_double3 |
struct | _OWL_int4 |
struct | _OWL_uint4 |
struct | _OWL_long4 |
struct | _OWL_ulong4 |
struct | _OWL_float4 |
struct | _OWL_double4 |
struct | _OWL_affine3f |
struct | _OWLVarDecl |
struct | _OWLDeviceBuffer2D |
Macros | |
#define | OWL_DLL_EXPORT |
#define | OWL_DLL_IMPORT |
#define | OWL_IF_CPP(a) /* drop it */ |
#define | OWL_API /* bla */ |
#define | OWL_OFFSETOF(type, member) |
#define | OWL_USER_TYPE(userType) ((OWLDataType)(OWL_USER_TYPE_BEGIN+sizeof(userType))) |
#define | OWL_ALL_RAY_TYPES -1 |
#define | _OWL_SET_HELPER(stype, abb) |
#define | _OWL_SET_HELPERS_C(OType, stype, abb) |
#define | _OWL_SET_HELPERS_CPP(OType, stype, abb) /* ignore in C99 mode */ |
#define | _OWL_SET_HELPERS(Type) |
Typedefs | |
typedef float | OWL_float |
typedef double | OWL_double |
typedef int32_t | OWL_int |
typedef uint32_t | OWL_uint |
typedef int64_t | OWL_long |
typedef uint64_t | OWL_ulong |
typedef struct _OWL_int2 | owl2i |
typedef struct _OWL_uint2 | owl2ui |
typedef struct _OWL_long2 | owl2l |
typedef struct _OWL_ulong2 | owl2ul |
typedef struct _OWL_float2 | owl2f |
typedef struct _OWL_double2 | owl2d |
typedef struct _OWL_int3 | owl3i |
typedef struct _OWL_uint3 | owl3ui |
typedef struct _OWL_long3 | owl3l |
typedef struct _OWL_ulong3 | owl3ul |
typedef struct _OWL_float3 | owl3f |
typedef struct _OWL_double3 | owl3d |
typedef struct _OWL_int4 | owl4i |
typedef struct _OWL_uint4 | owl4ui |
typedef struct _OWL_long4 | owl4l |
typedef struct _OWL_ulong4 | owl4ul |
typedef struct _OWL_float4 | owl4f |
typedef struct _OWL_double4 | owl4d |
typedef struct _OWL_affine3f | owl4x3f |
typedef struct _OWLVarDecl | OWLVarDecl |
typedef OptixTraversableHandle | OWLDeviceTraversable |
typedef struct _OWLDeviceBuffer2D | OWLDeviceBuffer2D |
typedef struct _OWLContext * | OWLContext |
typedef struct _OWLBuffer * | OWLBuffer |
typedef struct _OWLTexture * | OWLTexture |
typedef struct _OWLGeom * | OWLGeom |
typedef struct _OWLGeomType * | OWLGeomType |
typedef struct _OWLVariable * | OWLVariable |
typedef struct _OWLModule * | OWLModule |
typedef struct _OWLGroup * | OWLGroup |
typedef struct _OWLRayGen * | OWLRayGen |
typedef struct _OWLMissProg * | OWLMissProg |
typedef struct _OWLLaunchParams * | OWLLaunchParams |
typedef struct _OWLLaunchParams * | OWLParams |
typedef struct _OWLLaunchParams * | OWLGlobals |
#define _OWL_SET_HELPER | ( | stype, | |
abb | |||
) |
#define _OWL_SET_HELPERS | ( | Type | ) |
#define _OWL_SET_HELPERS_C | ( | OType, | |
stype, | |||
abb | |||
) |
#define _OWL_SET_HELPERS_CPP | ( | OType, | |
stype, | |||
abb | |||
) | /* ignore in C99 mode */ |
#define OWL_ALL_RAY_TYPES -1 |
#define OWL_API /* bla */ |
#define OWL_DLL_EXPORT |
#define OWL_DLL_IMPORT |
#define OWL_IF_CPP | ( | a | ) | /* drop it */ |
#define OWL_OFFSETOF | ( | type, | |
member | |||
) |
#define OWL_USER_TYPE | ( | userType | ) | ((OWLDataType)(OWL_USER_TYPE_BEGIN+sizeof(userType))) |
typedef struct _OWL_double2 owl2d |
typedef struct _OWL_float2 owl2f |
typedef struct _OWL_long2 owl2l |
typedef struct _OWL_uint2 owl2ui |
typedef struct _OWL_ulong2 owl2ul |
typedef struct _OWL_double3 owl3d |
typedef struct _OWL_float3 owl3f |
typedef struct _OWL_long3 owl3l |
typedef struct _OWL_uint3 owl3ui |
typedef struct _OWL_ulong3 owl3ul |
typedef struct _OWL_double4 owl4d |
typedef struct _OWL_float4 owl4f |
typedef struct _OWL_long4 owl4l |
typedef struct _OWL_uint4 owl4ui |
typedef struct _OWL_ulong4 owl4ul |
typedef struct _OWL_affine3f owl4x3f |
typedef double OWL_double |
typedef float OWL_float |
typedef int32_t OWL_int |
typedef int64_t OWL_long |
typedef uint32_t OWL_uint |
typedef uint64_t OWL_ulong |
typedef struct _OWLBuffer* OWLBuffer |
typedef struct _OWLContext* OWLContext |
typedef struct _OWLDeviceBuffer2D OWLDeviceBuffer2D |
typedef OptixTraversableHandle OWLDeviceTraversable |
typedef struct _OWLGeom* OWLGeom |
typedef struct _OWLGeomType* OWLGeomType |
typedef struct _OWLLaunchParams * OWLGlobals |
typedef struct _OWLGroup* OWLGroup |
typedef struct _OWLLaunchParams* OWLLaunchParams |
launch params (or "globals") are variables that can be put into device constant memory, accessible through a CUDA "__constant__ <Type> optixLaunchParams;" variable on the device side. Launch params capture the layout of this struct, and the value of its members, on the host side, then properly fill it in before executing a launch. OptiX calls those "launch parameters" because they are similar to how parameters to a CUDA kernel are internally treated; we also call them "globals" because they are globally accessible to all programs within a given launch
typedef struct _OWLMissProg* OWLMissProg |
typedef struct _OWLModule* OWLModule |
typedef struct _OWLLaunchParams * OWLParams |
typedef struct _OWLRayGen* OWLRayGen |
typedef struct _OWLTexture* OWLTexture |
typedef struct _OWLVarDecl OWLVarDecl |
typedef struct _OWLVariable* OWLVariable |
enum OWLBuildSBTFlags |
enum OWLDataType |
enum OWLGeomKind |
enum OWLMatrixFormat |
enum that specifies the different possible memory layouts for passing transformation matrices
Enumerator | |
---|---|
OWL_MATRIX_FORMAT_COLUMN_MAJOR | 4x3-float column-major matrix format, where a matrix is specified through four vec3fs, the first three being the basis vectors of the linear transform, and the fourth one the translation part. This is exactly the same layout as used in owl::common::affine3f (owl/common/math/AffineSpae.h) |
OWL_MATRIX_FORMAT_OWL | just another name for OWL_MATRIX_FORMAT_4X3_COLUMN_MAJOR that is easier to type - the "_OWL" indicates that this is the default format in the owl::common namespace |
OWL_MATRIX_FORMAT_ROW_MAJOR | 3x4-float row-major layout as preferred by optix; in this case it doesn't matter if it's a 4x3 or 4x4 matrix, since the last row in a 4x4 row major matrix can simply be ignored |
enum OWLTexelFormat |
enum OWLTextureFilterMode |
perform a raygen launch with lauch parameters, in a A*synchronous way; it, this will only launch, but *NOT wait for completion (see owlLaunchSync)
destroy the given buffer; this will both release the app's refcount on the given buffer handle, and the buffer itself; ie, even if some objects still hold variables that refer to the old handle the buffer itself will be freed
returns the device pointer of the given pointer for the given device ID. For host-pinned or managed memory buffers (where the buffer is shared across all devices) this pointer should be the same across all devices (and even be accessible on the host); for device buffers each device may see this buffer under a different address, and that address is not valid on the host. Note this function is paricuarly useful for CUDA-interop; allowing to cudaMemcpy to/from an owl buffer directly from CUDA code
OWL_API void owlBuildPipeline | ( | OWLContext | context | ) |
OWL_API void owlBuildPrograms | ( | OWLContext | context | ) |
OWL_API void owlBuildSBT | ( | OWLContext | context, |
OWLBuildSBTFlags flags | OWL_IF_CPP=OWL_SBT_ALL | ||
) |
OWL_API OWLContext owlContextCreate | ( | int32_t *requestedDeviceIDs | OWL_IF_CPP=nullptr, |
int numDevices | OWL_IF_CPP=0 | ||
) |
creates a new device context with the gives list of devices.
If requested device IDs list if null it implicitly refers to the list "0,1,2,...."; if numDevices <= 0 it automatically refers to "all devices you can find". Examples:
OWL_API void owlContextDestroy | ( | OWLContext | context | ) |
OWL_API OptixDeviceContext owlContextGetOptixContext | ( | OWLContext | context, |
int | deviceID | ||
) |
OWL_API CUstream owlContextGetStream | ( | OWLContext | context, |
int | deviceID | ||
) |
OWL_API void owlContextSetRayTypeCount | ( | OWLContext | context, |
size_t | numRayTypes | ||
) |
set number of ray types to be used in this context; this should be done before any programs, pipelines, geometries, etc get created
OWL_API OWLBuffer owlDeviceBufferCreate | ( | OWLContext | context, |
OWLDataType | type, | ||
size_t | count, | ||
const void * | init | ||
) |
creates a device buffer where every device has its own local copy of the given buffer
OWL_API void owlEnableMotionBlur | ( | OWLContext | _context | ) |
enable motion blur for this context. this has to be called before creating any geometries, groups, etc, and before the pipeline gets compiled. Ie, it shold be called right after context creation
OWL_API OWLGeom owlGeomCreate | ( | OWLContext | context, |
OWLGeomType | type | ||
) |
OWL_API OWLVariable owlGeomGetVariable | ( | OWLGeom | geom, |
const char * | varName | ||
) |
set the primitive count for the given uesr geometry. this has to be set before the group(s) that this geom is used in get built
OWL_API OWLGeomType owlGeomTypeCreate | ( | OWLContext | context, |
OWLGeomKind | kind, | ||
size_t | sizeOfVarStruct, | ||
OWLVarDecl * | vars, | ||
int | numVars | ||
) |
OWL_API void owlGeomTypeSetAnyHit | ( | OWLGeomType | type, |
int | rayType, | ||
OWLModule | module, | ||
const char * | progName | ||
) |
OWL_API void owlGeomTypeSetBoundsProg | ( | OWLGeomType | type, |
OWLModule | module, | ||
const char * | progName | ||
) |
OWL_API void owlGeomTypeSetClosestHit | ( | OWLGeomType | type, |
int | rayType, | ||
OWLModule | module, | ||
const char * | progName | ||
) |
OWL_API void owlGeomTypeSetIntersectProg | ( | OWLGeomType | type, |
int | rayType, | ||
OWLModule | module, | ||
const char * | progName | ||
) |
OWL_API int32_t owlGetDeviceCount | ( | OWLContext | context | ) |
returns number of devices available in the given context
OWL_API OWLBuffer owlGraphicsBufferCreate | ( | OWLContext | context, |
OWLDataType | type, | ||
size_t | count, | ||
cudaGraphicsResource_t | resource | ||
) |
creates a buffer wrapping a CUDA graphics resource; the resource must be created and registered by the user
OWL_API OWLBuffer owlHostPinnedBufferCreate | ( | OWLContext | context, |
OWLDataType | type, | ||
size_t | count | ||
) |
creates a buffer that uses CUDA host pinned memory; that memory is pinned on the host and accessive to all devices in the deviec group
OWL_API OWLGroup owlInstanceGroupCreate | ( | OWLContext | context, |
size_t | numInstances, | ||
const OWLGroup *initGroups | OWL_IF_CPP=nullptr, | ||
const uint32_t *initInstanceIDs | OWL_IF_CPP=nullptr, | ||
const float *initTransforms | OWL_IF_CPP=nullptr, | ||
OWLMatrixFormat matrixFormat | OWL_IF_CPP=OWL_MATRIX_FORMAT_OWL | ||
) |
create a new instance group with given number of instances. The child groups and their instance IDs and/or transforms can either be specified "in bulk" as part of this call, or can be set lateron with inviidaul calls to
Either or all of initGroups, initTranforms, or initInstanceIDs may be null, in which case the values used for the 'th child will be a null group, a unit transform, and 'i', respectively.
numInstances | number of instances in this group |
OWL_IF_CPP | the initial list of owl groups to use by the instances in this group; must be either null, or an array of the size 'numInstnaces', the i'th instnace in this gorup will be an instance o the i'th element in this list |
OWL_IF_CPP | instance IDs to use for the instance in this group; must be eithe rnull, or an array of size numInstnaces. If null, the i'th child of this instance group will use instanceID=i, otherwise, it will use the user-provided instnace ID from this list. Specifying an instanceID will affect what value 'optixGetInstanceID' will return in a CH program that refers to the given instance |
OWL_IF_CPP | initial list of transforms that this instance group will use; must be either null, or an array of size numInstnaces, of the format specified |
sets the list of IDs to use for the child instnaces. By default the instance ID of child #i is simply i, but optix allows to specify a user-defined instnace ID for each instance, which with owl can be done through this array. Array size must match number of instances in the specified group
OWL_API void owlInstanceGroupSetTransform | ( | OWLGroup | group, |
int | whichChild, | ||
const float * | floats, | ||
OWLMatrixFormat matrixFormat | OWL_IF_CPP=OWL_MATRIX_FORMAT_OWL | ||
) |
sets the transformatoin matrix to be applied to the childID'th child of the given instance group
OWL_API void owlInstanceGroupSetTransforms | ( | OWLGroup | group, |
uint32_t | timeStep, | ||
const float * | floatsForThisStimeStep, | ||
OWLMatrixFormat matrixFormat | OWL_IF_CPP=OWL_MATRIX_FORMAT_OWL | ||
) |
this function allows to set up to N different arrays of trnsforms for motion blur; the first such array is used as transforms for t=0, the last one for t=1.
timeStep | whether to set for t=0 or t=1 - currently supporting only 0 or 1 |
perform a raygen launch with lauch parameters, in a synchronous way; it, by the time this function returns the launch is completed
OWL_API OWLBuffer owlManagedMemoryBufferCreate | ( | OWLContext | context, |
OWLDataType | type, | ||
size_t | count, | ||
const void * | init | ||
) |
creates a buffer that uses CUDA managed memory; that memory is managed by CUDA (see CUDAs documentatoin on managed memory) and accessive to all devices in the deviec group
OWL_API OWLMissProg owlMissProgCreate | ( | OWLContext | context, |
OWLModule | module, | ||
const char * | programName, | ||
size_t | sizeOfVarStruct, | ||
OWLVarDecl * | vars, | ||
int | numVars | ||
) |
creates a miss program with given function name (in given module) and given variables. Note due to backwards compatibility this will also automatically set, by default, the first such created program as miss program for ray type number 0, the second one for ray type number 1, etc. If another order is desired, you can use
OWL_API OWLVariable owlMissProgGetVariable | ( | OWLMissProg | geom, |
const char * | varName | ||
) |
OWL_API void owlMissProgSet | ( | OWLContext | context, |
int | rayType, | ||
OWLMissProg | missProgToUse | ||
) |
sets the given miss program for the given ray type
OWL_API OWLModule owlModuleCreate | ( | OWLContext | context, |
const char * | ptxCode | ||
) |
OWL_API OWLParams owlParamsCreate | ( | OWLContext | context, |
size_t | sizeOfVarStruct, | ||
OWLVarDecl * | vars, | ||
int | numVars | ||
) |
OWL_API OWLVariable owlParamsGetVariable | ( | OWLParams | object, |
const char * | varName | ||
) |
OWL_API OWLRayGen owlRayGenCreate | ( | OWLContext | context, |
OWLModule | module, | ||
const char * | programName, | ||
size_t | sizeOfVarStruct, | ||
OWLVarDecl * | vars, | ||
int | numVars | ||
) |
OWL_API OWLVariable owlRayGenGetVariable | ( | OWLRayGen | geom, |
const char * | varName | ||
) |
executes an optix lauch of given size, with given launch program. Note this is asynchronous, and may not be completed by the time this function returns.
OWL_API void owlSetMaxInstancingDepth | ( | OWLContext | context, |
int32_t | maxInstanceDepth | ||
) |
sets maximum instancing depth for the given context:
'0' means 'no instancing allowed, only bottom-level accels; Note this mode isn't actually allowed in OWL right now, as the most convenient way of realizing it is actually slower than simply putting a single "dummy" instance (with just this one child, and a identify transform) over each blas.
'1' means 'at most one layer of instances' (ie, a two-level scene), where the 'root' world rays are traced against can be an instance group, but every child in that inscne group is a geometry group.
'N>1" means "up to N layers of instances are allowed.
The default instancing depth is 1 (ie, a two-level scene), since this allows for most use cases of instancing and is still hardware-accelerated. Using a node graph with instancing deeper than the configured value will result in wrong results; but be aware that using any value > 1 here will come with a cost. It is recommended to, if at all possible, leave this value to one and convert the input scene to a two-level scene layout (ie, with only one level of instances)
OWL_API OWLTexture owlTexture2DCreate | ( | OWLContext | context, |
OWLTexelFormat | texelFormat, | ||
uint32_t | size_x, | ||
uint32_t | size_y, | ||
const void * | texels, | ||
OWLTextureFilterMode filterMode | OWL_IF_CPP=OWL_TEXTURE_LINEAR, | ||
OWLTextureAddressMode addressMode | OWL_IF_CPP=OWL_TEXTURE_CLAMP, | ||
uint32_t linePitchInBytes | OWL_IF_CPP=0 | ||
) |
create new texture of given format and dimensions - for now, we only do "wrap" textures, and eithe rbilinear or nearest filter; once we allow for doing things like texture borders we'll have to change this api
size_x | number of texels in x dimension |
size_y | number of texels in y dimension |
OWL_IF_CPP | number of bytes between one line of texels and the next; '0' means 'size_x * sizeof(texel)' |
OWL_API void owlTexture2DDestroy | ( | OWLTexture | texture | ) |
destroy the given texture; after this call any accesses to the given texture are invalid
OWL_API CUtexObject owlTextureGetObject | ( | OWLTexture | texture, |
int | deviceID | ||
) |
returns the device handle of the given texture for the given device ID. Useful for custom texture object arrays.
OWL_API OWLGroup owlTrianglesGeomGroupCreate | ( | OWLContext | context, |
size_t | numGeometries, | ||
OWLGeom * | initValues | ||
) |
create a new group (which handles the acceleration strucure) for triangle geometries.
numGeometries | Number of geometries in this group, must be non-zero. |
arrayOfChildGeoms | A array of 'numGeometries' child geometries. Every geom in this array must be a valid owl geometry created with owlGeomCreate, and must be of a OWL_GEOM_TRIANGLES type. |
OWL_API void owlTrianglesSetIndices | ( | OWLGeom | triangles, |
OWLBuffer | indices, | ||
size_t | count, | ||
size_t | stride, | ||
size_t | offset | ||
) |
OWL_API void owlTrianglesSetMotionVertices | ( | OWLGeom | triangles, |
size_t | numKeys, | ||
OWLBuffer * | vertexArrays, | ||
size_t | count, | ||
size_t | stride, | ||
size_t | offset | ||
) |
numKeys | number of vertex arrays passed here, the first of those is for t=0, thelast for t=1, everything is linearly interpolated in-between |
OWL_API void owlTrianglesSetVertices | ( | OWLGeom | triangles, |
OWLBuffer | vertices, | ||
size_t | count, | ||
size_t | stride, | ||
size_t | offset | ||
) |
OWL_API OWLGroup owlUserGeomGroupCreate | ( | OWLContext | context, |
size_t | numGeometries, | ||
OWLGeom * | arrayOfChildGeoms | ||
) |
create a new group (which handles the acceleration strucure) for triangle geometries.
numGeometries | Number of geometries in this group, must be non-zero. |
arrayOfChildGeoms | A array of 'numGeomteries' child geometries. Every geom in this array must be a valid owl geometry created with owlGeomCreate, and must be of a OWL_GEOM_USER type. |
OWL_API void owlVariableRelease | ( | OWLVariable | variable | ) |
OWL_API void owlVariableSetBuffer | ( | OWLVariable | variable, |
OWLBuffer | value | ||
) |
OWL_API void owlVariableSetGroup | ( | OWLVariable | variable, |
OWLGroup | value | ||
) |
OWL_API void owlVariableSetPointer | ( | OWLVariable | variable, |
const void * | valuePtr | ||
) |
OWL_API void owlVariableSetRaw | ( | OWLVariable | variable, |
const void * | valuePtr | ||
) |
OWL_API void owlVariableSetTexture | ( | OWLVariable | variable, |
OWLTexture | value | ||
) |