插值方法 - Lagrange插值多项式
2024-09-07 20:35:52
Lagrange插值多项式代码:
1 # -*- coding: utf-8 -*-
2 """
3 Created on Wed Mar 25 15:43:42 2020
4
5 @author: 35035
6 """
7
8
9 import numpy as np
10
11 # Lagrange插值多项式:
12 def Lagrange(x, y, xi):
13 '''x、y是array,xi是一个值,函数返回结果ans'''
14 n = len(x)
15 m = len(y)
16 if n != m:
17 print("Error!")
18 return None
19 ans = 0
20 for i in range(n):
21 # 选定第i项循环计算
22 temp = 1
23 for j in range(n):
24 if i == j:
25 continue
26 temp *= (xi - x[j]) / (x[i] - x[j])
27 ans += temp * y[i]
28 return ans
29
30 # 当对多个值使用Lagrange插值时,使用map()建立映射:
31 # Iterator = map(Lagrange, Iterable)
32
33 # 用单个值测试函数:计算根号115
34
35 # 线性插值:
36 # 取x0 = 100, y0 = 10; x1 = 121, y1 = 11
37 # 抛物线插值:
38 # 多取一点 x2 = 144, y2 = 12
39 y = np.array((10, 11)) # 12
40 x = np.array((100, 121)) # 144
41 ans = Lagrange(x, y, 115)
42 print(ans)
43 # 线性插值结果:10.413 抛物线插值结果:10.7228
44 # 测试成功!
还想打一下公式的,搞了几小时结果对结果都不满意,果然在这个编辑器数学公式与代码不可兼得......
最新文章
- 1-linux系统管理(一)之安装RHEL 6.4
- Fragment全解析系列(一):那些年踩过的坑
- Linux IO漫谈
- 60,000毫秒内对Linux的性能诊断效的方法
- tomcat 6.0.44 “has failed to stop it. This is very likely to create a memory leak” 问题调查
- (顺序表的应用5.4.2)POJ 1591 M*A*S*H(约瑟夫环问题的变形——变换步长值)
- Swift与OC之间的选择
- disconf实践(一)
- Scala-逻辑判断
- stagefright框架(七)-Audio和Video的同步
- [转载]提升进程权限-OpenProcessToken等函数的用法
- hadoop搭建杂记:Linux下hadoop的安装配置
- Theano学习-scan循环
- VxWorks启动过程详解(上)
- 使用jquery模拟请求,测试项目是否存在跨域限制
- 初学python之路-day10
- h5微信支付在微信内页使用微信公众号支付
- git 的安装与初始化
- 什么是redis?redis有什么用途?
- 使用flask-alchemy 过程中报错KeyError: 'SQLALCHEMY_TRACK_MODIFICATIONS'