Hermite 三次插值可编辑样条

news2025/1/11 17:46:10

欢迎关注更多精彩
关注我,学习常用算法与数据结构,一题多解,降维打击。

问题描述

利用三次样条和Hermite插值制作一个类似于ppt里的曲线工作。

基本思路

  1. 对于给定点,初始生成时用参数化+三次函数插值的方式生成。三次样条函数插值法
  2. 生成后在各型值点处展示切线信息。
  3. 编辑时,利用两点两切线的信息,通过hermite三次插值进行分段插值。

切线计算

对曲线参数化后

P ( t ) = { y ( t ) x ( t ) P(t) = \left \{ \begin{array}{l} y(t) \\ x(t) \end{array} \right. P(t)={y(t)x(t)

切线信息就是 P(t)的1阶导
P ′ ( t ) = { y ′ ( t ) x ′ ( t ) P'(t) = \left \{ \begin{array}{l} y'(t) \\ x'(t) \end{array} \right. P(t)={y(t)x(t)

在这里插入图片描述
根据三弯矩公式求导,得到导数公式。
S i ′ ( x ) = − M i 2 h i ( x i + 1 − x ) 2 + M i + 1 2 h i ( x − x i ) 2 + ( y i + 1 h i − M i + 1 h i 6 ) + ( M i h i 6 − y i h i ) S_i'(x) = -\frac {M_i}{2h_i}(x_{i+1}-x)^2+\frac {M_{i+1}}{2h_i}(x-x_{i})^2+(\frac{y_{i+1}}{h_i}-\frac{M_{i+1}h_i}{6})+(\frac{M_ih_i}{6}-\frac{y_i}{h_i}) Si(x)=2hiMi(xi+1x)2+2hiMi+1(xxi)2+(hiyi+16Mi+1hi)+(6Mihihiyi)

Hermite 插值法

给定两点两切线信息,求出两点之间的曲线方程。

设两端点和导数如下:

P ( 0 ) = p i P ( 1 ) = p i + 1 P ′ ( 0 ) = D p i P ′ ( 1 ) = D p i + 1 \begin{array}{lc}\mathbf P\boldsymbol(\mathbf0\boldsymbol)\boldsymbol={\mathbf p}_{\mathbf i}\\\mathbf P\boldsymbol(\mathbf1\boldsymbol)\boldsymbol={\mathbf p}_{\mathbf i\boldsymbol+\mathbf1}\\\mathbf P\boldsymbol'\boldsymbol(\mathbf0\boldsymbol)\boldsymbol={\mathbf{Dp}}_{\mathbf i}\\\mathbf P\boldsymbol'\boldsymbol(\mathbf1\boldsymbol)\boldsymbol={\mathbf{Dp}}_{\mathbf i\boldsymbol+\mathbf1}\end{array} P(0)=piP(1)=pi+1P(0)=DpiP(1)=Dpi+1

可以给出待定式

P ( u ) = a u 3 + b u 2 + c u + d , u ∈ [ 0 , 1 ] \boldsymbol P(u) = \boldsymbol au^3 + \boldsymbol bu^2 +\boldsymbol cu + \boldsymbol d , u \in [0,1] P(u)=au3+bu2+cu+d,u[0,1]

我们希望求得a,b,c,d从而得到表达式

分量 P x ( u ) = a x u 3 + b x u 2 + c x u + d x 分量\boldsymbol P_x(u) = \boldsymbol a_xu^3 + \boldsymbol b_xu^2 +\boldsymbol c_xu + \boldsymbol d_x 分量Px(u)=axu3+bxu2+cxu+dx

y, z也有类似的关系。

可以写成矩阵形式

P ( u ) = [ u 3 u 2 u 1 ] [ a b c d ] ( 1 ) \boldsymbol P(u) = \begin{bmatrix} u^3 &u^2&u & 1 \end{bmatrix} \begin{bmatrix} \boldsymbol a\\ \boldsymbol b\\ \boldsymbol c\\ \boldsymbol d \end{bmatrix} (1) P(u)=[u3u2u1] abcd (1)

对P(u) 求导得到
P ′ ( u ) = [ 3 u 2 2 u 1 0 ] [ a b c d ] ( 2 ) \boldsymbol P'(u) = \begin{bmatrix} 3u^2 &2u &1 & 0 \end{bmatrix} \begin{bmatrix} \boldsymbol a\\ \boldsymbol b\\ \boldsymbol c\\ \boldsymbol d \end{bmatrix}(2) P(u)=[3u22u10] abcd (2)

把u=0, u=1 时的值和一阶导代入式(1),式(2)可以得到方程组

[ P i P i + 1 D p i D p i + 1 ] = [ 0 0 0 1 1 1 1 1 0 0 1 0 3 2 1 0 ] [ a b c d ] \begin{bmatrix} \boldsymbol P_i\\ \boldsymbol P_{i+1}\\ \boldsymbol Dp_i\\ \boldsymbol Dp_{i+1} \end{bmatrix} = \begin{bmatrix} 0&0&0&1 \\ 1&1&1&1\\ 0&0&1&0\\3&2&1&0\end{bmatrix} \begin{bmatrix} \boldsymbol a\\ \boldsymbol b\\ \boldsymbol c\\ \boldsymbol d \end{bmatrix} PiPi+1DpiDpi+1 = 0103010201111100 abcd

[ P i P i + 1 D p i D p i + 1 ] = [ 0 0 0 1 1 1 1 1 0 0 1 0 3 2 1 0 ] [ a b c d ] \begin{bmatrix} \boldsymbol P_i\\ \boldsymbol P_{i+1}\\ \boldsymbol Dp_i\\ \boldsymbol Dp_{i+1} \end{bmatrix} = \begin{bmatrix} 0&0&0&1 \\ 1&1&1&1\\ 0&0&1&0\\3&2&1&0\end{bmatrix} \begin{bmatrix} \boldsymbol a\\ \boldsymbol b\\ \boldsymbol c\\ \boldsymbol d \end{bmatrix} PiPi+1DpiDpi+1 = 0103010201111100 abcd

[ a b c d ] = [ 0 0 0 1 1 1 1 1 0 0 1 0 3 2 1 0 ] − 1 [ P i P i + 1 D p i D p i + 1 ] \begin{bmatrix} \boldsymbol a\\ \boldsymbol b\\ \boldsymbol c\\ \boldsymbol d \end{bmatrix}= \begin{bmatrix} 0&0&0&1 \\ 1&1&1&1\\ 0&0&1&0\\3&2&1&0\end{bmatrix}^{-1} \begin{bmatrix} \boldsymbol P_i\\ \boldsymbol P_{i+1}\\ \boldsymbol Dp_i\\ \boldsymbol Dp_{i+1} \end{bmatrix} abcd = 0103010201111100 1 PiPi+1DpiDpi+1

= [ 2 − 2 1 1 − 3 3 − 2 − 1 0 0 1 0 1 0 0 0 ] [ P i P i + 1 D p i D p i + 1 ] = \begin{bmatrix} 2&-2&1&1 \\ -3&3&-2&-1\\ 0&0&1&0\\1&0&0&0\end{bmatrix} \begin{bmatrix} \boldsymbol P_i\\ \boldsymbol P_{i+1}\\ \boldsymbol Dp_i\\ \boldsymbol Dp_{i+1} \end{bmatrix} = 2301230012101100 PiPi+1DpiDpi+1


M H = [ 2 − 2 1 1 − 3 3 − 2 − 1 0 0 1 0 1 0 0 0 ] \boldsymbol M_H= \begin{bmatrix} 2&-2&1&1 \\ -3&3&-2&-1\\ 0&0&1&0\\1&0&0&0\end{bmatrix} MH= 2301230012101100

P ( u ) = [ u 3 u 2 u 1 ] M H [ P i P i + 1 D p i D p i + 1 ] \boldsymbol P(u) = \begin{bmatrix} u^3 &u^2&u & 1 \end{bmatrix} \boldsymbol M_H \begin{bmatrix} \boldsymbol P_i\\ \boldsymbol P_{i+1}\\ \boldsymbol Dp_i\\ \boldsymbol Dp_{i+1} \end{bmatrix} P(u)=[u3u2u1]MH PiPi+1DpiDpi+1

这样就可以直接由两点两切线直接得到表达式。

展开得到分段表达式

P i ( u ) = P i ( 2 u 3 − 3 u 2 + 1 ) + P i + 1 ( − 2 u 3 + 3 u 2 ) + D p i ( u 3 − 2 u 2 + u ) + D p i + 1 ( u 3 − u 2 ) \boldsymbol P_i(u) = \boldsymbol P_i(2u^3-3u^2+1)+ \boldsymbol P_{i+1}(-2u^3+3u^2) + \boldsymbol Dp_i(u^3-2u^2+u) +\boldsymbol Dp_{i+1}(u^3-u^2) Pi(u)=Pi(2u33u2+1)+Pi+1(2u3+3u2)+Dpi(u32u2+u)+Dpi+1(u3u2)

实现

代码:
https://gitcode.com/chenbb1989/geometric_model/tree/master/gohw4-1

演示视频

三次样条编辑

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


本人码农,希望通过自己的分享,让大家更容易学懂计算机知识。创作不易,帮忙点击公众号的链接,帮忙转发,感激不尽。

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

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

相关文章

【Py/Java/C++三种语言详解】LeetCode743、网络延迟时间【单源最短路问题Djikstra算法】

可上 欧弟OJ系统 练习华子OD、大厂真题 绿色聊天软件戳 od1441了解算法冲刺训练(备注【CSDN】否则不通过) 文章目录 相关推荐阅读一、题目描述二、题目解析三、参考代码PythonJavaC 时空复杂度 华为OD算法/大厂面试高频题算法练习冲刺训练 相关推荐阅读 …

Java入门:06.Java中的方法--进阶01

1 JVM中方法的执行过程 1.1 JVM内存模型 在java程序的执行过程中会产生一些数据,这些数据将会存在jvm内存中。 JVM将内存分成了不同的逻辑区域,存储不同含义(类别)的数据 JVM内存模型有5种 方法区 : 存储类信息 堆…

初识redis:Set类型

Set有很多种含义,比如集合,比如设置(和get相对应)。 在这里我们说的set是指的redis中的集合,并且这里的集合是无序的,和之前的list是对应的。 List : [1,2,3] 和 [2,1,3] 是两个不同的listSe…

hbase-manager图形化界面的安装与配置

相关资料下载 夸克网盘分享 1、上传项目到linux上 解压: 切换到conf目录下:/opt/installs/hbase-manager-2.0.8-hbase-2.x/conf/ 2、修改数据库配置信息 application-druid.yml 3、创建hbase-manager数据库(注意字符集编码),导入数据库脚本…

飞鸟物联平台数字化解决方案:全方位提升OEM厂商销售、售后服务能力

自从OEM厂商把设备销售给终端客户,这笔交易就到此为止了。一旦目标行业出现下行趋势,订单和利润往往难以为继,OEM厂商往往遭受着其特有的三重考验:设备状况不透明、设备维保成本高、终端客户粘性低。这些挑战如同“三害”压得OEM厂…

AI搜索产品:秘塔、天工、perplexity、felo、360AI搜索

1、秘塔 https://metaso.cn/ 2、天工 https://www.tiangong.cn/ 3、perplexity https://www.perplexity.ai/ 4、Felo https://felo.ai/search 5、360ai搜索 https://www.sou.com/

洛谷P3865.ST表

洛谷P3865.ST表 i的取值为[1,n−2j1]从而推出j的取值为 j < lg[n]找区间最值时&#xff1a; 要找一段起始点L的可覆盖[L,R]的区间&#xff0c;即L 2k - 1 < R –> k < lg[R-L1] (区间长度)同时起点为 D R - 2k 1 (起始点)即f[D][k] #include <bits/stdc.…

12.1.案例专题-数据流图

文章目录 数据流图结构化语言描述示例 练习题2020年真题2021年上真题 数据流图 数据流图DFD基本图形元素&#xff1a;外部实体、加工、数据存储、数据流。 数据流&#xff1a;由一组固定成分的数据组成&#xff0c;表示数据的流向。在DFD中&#xff0c;数据流的流向必须经过…

IP进程间的通信方式以及不同主机间的通信方式

一&#xff0c;IP进程间的通信方式 共享内存&#xff08;最高效&#xff09; 1.是一块内核的预留空间 2.避免了用户空间到内核空间的数据拷贝 1.产生key:ftok函数 功能&#xff1a;将pathname和pid_id转化为key 参数&#xff1a;(路径名&#xff0c;A) 返回值&#xff1…

Java并发类API——ExecutorService

1.ExecutorService概述 ExecutorService 是 Java 并发库中一个非常重要的接口&#xff0c;它提供了一种管理和控制线程执行的方法。ExecutorService 是 Executor 接口的扩展&#xff0c;除了 Executor 提供的基础任务执行功能之外&#xff0c;ExecutorService 提供了更强大的功…

如何用Python构建高校爬虫与k-means算法实现专业评分可视化分析

&#x1f34a;作者&#xff1a;计算机毕设匠心工作室 &#x1f34a;简介&#xff1a;毕业后就一直专业从事计算机软件程序开发&#xff0c;至今也有8年工作经验。擅长Java、Python、微信小程序、安卓、大数据、PHP、.NET|C#、Golang等。 擅长&#xff1a;按照需求定制化开发项目…

工业互联网与大数据实训室解决方案

一、引言 1.1 工业互联网与大数据的重要性 工业互联网作为新一代信息技术与制造业深度融合的产物&#xff0c;正在全球范围内推动着制造业的数字化、网络化、智能化转型。它通过连接机器、物料、人和信息系统&#xff0c;实现数据的全面感知、动态传输和智能分析&#xff0c;…

白酒与素食:健康与美味的双重享受

在美食的世界里&#xff0c;白酒与素食的搭配仿佛是一场跨界的盛宴。豪迈白酒&#xff08;HOMANLISM&#xff09;的醇香与精致素食的清新&#xff0c;在不经意间交织出了一幅美妙的画卷&#xff0c;让人在品味中感受到健康与美味的双重享受。 素食&#xff0c;以其清淡、自然的…

Verilog刷题笔记54

题目&#xff1a; Fsm serialdp See also: Serial receiver and datapath We want to add parity checking to the serial receiver. Parity checking adds one extra bit after each data byte. We will use odd parity, where the number of 1s in the 9 bits received must…

如何在 FastReport .NET 中构建和安装 Postgres 插件

FastReport .NET 是一款全功能的Windows Forms、ASP.NET和MVC报表分析解决方案。 功能非常丰富&#xff0c;功能广泛。今天我们将介绍如何使用报表设计器的 FastReport 插件连接数据库。 FastReport .NET 是适用于.NET Core 3&#xff0c;ASP.NET&#xff0c;MVC和Windows窗体…

LlamaIndex 介绍

LlamaIndex 是什么&#xff1f; 从字面上理解&#xff0c;是 Llama Index&#xff0c;Llama 是大语言模型&#xff0c;Index 是索引&#xff0c;Index for Llama 就是为大语言模型做索引&#xff0c;那么大语言模型为什么需要索引&#xff0c;索引的作用是什么&#xff1f; …

CAS-ViT实战:使用CAS-ViT实现图像分类任务(一)

摘要 在视觉转换器&#xff08;Vision Transformers, ViTs&#xff09;领域&#xff0c;随着技术的不断发展&#xff0c;研究者们不断探索如何在保持高效性能的同时&#xff0c;降低模型的计算复杂度&#xff0c;以满足资源受限场景&#xff08;如移动设备&#xff09;的需求。…

住宅代理助力网页抓取,DaaS实现数据驱动的业务优化

什么是DaaS&#xff1f;有什么作用&#xff1f; DaaS的工作原理是什么&#xff1f;哪些行业需要&#xff1f; 如何应用DaaS&#xff1f; 网页抓取如何助力优化DaaS&#xff1f; 总结 在数字化转型的浪潮中&#xff0c;数据已成为企业决策和业务优化的核心资源。数据即服务&…

特殊采购转包

在转包期间&#xff0c;公司从外部供应商处订购物料。与正常外部采购流程不同&#xff0c;公司将为供应商&#xff08;转包商&#xff09;提供部分或全部用于物料生产的部件。 该流程拥有以下特征&#xff1a; 通过转包订单订购成品&#xff0c;该转包订单还包含有关要为转包商…

培训第三十二天(学习playbook-roles,脚本创建数据库和表,mycat读写分离)

上午 1、roles&#xff08;角色&#xff09;介绍 roles(⻆⾊): 就是通过分别将variables, tasks及handlers等放置于单独 的⽬录中,并可以便捷地调⽤它们的⼀种机制。 假设我们要写⼀个playbook来安装管理lamp环境&#xff0c;那么这个 playbook就会写很⻓。所以我们希望把这…