首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用PYTHON点集绘制拉格朗日多项式

用PYTHON点集绘制拉格朗日多项式
EN

Stack Overflow用户
提问于 2018-06-03 16:18:11
回答 1查看 4.2K关注 0票数 1

我需要画一条曲线,通过点(0,0),(20,10),(0,50)。因为有两个点具有相同的x坐标,所以我决定用参数t来参数x和y,因为我需要这个多项式的方程(曲线),所以我决定使用拉格朗日。嗯,这个情节真的很奇怪,它会打印点,但是没有曲线:

代码语言:javascript
复制
x_parabola = np.array([0, 20, 0]) # array for x
y_parabola = np.array([0, 10, 50]) # array for y
plt.figure()
u = plt.plot(x_parabola,y_parabola,'ro') # plot the points
t = np.linspace(0, 1, len(x_parabola)) # parameter t to parametrize x and y
pxLagrange = scipy.interpolate.lagrange(t, x) # X(T)
pyLagrange = scipy.interpolate.lagrange(t, y) # Y(T)
n = 100
ts = np.linspace(t[0],t[-1],n)
xLagrange = pxLagrange(ts) # lagrange x coordinates
yLagrange = pyLagrange(ts) # lagrange y coordinates
plt.plot(xLagrange, yLagrange,'b-',label = "Polynomial")

拜托,你能告诉我密码有什么问题吗?提前感谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-06-03 16:31:47

您必须重新定义variables.This works

代码语言:javascript
复制
import numpy as np
import scipy.interpolate
import matplotlib.pyplot as plt

x_parabola = np.array([0, 20, 0]) # array for x
y_parabola = np.array([0, 10, 50]) # array for y
plt.figure()
u = plt.plot(x_parabola,y_parabola,'ro') # plot the points
t = np.linspace(0, 1, len(x_parabola)) # parameter t to parametrize x and y
pxLagrange = scipy.interpolate.lagrange(t, x_parabola) # X(T)
pyLagrange = scipy.interpolate.lagrange(t, y_parabola) # Y(T)
n = 100
ts = np.linspace(t[0],t[-1],n)
xLagrange = pxLagrange(ts) # lagrange x coordinates
yLagrange = pyLagrange(ts) # lagrange y coordinates
plt.plot(xLagrange, yLagrange,'b-',label = "Polynomial")
plt.show()
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50668453

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档