本文整理汇总了C#中RayDen.Library.Core.Primitives.RgbSpectrum.Clamp方法的典型用法代码示例。如果您正苦于以下问题:C# RgbSpectrum.Clamp方法的具体用法?C# RgbSpectrum.Clamp怎么用?C# RgbSpectrum.Clamp使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类RayDen.Library.Core.Primitives.RgbSpectrum
的用法示例。
在下文中一共展示了RgbSpectrum.Clamp方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: FresnelApproxK
static RgbSpectrum FresnelApproxK(ref RgbSpectrum Fr)
{
RgbSpectrum reflectance = Fr.Clamp(0f, .999f);
var r = reflectance / (RgbSpectrum.UnitSpectrum() - reflectance);
return 2f * RgbSpectrum.Sqrt(ref r);
}
示例2: FresnelGeneral_Evaluate
protected Spectrum FresnelGeneral_Evaluate(Spectrum eta, Spectrum k, float cosi)
{
Spectrum sint2 = new Spectrum(Math.Max(0f, 1f - cosi * cosi));
if (cosi > 0f)
sint2 /= eta * eta;
else
sint2 *= eta * eta;
sint2 = sint2.Clamp(0f, 1f);
Spectrum cost2 = (Spectrum.UnitSpectrum() - sint2);
if (cosi > 0f)
{
Spectrum a = 2f * k * k * sint2;
return FrFull(cosi, ((cost2 + ((cost2 * cost2 + a * a).Sqrt())) / 2f).Sqrt(), eta, k);
}
else
{
Spectrum a = (2f * k * k * sint2);
Spectrum d2 = eta * eta + k * k;
return FrFull(-cosi, ((cost2 + (cost2 * cost2 + a * a).Sqrt()) / 2f).Sqrt(), eta / d2, (-1 * k) / d2);
}
}
示例3: FresnelApproxEta
static RgbSpectrum FresnelApproxEta(ref RgbSpectrum Fr)
{
RgbSpectrum reflectance = Fr.Clamp(0f, .999f);
return (RgbSpectrum.UnitSpectrum() + RgbSpectrum.Sqrt(ref reflectance)) / (RgbSpectrum.UnitSpectrum() - RgbSpectrum.Sqrt(ref reflectance));
}