当前位置: 首页 > news >正文

GAMES101 笔记 Lecture13 光线追踪1

目录

      • Why Ray Tracing?(为什么需要光线追踪?)
      • Basic Ray Tracing Algorithm(基础的光线追踪算法)
        • Ray Casting(光线的投射)
          • Generating Eye Rays(生成Eye Rays)
        • Recursive(Whitted-Styled) Ray Tracing
      • Ray-Surface Intersection(光线和平面的交点)
        • Ray Rquation(射线方程)
        • Ray Intersection With Sphere(光线和球体求交)
        • Ray Intersection With Implicit Surface(光线和隐式曲面求交)
        • Ray Intersection With Triangle Mesh(光线和三角网格求交)
          • Ray Intersection With Triangle(光线与三角形求交)
          • Moller Trumble Algorithm
      • Accelerating Ray-Surface Intersection(加速光线和曲面求交)
        • Bounding Volumes(包围盒)
          • Ray Intersection With Axis-Aligned Box(光线与AABB求交)
          • Why Axis-Aligned?
      • 参考资料

Why Ray Tracing?(为什么需要光线追踪?)

  • 光栅化不能很好地表示全局的效果
    • 软阴影
    • 光线反弹超过一次(间接光照)
  • 光栅化很快,但是质量不高
  • 光线追踪是一种准确的方法,但是非常慢
    • 光栅化:实时;光线追踪:离线

在这里插入图片描述

Basic Ray Tracing Algorithm(基础的光线追踪算法)

关于光线的三个想法:

  1. 光线是沿直线传播的
  2. 光线和光线不会发生碰撞
  3. 光线从光源发射出来后经过传播后到达眼睛。

Ray Casting(光线的投射)

  1. 从相机出发,生成一张图片通过投射每个像素。
  2. 将物体每个点连接一条光线到光源,通过计算能量来进行着色。

在这里插入图片描述

Generating Eye Rays(生成Eye Rays)

针孔相机模型:

  1. 从摄像机发出一条光线,打到场景中最近的物体上的某个点上。
  2. 将该点与光源进行连线,这跟光线称作shadow ray
  3. 如果这条光线没有被其它物体挡着,我们就认为这个点对光源可见。
  4. 有了法线,入射方向和出射方向,我们就可以算出这一点的着色(Blinn Phong模型),然后写入像素。
    在这里插入图片描述

Recursive(Whitted-Styled) Ray Tracing

与上面的模型不同,Whitted光线追踪模型中,一个光线在打到一个物体后可以继续传播,我们只需要知道它的折射方向和反射方向的参数。
在这里插入图片描述
在光线传播中遇到的每个点,都和光线连一条光线判断是否能被光源照亮。

如何光源可以照亮某个点,我们就把这个点的着色算出加到像素的最终着色值上去。

在这里插入图片描述

Ray-Surface Intersection(光线和平面的交点)

Ray Rquation(射线方程)

一条光线由起点和传播方向就可以定义。

射线方程:

r ( t ) = o + t d , 0 ≤ t < ∞ r(t) = o + td , 0 \leq t \lt \infty r(t)=o+td,0t<

Ray Intersection With Sphere(光线和球体求交)

球体方程:

在这里插入图片描述

其中, p p p是球面上的点, c c c是球心, R R R是半径。

交点一定同时满足光线的射线方程和球体方程。

可以通过求解方程得到交点:

在这里插入图片描述
通过二次函数求根公式,得到解:

在这里插入图片描述

Ray Intersection With Implicit Surface(光线和隐式曲面求交)

联立光线射线方程和曲面的隐式方程求解即可,注意解需要满足是实数并且是正数。

在这里插入图片描述

Ray Intersection With Triangle Mesh(光线和三角网格求交)

需求:

  1. 渲染:可视性、阴影、光照
  2. 几何:内部/外部测试,如果一个点在物体内部,那么令该点向四周发射光线,交点数一定是奇数。

如何求交呢?

可以将光线与三角网格中的每个三角形分别求交,最后取 t t t最小的值即可。

十分简单,但是效率非常低。

Ray Intersection With Triangle(光线与三角形求交)

三角形是一个平面,可以首先将光线与该平面求交,然后判断交点是否在三角形内部。

平面方程:

我们可以定义成法线 N N N和一个平面经过的某个点 p ′ p' p的组合。

平面方程定义如下:

在这里插入图片描述

联立光线和平面的方程,求解得到交点:

在这里插入图片描述

Moller Trumble Algorithm

