Path: blob/master/thirdparty/embree/kernels/common/scene_user_geometry.h
9905 views
// Copyright 2009-2021 Intel Corporation1// SPDX-License-Identifier: Apache-2.023#pragma once45#include "accelset.h"67namespace embree8{9/*! User geometry with user defined intersection functions */10struct UserGeometry : public AccelSet11{12/*! type of this geometry */13static const Geometry::GTypeMask geom_type = Geometry::MTY_USER_GEOMETRY;1415public:16UserGeometry (Device* device, unsigned int items = 0, unsigned int numTimeSteps = 1);17virtual void setMask (unsigned mask) override;18virtual void setBoundsFunction (RTCBoundsFunction bounds, void* userPtr) override;19virtual void setIntersectFunctionN (RTCIntersectFunctionN intersect) override;20virtual void setOccludedFunctionN (RTCOccludedFunctionN occluded) override;21virtual void build() override {}22virtual void addElementsToCount (GeometryCounts & counts) const override;23virtual size_t getGeometryDataDeviceByteSize() const override;24virtual void convertToDeviceRepresentation(size_t offset, char* data_host, char* data_device) const override;2526__forceinline float projectedPrimitiveArea(const size_t i) const { return 0.0f; }27};2829namespace isa30{31struct UserGeometryISA : public UserGeometry32{33UserGeometryISA (Device* device)34: UserGeometry(device) {}3536PrimInfo createPrimRefArray(PrimRef* prims, const range<size_t>& r, size_t k, unsigned int geomID) const37{38PrimInfo pinfo(empty);39for (size_t j=r.begin(); j<r.end(); j++)40{41BBox3fa bounds = empty;42if (!buildBounds(j,&bounds)) continue;43const PrimRef prim(bounds,geomID,unsigned(j));44pinfo.add_center2(prim);45prims[k++] = prim;46}47return pinfo;48}4950PrimInfo createPrimRefArrayMB(mvector<PrimRef>& prims, size_t itime, const range<size_t>& r, size_t k, unsigned int geomID) const51{52PrimInfo pinfo(empty);53for (size_t j=r.begin(); j<r.end(); j++)54{55BBox3fa bounds = empty;56if (!buildBounds(j,itime,bounds)) continue;57const PrimRef prim(bounds,geomID,unsigned(j));58pinfo.add_center2(prim);59prims[k++] = prim;60}61return pinfo;62}6364PrimInfo createPrimRefArrayMB(PrimRef* prims, const BBox1f& time_range, const range<size_t>& r, size_t k, unsigned int geomID) const65{66PrimInfo pinfo(empty);67const BBox1f t0t1 = BBox1f::intersect(getTimeRange(), time_range);68if (t0t1.empty()) return pinfo;6970for (size_t j = r.begin(); j < r.end(); j++) {71LBBox3fa lbounds = empty;72if (!linearBounds(j, t0t1, lbounds))73continue;74const PrimRef prim(lbounds.bounds(), geomID, unsigned(j));75pinfo.add_center2(prim);76prims[k++] = prim;77}78return pinfo;79}8081PrimInfoMB createPrimRefMBArray(mvector<PrimRefMB>& prims, const BBox1f& t0t1, const range<size_t>& r, size_t k, unsigned int geomID) const82{83PrimInfoMB pinfo(empty);84for (size_t j=r.begin(); j<r.end(); j++)85{86if (!valid(j, timeSegmentRange(t0t1))) continue;87const PrimRefMB prim(linearBounds(j,t0t1),this->numTimeSegments(),this->time_range,this->numTimeSegments(),geomID,unsigned(j));88pinfo.add_primref(prim);89prims[k++] = prim;90}91return pinfo;92}93};94}9596DECLARE_ISA_FUNCTION(UserGeometry*, createUserGeometry, Device*);97}9899100