码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数学问题-反射定律&折射定律的向量形式推导


    作者:翟天保Steven
    版权声明:著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处

    说明

           近期项目中有光线反射和折射的相关知识点,涉及到其向量形式,有些遗忘,因此进行了一轮公式推导工作,为了便于后期查看,整理在文章中。

           本文主要针对反射定律和折射定律的向量形式,进行公式推导,以加深记忆和理解。

    反射定律

    向量形式公式:

           假设A为入射光单位向量,B为反射光单位向量,N为法线单位向量,则有如下公式成立:

    \vec{B}=\vec{A}-2\left(\vec{A} \cdot \vec{N}\right) \cdot \vec{N}

    证明:

           假设\vec{A}_{1}是入射光在法线上的投影且方向向下,\vec{B}_{1}是反射光在法线上的投影且方向向上,\vec{A}_{2}是入射光在界面上的投影且方向向右,\vec{B}_{2}是反射光在界面上的投影且方向向右,\theta_{A}是入射角,\theta_{B}是反射角。

           根据反射定律知,入射角等于反射角,则有:

    \theta_{A}=\theta_{B}

           又有:

    \vec{A}_{1}=-|\vec{A}_{1}|\vec{N}=-(|\vec{A}|cos\theta _{A})\vec{N}=|\vec{A}|cos(\pi -\theta _{A})\vec{N}=(\vec{A}\cdot \vec{N}))\vec{N}

           不难知道\vec{A}_{2}和\vec{B}_{2}相等,\vec{A}_{1}和\vec{B}_{1}方向相反数值相等,所以有:

    \vec{B}=\vec{B}_{2}+\vec{B}_{1}=\vec{A}_{2}-\vec{A}_{1}=\vec{A}-\vec{A}_{1}-\vec{A}_{1}=\vec{A}-2(\vec{A}\cdot \vec{N}))\vec{N}

           得证。

    折射定律

    向量形式公式:

           假设A为入射光单位向量,B为折射光单位向量,N为法线单位向量,n1是入射区的折射率,n2是折射区的折射率,则有如下公式成立:

    \vec{B}=\frac{n_{1}}{n_{2}}\vec{A}-\left(\frac{n_{1}}{n_{2}}(\vec{A}\cdot\vec{N})+\sqrt{1-(\frac{n_{1}}{n_{2}})^{2}(1-(\vec{A}\cdot\vec{N})^{2})}\right) \cdot \vec{N}

    证明:

           假设\vec{A}_{1}是入射光在法线上的投影且方向向下,\vec{B}_{1}是折射光在法线上的投影且方向向下,\vec{A}_{2}是入射光在界面上的投影且方向向右,\vec{B}_{2}是折射光在界面上的投影且方向向右,\theta_{A}是入射角,\theta_{B}是折射角。

           根据折射定律知,则有:

    n_{1}sin(\theta_{A})=n_{2}sin(\theta_{B})

           考虑到A2和B2平行且方向一致,有:

    \vec{B}_{2}=\frac{|\vec{B}_{2}|}{|\vec{A}_{2}|}\vec{A}_{2}=\frac{sin(\theta _{B})}{sin(\theta _{A})}\vec{A}_{2}=\frac{n_{A}}{n_{B}}\vec{A}_{2}=\frac{n_{A}}{n_{B}}(\vec{A}+cos(\theta_{A})\vec{N})

           由勾股定理得:

    |\vec{B_{1}}|=\sqrt{|\vec{B}|^{2}-|\vec{B_{2}}|^{2}}=\sqrt{1-sin^{2}(\theta_{B})}

           进而得:

    \vec{B_{1}}=-|\vec{B_{1}}|\vec{N}=-\sqrt{1-sin^{2}(\theta_{B})}\vec{N}

           结合折射定律得出:

    sin^{2}(\theta_{B})=(\frac{n_{A}}{n_{B}})^{2}sin^{2}(\theta_{A})=(\frac{n_{A}}{n_{B}})^{2}(1-cos^{2}(\theta_{A}))

           代入得:

    \vec{B_{1}}=-\sqrt{1-(\frac{n_{A}}{n_{B}})^{2}(1-cos^{2}(\theta_{A}))}\vec{N}

           合并得:

    \vec{B}\\=\vec{B_{1}}+\vec{B_{2}}=\frac{n_{A}}{n_{B}}(\vec{A}+cos(\theta_{A})\vec{N})-\sqrt{1-(\frac{n_{A}}{n_{B}})^{2}(1-cos^{2}(\theta_{A}))}\vec{N}\\=\frac{n_{A}}{n_{B}}\vec{A}+(\frac{n_{A}}{n_{B}}cos(\theta_{A})-\sqrt{1-(\frac{n_{A}}{n_{B}})^{2}(1-cos^{2}(\theta_{A}))})\vec{N}

           又因为cos\theta _{A}=-\vec{A}\cdot \vec{N}得:

    \vec{B}=\frac{n_{A}}{n_{B}}\vec{A}-(\frac{n_{A}}{n_{B}}(\vec{A}\cdot \vec{N})+\sqrt{1-(\frac{n_{A}}{n_{B}})^{2}(1-(\vec{A}\cdot \vec{N})^{2})})\vec{N}

           得证。

           以上就是反射定律&折射定律向量形式的公式推导过程。

           如果文章帮助到你了,可以点个赞让我知道,我会很快乐~加油!

  • 相关阅读:
    现代图片性能优化及体验优化指南 - 懒加载及异步图像解码方案
    突破万字长文输出瓶颈!清华大学开源 LongWriter-6k 数据集;7 个 CCF A 类顶会即将截稿
    移动应用安全
    舆情监控究竟是什么?怎么运作的?
    安全智能体的前沿技术研究与实践
    [数据结构] 图---图的邻接矩阵存储方式模拟实现,包括BFS广度优先遍历和DFS深度优先遍历(上)
    Lazada店铺如何产号高效补单?(测评自养号技术详解篇)
    Java毕设项目——书画拍卖网站(java+SSM+Maven+Mysql+Jsp)
    微服务简介
    态势丨黑客侵扰加剧,靶场为网络安全架设“防御盾”
  • 原文地址:https://blog.csdn.net/zhaitianbao/article/details/127646109
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号