GAMES101 学习3

Lecture 13 ~ 16

Shadow mapping

  • 一种图像空间算法
  • 生成阴影时不需要知道场景中的几何信息
  • 会产生走样现象

最重要的思想:如果有的点不在阴影里你又能看到这个点,那么说明摄像机可以看到这个点,光源也可以看到这个点

经典的Shadow mapping 只能处理电光源

步骤:

  • 从光源看像场景,记录看到的任何点的深度
  • Project visible points in eye view back to light source  眼睛看向场景,将看到的场景投影回光源,查看记录的深度是否一致。如果只被光线看到,不被相机看到,就不会被渲染;如果被相机看到,没被光线看到,就是阴影。

问题:画面会脏,数值精度问题(浮点数的相等不好判断,可以改判大小,或加个bias,但效果不好);受限于shadow mapping的分辨率;只能产生硬阴影。
应用:所有的3d游戏和早期动画
 

光栅化的问题

光栅化的渲染是将场景的渲染任务按层次拆解:物体——三角面——像素。这种拆解会导致全局信息的丢失,因此光栅化实现不了软阴影、间接光照等。

shadow mapping

光栅化没法考虑全局光照(GI),只能计算直接光照,没法考虑光源与物体间的遮挡,无法计算阴影。那怎么产生阴影的效果?用shadow mapping!但是只能处理点/方向光源,只能产生硬阴影(要么在阴影里,要么不在)。光栅化是快速的,近似的效果

Ray Casting  光线投射(by Author Appel)

光线追踪 --> 实时,很慢,经常用来进行离线的制作,比如用来制作电影

Light Rays  (假设)

  • 光线沿着直线传播 (本身是错误的)
  • 光线不会互相碰撞 (也是错误的)
  • 光线是从光源发射出来然后经过反射最终到达人眼  (利用了光线的可逆性)

假设:

  • 人的眼睛是针孔摄像机,光源是点光源
  • 光线打到场景物体上会发生完美的反射/折射

Eye Ray :从眼睛开始,往成像屏幕的任何一个像素投射,打到场景中某个位置(最近的交点,因为人眼肯定是看到最近的东西,从而也解决了深度测试的问题)

Shadow Ray :再从这个交点往光源连一条线,如果这条线上没有任何东西阻挡,那我们就认为该点被光线照亮,如果有,就认为该点在阴影中

从相机出发,对于每个像素点向场景投射光线,直到光线与场景中第一个物体相交,在交点处,根据物体本身性质、光源属性和光照模型等来计算像素点的颜色;

光线投射只考虑投射光线,光线与物体相交后不会继续跟踪,不考虑后续的折射、反射等。

whitted-style 光线追踪  递归

Whitted 主要说在任何一个点,光线可以继续传播

  • 计算折射,反射
  • 每一个和场景相交的点都与光源做连线,进行着色

技术问题

Ray - Surface Intersection 求光线与表面的交点

数学上的光线有一个起点,有方向,就是一条射线

光线与物体求交

推广到隐式表面

得到的根必须具有实际意义

  • 必须是正的
  • 必须是实数,不能是虚数

那么对于显式的表面呢?

可以判断是否在物体内:一个点在封闭的图形内,往任意方向打一束光线储出去

  • 奇数个交点  -- 物体内
  • 偶数个交点 -- 物体外

光线和三角形求交 -- 太慢了  做法分解:

  • 求光线与平面的交点
  • 判断交点是否在三角形内部

定义一个平面:一条法线,一个点

法线与平面上任意一条线段垂直

