码农知识堂 - 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}

           得证。

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

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

  • 相关阅读:
    艾美捷内毒素纯化树脂基本参数和原理说明
    树莓派高级开发------总线地址、物理地址和虚拟地址的认识
    使用VBS编写xshell/SecureCRT自动化脚本
    小黑受到了封校的恐惧,秋招结束该何去何从的日常积累:进程初步
    js构造函数之工厂模式(学习笔记1)
    uni-app报错“本应用使用HBuilderX x.x.x 或对应的cli版本编译,而手机端SDK版本是x.x.x不匹配的版本可能造成应用异常”
    0搭建VMware vSphere企业虚拟化环境
    第二章 Caché 服务器页面简介 - 你应该知道
    vs2013调试的时候我想查看某个变量的值的窗口被我删了,我需要找到那个查看局部变量的值的窗口
    靶机 DC-2
  • 原文地址: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号