用R语言画切线和法线

news2025/1/6 19:19:54

文章目录

    • 7 法线
      • 梯度、切线和法线
      • 切线和法线的绘制

7 法线

梯度、切线和法线

为了书写方便,记 x i = x 1 , x 2 , . . . , x n x_i=x_1,x_2,...,x_n xi=x1,x2,...,xn ∂ f ∂ x i = ∂ f ∂ x 1 , ∂ f ∂ x 2 , ⋯ ∂ f ∂ x n \frac{\partial f}{\partial x_i}=\frac{\partial f}{\partial x_1},\frac{\partial f}{\partial x_2},\cdots\frac{\partial f}{\partial x_n} xif=x1f,x2f,xnf

对于函数 f ( x i ) = 0 f(x_i)=0 f(xi)=0而言,其梯度为 ( ∂ f ∂ x i ) (\frac{\partial f}{\partial x_i}) (xif)。而 x n + 1 = f ( x i ) x_{n+1}=f(x_i) xn+1=f(xi)可以写为 F ( x i , x n + 1 ) = f ( x i ) − x n + 1 = 0 F(x_i,x_{n+1})=f(x_i)-x_{n+1}=0 F(xi,xn+1)=f(xi)xn+1=0,其梯度为

( ∂ F ∂ f ∂ f ∂ x i , − ∂ F ∂ x n + 1 ) = ∂ F ∂ f ( ∂ f ∂ x i , − ∂ f ∂ F ∂ F ∂ x n + 1 ) (\frac{\partial F}{\partial f}\frac{\partial f}{\partial x_i}, -\frac{\partial F}{\partial x_{n+1}})=\frac{\partial F}{\partial f}(\frac{\partial f}{\partial x_i},-\frac{\partial f}{\partial F} \frac{\partial F}{\partial x_{n+1}}) (fFxif,xn+1F)=fF(xif,Ffxn+1F)

如果只关注方向的话,那么矢量的数乘是没有意义的,所以可以把括号外的值消去;另外, f f f x n + 1 x_{n+1} xn+1是相同的值,所以 x n + 1 = f ( x i ) x_{n+1}=f(x_i) xn+1=f(xi)的法向量可以写为

( ∂ f ∂ x i , − 1 ) (\frac{\partial f}{\partial x_i},-1) (xif,1)

用几何的观点来看待 n n n变量函数 x n + 1 = f ( x i ) x_{n+1}=f(x_i) xn+1=f(xi),实际上是 n + 1 n+1 n+1维空间中嵌入的一个n维曲面。 ∇ f \nabla f f代表的是这个 n + 1 n+1 n+1维超曲面在以第 n + 1 n+1 n+1个轴方向进行投影得到的 n n n维曲面的法向量。 ( ∂ f ∂ x i , 1 ) (\frac{\partial f}{\partial x_i},1) (xif,1)表示这个n维曲面的法向量。

相应地最大方向导数的方向即为梯度的归一化

( ∂ f ∂ x i ) ∑ j = 0 n ( ∂ f ∂ x j ) 2 \frac{(\frac{\partial f}{\partial x_i})}{\sqrt{\sum^n_{j=0}(\frac{\partial f}{\partial x_j})^2}} j=0n(xjf)2 (xif)

由此得到的方向导数为

∑ j = 0 n ( ∂ f ∂ x j ) 2 \sqrt{\sum^n_{j=0}(\frac{\partial f}{\partial x_j})^2} j=0n(xjf)2

相应地,空间中根据曲面的方向导数得到一个切向量

( ( ∂ f ∂ x i ) ∑ j = 0 n ( ∂ f ∂ x j ) 2 , ∑ j = 0 n ( ∂ f ∂ x j ) 2 ) \bigg(\frac{(\frac{\partial f}{\partial x_i})}{\sqrt{\sum^n_{j=0}(\frac{\partial f}{\partial x_j})^2}} ,\sqrt{\sum^n_{j=0}(\frac{\partial f}{\partial x_j})^2} \bigg) (j=0n(xjf)2 (xif),j=0n(xjf)2 )

切、法相乘,结果为0。但是,对于任何一个不小于3维的向量而言,总是有无穷多个与之相乘为0且方向不同的向量。

例如,随机抽选出一个序号不大于 n n n的第 j j j坐标轴,沿该坐标轴方向做其切线,则其切线方向为

( 0 , ⋯   , 1 , ⋯   , 0 , ∂ f ∂ x j ) (0,\cdots,1,\cdots,0,\frac{\partial f}{\partial x_j}) (0,,1,,0,xjf)

该矢量与法矢量的点乘仍然为0。

切线和法线的绘制

