| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149 |
- // ======================================================================== //
- // 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. //
- // ======================================================================== //
- #include "instance_intersector1.h"
- #include "../common/scene.h"
- namespace embree
- {
- namespace isa
- {
- void InstanceBoundsFunction(void* userPtr, const Instance* instance, size_t item, size_t itime, BBox3fa& bounds_o)
- {
- assert(itime < instance->numTimeSteps);
- unsigned num_time_segments = instance->numTimeSegments();
- if (num_time_segments == 0) {
- bounds_o = xfmBounds(instance->local2world[itime],instance->object->bounds.bounds());
- }
- else {
- const float ftime = float(itime) / float(num_time_segments);
- const BBox3fa obounds = instance->object->bounds.interpolate(ftime);
- bounds_o = xfmBounds(instance->local2world[itime],obounds);
- }
- }
- RTCBoundsFunc3 InstanceBoundsFunc() {
- return (RTCBoundsFunc3) InstanceBoundsFunction;
- }
- void FastInstanceIntersector1::intersect(const Instance* instance, Ray& ray, size_t item)
- {
- const AffineSpace3fa world2local =
- likely(instance->numTimeSteps == 1) ? instance->getWorld2Local() : instance->getWorld2Local(ray.time);
- const Vec3fa ray_org = ray.org;
- const Vec3fa ray_dir = ray.dir;
- const int ray_geomID = ray.geomID;
- const int ray_instID = ray.instID;
- ray.org = xfmPoint (world2local,ray_org);
- ray.dir = xfmVector(world2local,ray_dir);
- ray.geomID = RTC_INVALID_GEOMETRY_ID;
- ray.instID = instance->id;
- IntersectContext context(instance->object,nullptr);
- instance->object->intersect((RTCRay&)ray,&context);
- ray.org = ray_org;
- ray.dir = ray_dir;
- if (ray.geomID == RTC_INVALID_GEOMETRY_ID) {
- ray.geomID = ray_geomID;
- ray.instID = ray_instID;
- }
- }
-
- void FastInstanceIntersector1::occluded (const Instance* instance, Ray& ray, size_t item)
- {
- const AffineSpace3fa world2local =
- likely(instance->numTimeSteps == 1) ? instance->getWorld2Local() : instance->getWorld2Local(ray.time);
- const Vec3fa ray_org = ray.org;
- const Vec3fa ray_dir = ray.dir;
- ray.org = xfmPoint (world2local,ray_org);
- ray.dir = xfmVector(world2local,ray_dir);
- ray.instID = instance->id;
- IntersectContext context(instance->object,nullptr);
- instance->object->occluded((RTCRay&)ray,&context);
- ray.org = ray_org;
- ray.dir = ray_dir;
- }
-
- DEFINE_SET_INTERSECTOR1(InstanceIntersector1,FastInstanceIntersector1);
- void FastInstanceIntersector1M::intersect(const Instance* instance, RTCIntersectContext* context, Ray** rays, size_t M, size_t item)
- {
- assert(M<=MAX_INTERNAL_STREAM_SIZE);
- Ray lrays[MAX_INTERNAL_STREAM_SIZE];
- AffineSpace3fa world2local = instance->getWorld2Local();
- for (size_t i=0; i<M; i++)
- {
- if (unlikely(instance->numTimeSteps != 1))
- world2local = instance->getWorld2Local(rays[i]->time);
- lrays[i].org = xfmPoint (world2local,rays[i]->org);
- lrays[i].dir = xfmVector(world2local,rays[i]->dir);
- lrays[i].tnear = rays[i]->tnear;
- lrays[i].tfar = rays[i]->tfar;
- lrays[i].time = rays[i]->time;
- lrays[i].mask = rays[i]->mask;
- lrays[i].geomID = RTC_INVALID_GEOMETRY_ID;
- lrays[i].instID = instance->id;
- }
- rtcIntersect1M((RTCScene)instance->object,context,(RTCRay*)lrays,M,sizeof(Ray));
-
- for (size_t i=0; i<M; i++)
- {
- if (lrays[i].geomID == RTC_INVALID_GEOMETRY_ID) continue;
- rays[i]->instID = lrays[i].instID;
- rays[i]->geomID = lrays[i].geomID;
- rays[i]->primID = lrays[i].primID;
- rays[i]->u = lrays[i].u;
- rays[i]->v = lrays[i].v;
- rays[i]->tfar = lrays[i].tfar;
- rays[i]->Ng = lrays[i].Ng;
- }
- }
-
- void FastInstanceIntersector1M::occluded (const Instance* instance, RTCIntersectContext* context, Ray** rays, size_t M, size_t item)
- {
- assert(M<MAX_INTERNAL_STREAM_SIZE);
- Ray lrays[MAX_INTERNAL_STREAM_SIZE];
- AffineSpace3fa world2local = instance->getWorld2Local();
-
- for (size_t i=0; i<M; i++)
- {
- if (unlikely(instance->numTimeSteps != 1))
- world2local = instance->getWorld2Local(rays[i]->time);
- lrays[i].org = xfmPoint (world2local,rays[i]->org);
- lrays[i].dir = xfmVector(world2local,rays[i]->dir);
- lrays[i].tnear = rays[i]->tnear;
- lrays[i].tfar = rays[i]->tfar;
- lrays[i].time = rays[i]->time;
- lrays[i].mask = rays[i]->mask;
- lrays[i].geomID = RTC_INVALID_GEOMETRY_ID;
- lrays[i].instID = instance->id;
- }
- rtcOccluded1M((RTCScene)instance->object,context,(RTCRay*)lrays,M,sizeof(Ray));
-
- for (size_t i=0; i<M; i++)
- {
- if (lrays[i].geomID == RTC_INVALID_GEOMETRY_ID) continue;
- rays[i]->geomID = 0;
- }
- }
- DEFINE_SET_INTERSECTOR1M(InstanceIntersector1M,FastInstanceIntersector1M);
- }
- }
|