2011-04-27 11:58:34 +00:00
|
|
|
/*
|
|
|
|
* Adapted from Open Shading Language with this license:
|
|
|
|
*
|
|
|
|
* Copyright (c) 2009-2010 Sony Pictures Imageworks Inc., et al.
|
|
|
|
* All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Modifications Copyright 2011, Blender Foundation.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions are
|
|
|
|
* met:
|
|
|
|
* * Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* * Neither the name of Sony Pictures Imageworks nor the names of its
|
|
|
|
* contributors may be used to endorse or promote products derived from
|
|
|
|
* this software without specific prior written permission.
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __OSL_CLOSURES_H__
|
|
|
|
#define __OSL_CLOSURES_H__
|
|
|
|
|
|
|
|
#include <OSL/oslclosure.h>
|
|
|
|
#include <OSL/oslexec.h>
|
|
|
|
#include <OSL/genclosure.h>
|
|
|
|
|
2012-10-20 12:18:00 +00:00
|
|
|
#include "kernel_types.h"
|
2011-04-27 11:58:34 +00:00
|
|
|
|
2012-10-20 12:18:00 +00:00
|
|
|
#include "util_types.h"
|
|
|
|
|
|
|
|
CCL_NAMESPACE_BEGIN
|
2011-04-27 11:58:34 +00:00
|
|
|
|
2012-10-06 16:28:02 +00:00
|
|
|
OSL::ClosureParam *closure_emission_params();
|
|
|
|
OSL::ClosureParam *closure_background_params();
|
|
|
|
OSL::ClosureParam *closure_holdout_params();
|
2012-11-06 19:59:02 +00:00
|
|
|
OSL::ClosureParam *closure_ambient_occlusion_params();
|
2012-12-11 14:39:41 +00:00
|
|
|
OSL::ClosureParam *closure_bsdf_diffuse_ramp_params();
|
2012-12-19 21:17:16 +00:00
|
|
|
OSL::ClosureParam *closure_bsdf_phong_ramp_params();
|
2013-05-18 14:36:03 +00:00
|
|
|
OSL::ClosureParam *closure_westin_backscatter_params();
|
|
|
|
OSL::ClosureParam *closure_westin_sheen_params();
|
2013-04-01 20:26:52 +00:00
|
|
|
OSL::ClosureParam *closure_bssrdf_params();
|
2012-10-20 12:18:00 +00:00
|
|
|
|
2011-04-27 11:58:34 +00:00
|
|
|
void closure_emission_prepare(OSL::RendererServices *, int id, void *data);
|
|
|
|
void closure_background_prepare(OSL::RendererServices *, int id, void *data);
|
|
|
|
void closure_holdout_prepare(OSL::RendererServices *, int id, void *data);
|
2012-11-06 19:59:02 +00:00
|
|
|
void closure_ambient_occlusion_prepare(OSL::RendererServices *, int id, void *data);
|
2012-12-11 14:39:41 +00:00
|
|
|
void closure_bsdf_diffuse_ramp_prepare(OSL::RendererServices *, int id, void *data);
|
2012-12-19 21:17:16 +00:00
|
|
|
void closure_bsdf_phong_ramp_prepare(OSL::RendererServices *, int id, void *data);
|
2013-05-18 14:36:03 +00:00
|
|
|
void closure_westin_backscatter_prepare(OSL::RendererServices *, int id, void *data);
|
|
|
|
void closure_westin_sheen_prepare(OSL::RendererServices *, int id, void *data);
|
2013-04-01 20:26:52 +00:00
|
|
|
void closure_bssrdf_prepare(OSL::RendererServices *, int id, void *data);
|
2012-11-06 19:59:02 +00:00
|
|
|
|
|
|
|
enum {
|
|
|
|
AmbientOcclusion = 100
|
|
|
|
};
|
2011-04-27 11:58:34 +00:00
|
|
|
|
|
|
|
#define CLOSURE_PREPARE(name, classname) \
|
|
|
|
void name(RendererServices *, int id, void *data) \
|
|
|
|
{ \
|
|
|
|
memset(data, 0, sizeof(classname)); \
|
|
|
|
new (data) classname(); \
|
|
|
|
}
|
|
|
|
|
2012-11-21 13:41:47 +00:00
|
|
|
#define CLOSURE_PREPARE_STATIC(name, classname) static CLOSURE_PREPARE(name, classname)
|
|
|
|
|
2012-12-15 10:18:42 +00:00
|
|
|
#define CLOSURE_FLOAT3_PARAM(st, fld) \
|
|
|
|
{ TypeDesc::TypeVector, reckless_offsetof(st, fld), NULL, sizeof(OSL::Vec3) }
|
|
|
|
|
|
|
|
#define TO_VEC3(v) OSL::Vec3(v.x, v.y, v.z)
|
|
|
|
#define TO_COLOR3(v) OSL::Color3(v.x, v.y, v.z)
|
2012-10-20 12:18:00 +00:00
|
|
|
#define TO_FLOAT3(v) make_float3(v[0], v[1], v[2])
|
|
|
|
|
|
|
|
/* BSDF */
|
|
|
|
|
|
|
|
class CBSDFClosure : public OSL::ClosurePrimitive {
|
|
|
|
public:
|
|
|
|
ShaderClosure sc;
|
|
|
|
|
2012-11-21 13:45:37 +00:00
|
|
|
CBSDFClosure(int scattering) : OSL::ClosurePrimitive(BSDF),
|
|
|
|
m_scattering_label(scattering), m_shaderdata_flag(0) { }
|
|
|
|
~CBSDFClosure() { }
|
2012-10-20 12:18:00 +00:00
|
|
|
|
2012-11-21 13:45:37 +00:00
|
|
|
int scattering() const { return m_scattering_label; }
|
|
|
|
int shaderdata_flag() const { return m_shaderdata_flag; }
|
2012-10-20 12:18:00 +00:00
|
|
|
|
2012-11-21 13:45:37 +00:00
|
|
|
virtual void blur(float roughness) = 0;
|
|
|
|
virtual float3 eval_reflect(const float3 &omega_out, const float3 &omega_in, float &pdf) const = 0;
|
|
|
|
virtual float3 eval_transmit(const float3 &omega_out, const float3 &omega_in, float &pdf) const = 0;
|
2012-10-20 12:18:00 +00:00
|
|
|
|
2012-11-21 13:45:37 +00:00
|
|
|
virtual int sample(const float3 &Ng,
|
|
|
|
const float3 &omega_out, const float3 &domega_out_dx, const float3 &domega_out_dy,
|
|
|
|
float randu, float randv,
|
|
|
|
float3 &omega_in, float3 &domega_in_dx, float3 &domega_in_dy,
|
|
|
|
float &pdf, float3 &eval) const = 0;
|
2012-10-20 12:18:00 +00:00
|
|
|
|
|
|
|
protected:
|
2012-11-21 13:45:37 +00:00
|
|
|
int m_scattering_label;
|
2012-10-20 12:18:00 +00:00
|
|
|
int m_shaderdata_flag;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define BSDF_CLOSURE_CLASS_BEGIN(Upper, lower, svmlower, TYPE) \
|
|
|
|
\
|
|
|
|
class Upper##Closure : public CBSDFClosure { \
|
|
|
|
public: \
|
|
|
|
Upper##Closure() : CBSDFClosure(TYPE) {} \
|
|
|
|
size_t memsize() const { return sizeof(*this); } \
|
|
|
|
const char *name() const { return #lower; } \
|
|
|
|
\
|
|
|
|
void setup() \
|
|
|
|
{ \
|
2012-12-15 10:18:42 +00:00
|
|
|
sc.prim = NULL; \
|
2012-10-20 12:18:00 +00:00
|
|
|
m_shaderdata_flag = bsdf_##lower##_setup(&sc); \
|
|
|
|
} \
|
|
|
|
\
|
|
|
|
bool mergeable(const ClosurePrimitive *other) const \
|
|
|
|
{ \
|
|
|
|
return false; \
|
|
|
|
} \
|
|
|
|
\
|
|
|
|
void blur(float roughness) \
|
|
|
|
{ \
|
|
|
|
bsdf_##svmlower##_blur(&sc, roughness); \
|
|
|
|
} \
|
|
|
|
\
|
|
|
|
void print_on(std::ostream &out) const \
|
|
|
|
{ \
|
|
|
|
out << name() << " ((" << sc.N[0] << ", " << sc.N[1] << ", " << sc.N[2] << "))"; \
|
|
|
|
} \
|
|
|
|
\
|
|
|
|
float3 eval_reflect(const float3 &omega_out, const float3 &omega_in, float& pdf) const \
|
|
|
|
{ \
|
|
|
|
return bsdf_##svmlower##_eval_reflect(&sc, omega_out, omega_in, &pdf); \
|
|
|
|
} \
|
|
|
|
\
|
|
|
|
float3 eval_transmit(const float3 &omega_out, const float3 &omega_in, float& pdf) const \
|
|
|
|
{ \
|
|
|
|
return bsdf_##svmlower##_eval_transmit(&sc, omega_out, omega_in, &pdf); \
|
|
|
|
} \
|
|
|
|
\
|
|
|
|
int sample(const float3 &Ng, \
|
|
|
|
const float3 &omega_out, const float3 &domega_out_dx, const float3 &domega_out_dy, \
|
|
|
|
float randu, float randv, \
|
|
|
|
float3 &omega_in, float3 &domega_in_dx, float3 &domega_in_dy, \
|
|
|
|
float &pdf, float3 &eval) const \
|
|
|
|
{ \
|
|
|
|
return bsdf_##svmlower##_sample(&sc, Ng, omega_out, domega_out_dx, domega_out_dy, \
|
|
|
|
randu, randv, &eval, &omega_in, &domega_in_dx, &domega_in_dy, &pdf); \
|
|
|
|
} \
|
|
|
|
}; \
|
|
|
|
\
|
2012-11-21 13:41:47 +00:00
|
|
|
static ClosureParam *bsdf_##lower##_params() \
|
2012-10-20 12:18:00 +00:00
|
|
|
{ \
|
|
|
|
static ClosureParam params[] = {
|
|
|
|
|
|
|
|
/* parameters */
|
|
|
|
|
|
|
|
#define BSDF_CLOSURE_CLASS_END(Upper, lower) \
|
|
|
|
CLOSURE_STRING_KEYPARAM("label"), \
|
|
|
|
CLOSURE_FINISH_PARAM(Upper##Closure) \
|
|
|
|
}; \
|
|
|
|
return params; \
|
|
|
|
} \
|
|
|
|
\
|
2012-11-21 13:41:47 +00:00
|
|
|
CLOSURE_PREPARE_STATIC(bsdf_##lower##_prepare, Upper##Closure)
|
2012-10-20 12:18:00 +00:00
|
|
|
|
2011-04-27 11:58:34 +00:00
|
|
|
CCL_NAMESPACE_END
|
|
|
|
|
|
|
|
#endif /* __OSL_CLOSURES_H__ */
|
|
|
|
|