对于 z = 1 − x 2 − y 2 z=1-x^2-y^2 z=1x2y2,其法向量为 ( − 2 x , − 2 y , − 1 ) (-2x,-2y,-1) (2x,2y,1),其最大方向导数处的切向量为 ( − x x 2 + y 2 , − y x 2 + y 2 , 2 x 2 + y 2 ) = ( − x , − y , 2 − 2 z ) (\frac{-x}{\sqrt{x^2+y^2}},\frac{-y}{\sqrt{x^2+y^2}},2\sqrt{x^2+y^2})=(-x,-y,2-2z) (x2+y2 x,x2+y2 y,2x2+y2 )=(x,y,22z) x x x轴方向的切向量为 ( 1 , 0 , − 2 x ) (1,0,-2x) (1,0,2x) y y y轴方向处的切向量为 ( 0 , 1 , − 2 y ) (0,1,-2y) (0,1,2y)

现随机选择一些点,来绘制一下这四个方向的向量

library(rgl)
N = 1500
x<-rnorm(N)
y<-rnorm(N)
z<-1-x^2-y^2
for(i in 1:N){
    lines3d(c(x[i],3*x[i]),c(y[i],3*y[i]),c(z[i],z[i]+1),col='red')
    if(y[i]>0.1)
        lines3d(c(x[i],x[i]),c(y[i],y[i]-1/y[i]/2),c(z[i],z[i]+1),col='green')
    if(x[i]>0.1)
    lines3d(c(x[i],x[i]-1/x[i]/2),c(y[i],y[i]),c(z[i],z[i]+1),col='green')
    lines3d(c(x[i],x[i]*(1-2*z[i])/(2-2*z[i])),c(y[i],y[i]*(1-2*z[i])/(2-2*z[i])),c(z[i],z[i]+1),col='green')
}

在这里插入图片描述

可以看到,绿线几乎重新编织了一遍原函数,而红线则刺破了曲面。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/163855.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

springboot+rabbitmq搭建mqtt协议实现订阅发布(亲测9w消息并发)

一、mqtt协议简单介绍 mqtt是一种基于发布/订阅&#xff08;publish/subscribe&#xff09;模式的轻量级通讯协议&#xff0c;通过订阅相应的主题来获取消息&#xff0c;是物联网&#xff08;Internet of Thing&#xff09;中的一个标准传输协议。 二、rabbitmq的安装部署 1. …

c# 随机数,c# 生成随机数,c# 生成区间随机数,c# 生成随机数组

c# 随机数&#xff0c;c# 生成随机数&#xff0c;c# 生成区间随机数&#xff0c;c# 生成随机数组 小试牛刀 先看结果 生成200-700之间的5个随机数 第1的随机数是&#xff1a;647 第2的随机数是&#xff1a;219 第3的随机数是&#xff1a;311 第4的随机数是&#xff1a;210 第5…

Redisson的看门狗机制

背景 据Redisson官网的介绍&#xff0c;Redisson是一个Java Redis客户端&#xff0c;与Spring 提供给我们的 RedisTemplate 工具没有本质的区别&#xff0c;可以把它看做是一个功能更强大的客户端&#xff08;虽然官网上声称Redisson不只是一个Java Redis客户端&#xff09; …

记录Maven的相关操作(笔记整理)

一、安装 我使用的是免安装版的&#xff0c;直接解压缩就可以使用。 二、配置环境变量 打开环境变量配置。右键计算机→属性→高级系统设置→高级→环境变量&#xff0c;在系统变量中配置。 配置MAVEN_HOME。在系统变量中新建&#xff0c;变量名MAVEN_HOME&#xff0c;变量值…

parquet

一、parquet结构 Row Group ​ --Column Chunk&#xff1a;一列对应一个Column Chunk ​ – Page&#xff1a;压缩和编码的单元&#xff0c;parquet的 min/max 索引是针对于page的&#xff0c;存在了文件的页脚。以前的版本是存储Column Chunk和Page的索引&#xff0c;导致在…

Linux命令scp用法

本文主要讲的是scp用法如果哪里不对欢迎指出&#xff0c;主页https://blog.csdn.net/qq_57785602?typeblog首先讲述一下scp用法并不是让你连接公司服务器后用的&#xff08;不是连接公司服务器使用&#xff09;&#xff0c;如果要使用的情况下那么请看下面&#xff1a;winr打开…

【C语言篇】请把这篇文章推给现在还对指针一知半解的童鞋~超生动图解,详细讲解,易懂,易学,让天下没有难懂的指针~

&#x1f331;博主简介&#xff1a;是瑶瑶子啦&#xff0c;一名大一计科生&#xff0c;目前在努力学习C进阶,JavaSE。热爱写博客~正在努力成为一个厉害的开发程序媛&#xff01; &#x1f4dc;所属专栏&#xff1a;C/C ✈往期博文回顾:进入内存,透彻理解数据类型存在的意义,整形…

[java拓展]Mysql数据库的基础指令,和JDBC的使用

1.关于mysql数据库 &#xff08;1&#xff09;概述 DBMS数据库管理系统&#xff0c;用来管理数据库&#xff0c;执行sql语句的东西&#xff0c;Mysql&#xff0c;oracle&#xff0c;sqlite这些严格来说不是数据库而是数据库管理系统&#xff0c;其中Mysql最常用&#xff0c;而…

