00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024 #if defined(_MSC_VER)
00025 #pragma once
00026 #endif
00027
00028 #ifndef PBRT_RENDERERS_AGGREGATETEST_H
00029 #define PBRT_RENDERERS_AGGREGATETEST_H
00030
00031
00032 #include "pbrt.h"
00033 #include "renderer.h"
00034 #include "memory.h"
00035
00036
00037 class AggregateTest : public Renderer {
00038 public:
00039
00040 AggregateTest(int nIters, const vector<Reference<Primitive> > &primitives);
00041 void Render(const Scene *scene);
00042 Spectrum Li(const Scene *scene, const RayDifferential &ray,
00043 const Sample *sample, RNG &rng, MemoryArena &arena, Intersection *isect = NULL,
00044 Spectrum *T = NULL) const;
00045 Spectrum Transmittance(const Scene *scene, const RayDifferential &ray,
00046 const Sample *sample, RNG &rng, MemoryArena &arena) const;
00047 private:
00048
00049 int nIterations;
00050 vector<Reference<Primitive> > primitives;
00051 vector<BBox> bboxes;
00052 };
00053
00054
00055 AggregateTest *CreateAggregateTestRenderer(const ParamSet ¶ms,
00056 const vector<Reference<Primitive> > &primitives);
00057
00058 #endif // PBRT_RENDERERS_AGGREGATETEST_H