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 inline 00024 sheep::Real LambertianEDF::Evaluate(const Context &context, 00025 const sheep::Vector3 &direction) const 00026 { 00027 assert(direction.IsUnitLength()); 00028 assert(direction.m_y >= 0.0); 00029 00030 return 1.0 / sheep::PI; 00031 } 00032 00033 inline 00034 void LambertianEDF::Sample(const Context &context, 00035 sheep::Vector3 *direction, 00036 sheep::Real *prob) const 00037 { 00038 assert(direction); 00039 assert(prob); 00040 00041 const sheep::Real xi1 = context.m_rng->RandomReal1(); 00042 const sheep::Real xi2 = context.m_rng->RandomReal1(); 00043 00044 *direction = sheep::CosineHemisphereSampling(xi1, xi2); 00045 assert(direction->IsUnitLength()); 00046 00047 *prob = direction->m_y / sheep::PI; 00048 }
1.3.6