2022-04-07 18:46:57 +02:00

88 lines
3.3 KiB
C++

/*
This file is part of Nori, a simple educational ray tracer
Copyright (c) 2015 by Wenzel Jakob
Nori is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License Version 3
as published by the Free Software Foundation.
Nori is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include <nori/common.h>
#include <nori/mipmap.h>
#include <nori/sampler.h>
NORI_NAMESPACE_BEGIN
/// A collection of useful warping functions for importance sampling
class Warp {
public:
/// Dummy warping function: takes uniformly distributed points in a square and just returns them
static Point2f squareToUniformSquare(const Point2f &sample);
/// Probability density of \ref squareToUniformSquare()
static float squareToUniformSquarePdf(const Point2f &p);
/// Sample a 2D tent distribution
static Point2f squareToTent(const Point2f &sample);
/// Probability density of \ref squareToTent()
static float squareToTentPdf(const Point2f &p);
/// Uniformly sample a vector on a 2D disk with radius 1, centered around the origin
static Point2f squareToUniformDisk(const Point2f &sample);
/// Probability density of \ref squareToUniformDisk()
static float squareToUniformDiskPdf(const Point2f &p);
/// Uniformly sample a vector on the unit sphere with respect to solid angles
static Vector3f squareToUniformSphere(const Point2f &sample);
/// Probability density of \ref squareToUniformSphere()
static float squareToUniformSpherePdf(const Vector3f &v);
/// Uniformly sample a vector on the unit hemisphere around the pole (0,0,1) with respect to solid angles
static Vector3f squareToUniformHemisphere(const Point2f &sample);
/// Probability density of \ref squareToUniformHemisphere()
static float squareToUniformHemispherePdf(const Vector3f &v);
/// Uniformly sample a vector on the unit hemisphere around the pole (0,0,1) with respect to projected solid angles
static Vector3f squareToCosineHemisphere(const Point2f &sample);
/// Probability density of \ref squareToCosineHemisphere()
static float squareToCosineHemispherePdf(const Vector3f &v);
/// Warp a uniformly distributed square sample to a Beckmann distribution * cosine for the given 'alpha' parameter
static Vector3f squareToBeckmann(const Point2f &sample, float alpha);
/// Probability density of \ref squareToBeckmann()
static float squareToBeckmannPdf(const Vector3f &m, float alpha);
/// Warp a uniformly distributed square sample using Hierarchical Sample Warping
static Point2f squareToHSW(const Point2f &sample, const Mipmap &mm);
/// Probability density of \ref squareToHSW()
static float squareToHSWPdf(const Point2f &m, const Mipmap &mm);
static Vector3f squareToGTR1(const Point2f & sample, float a);
static float squareToGTR1Pdf(const Vector3f & m, float a);
static Vector3f squareToGTR2(const Point2f & sample, float a);
static float squareToGTR2Pdf(const Vector3f & m, float a);
};
NORI_NAMESPACE_END