Cheap Curvature代码解析

2023-10-10 23:50
文章标签 代码 解析 cheap curvature

本文主要是介绍Cheap Curvature代码解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Cheap Curvature代码解析

作者:Nimitz,网址:https://www.shadertoy.com/view/Xts3WM

标签:3d,cheap,curvature

简介:主要是对曲率的简单计算

在这里插入图片描述
在这里插入图片描述

相机的简单设置

在相机的常规设置上,加上了鼠标点击的控制,较为简单。

射线步进
float map(vec3 p)
{p.x += sin(p.y*4.+time+sin(p.z))*0.15;//float d = length(p)-1.;float st = sin(time*0.42)*.5+0.5; const float frq = 10.;d += sin(p.x*frq + time*.3 + sin(p.z*frq+time*.5+sin(p.y*frq+time*.7)))*0.075*st;return d;
}

常规的RayMarching步骤,比较特殊的是Map函数——为了更好体现曲率的作用。粗看之下,完全不知道讲的啥玩意,来逐句分析。

p.x += sin(p.y*4.+time+sin(p.z))*0.15;

​ 第一句的作用主要是对变形体进行一个整体的坐标迁移(随时间变化),如果没有此句,则将会在某个时刻呈现为完整的球体。个人总结:非核心代码,但加上,会增强球体的变形感。

float d = length(p)-1.;

​ 对3D SDF了解的话,一眼就能看出此句就是Sphere的SDF,那么作用很明显:决定了变形体整体的大小(球的半径)

//f=A*sin(B*x+C)
float st = sin(time*0.42)*.5+0.5; 

​ st的作用根据最后一句可以明显得出:变形的程度——A

//f=A*sin(B*x+C)
const float frq = 10.;

​ frg很明显是频率的缩写,根据最后一句,其效果也容易得出:控制变形的步长——B

d += sin(p.x*frq + time*.3 + sin(p.z*frq+time*.5+sin(p.y*frq+time*.7)))*0.075*st;

​ 核心代码:在正常的球体距离d的基础上加上一个嵌套的三角函数

颜色计算
vec3 pos = ro+rz*rd;
float crv;
vec3 nor = norcurv(pos, crv);
crv = curv2(pos, 0.01);
vec3 ligt = normalize( vec3(.0, 1., 0.) );
float dif = clamp(dot( nor, ligt ), 0., 1.);
float bac = clamp( dot( nor, -ligt), 0.0, 1.0 );
float spe = pow(clamp( dot( reflect(rd,nor), ligt ), 0.0, 1.0 ),400.);
float fre = pow( clamp(1.0+dot(nor,rd),0.0,1.0), 2.0 );
vec3 brdf = vec3(0.10,0.11,0.13);
brdf += bac*vec3(0.1);
brdf += dif*vec3(1.00,0.90,0.60);
col = abs(sin(vec3(0.2,0.5,.9)+clamp(crv*80.,0.,1.)*1.2));
col = mix(col,texture(iChannel0,reflect(rd,nor)).rgb,.5);
col = col*brdf + col*spe +.3*fre*mix(col,vec3(1),0.5);
col *= smoothstep(-1.,-.9,sin(crv*200.))*0.15+0.85;

​ 一开始是常见的操作:pos更新,dif、bac、spec、fre项的计算,还计算了曲率。第一个col计算式,是根据曲率进行颜色过渡,所以,扭曲的峰谷是蓝色,峰顶是黄色。第二个col式是让球体拥有一定的反射效果(反射周围的环境)。后面两个是效果的结合以及微调。

曲率计算
//Curvature only, 5 taps, with epsilon width as input
float curv(in vec3 p, in float w)
{vec2 e = vec2(-1., 1.)*w;   float t1 = map(p + e.yxx), t2 = map(p + e.xxy);float t3 = map(p + e.xyx), t4 = map(p + e.yyy);return .25/e.y*(t1 + t2 + t3 + t4 - 4.0*map(p));
}//Curvature in 7-tap (more accurate)
float curv2(in vec3 p, in float w)
{vec3 e = vec3(w, 0, 0);float t1 = map(p + e.xyy), t2 = map(p - e.xyy);float t3 = map(p + e.yxy), t4 = map(p - e.yxy);float t5 = map(p + e.yyx), t6 = map(p - e.yyx);return .25/e.x*(t1 + t2 + t3 + t4 + t5 + t6 - 6.0*map(p));
}

这篇关于Cheap Curvature代码解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/183991

相关文章

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

全面解析Golang 中的 Gorilla CORS 中间件正确用法

《全面解析Golang中的GorillaCORS中间件正确用法》Golang中使用gorilla/mux路由器配合rs/cors中间件库可以优雅地解决这个问题,然而,很多人刚开始使用时会遇到配... 目录如何让 golang 中的 Gorilla CORS 中间件正确工作一、基础依赖二、错误用法(很多人一开

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

Spring Boot 3.x 中 WebClient 示例详解析

《SpringBoot3.x中WebClient示例详解析》SpringBoot3.x中WebClient是响应式HTTP客户端,替代RestTemplate,支持异步非阻塞请求,涵盖GET... 目录Spring Boot 3.x 中 WebClient 全面详解及示例1. WebClient 简介2.

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分