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 -…

【SpringCloud微服务实战09】Elasticsearch 搜索引擎

一、Elasticsearch 安装 1、Docker安装ES #创建一个网络 docker network create es-net#拉取ES镜像(这里使用7.17.18版本) docker pull elasticsearch:7.17.18#新建一个目录存放es数据 mkdir es cd es#docker运行 单机启动es docker run -d \--name es \-e "ES_JAVA_O…

数据结构 之 二叉树

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

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

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

代码随想录刷题笔记 Day 55 | 买卖股票的最佳时机含冷冻期 No.309 | 买卖股票的最佳时机含手续费 No.714

文章目录 Day 5501. 买卖股票的最佳时机含冷冻期&#xff08;No. 309&#xff09;<1> 题目<2> 笔记<3> 代码 02. 买卖股票的最佳时机含手续费&#xff08;No. 714&#xff09;<1> 题目<2> 笔记<3> 代码 Day 55 01. 买卖股票的最佳时机含冷…

安卓面试题多线程 81-85

81. 共享变量在多线程下如何保证线程安全?因为多线程是交替执⾏,每个线程操作共享变量时可能会导致数据不⼀致,要确保线程 安全,需要在访问共享变量时添加同步机制。当然,如果这个变量本⾝是线程安全的,⽐如AtomicLong,那么多线程访问也是安全 的🚀🚀🚀🚀🚀�…

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…

软件测试工程师面试汇总功能测试篇

Q:一、进行测试用例设计的时候用到的方法有哪些&#xff1f; A:最常使用的测试用例设计方法包括等价类划分法、边界值分析方法、场景法、错误推测法。其中&#xff0c;最容易 发现错误的是边界值法&#xff0c;使用最多的是场景法。以注册为例&#xff1a;首先从需求确定用户名…

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…

为啥浮点数会有精度丢失的风险?

浮点数运算精度丢失代码演示&#xff1a; float a 2.0f - 1.9f; float b 1.8f - 1.7f; System.out.println(a);// 0.100000024 System.out.println(b);// 0.099999905 System.out.println(a b);// false为什么会出现这个问题呢&#xff1f; 这个和计算机保存浮点数的机制有…

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;养成先点赞后阅读的好…

BS4网络提取selenium.chrome.WebDriver类的方法及属性

BS4网络提取selenium.chrome.WebDriver类的方法及属性 chrome.webdriver: selenium.webdriver.chrome.webdriver — Selenium 4.18.1 documentation class selenium.webdriver.chrome.webdriver.WebDriver 是 Selenium 中用于操作 Chrome 浏览器的 WebDriver 类。WebDriver 类…

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] …