diff options
Diffstat (limited to 'src/render.cpp')
-rw-r--r-- | src/render.cpp | 17 |
1 files changed, 8 insertions, 9 deletions
diff --git a/src/render.cpp b/src/render.cpp index 0bbe5cb..c278797 100644 --- a/src/render.cpp +++ b/src/render.cpp @@ -13,28 +13,26 @@ const Vec3d up = Vec3d(0, 1, 0); -Sampler::Sampler() { - m_seed = 0; -} - -void Sampler::seed(unsigned seed) { +void Random::seed(unsigned seed) { for (unsigned i = 0; i < seed; i++) { rand_r(&m_seed); } } -double Sampler::random() { +double Random::operator()() { return (double)rand_r(&m_seed) / (double)RAND_MAX; } +Sampler::Sampler(Random &src) : m_src(src) { } + Vec3d Sampler::sample(const Vec3d &norm) { /* auto theta = asin(pow(1 - random(), (double)1 / (1 + SAMPLING_POWER))); auto phi = 2 * M_PI * random(); */ - auto theta = 2.0 * M_PI * random(); - auto phi = acos(2.0 * random() - 1.0); + auto theta = 2.0 * M_PI * m_src(); + auto phi = acos(2.0 * m_src() - 1.0); auto sinphi = sin(phi); @@ -48,6 +46,7 @@ Vec3d Sampler::sample(const Vec3d &norm) { } Renderer::Renderer(const Scene &scn, Vec3d eye, Vec3d target, unsigned width, unsigned height, unsigned maxhops) : + m_sampler(m_random), m_scn(scn) { m_eye = eye; @@ -88,11 +87,11 @@ Ray Renderer::findray(double x, double y) const { } Color Renderer::render(unsigned x, unsigned y, unsigned samples) { - auto r = findray(x, y); Color sum(0, 0, 0); for (unsigned i = 0; i < samples; i++) { + auto r = findray(x + m_random(), y + m_random()); sum += pathtrace_sample(r, 0); } |