Regular采样类定义和测试
这个算法是均匀采样算法,继承于Sampler类。
类声明:
#pragma once
#ifndef __REGULAR_HEADER__
#define __REGULAR_HEADER__ #include "sampler.h" class Regular :public Sampler {
public:
Regular();
~Regular();
Regular(const integer samps);
Regular(const integer samps, const integer sets);
Regular(const Regular& reg);
Regular& operator=(const Regular& reg);
virtual Sampler* clone() const;
virtual void generate_samples();
};
#endif
类实现:
#include "pch.h"
#include "regular.h" Regular::Regular() :Sampler() {
generate_samples();
} Regular::~Regular() {} Regular::Regular(const integer samps) : Sampler(samps) {
generate_samples();
} Regular::Regular(const integer samps, const integer sets) : Sampler(samps, sets) {
generate_samples();
} Regular::Regular(const Regular& reg) : Sampler(reg) {
generate_samples();
} Regular& Regular::operator=(const Regular& reg) {
if (this == ®)
return *this;
Sampler::operator=(reg);
return *this;
} Sampler* Regular::clone() const {
return new Regular(*this);
} void Regular::generate_samples() {
integer n = (integer)std::sqrt((ldouble)nsamples);
for (integer p = 0; p < nsets; p++) {
for (integer i=0;i<n;i++)
for (integer j = 0; j < n; j++) {
Point2 sp((j + 0.5) / n, (i + 0.5) / n); //均匀采样
samples.push_back(sp);
}
}
}
测试采样算法:
添加Sampler类和采样数到ViewPlane类中,增加函数(若无特殊声明,不再重复修改的部分)
void set_samples(const integer n);
void set_sampler(Sampler* const sp);
ViewPlane类具体声明如下:
#pragma once
#ifndef __VIEWPLANE_HEADER__
#define __VIEWPLANE_HEADER__ #include "../../Types.h" class Sampler; class ViewPlane {
public:
ViewPlane();
ViewPlane(const ViewPlane& vp);
void set_hres(const integer hr);
void set_vres(const integer vr);
void set_pixelsize(const ldouble ps);
void set_gamma(const ldouble ga);
void set_samples(const integer n);//新增
void set_sampler(Sampler* const sp);//新增
integer hres;
integer vres;
integer nsamples;//新增
ldouble s;
ldouble g;
Sampler* sampler;//新增
}; #endif
需要修改的类成员:
#include "pch.h"
#include "viewplane.h"
#include "../samplers/jittered.h" ViewPlane::ViewPlane() :hres(200), vres(100), s(0.02), g(1), nsamples(16), sampler(nullptr) {} ViewPlane::ViewPlane(const ViewPlane& vp)
: hres(vp.hres), vres(vp.vres), s(vp.s), g(vp.g), nsamples(vp.nsamples), sampler(vp.sampler) {} ... void ViewPlane::set_samples(const integer n) {//和书上不同,剔除特殊性,增加兼容性
nsamples = n;
sampler->clear();
sampler->set_num_samples(nsamples);
sampler->setup_shuffled_indices();
sampler->generate_samples();
} void ViewPlane::set_sampler(Sampler* const sp) {
if (sampler != nullptr) {
delete sampler;
sampler = nullptr;
}
nsamples = sp->get_num_samples();
sampler = sp;
}
World类只修改build和render部分:
void World::build() {
vp.set_hres(200);
vp.set_vres(100);
vp.set_sampler(new Regular());//所有采样修改都在这里测试
tracer_ptr = new MultiSphere(this);
Geometrics* obj = new Sphere(0, 0.5);
obj->set_color(RGBColor(1, 0, 0));
add_object(obj);
obj = new Sphere(Point3(0, -100.5, 0), 100);
obj->set_color(RGBColor(0, 0, 1));
add_object(obj);
}
render部分若无特殊声明,之后不再重复修改部分。
void World::render() {
Ray ray;
ldouble x, y;
open_window(vp.hres, vp.vres);
Point3 sp;
ray.o = Point3(0, 0, 1);
for (integer r = vp.vres - 1; r >= 0; r--)//render from left-corner to right-corner
for (integer c = 0; c < vp.hres; c++) {
RGBColor color;
for (integer p = 0; p < vp.nsamples; p++) {//增加样本
sp = vp.sampler->sample_unit_square();
x = vp.s * (c - 0.5 * vp.hres + sp.x);
y = vp.s * (r - 0.5 * vp.vres + sp.y);
ray.d = Point3(x, y, -1);
color += tracer_ptr->trace_ray(ray);
}
color /= vp.nsamples;
display_pixel(r, c, color);
}
}
修改完后,运行程序,测试效果如下(放大后,发现边角圆润了不少,接下来我们测试别的采样算法):
Regular采样类定义和测试的更多相关文章
- Jittered采样类定义和测试
抖动采样算法测试,小图形看不出什么明显区别,还是上代码和测试图吧. 类声明: #pragma once #ifndef __JITTERED_HEADER__ #define __JITTERED_H ...
- PureRandom采样类定义和测试
此是随机采样算法,效果感觉一般般. 类声明: #pragma once #ifndef __PURERANDOM_HEADER__ #define __PURERANDOM_HEADER__ #inc ...
- Hammersley采样类定义和测试
原理参照书籍 类声明: #pragma once #ifndef __HAMMERSLEY_HEADER__ #define __HAMMERSLEY_HEADER__ #include " ...
- NRooks采样类定义和测试
类声明: #pragma once #ifndef __NROOKS_HEADER__ #define __NROOKS_HEADER__ #include "sampler.h" ...
- MultiJittered采样类定义和测试
多重抖动在书上说的是水平和竖直方面随机交换. 类声明: #pragma once #ifndef __MULTIJITTERED_HEADER__ #define __MULTIJITTERED_HE ...
- Sampler类定义
此是所有采样的基类,这样定义的好处是,我们可以分别测试每一个采样算法. 类定义: #pragma once #ifndef __SAMPLER_HEADER__ #define __SAMPLER_H ...
- 开涛spring3(12.4) - 零配置 之 12.4 基于Java类定义Bean配置元数据
12.4 基于Java类定义Bean配置元数据 12.4.1 概述 基于Java类定义Bean配置元数据,其实就是通过Java类定义Spring配置元数据,且直接消除XML配置文件. 基于Java ...
- python类定义
在我的收藏中有一篇特别详细的类讲解 此处部分内容引自:http://blog.sina.com.cn/s/blog_59b6af690101bfem.html class myclass: 'this ...
- 20175312 2018-2019-2 《Java程序设计》第6周课下选做——类定义
20175312 2018-2019-2 <Java程序设计>第6周课下选做--类定义 设计思路 1.我觉得Book其实就是一个中转的作用,由测试类Bookself通过Book输入数据,然 ...
随机推荐
- Docker 与 K8S学习笔记(二十三)—— Kubernetes集群搭建
小伙伴们,好久不见,这几个月实在太忙,所以一直没有更新,今天刚好有空,咱们继续k8s的学习,由于我们后面需要深入学习Pod的调度,所以我们原先使用MiniKube搭建的实验环境就不能满足我们的需求了, ...
- 详解TCP四次挥手(断开TCP连接过程)
在讲述TCP四次挥手,即断开TCP连接的过程之前,需要先介绍一下TCP协议的包结构. TCP协议包结构: 这里只对涉及到四次挥手过程的字段做解释 (1) 序号(Sequence number) 我们通 ...
- EnvironmentLocationNotFound: Not a conda environment: C:\Program Files\Anaconda3
可参考:https://blog.csdn.net/dscn15848078969/article/details/114743744
- fpm工具安装
概述 最近在对机房的编译环境做整理,过程曲折而痛苦,记录一下. 之前的一个老项目,在打包的时候用到了一个叫做fpm的工具. 编译环境涉及centos6和centos7,在新的编译环境的过程中,如何安装 ...
- SQL语句修改MySQL用户密码
SQL语句修改MySQL用户密码 前言 上数据库安全实验课,用命令行和DataGrip试图修改用户密码,一直语法报错.最后用Navicat才修改成功,预览Navicat的SQL语句,发现语句和网上都不 ...
- 华为云Stack首席架构师:打造“称手”的数字化工具,答好政企IT数字化转型这道必选题
摘要:数字化转型是一号位工程,数字化的工具本身就是企业的核心竞争力. 本文分享自华为云社区<华为云Stack首席架构师:打造"称手"的数字化工具,答好政企IT数字化转型这道必 ...
- bitmap技术解析:redis与roaringBitmap
bitmap的表象意义是,使用一个01标识位来表示是否的状态,可以达到节省空间和高效判定的效果.在我们的实际工作中,也有着许多的应用场景,相信了解bitmap定会给你带来一些额外的收获. 1. bit ...
- word-制作三线表
找一个表格或插入一个表格, 找到 [设计] [新建表格样式] [将格式应用于: 整个表格] 点击"框线设置"按钮,在弹出的下拉菜单中分别选择 [上框线] 和 [下框线],然后分别设 ...
- SAP 实例 4 CFW
*&---------------------------------------------------------------------* *& Report demo_cfw ...
- Linux远程连接工具和运行级别
常用的Linux远程连接工具: xshell MobaXterm windows的命令行工具 Linux的运行级别 linux有七个运行级别 0----所有的服务都不开启,代表的式关机 1---代表的 ...