这个算法可以一步到位地算出光线是否与三角形求交,主要利用的知识是三角形的重心坐标。

在这里插入图片描述

Accelerating Ray-Surface Intersection(加速光线和曲面求交)

Bounding Volumes(包围盒)

包围盒是一个非常快速的方法来避免求交:将一个复杂的物体用一个简单的包围盒包围起来。

  • 物体被完全包围在包围盒中。
  • 如果光线连包围盒都不相交,那么一定不和物体求交。
  • 所以,首先判断是否与包围盒相交,然后再判断是否和物体相交。

包围盒是三个不同的对立面形成的交集:

在这里插入图片描述

Ray Intersection With Axis-Aligned Box(光线与AABB求交)

考虑二维情况,三维同理。

分别考虑每一对面,计算出在最近和最远的交点。

t m i n t_{min} tmin取最大值得到 t e n t e r t_{enter} tenter t m a x t_{max} tmax取最小值得到 t e x i t t_{exit} texit

关键思想:

只有当光线全部进入所有对立面的时候,才是真正进入包围盒。
只要光线出任意一个对立面时,光线就穿出包围盒了。

如果 t e n t e r < t e x i t t_{enter} < t_{exit} tenter<texit,光线就和包围盒有交点。

在这里插入图片描述
考虑两种特殊情况:

  • 如果 t e x i t < 0 t_{exit} < 0 texit<0
    包围盒在光源的后面。
  • 如果 t e x i t ≥ 0 , t e n t e r < 0 t_{exit} \geq 0, t_{enter} \lt 0 texit0tenter<0
    光源在包围盒的内部。
Why Axis-Aligned?

选择轴对齐的包围盒,可以使得求交点更简单。

参考资料

GAMES101 Lecture13

相关文章:

GAMES101 笔记 Lecture13 光线追踪1