马来酰亚胺聚乙二醇硅烷,MAL-PEG-Silane 结构,科研试剂溶于大部分有机溶剂

马来酰亚胺聚乙二醇硅烷&#xff0c;MAL-PEG-Silane 中文名称&#xff1a;马来酰亚胺聚乙二醇硅烷 分子量&#xff1a;1k&#xff0c;2k&#xff0c;3.4k&#xff0c;5k&#xff0c;10k&#xff0c;20k。。。 存储条件&#xff1a;-20C&#xff0c;避光&#xff0c;避湿 用…

剑指offer----C语言版----第十九天----面试题25:合并两个有序的链表

目录 1. 合并两个排序的链表 1.1 题目描述 1.2 解题思路 1.3 往期回顾 1. 合并两个排序的链表 原题链接&#xff1a;21. 合并两个有序链表 - 力扣&#xff08;LeetCode&#xff09;1.1 题目描述 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个…

new-Crack:StarUML 5.1.0 -2023

StarUML 用于敏捷和简洁建模的复杂软件建模器 当前版本&#xff1a;v5.1.0 主要特征 通用语言2 兼容 UML 2.x 标准元模型和图表&#xff1a;类、对象、用例、组件、部署、复合结构、序列、通信、状态图、活动、时间、交互溢出、信息流和剖面图。 SYSML 支持 支持使用 SysML 图…

SSM03_SpringMVC REST风格 SSM整合

01-SpringMVC简介SpringMVC是隶属于Spring框架的一部分&#xff0c;主要是用来进行Web开发&#xff0c;是对Servlet进行了封装。SpringMVC是处于Web层的框架&#xff0c;所以其主要的作用就是用来接收前端发过来的请求和数据然后经过处理并将处理的结果响应给前端&#xff0c;所…

【iHooya】1月14日寒假集训课作业解析

内部元素之和 输入一个整数矩阵&#xff0c;计算位于矩阵内部的元素之和。所谓矩阵内部的元素&#xff0c;不在第一行和最后一行的元素以及第一列和最后一列的元素。 输入 第一行分别为矩阵的行数m和列数n&#xff08;m < 100&#xff0c;n < 100&#xff09;&#xff0…

Arthas 入门到实战(一)快速入门

Arthas官方文档指出&#xff1a; 介绍&#xff1a;Arthas 是一款线上监控诊断产品&#xff0c;通过全局视角实时查看应用 load、内存、gc、线程的状态信息&#xff0c;并能在不修改应用代码的情况下&#xff0c;对业务问题进行诊断&#xff0c;包括查看方法调用的出入参、异常&…

人工智能与游戏

游戏是智能应用最好的平台&#xff0c;可惜的是&#xff1a;只用了少部分计算AI&#xff0c;还没有用到智能的计算计1 引言从1950年香农教授提出为计算机象棋博弈编写程序开始&#xff0c;游戏人工智能就是人工智能技术研究的前沿&#xff0c;被誉为人工智能界的“果蝇”&#…

微信小程序070校园食堂订餐多商家带配送

基于微信小程序食堂订餐管理系 系统分为用户和管理员&#xff0c;商家三个角色 用户小程序端的主要功能有&#xff1a; 1.用户注册和登陆小程序 2.查看系统新闻资讯公告 3.用户查看小程序端的菜品信息&#xff0c;在线搜索菜品&#xff0c; 4.用户查看菜品详情&#xff0c;收…

数据结构-二叉搜索树解析和实现

1.含义规则特性二叉搜索树也叫排序二叉树、有序二叉树&#xff0c;为什么这么叫呢&#xff1f;名字由来是什么&#xff1f;主要是它的规则图一规则一&#xff0c;左子树的所有节点的值均小于它的根节点的值规则二&#xff0c;右子树的所有节点的值均大于它的根节点的值&#xf…

摇头测距小车01_舵机和超声波代码封装

目录 一、摇头测距小车图片演示 二、接线方式 三、代码实现 一、摇头测距小车图片演示 就是在小车原有的基础上&#xff0c;在小车前面加一个舵机和一个超声波&#xff0c;把超声波粘在舵机上 二、接线方式 1、超声波接线 VCC-----上官一号5V GND----上官一号GND Trig----…

.net开发安卓入门-Dialog

.net开发安卓入门-DialogAndroid.App.AlertDialog运行效果代码UI源码引入 下面这个类库才可以使用Java.Interop.Export特性绑定事件Android.App.AlertDialog https://learn.microsoft.com/zh-cn/dotnet/api/android.app.alertdialog?viewxamarin-android-sdk-13 SetTitle &…

nodejs+vue摄影跟拍预定管理系统

&#xff0c;本系统分为用户&#xff0c;摄影师&#xff0c;管理员三个角色&#xff0c;用户可以注册登陆系统&#xff0c;查看摄影套餐&#xff0c;预约套餐&#xff0c;购买摄影周边商品&#xff0c;查看跟拍照片等。摄影师可以对用户的摄影预约审核&#xff0c;跟拍流程管理…