matlab插值函数的优缺点,Python和Matlab插值函数的不同结果

matlab插值函数的优缺点,Python和Matlab插值函数的不同结果我正在将代码从Matlab转换为Python2.7,在转换interp1函数时遇到问题。我看过已经贴出来的类似问题,但还没有解决。问题是新生成的值(yn)的向量的第一个值不同,而其余的几乎相同。当使用不同的插值方法时,我得到的值略有不同,但是同样的问题。目前我真的不知道为什么会这样。有没有人对此有任何了解或看到我可能犯的错误?谢谢。在变量:x=[5.5,5.46678,5….

大家好,又见面了,我是你们的朋友全栈君。

我正在将代码从Matlab转换为Python2.7,在转换interp1函数时遇到问题。我看过已经贴出来的类似问题,但还没有解决。问题是新生成的值(yn)的向量的第一个值不同,而其余的几乎相同。当使用不同的插值方法时,我得到的值略有不同,但是同样的问题。目前我真的不知道为什么会这样。有没有人对此有任何了解或看到我可能犯的错误?谢谢。在

变量:x = [5.5 , 5.46678 , 5.408315, 5.33929 , 5.261025, 5.17605 ,

5.08684 , 4.995375, 4.902755, 4.80942 , 4.7157 , 4.621815,

4.52782 , 4.433715, 4.339555, 4.245395, 4.151235, 4.05713 ,

3.962915, 3.868645, 3.77432 , 3.680105, 3.585945, 3.491895,

3.397845, 3.303905, 3.21002 , 3.11619 , 3.02247 , 2.928805,

2.835195, 2.741695, 2.64836 , 2.55519 , 2.462295, 2.36951 ,

2.27689 , 2.184435, 2.092255, 2.00035 , 1.908775, 1.817475,

1.726505, 1.63592 , 1.54583 , 1.4564 , 1.36752 , 1.279245,

1.19163 , 1.10539 , 1.02135 , 0.94006 , 0.86163 , 0.786115,

0.713515, 0.64394 , 0.577555, 0.514635, 0.45562 , 0.400785,

0.35035 , 0.304425, 0.26301 , 0.22627 , 0.193875, 0.16544 ,

0.14058 , 0.118745, 0.09944 , 0.082335, 0.067265, 0.05401 ,

0.042405, 0.03234 , 0.023595, 0.01628 , 0.010175, 0.00528 ,

0.001485, -0.00121 , -0.002805, -0.003355, -0.00275 , -0.000935]

y = [0.19896, 0.18722, 0.155 , 0.13133, 0.11168, 0.09543,

0.0815 , 0.06556, 0.04191, 0.0117 , 0.00513, 0.00123,

-0.0036 , -0.00885, -0.01429, -0.01985, -0.02532, -0.03065,

-0.03574, -0.04082, -0.04594, -0.05104, -0.05596, -0.06091,

-0.06561, -0.07023, -0.07482, -0.07913, -0.08341, -0.08749,

-0.09155, -0.09551, -0.09952, -0.10334, -0.10694, -0.11011,

-0.11319, -0.11587, -0.11856, -0.12092, -0.12277, -0.12428,

-0.12506, -0.12567, -0.12567, -0.12497, -0.12369, -0.12135,

-0.11944, -0.1191 , -0.11983, -0.11819, -0.11197, -0.10004,

-0.08016, -0.05285, -0.01569, 0.03055, 0.08527, 0.1492 ,

0.21971, 0.29507, 0.37453, 0.45682, 0.53766, 0.61562,

0.6916 , 0.763 , 0.82907, 0.88665, 0.9367 , 0.97418,

0.99617, 0.99807, 0.97457, 0.91708, 0.81796, 0.66987,

0.46359, 0.19778, -0.13378, -0.54232, -1.0126 , -1.5297 ]

xn = [ 0., 0.61111111, 1.22222222, 1.83333333, 2.44444444,

3.05555556, 3.66666667, 4.27777778, 4.88888889, 5.5 ]

Matlab代码:

^{pr2}$

Python代码:from scipy.interpolate import InterpolatedUnivariateSpline

yn_f1 = InterpolatedUnivariateSpline(x[::-1], y[::-1])

yn_py1 = yn_f1(xn)

from scipy.interpolate import interp1d

yn_f2 = interp1d(x[::-1], y[::-1])

yn_py2 = yn_f2(xn)

import numpy as np

yn_py3 = np.interp(xn, x[::-1], y[::-1])

结果:yn_mat = [-0.7596, -0.0345, -0.1201, -0.1240, -0.1075,

-0.0819, -0.0517, -0.0179, 0.0374, 0.1990 ]

yn_py1 = [-0.23310355, -0.03594415, -0.11996893, -0.12406894, -0.10757466,

-0.08191329, -0.05174936, -0.01793778, 0.0371338 , 0.19896 ]

yn_py2 = [ 0.31712327, -0.03447354, -0.12010691, -0.12401772, -0.10754986,

-0.08189905, -0.05174217, -0.01793785, 0.03742192, 0.19896 ]

yn_py3 = [ 0.31712327, -0.03447354, -0.12010691, -0.12401772, -0.10754986,

-0.08189905, -0.05174217, -0.01793785, 0.03742192, 0.19896 ]

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/146082.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • global south 有哪些国家_global ethics

    global south 有哪些国家_global ethicsThedifferenceofkeywordsofglobalandnonlocalistheplacewheretheyareuses.Forexample,nonlocolisusedwithinthefunctionforstatingavariablewhichcanbeusedoutsidethefunctionInthesamemeaning,globalisusedoutsidethefunctionfo

    2025年9月3日
    6
  • 看了这篇文章觉得MySQL读写分离这么简单「建议收藏」

    点赞多大胆,就有多大产!有支持才有动力!微信搜索公众号【达摩克利斯之笔】获取更多资源,文末有二维码!前言​  Mysql优化那篇文章有朋友留言说就这么点?,深深刺痛了晓添的心,感觉知识深度被小看了,痛定思痛决定发布读写分离,分表分库优化文章,其实这系列文章也在Mysql优化的计划之内,最近较忙断断续续写的有点难受,到今天才跟大家见面,篇幅有限这篇我们来说说基于Mycat实现读写分离,话不多…

    2022年4月13日
    59
  • python抛出异常写法_零基础学 Python(32):如何抛出和捕获异常?「建议收藏」

    python抛出异常写法_零基础学 Python(32):如何抛出和捕获异常?「建议收藏」1.如何抛出异常?异常的产生有两种来源:一种是程序自动抛出,比如1/0会自动抛出ZeroDivisionError一种是开发者主动抛出,使用raise关键字抛出。在Python中是使用raise关键字来抛出异常的,比如在下面这个函数中,如果不存在目标文件,则会抛出一个Exception通用异常。2.如何捕获异常?出现错误或者异常没有关系,关键在于你要学会预判程序可能会出现…

    2022年10月10日
    2
  • kettle 教程(四):自定义 Java 代码

    kettle 教程(四):自定义 Java 代码kettle拥有很多自带的组件,能帮我们实现很多的功能。但是我们总有一些很复(qi)杂(pa)的需求,用自带的组件实现不了,或者说实现起来很复杂。那么这时我们就要用到万能的组件了(Java代码),通过自己写代码来实现任何想要的功能。自定义Java代码假设有这样一个需…

    2022年5月23日
    243
  • matlab保存图片去掉白边_matlab输出图像不留白

    matlab保存图片去掉白边_matlab输出图像不留白MATLAB保存图片去白边MATLAB保存图片的时候经常有白边,此法可以去除四周的白边法1:imwrite(x,’name’,’format’)经过测试非常好用eg:    name_mask=[currentpath,’\data_prepare_fig\’ name’_mask.tif’];  imwrite(BW3_prepare,name_mask);法二:imshow…

    2025年11月5日
    5
  • idea中如何配置maven项目_idea配置maven环境

    idea中如何配置maven项目_idea配置maven环境一、使用步骤1.在Idea中配置maven(1)、打开Idea,点击File,然后点击Settings,进入设置,或者直接按Ctrl+Alt+S进入设置在这里插入图片描述(2)、先在左上角的搜索框输入maven,找到maven后单击,然后在右边的mavenhomepath的右边选择你的maven安装路径,选择到根目录就好了,然后点击确定,具体步骤看下图:在这里插入图片描述(3)、Localrepository是maven的本地仓库,默认路径是C:UsersAdministrator.

    2022年10月3日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号