目录 Why Ray Tracing?(为什么需要光线追踪&#xff1f;)Basic Ray Tracing Algorithm(基础的光线追踪算法)Ray Casting(光线的投射)Generating Eye Rays(生成Eye Rays) Recursive(Whitted-Styled) Ray Tracing Ray-Surface Intersection(光线和平面的交点)Ray Rquation(射线方…...

【多模态】21、BARON | 通过引入大量 regions 来提升模型开放词汇目标检测能力

文章目录 一、背景二、方法2.1 主要过程2.2 Forming Bag of Regions2.3 Representing Bag of Regions2.4 Aligning bag of regions 三、效果 论文&#xff1a;Aligning Bag of Regions for Open-Vocabulary Object Detection 代码&#xff1a;https://github.com/wusize/ovdet…...

2023“Java 基础 - 中级 - 高级”面试集结,已奉上我的膝盖

Java 基础&#xff08;对象线程字符接口变量异常方法&#xff09; 面向对象和面向过程的区别&#xff1f; Java 语言有哪些特点&#xff1f; 关于 JVM JDK 和 JRE 最详细通俗的解答 Oracle JDK 和 OpenJDK 的对比 Java 和 C的区别&#xff1f; 什么是 Java 程序的主类&…...

开源项目-erp企业资源管理系统(毕设)

哈喽,大家好,今天给大家带来一个开源项目-erp企业资源管理系统,项目通过ssh+oracle技术实现。 系统主要有基础数据,人事管理,采购管理,销售管理,库存管理,权限管理模块 登录 主页 基础数据 基础数据有商品类型,商品,供应商,客户,仓库管理功能...

Leetcode刷题---C语言实现初阶数据结构---单链表

1 删除链表中等于给定值 val 的所有节点 删除链表中等于给定值 val 的所有节点 给你一个链表的头节点head和一个整数val&#xff0c;请你删除链表中所有满足Node.valval的节点&#xff0c;并返回新的头节点 输入&#xff1a;head [1,2,6,3,4,5,6], val 6 输出&#xff1a;[…...

opencv hand openpose

使用opencv c 来调用caffemodel 使用opencv 得dnn 模块调用 caffemodel得程序&#xff0c;图片自己输入就行&#xff0c;不做过多得解释&#xff0c;看代码清单。 定义手指关节点 const int POSE_PAIRS[20][2] { {0,1}, {1,2}, {2,3}, {3,4}, // thumb {0,5}, {5,6}, {6,7}…...

flutter fl_chart 柱状图 柱条数量较多 实现左右滑动 固定y轴

一、引入插件 pub.dev&#xff1a;fl_chart package - All Versions 根据项目版本&#xff0c;安装可适配的 fl_chart 版本 二、官网柱状图示例 github参数配置&#xff1a;&#xff08;x轴、y轴、边框、柱条数据、tooltip等&#xff09; https://github.com/imaNNeo/fl_c…...

CAN学习笔记1:计算机网络

计算机网络 1 概述 计算机网络就是把多种形式的计算机用通信线路连接起来&#xff0c;并使其能够互相进行交换的系统。实际上&#xff0c;计算机网络包括了计算机、各种硬件、各种软件、组成网络的体系结构、网络传输介质和网络通信计数。因此&#xff0c;计算机网络是计算机…...

NAND flash的坏块

NAND flash的坏块 1.为什么会出现坏块 由于NAND Flash的工艺不能保证NAND的Memory Array&#xff08;由NAND cell组成的阵列&#xff09;在其生命周期中保持性能的可靠&#xff08;电荷可能由于其他异常原因没有被锁起来。因此&#xff0c;在NAND的生产中及使用过程中会产生坏…...

代码随想录算法训练营第二十五天 | 读PDF复习环节3

读PDF复习环节3 本博客的内容只是做一个大概的记录&#xff0c;整个PDF看下来&#xff0c;内容上是不如代码随想录网站上的文章全面的&#xff0c;并且PDF中有些地方的描述&#xff0c;是很让我疑惑的&#xff0c;在困扰我很久后&#xff0c;无意间发现&#xff0c;其网站上的讲…...

18.Netty源码之ByteBuf 详解

highlight: arduino-light ByteBuf 是 Netty 的数据容器&#xff0c;所有网络通信中字节流的传输都是通过 ByteBuf 完成的。 然而 JDK NIO 包中已经提供了类似的 ByteBuffer 类&#xff0c;为什么 Netty 还要去重复造轮子呢&#xff1f;本节课我会详细地讲解 ByteBuf。 JDK NIO…...

#P0999. [NOIP2008普及组] 排座椅

题目描述 上课的时候总会有一些同学和前后左右的人交头接耳&#xff0c;这是令小学班主任十分头疼的一件事情。不过&#xff0c;班主任小雪发现了一些有趣的现象&#xff0c;当同学们的座次确定下来之后&#xff0c;只有有限的 DD 对同学上课时会交头接耳。 同学们在教室中坐…...

Sentinel 容灾中心的使用

Sentinel 容灾中心的使用 往期文章 Nacos环境搭建Nacos注册中心的使用Nacos配置中心的使用 熔断/限流结果 Jar 生产者 spring-cloud-alibaba&#xff1a;2021.0.4.0 spring-boot&#xff1a;2.6.8 spring-cloud-loadbalancer&#xff1a;3.1.3 sentinel&#xff1a;2021.0…...

深度学习中简易FC和CNN搭建

TensorFlow是由谷歌开发的PyTorch是由Facebook人工智能研究院&#xff08;Facebook AI Research&#xff09;开发的 Torch和cuda版本的对应&#xff0c;手动安装较好 全连接FC(Batch*Num) 搭建建议网络&#xff1a; from torch import nnclass Mnist_NN(nn.Module):def __i…...

【多模态】20、OVR-CNN | 使用 caption 来实现开放词汇目标检测

文章目录 一、背景二、方法2.1 学习 视觉-语义 空间2.2 学习开放词汇目标检测 三、效果 论文&#xff1a;Open-Vocabulary Object Detection Using Captions 代码&#xff1a;https://github.com/alirezazareian/ovr-cnn 出处&#xff1a;CVPR2021 Oral 一、背景 目标检测数…...

网络编程 IO多路复用 [select版] (TCP网络聊天室)

//head.h 头文件 //TcpGrpSer.c 服务器端 //TcpGrpUsr.c 客户端 select函数 功能&#xff1a;阻塞函数&#xff0c;让内核去监测集合中的文件描述符是否准备就绪&#xff0c;若准备就绪则解除阻塞。 原型&#xff1a; #include <sys/select.…...

数学建模学习(7):单目标和多目标规划

优化问题描述 优化 优化算法是指在满足一定条件下,在众多方案中或者参数中最优方案,或者参数值,以使得某个或者多个功能指标达到最优,或使得系统的某些性能指标达到最大值或者最小值 线性规划 线性规划是指目标函数和约束都是线性的情况 [x,fval]linprog(f,A,b,Aeq,Beq,LB,U…...

Element UI如何自定义样式

简介 Element UI是一套非常完善的前端组件库&#xff0c;但是如何个性化定制其中的组件样式呢&#xff1f;今天我们就来聊一聊这个 举例 就拿最常见的按钮el-button来举例&#xff0c;一般来说默认是蓝底白字。效果图如下 可是我们想个性化定制&#xff0c;让他成为粉底红字应…...

protobuf入门实践2

如何在proto中定义一个rpc服务? syntax "proto3"; //声明protobuf的版本package fixbug; //声明了代码所在的包 &#xff08;对于C来说就是namespace)//下面的选项&#xff0c;表示生成service服务类和rpc方法描述&#xff0c; 默认是不生成的 option cc_generi…...

adb shell使用总结

文章目录 日志记录系统概览adb 使用方式 adb命令日志过滤按照告警等级进行过滤按照tag进行过滤根据告警等级和tag进行联合过滤屏蔽系统和其他App干扰&#xff0c;仅仅关注App自身日志 查看“当前页面”Activity文件传输截屏和录屏安装、卸载App启动activity其他 日志记录系统概…...

RestClient

什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端&#xff0c;它允许HTTP与Elasticsearch 集群通信&#xff0c;而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级&#xff…...

利用ngx_stream_return_module构建简易 TCP/UDP 响应网关

一、模块概述 ngx_stream_return_module 提供了一个极简的指令&#xff1a; return <value>;在收到客户端连接后&#xff0c;立即将 <value> 写回并关闭连接。<value> 支持内嵌文本和内置变量&#xff08;如 $time_iso8601、$remote_addr 等&#xff09;&a…...

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...

《用户共鸣指数(E)驱动品牌大模型种草:如何抢占大模型搜索结果情感高地》

在注意力分散、内容高度同质化的时代&#xff0c;情感连接已成为品牌破圈的关键通道。我们在服务大量品牌客户的过程中发现&#xff0c;消费者对内容的“有感”程度&#xff0c;正日益成为影响品牌传播效率与转化率的核心变量。在生成式AI驱动的内容生成与推荐环境中&#xff0…...

Unity | AmplifyShaderEditor插件基础(第七集:平面波动shader)

目录 一、&#x1f44b;&#x1f3fb;前言 二、&#x1f608;sinx波动的基本原理 三、&#x1f608;波动起来 1.sinx节点介绍 2.vertexPosition 3.集成Vector3 a.节点Append b.连起来 4.波动起来 a.波动的原理 b.时间节点 c.sinx的处理 四、&#x1f30a;波动优化…...

蓝桥杯 冶炼金属

原题目链接 &#x1f527; 冶炼金属转换率推测题解 &#x1f4dc; 原题描述 小蓝有一个神奇的炉子用于将普通金属 O O O 冶炼成为一种特殊金属 X X X。这个炉子有一个属性叫转换率 V V V&#xff0c;是一个正整数&#xff0c;表示每 V V V 个普通金属 O O O 可以冶炼出 …...

如何在Windows本机安装Python并确保与Python.NET兼容

✅作者简介&#xff1a;2022年博客新星 第八。热爱国学的Java后端开发者&#xff0c;修心和技术同步精进。 &#x1f34e;个人主页&#xff1a;Java Fans的博客 &#x1f34a;个人信条&#xff1a;不迁怒&#xff0c;不贰过。小知识&#xff0c;大智慧。 &#x1f49e;当前专栏…...

Vue 实例的数据对象详解

Vue 实例的数据对象详解 在 Vue 中,数据对象是响应式系统的核心,也是组件状态的载体。理解数据对象的原理和使用方式是成为 Vue 专家的关键一步。我将从多个维度深入剖析 Vue 实例的数据对象。 一、数据对象的定义方式 1. Options API 中的定义 在 Options API 中,使用 …...

JUC并发编程(二)Monitor/自旋/轻量级/锁膨胀/wait/notify/锁消除

目录 一 基础 1 概念 2 卖票问题 3 转账问题 二 锁机制与优化策略 0 Monitor 1 轻量级锁 2 锁膨胀 3 自旋 4 偏向锁 5 锁消除 6 wait /notify 7 sleep与wait的对比 8 join原理 一 基础 1 概念 临界区 一段代码块内如果存在对共享资源的多线程读写操作&#xf…...

Docker环境下安装 Elasticsearch + IK 分词器 + Pinyin插件 + Kibana(适配7.10.1)

做RAG自己打算使用esmilvus自己开发一个&#xff0c;安装时好像网上没有比较新的安装方法&#xff0c;然后找了个旧的方法对应试试&#xff1a; &#x1f680; 本文将手把手教你在 Docker 环境中部署 Elasticsearch 7.10.1 IK分词器 拼音插件 Kibana&#xff0c;适配中文搜索…...