Path Tracer
SpecularMaterial.h
Go to the documentation of this file.
1 #ifndef DEF_SPECULARMATERIAL
2 #define DEF_SPECULARMATERIAL
3 
4 #include "Material.h"
5 
61 class SpecularMaterial : public Material {
62 public:
63  SpecularMaterial(DoubleVec3D emittance = 0);
64  SpecularMaterial(const SpecularMaterial& material);
65 
66  Material* deepCopy() const;
67 
68  DoubleUnitVec3D getNewDirection(const Ray& previousRay, const DoubleUnitVec3D& normal) const;
69  DoubleVec3D computeCurrentRadiance(const DoubleVec3D& recursiveRadiance, double cosAngleNewDirectionNormal, bool nextEventEstimation = false) const;
70  bool worksWithNextEventEstimation() const;
71 
72  std::ostream& getDescription(std::ostream& stream) const;
73  std::string getType() const;
75  void setSpecificParametersJson(const json& j);
76 };
77 
78 #endif
nlohmann::json json
Definition: InterfaceGestion.h:14
Defines the Material class and some functions around it.
A three-dimensional unit vector using doubles.
Definition: DoubleUnitVec3D.h:61
A three-dimensional vector using double values.
Definition: DoubleVec3D.h:190
Abstrat class that models a material.
Definition: Material.h:77
Combination of an origin and a direction.
Definition: Ray.h:44
Models a specular material.
Definition: SpecularMaterial.h:61
void setSpecificParametersJson(const json &j)
Sets this material's specific parameters according to json.
Definition: SpecularMaterial.cpp:38
DoubleUnitVec3D getNewDirection(const Ray &previousRay, const DoubleUnitVec3D &normal) const
Computes the new ray direction.
Definition: SpecularMaterial.cpp:16
SpecularMaterial(DoubleVec3D emittance=0)
Default and main constructor.
Definition: SpecularMaterial.cpp:4
std::ostream & getDescription(std::ostream &stream) const
Returns this material's description.
Definition: SpecularMaterial.cpp:29
std::string getType() const
Returns "Specular".
Definition: SpecularMaterial.cpp:36
DoubleVec3D computeCurrentRadiance(const DoubleVec3D &recursiveRadiance, double cosAngleNewDirectionNormal, bool nextEventEstimation=false) const
Computes the new radiance.
Definition: SpecularMaterial.cpp:21
json getSpecificParametersJson() const
Converts this material's specific parameters to json.
Definition: SpecularMaterial.cpp:37
Material * deepCopy() const
Makes a deep copy of this material.
Definition: SpecularMaterial.cpp:12
bool worksWithNextEventEstimation() const
Returns whether this material works with next event estimation.
Definition: SpecularMaterial.cpp:25