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. 1-linux系统管理(一)之安装RHEL 6.4
  2. Fragment全解析系列(一):那些年踩过的坑
  3. Linux IO漫谈
  4. 60,000毫秒内对Linux的性能诊断效的方法
  5. tomcat 6.0.44 “has failed to stop it. This is very likely to create a memory leak” 问题调查
  6. (顺序表的应用5.4.2)POJ 1591 M*A*S*H(约瑟夫环问题的变形——变换步长值)
  7. Swift与OC之间的选择
  8. disconf实践(一)
  9. Scala-逻辑判断
  10. stagefright框架(七)-Audio和Video的同步
  11. [转载]提升进程权限-OpenProcessToken等函数的用法
  12. hadoop搭建杂记:Linux下hadoop的安装配置
  13. Theano学习-scan循环
  14. VxWorks启动过程详解(上)
  15. 使用jquery模拟请求,测试项目是否存在跨域限制
  16. 初学python之路-day10
  17. h5微信支付在微信内页使用微信公众号支付
  18. git 的安装与初始化
  19. 什么是redis?redis有什么用途?
  20. 使用flask-alchemy 过程中报错KeyError: 'SQLALCHEMY_TRACK_MODIFICATIONS'

热门文章

  1. 【C#设计模式】里氏替换原则
  2. Windows三种文件系统:NTFS、FAT32、FAT16的区别
  3. Activity跳转显式方法及隐式方法
  4. Qt:QString
  5. Spring系列20:注解详解和Spring注解增强(基础内功)
  6. 二级py--day6数据库设计基础
  7. 【一】TSP、VRP、VRP模型介绍
  8. TP5实现多文件上传及展示
  9. PhpStorm中绘画UML
  10. 20192204李龙威 2019-2020-2 《Python程序设计》实验一报告