| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276 |
- // ======================================================================== //
- // Copyright 2009-2017 Intel Corporation //
- // //
- // Licensed under the Apache License, Version 2.0 (the "License"); //
- // you may not use this file except in compliance with the License. //
- // You may obtain a copy of the License at //
- // //
- // http://www.apache.org/licenses/LICENSE-2.0 //
- // //
- // Unless required by applicable law or agreed to in writing, software //
- // distributed under the License is distributed on an "AS IS" BASIS, //
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. //
- // See the License for the specific language governing permissions and //
- // limitations under the License. //
- // ======================================================================== //
- #ifndef __RTCORE_SCENE_H__
- #define __RTCORE_SCENE_H__
- /*! \ingroup embree_kernel_api */
- /*! \{ */
- /*! forward declarations for ray structures */
- struct RTCRay;
- struct RTCRay4;
- struct RTCRay8;
- struct RTCRay16;
- struct RTCRayNp;
- /*! scene flags */
- enum RTCSceneFlags
- {
- /* dynamic type flags */
- RTC_SCENE_STATIC = (0 << 0), //!< specifies static scene
- RTC_SCENE_DYNAMIC = (1 << 0), //!< specifies dynamic scene
- /* acceleration structure flags */
- RTC_SCENE_COMPACT = (1 << 8), //!< use memory conservative data structures
- RTC_SCENE_COHERENT = (1 << 9), //!< optimize data structures for coherent rays
- RTC_SCENE_INCOHERENT = (1 << 10), //!< optimize data structures for in-coherent rays (enabled by default)
- RTC_SCENE_HIGH_QUALITY = (1 << 11), //!< create higher quality data structures
- /* traversal algorithm flags */
- RTC_SCENE_ROBUST = (1 << 16) //!< use more robust traversal algorithms
- };
- /*! enabled algorithm flags */
- enum RTCAlgorithmFlags
- {
- RTC_INTERSECT1 = (1 << 0), //!< enables the rtcIntersect1 and rtcOccluded1 functions for this scene
- RTC_INTERSECT4 = (1 << 1), //!< enables the rtcIntersect4 and rtcOccluded4 functions for this scene
- RTC_INTERSECT8 = (1 << 2), //!< enables the rtcIntersect8 and rtcOccluded8 functions for this scene
- RTC_INTERSECT16 = (1 << 3), //!< enables the rtcIntersect16 and rtcOccluded16 functions for this scene
- RTC_INTERPOLATE = (1 << 4), //!< enables the rtcInterpolate function for this scene
- RTC_INTERSECT_STREAM = (1 << 5), //!< enables the rtcIntersectN and rtcOccludedN functions for this scene
- };
- /*! intersection flags */
- enum RTCIntersectFlags
- {
- RTC_INTERSECT_COHERENT = 0, //!< optimize for coherent rays
- RTC_INTERSECT_INCOHERENT = 1 //!< optimize for incoherent rays
- };
- /*! intersection context passed to intersect/occluded calls */
- struct RTCIntersectContext
- {
- RTCIntersectFlags flags; //!< intersection flags
- void* userRayExt; //!< can be used to pass extended ray data to callbacks
- };
- /*! \brief Defines an opaque scene type */
- typedef struct __RTCScene {}* RTCScene;
- /*! Creates a new scene.
- WARNING: This function is deprecated, use rtcDeviceNewScene instead.
- */
- RTCORE_API RTCORE_DEPRECATED RTCScene rtcNewScene (RTCSceneFlags flags, RTCAlgorithmFlags aflags);
- /*! Creates a new scene. */
- RTCORE_API RTCScene rtcDeviceNewScene (RTCDevice device, RTCSceneFlags flags, RTCAlgorithmFlags aflags);
- /*! \brief Type of progress callback function. */
- typedef bool (*RTCProgressMonitorFunc)(void* ptr, const double n);
- RTCORE_DEPRECATED typedef RTCProgressMonitorFunc RTC_PROGRESS_MONITOR_FUNCTION;
- /*! \brief Sets the progress callback function which is called during hierarchy build of this scene. */
- RTCORE_API void rtcSetProgressMonitorFunction(RTCScene scene, RTCProgressMonitorFunc func, void* ptr);
- /*! Commits the geometry of the scene. After initializing or modifying
- * geometries, commit has to get called before tracing
- * rays. */
- RTCORE_API void rtcCommit (RTCScene scene);
- /*! Commits the geometry of the scene in join mode. When Embree is
- * using TBB (default), threads that call `rtcCommitJoin` will
- * participate in the hierarchy build procedure. When Embree is using
- * the internal tasking system, exclusively threads that call
- * `rtcCommitJoin` will execute the build procedure. Do not
- * mix `rtcCommitJoin` with other commit calls. */
- RTCORE_API void rtcCommitJoin (RTCScene scene);
- /*! Commits the geometry of the scene. The calling threads will be
- * used internally as a worker threads on some implementations. The
- * function will wait until 'numThreads' threads have called this
- * function and all threads return from the function after the scene
- * commit is finished. The application threads will not be used as
- * worker threads when the TBB tasking system is enabled (which is
- * the default). On CPUs, we recommend also using TBB inside your
- * application to share threads. We recommend using the
- * rtcCommitThread feature to share threads on the Xeon Phi
- * coprocessor. */
- RTCORE_API void rtcCommitThread(RTCScene scene, unsigned int threadID, unsigned int numThreads);
- /*! Returns AABB of the scene. rtcCommit has to get called
- * previously to this function. */
- RTCORE_API void rtcGetBounds(RTCScene scene, RTCBounds& bounds_o);
- /*! Returns linear AABBs of the scene. The result bounds_o gets filled
- * with AABBs for time 0 and time 1. rtcCommit has to get called
- * previously to this function. */
- RTCORE_API void rtcGetLinearBounds(RTCScene scene, RTCBounds* bounds_o);
- /*! Intersects a single ray with the scene. The ray has to be aligned
- * to 16 bytes. This function can only be called for scenes with the
- * RTC_INTERSECT1 flag set. */
- RTCORE_API void rtcIntersect (RTCScene scene, RTCRay& ray);
- /*! Intersects a single ray with the scene. The ray has to be aligned
- * to 16 bytes. This function can only be called for scenes with the
- * RTC_INTERSECT1 flag set. */
- RTCORE_API void rtcIntersect1Ex (RTCScene scene, const RTCIntersectContext* context, RTCRay& ray);
- /*! Intersects a packet of 4 rays with the scene. The valid mask and
- * ray have both to be aligned to 16 bytes. This function can only be
- * called for scenes with the RTC_INTERSECT4 flag set. */
- RTCORE_API void rtcIntersect4 (const void* valid, RTCScene scene, RTCRay4& ray);
- /*! Intersects a packet of 4 rays with the scene. The valid mask and
- * ray have both to be aligned to 16 bytes. This function can only be
- * called for scenes with the RTC_INTERSECT4 flag set. */
- RTCORE_API void rtcIntersect4Ex (const void* valid, RTCScene scene, const RTCIntersectContext* context, RTCRay4& ray);
- /*! Intersects a packet of 8 rays with the scene. The valid mask and
- * ray have both to be aligned to 32 bytes. This function can only be
- * called for scenes with the RTC_INTERSECT8 flag set. For performance
- * reasons, the rtcIntersect8 function should only get called if the
- * CPU supports AVX. */
- RTCORE_API void rtcIntersect8 (const void* valid, RTCScene scene, RTCRay8& ray);
- /*! Intersects a packet of 8 rays with the scene. The valid mask and
- * ray have both to be aligned to 32 bytes. This function can only be
- * called for scenes with the RTC_INTERSECT8 flag set. For performance
- * reasons, the rtcIntersect8 function should only get called if the
- * CPU supports AVX. */
- RTCORE_API void rtcIntersect8Ex (const void* valid, RTCScene scene, const RTCIntersectContext* context, RTCRay8& ray);
- /*! Intersects a packet of 16 rays with the scene. The valid mask and
- * ray have both to be aligned to 64 bytes. This function can only be
- * called for scenes with the RTC_INTERSECT16 flag set. For
- * performance reasons, the rtcIntersect16 function should only get
- * called if the CPU supports the 16-wide SIMD instructions. */
- RTCORE_API void rtcIntersect16 (const void* valid, RTCScene scene, RTCRay16& ray);
- /*! Intersects a packet of 16 rays with the scene. The valid mask and
- * ray have both to be aligned to 64 bytes. This function can only be
- * called for scenes with the RTC_INTERSECT16 flag set. For
- * performance reasons, the rtcIntersect16 function should only get
- * called if the CPU supports the 16-wide SIMD instructions. */
- RTCORE_API void rtcIntersect16Ex (const void* valid, RTCScene scene, const RTCIntersectContext* context, RTCRay16& ray);
- /*! Intersects a stream of M rays with the scene. This function can
- * only be called for scenes with the RTC_INTERSECT_STREAM flag set. The
- * stride specifies the offset between rays in bytes. */
- RTCORE_API void rtcIntersect1M (RTCScene scene, const RTCIntersectContext* context, RTCRay* rays, const size_t M, const size_t stride);
- /*! Intersects a stream of pointers to M rays with the scene. This function can
- * only be called for scenes with the RTC_INTERSECT_STREAM flag set. */
- RTCORE_API void rtcIntersect1Mp (RTCScene scene, const RTCIntersectContext* context, RTCRay** rays, const size_t M);
- /*! Intersects a stream of M ray packets of size N in SOA format with the
- * scene. This function can only be called for scenes with the
- * RTC_INTERSECT_STREAM flag set. The stride specifies the offset between
- * ray packets in bytes. */
- RTCORE_API void rtcIntersectNM (RTCScene scene, const RTCIntersectContext* context, struct RTCRayN* rays, const size_t N, const size_t M, const size_t stride);
- /*! Intersects a stream of M ray packets of size N in SOA format with
- * the scene. This function can only be called for scenes with the
- * RTC_INTERSECT_STREAM flag set. The stride specifies the offset between
- * ray packets in bytes. In contrast to the rtcIntersectNM function
- * this function accepts a separate data pointer for each component
- * of the ray packet. */
- RTCORE_API void rtcIntersectNp (RTCScene scene, const RTCIntersectContext* context, const RTCRayNp& rays, const size_t N);
- /*! Tests if a single ray is occluded by the scene. The ray has to be
- * aligned to 16 bytes. This function can only be called for scenes
- * with the RTC_INTERSECT1 flag set. */
- RTCORE_API void rtcOccluded (RTCScene scene, RTCRay& ray);
- /*! Tests if a single ray is occluded by the scene. The ray has to be
- * aligned to 16 bytes. This function can only be called for scenes
- * with the RTC_INTERSECT1 flag set. */
- RTCORE_API void rtcOccluded1Ex (RTCScene scene, const RTCIntersectContext* context, RTCRay& ray);
- /*! Tests if a packet of 4 rays is occluded by the scene. This
- * function can only be called for scenes with the RTC_INTERSECT4
- * flag set. The valid mask and ray have both to be aligned to 16
- * bytes. */
- RTCORE_API void rtcOccluded4 (const void* valid, RTCScene scene, RTCRay4& ray);
- /*! Tests if a packet of 4 rays is occluded by the scene. This
- * function can only be called for scenes with the RTC_INTERSECT4
- * flag set. The valid mask and ray have both to be aligned to 16
- * bytes. */
- RTCORE_API void rtcOccluded4Ex (const void* valid, RTCScene scene, const RTCIntersectContext* context, RTCRay4& ray);
- /*! Tests if a packet of 8 rays is occluded by the scene. The valid
- * mask and ray have both to be aligned to 32 bytes. This function
- * can only be called for scenes with the RTC_INTERSECT8 flag
- * set. For performance reasons, the rtcOccluded8 function should
- * only get called if the CPU supports AVX. */
- RTCORE_API void rtcOccluded8 (const void* valid, RTCScene scene, RTCRay8& ray);
- /*! Tests if a packet of 8 rays is occluded by the scene. The valid
- * mask and ray have both to be aligned to 32 bytes. This function
- * can only be called for scenes with the RTC_INTERSECT8 flag
- * set. For performance reasons, the rtcOccluded8 function should
- * only get called if the CPU supports AVX. */
- RTCORE_API void rtcOccluded8Ex (const void* valid, RTCScene scene, const RTCIntersectContext* context, RTCRay8& ray);
- /*! Tests if a packet of 16 rays is occluded by the scene. The valid
- * mask and ray have both to be aligned to 64 bytes. This function
- * can only be called for scenes with the RTC_INTERSECT16 flag
- * set. For performance reasons, the rtcOccluded16 function should
- * only get called if the CPU supports the 16-wide SIMD
- * instructions. */
- RTCORE_API void rtcOccluded16 (const void* valid, RTCScene scene, RTCRay16& ray);
- /*! Tests if a packet of 16 rays is occluded by the scene. The valid
- * mask and ray have both to be aligned to 64 bytes. This function
- * can only be called for scenes with the RTC_INTERSECT16 flag
- * set. For performance reasons, the rtcOccluded16 function should
- * only get called if the CPU supports the 16-wide SIMD
- * instructions. */
- RTCORE_API void rtcOccluded16Ex (const void* valid, RTCScene scene, const RTCIntersectContext* context, RTCRay16& ray);
- /*! Tests if a stream of M rays is occluded by the scene. This
- * function can only be called for scenes with the RTC_INTERSECT_STREAM
- * flag set. The stride specifies the offset between rays in bytes.*/
- RTCORE_API void rtcOccluded1M (RTCScene scene, const RTCIntersectContext* context, RTCRay* rays, const size_t M, const size_t stride);
- /*! Tests if a stream of pointers to M rays is occluded by the scene. This
- * function can only be called for scenes with the RTC_INTERSECT_STREAM
- * flag set. */
- RTCORE_API void rtcOccluded1Mp (RTCScene scene, const RTCIntersectContext* context, RTCRay** rays, const size_t M);
- /*! Tests if a stream of M ray packets of size N in SOA format is occluded by
- * the scene. This function can only be called for scenes with the
- * RTC_INTERSECT_STREAM flag set. The stride specifies the offset between
- * rays in bytes.*/
- RTCORE_API void rtcOccludedNM (RTCScene scene, const RTCIntersectContext* context, struct RTCRayN* rays, const size_t N, const size_t M, const size_t stride);
- /*! Tests if a stream of M ray packets of size N in SOA format is
- * occluded by the scene. This function can only be called for scenes
- * with the RTC_INTERSECT_STREAM flag set. The stride specifies the offset
- * between rays in bytes. In contrast to the rtcOccludedNM function
- * this function accepts a separate data pointer for each component
- * of the ray packet. */
- RTCORE_API void rtcOccludedNp (RTCScene scene, const RTCIntersectContext* context, const RTCRayNp& rays, const size_t N);
- /*! Deletes the scene. All contained geometry get also destroyed. */
- RTCORE_API void rtcDeleteScene (RTCScene scene);
- /*! @} */
- #endif
|