• 数学问题-反射定律&折射定律的向量形式推导


    作者:翟天保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}

           得证。

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

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

  • 相关阅读:
    电脑重装系统打印机脱机状态怎么恢复正常
    C语言牛客网(NowCoder)刷题篇
    资深Java工程师蚂蚁金服三面详解,看完你也可以拿offer
    Golang Gocron开源定时框架
    [CSS入门到进阶] 外国前端开发者说的 Intrinsic Ratios in css 是什么意思?
    微信小程序------框架
    政务数据质量管理提升的5个最佳实践
    矩阵分析与应用-14-行列式
    云桌面 node_modules 切换艰辛历程记录 rebuild失败记录
    【企业数字化】企业数字化技术应用5大技术趋势
  • 原文地址:https://blog.csdn.net/zhaitianbao/article/details/127646109