Path: blob/master/thirdparty/embree/kernels/common/rtcore.h
9905 views
// Copyright 2009-2021 Intel Corporation1// SPDX-License-Identifier: Apache-2.023#pragma once45#include "../../include/embree4/rtcore.h"6RTC_NAMESPACE_USE78namespace embree9{10/*! decoding of intersection flags */11__forceinline bool isCoherent (RTCRayQueryFlags flags) { return (flags & RTC_RAY_QUERY_FLAG_COHERENT) == RTC_RAY_QUERY_FLAG_COHERENT; }12__forceinline bool isIncoherent(RTCRayQueryFlags flags) { return (flags & RTC_RAY_QUERY_FLAG_COHERENT) == RTC_RAY_QUERY_FLAG_INCOHERENT; }1314/*! Macros used in the rtcore API implementation */15#if 116# define RTC_CATCH_BEGIN17# define RTC_CATCH_END(device)18# define RTC_CATCH_END2(scene)19# define RTC_CATCH_END2_FALSE(scene) return false;20#else2122#define RTC_CATCH_BEGIN try {2324#define RTC_CATCH_END(device) \25} catch (std::bad_alloc&) { \26Device::process_error(device,RTC_ERROR_OUT_OF_MEMORY,"out of memory"); \27} catch (rtcore_error& e) { \28Device::process_error(device,e.error,e.what()); \29} catch (std::exception& e) { \30Device::process_error(device,RTC_ERROR_UNKNOWN,e.what()); \31} catch (...) { \32Device::process_error(device,RTC_ERROR_UNKNOWN,"unknown exception caught"); \33}3435#define RTC_CATCH_END2(scene) \36} catch (std::bad_alloc&) { \37Device* device = scene ? scene->device : nullptr; \38Device::process_error(device,RTC_ERROR_OUT_OF_MEMORY,"out of memory"); \39} catch (rtcore_error& e) { \40Device* device = scene ? scene->device : nullptr; \41Device::process_error(device,e.error,e.what()); \42} catch (std::exception& e) { \43Device* device = scene ? scene->device : nullptr; \44Device::process_error(device,RTC_ERROR_UNKNOWN,e.what()); \45} catch (...) { \46Device* device = scene ? scene->device : nullptr; \47Device::process_error(device,RTC_ERROR_UNKNOWN,"unknown exception caught"); \48}4950#define RTC_CATCH_END2_FALSE(scene) \51} catch (std::bad_alloc&) { \52Device* device = scene ? scene->device : nullptr; \53Device::process_error(device,RTC_ERROR_OUT_OF_MEMORY,"out of memory"); \54return false; \55} catch (rtcore_error& e) { \56Device* device = scene ? scene->device : nullptr; \57Device::process_error(device,e.error,e.what()); \58return false; \59} catch (std::exception& e) { \60Device* device = scene ? scene->device : nullptr; \61Device::process_error(device,RTC_ERROR_UNKNOWN,e.what()); \62return false; \63} catch (...) { \64Device* device = scene ? scene->device : nullptr; \65Device::process_error(device,RTC_ERROR_UNKNOWN,"unknown exception caught"); \66return false; \67}6869#endif7071#define RTC_VERIFY_HANDLE(handle) \72if (handle == nullptr) { \73throw_RTCError(RTC_ERROR_INVALID_ARGUMENT,"invalid argument"); \74}7576#define RTC_VERIFY_GEOMID(id) \77if (id == RTC_INVALID_GEOMETRY_ID) { \78throw_RTCError(RTC_ERROR_INVALID_ARGUMENT,"invalid argument"); \79}8081#define RTC_VERIFY_UPPER(id,upper) \82if (id > upper) { \83throw_RTCError(RTC_ERROR_INVALID_ARGUMENT,"invalid argument"); \84}8586#define RTC_VERIFY_RANGE(id,lower,upper) \87if (id < lower || id > upper) \88throw_RTCError(RTC_ERROR_INVALID_OPERATION,"argument out of bounds");8990#if 0 // enable to debug print all API calls91#define RTC_TRACE(x) std::cout << #x << std::endl;92#else93#define RTC_TRACE(x)94#endif9596#if 097/*! used to throw embree API errors */98struct rtcore_error : public std::exception99{100__forceinline rtcore_error(RTCError error, const std::string& str)101: error(error), str(str) {}102103~rtcore_error() throw() {}104105const char* what () const throw () {106return str.c_str();107}108109RTCError error;110std::string str;111};112#endif113114#if defined(DEBUG) // only report file and line in debug mode115#define throw_RTCError(error,str) \116printf("%s (%d): %s", __FILE__, __LINE__, std::string(str).c_str()), abort();117//throw rtcore_error(error,std::string(__FILE__) + " (" + toString(__LINE__) + "): " + std::string(str));118#else119#define throw_RTCError(error,str) \120abort();121//throw rtcore_error(error,str);122#endif123124#define RTC_BUILD_ARGUMENTS_HAS(settings,member) \125(settings.byteSize > (offsetof(RTCBuildArguments,member)+sizeof(settings.member)))126127128inline void storeTransform(const AffineSpace3fa& space, RTCFormat format, float* xfm)129{130switch (format)131{132case RTC_FORMAT_FLOAT3X4_ROW_MAJOR:133xfm[ 0] = space.l.vx.x; xfm[ 1] = space.l.vy.x; xfm[ 2] = space.l.vz.x; xfm[ 3] = space.p.x;134xfm[ 4] = space.l.vx.y; xfm[ 5] = space.l.vy.y; xfm[ 6] = space.l.vz.y; xfm[ 7] = space.p.y;135xfm[ 8] = space.l.vx.z; xfm[ 9] = space.l.vy.z; xfm[10] = space.l.vz.z; xfm[11] = space.p.z;136break;137138case RTC_FORMAT_FLOAT3X4_COLUMN_MAJOR:139xfm[ 0] = space.l.vx.x; xfm[ 1] = space.l.vx.y; xfm[ 2] = space.l.vx.z;140xfm[ 3] = space.l.vy.x; xfm[ 4] = space.l.vy.y; xfm[ 5] = space.l.vy.z;141xfm[ 6] = space.l.vz.x; xfm[ 7] = space.l.vz.y; xfm[ 8] = space.l.vz.z;142xfm[ 9] = space.p.x; xfm[10] = space.p.y; xfm[11] = space.p.z;143break;144145case RTC_FORMAT_FLOAT4X4_COLUMN_MAJOR:146xfm[ 0] = space.l.vx.x; xfm[ 1] = space.l.vx.y; xfm[ 2] = space.l.vx.z; xfm[ 3] = 0.f;147xfm[ 4] = space.l.vy.x; xfm[ 5] = space.l.vy.y; xfm[ 6] = space.l.vy.z; xfm[ 7] = 0.f;148xfm[ 8] = space.l.vz.x; xfm[ 9] = space.l.vz.y; xfm[10] = space.l.vz.z; xfm[11] = 0.f;149xfm[12] = space.p.x; xfm[13] = space.p.y; xfm[14] = space.p.z; xfm[15] = 1.f;150break;151152default:153#if !defined(__SYCL_DEVICE_ONLY__)154throw_RTCError(RTC_ERROR_INVALID_OPERATION, "invalid matrix format");155#endif156break;157}158}159}160161162