我目前正在尝试使用 matplotlib 绘制以下方程:
-4xy + x² - y² + 4(x³y - xy³) = 0
我不想通过简单地分配x = np.linspace(-5,5)
然后将其放入我的方程来求解这个可怕的方程。
我想知道是否可以直接使用matplotlib.pyplot
绘制解决方案?我能够使用 Geogebra 很好、快速地绘制函数,所以我想这也应该可以使用 python 实现。但是,我还没有发现任何其他与此相关的问题。有人有什么想法吗?
最佳答案
实现此目的的一种方法是使用 Sympy 的 plot_implicit
功能。
代码:
from sympy import plot_implicit, symbols, Eq
x, y = symbols('x y')
plot_implicit(Eq(-4*x*y+x**2-y**2+4*(x**3-x*y**3), 0),
adaptive=False,
points=1000)
输出:
在底层,它使用网格来决定是否在图表上的每个点绘制函数。这也是 Geogebra 将在幕后做的事情。要在普通 matplotlib 中应用这种方法,我们可以使用等高线图:
代码:
import numpy as np
import matplotlib.pyplot as plt
# Plot axes in middle
fig, ax = plt.subplots()
ax.spines['left'].set_position('center')
ax.spines['bottom'].set_position('center')
ax.spines['right'].set_color('none')
ax.spines['top'].set_color('none')
ax.xaxis.set_ticks_position('bottom')
ax.yaxis.set_ticks_position('left')
# Set up mesh grid
x = y = np.linspace(-1.0, 1.0, 100)
X, Y = np.meshgrid(x,y)
# Plot contour
ax.contour(X, Y, -4*X*Y+X**2-Y**2+4*(X**3-x*Y**3), [0])
plt.show()
输出:
关于python - 绘制非多项式多元隐式方程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60111935/