00001 /* 00002 toxic - A Global Illumination Renderer 00003 Copyright (C) 2003-2004 Francois Beaune 00004 Contact: http://toxicengine.sourceforge.net/ 00005 00006 This file is part of toxic. 00007 00008 toxic is free software; you can redistribute it and/or modify 00009 it under the terms of the GNU General Public License as published by 00010 the Free Software Foundation; either version 2 of the License, or 00011 (at your option) any later version. 00012 00013 toxic is distributed in the hope that it will be useful, 00014 but WITHOUT ANY WARRANTY; without even the implied warranty of 00015 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00016 GNU General Public License for more details. 00017 00018 You should have received a copy of the GNU General Public License 00019 along with toxic; if not, write to the Free Software 00020 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00021 */ 00022 00023 #include "stratifiedsurfacesampler.h" // include first 00024 #include "context.h" 00025 00026 #include <cassert> 00027 00028 using namespace sheep; 00029 using namespace toxic; 00030 00031 StratifiedSurfaceSampler::StratifiedSurfaceSampler(int w, int h) : 00032 ISurfaceSampler(w * h), 00033 m_w(w), m_h(h), 00034 m_inv_w(1.0 / w), 00035 m_inv_h(1.0 / h) 00036 { 00037 assert(m_w > 0); 00038 assert(m_h > 0); 00039 } 00040 00041 void StratifiedSurfaceSampler::GenerateNewSamples(const Context &context) { 00042 m_samples.clear(); 00043 00044 for(int j = 0; j < m_h; ++j) { 00045 for(int i = 0; i < m_w; ++i) { 00046 const Real xi1 = (i + context.m_rng->RandomReal1()) * m_inv_w; 00047 const Real xi2 = (j + context.m_rng->RandomReal1()) * m_inv_h; 00048 00049 m_samples.push_back(Point2(xi1, xi2)); 00050 } 00051 } 00052 }
1.3.6