定义点 p 的要求:任何一个在平面上的点 p 与给定 p`的连线都与 N 法线垂直

重心坐标求解

左边式子:光线方程 右边式子:用中心坐标表示的三角形内的任意一点

求解:t ,b1,b2 三个未知量,三个式子  -- 克莱姆法则

要求:t 是正数,1 - b1 - b2  非负, b1 ,b2 非负

光线与表面求交的加速算法

不可能光线与每个三角形求一次交,加速的重要概念 -- 包围盒 (Bounding Volumes )

如果连包围盒都碰不到,就更不可能碰到里面的物体

  但是效果有限

3D中,长方体的理解:上下,前后,左右三个对面形成的交集

通常常用的:Axis-Aligned Bounding Box (AABB) 轴对齐包围盒

  • 沿着x,y,z轴的,对应2d情况,长方形的边一定是横平竖直

从二维情况考虑:

  • 光线是否和AABB相交?
  • 长方形两个对面的交集,求光线进,出的时间
  • 如何求进,出时间

三维:

  • 逻辑:光线进入了三个对面,才算进入了包围盒。只要离开了任一的对面,就算离开了包围盒
  • 计算三组 x,y,z 的 tmin,tmax
  • T enter:光线进入最晚对面的时间 -- tmin 的最大值,t exit :最早离开对面的时间 --tmax的最小值
  • 光线与包围盒有交点:进入时间 < 离开时间 

特殊情况:

t exit < 0 表示盒子在光线背后,光线向后延申才进入盒子

进入时间 < 0,离开时间 > 0;光线在盒子里,一定有交点

当且仅当,光线进入时间小于光线离开时间,并且离开时间大于等于0的时候,光线与包围盒有交点

参考文章:GAMES101 梳理 / 个人向图形学笔记-CSDN博客

13_Ray Tracing_Whitted Style Ray Tracing (yuque.com)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/757899.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux-docker安装数据库mysql

1、拉去mysql镜像&#xff1a; docker pull mysql2、创建容器挂载路径 mkdir -p /usr/local/jiuxiang/mysql/data # 数据存储位置 mkdir -p /usr/local/jiuxiang/mysql/logs # 日志存储位置 mkdir -p /usr/local/jiuxiang/mysql/conf # 配置文件3、启动容器 docker run -…

数据结构 之 二叉树

&#x1f389;欢迎大家观看AUGENSTERN_dc的文章(o゜▽゜)o☆✨✨ &#x1f389;感谢各位读者在百忙之中抽出时间来垂阅我的文章&#xff0c;我会尽我所能向的大家分享我的知识和经验&#x1f4d6; &#x1f389;希望我们在一篇篇的文章中能够共同进步&#xff01;&#xff01;&…

Transformer在计算机视觉中的应用-VIT、TNT模型

Transformer是传统机器翻译模型中常见的seq2seq网络&#xff0c;里面加入了注意力机制&#xff0c;QKV矩阵的运算使得计算并行。 当然&#xff0c;最大的重点不是矩阵运算&#xff0c;而是注意力机制的出现。 一、CNN最大的问题是什么 CNN依旧是十分优秀的特征提取器&#xf…

CSS中如何设置单行或多行内容超出后,显示省略号

1. 设置超出显示省略号 css设置超出显示省略号可分两种情况&#xff1a; 单行文本溢出显示省略号…多行文本溢出显示省略号… 但使用的核心代码是一样的&#xff1a;需要先使用 overflow:hidden;来把超出的部分隐藏&#xff0c;然后使用text-overflow:ellipsis;当文本超出时…

idea如何复制一个module

选中要复制的模块&#xff0c;按ctrl C 然后按ctrl V&#xff0c;会出来一个对话框&#xff0c;输入复制后的项目名称&#xff0c;这里随便写。 路径就选择的当前路径&#xff0c;点击OK 打开project structure 选择modules&#xff0c;点击加号 弹出一个对话框&#xff0c…

Linux——程序地址空间

我们先来看这样一段代码&#xff1a; #include <stdio.h> #include <unistd.h> #include <stdlib.h>int g_val 0;int main() {pid_t id fork();if(id < 0){perror("fork");return 0;}else if(id 0){ //child,子进程肯定先跑完&#xff0c;也…

生成单一c段或者连续c段范围内的所有ip地址+生成范围内C段脚本

1. 背景 马上有电子政务外网攻防演练要处理ip 2. 脚本1 生成c段和连续c段所有ip地址.py 用处&#xff1a;生成单一c段或者连续c段范围内的所有ip地址。 用法&#xff1a;ipc.txt 放入 ip段或者两个ip段范围&#xff1a;如&#xff1a; 192.168.3.0/24 172.16.1.0/24-1…

Sora 发布的意义能和 ChatGPT 相比吗?

个人觉得&#xff0c;Sora 的发布弥补了ChatGPT语言模型在视频内容领域的不足&#xff0c;简单来说&#xff0c;这两个模型均有自己的优势&#xff0c;ChatGPT是一种语言模型&#xff0c;可以理解和解释自然语言&#xff0c;而Sora是文字到视频转化的应用&#xff0c;将文本内容…

【进阶五】Python实现SDVRP(需求拆分)常见求解算法——差分进化算法(DE)

基于python语言&#xff0c;采用经典差分进化算法&#xff08;DE&#xff09;对 需求拆分车辆路径规划问题&#xff08;SDVRP&#xff09; 进行求解。 目录 往期优质资源1. 适用场景2. 代码调整3. 求解结果4. 代码片段参考 往期优质资源 经过一年多的创作&#xff0c;目前已经成…

保护王国的钥匙:探索特权访问管理 (PAM) 的深度

在零信任架构的范例中&#xff0c;特权访问管理&#xff08;PAM&#xff09;正在成为网络安全策略的关键组成部分&#xff0c;旨在控制和监控组织内的特权访问。本文深入探讨了 PAM 在现代网络安全中的关键作用&#xff0c;探讨了其原理、实施策略以及特权访问的演变格局。 什么…

告别卡顿,CleanMyMac X让你的Mac跑得更快更稳!

CleanMyMac X是一款专业的Mac清理软件&#xff0c;具备智能扫描、恶意软件检测和清除、应用程序管理等全面的功能特点&#xff0c;可以智能清理Mac磁盘垃圾和多余语言安装包&#xff0c;快速释放电脑内存&#xff0c;轻松管理和升级Mac上的应用。同时&#xff0c;它也能强力卸载…

「滚雪球学Java」:内存管理和垃圾回收(章节汇总)

咦咦咦&#xff0c;各位小可爱&#xff0c;我是你们的好伙伴——bug菌&#xff0c;今天又来给大家普及Java SE相关知识点了&#xff0c;别躲起来啊&#xff0c;听我讲干货还不快点赞&#xff0c;赞多了我就有动力讲得更嗨啦&#xff01;所以呀&#xff0c;养成先点赞后阅读的好…

Python内存管理与垃圾回收机制:深入理解与优化【第138篇—RESTful API】

&#x1f47d;发现宝藏 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。【点击进入巨牛的人工智能学习网站】。 Python内存管理与垃圾回收机制&#xff1a;深入理解与优化 在Python编程中&#xff0c;内存…

稀碎从零算法笔记Day22-LeetCode:存在重复元素 II

题型&#xff1a;哈希表、数组 链接&#xff1a;219. 存在重复元素 II - 力扣&#xff08;LeetCode&#xff09; 来源&#xff1a;LeetCode 题目描述 给你一个整数数组 nums 和一个整数 k &#xff0c;判断数组中是否存在两个 不同的索引 i 和 j &#xff0c;满足 nums[i] …

K8s-网络原理-上篇

引言 本文是学习《深入剖析K8s》网络原理部分的学习笔记&#xff0c;相关图片和案例可以从https://github.com/WeiXiao-Hyy/k8s_example获取&#xff0c;欢迎Star&#xff01; 网络基础 IP组成 IP地址由两部分组成&#xff0c;即网络地址和主机地址。网络地址表示其属于互联…

UE4_官方动画内容示例1.1_使用动画资产

对一个SkeletalMeshActor进行设置&#xff0c;设置好之后&#xff0c;可以通过该Actor的细节&#xff08;Details&#xff09;面板播放指定的动画序列&#xff08;AnimationSequence&#xff09;资产&#xff08;例如让Actor翻跟斗并做开合跳&#xff09;。 骨架网格体定义&am…

Linux第79步_使用自旋锁保护某个全局变量来实现“互斥访问”共享资源

自旋锁使用注意事项:自旋锁保护的“临界区”要尽可能的短。 因此&#xff0c;在open()函数中申请“spinlock_t自旋锁结构变量”&#xff0c;然后在release()函数中释放“spinlock_t自旋锁结构变量”&#xff0c;这种方法就行不通了。如果使用一个变量“dev_stats”来表示“共享…

【开发环境搭建篇】Redis客户端安装和配置

作者介绍&#xff1a;本人笔名姑苏老陈&#xff0c;从事JAVA开发工作十多年了&#xff0c;带过大学刚毕业的实习生&#xff0c;也带过技术团队。最近有个朋友的表弟&#xff0c;马上要大学毕业了&#xff0c;想从事JAVA开发工作&#xff0c;但不知道从何处入手。于是&#xff0…

《手把手教你》系列技巧篇(四十三)-java+ selenium自动化测试-处理https 安全问题或者非信任站点-上篇(详解教程)

1.简介 这一篇宏哥主要介绍webdriver在IE、Chrome和Firefox三个浏览器上处理不信任证书的情况&#xff0c;我们知道&#xff0c;有些网站打开是弹窗&#xff0c;SSL证书不可信任&#xff0c;但是你可以点击高级选项&#xff0c;继续打开不安全的链接。举例来说&#xff0c;想必…

MISC:常见编码

一、字符编码 1.ASCII码 使用指定7位或8位二进制数组合表示128-256种可能。 常⻅考点&#xff1a;解题过程中给出十进制或十六进制的连续数值。 进制转换工具&#xff1a; ASCII text,Hex,Binary,Decimal,Base64 converter (rapidtables.com) 2.Base64编码 ASCII编码以8个比特…