Использование np.piecewise
для определения функции и np.mgrid
:
import numpy as np
import matplotlib.pyplot as plt
w = 3
y, x = np.mgrid[-w:w:100j, -w:w:100j]
U = y
V = np.piecewise(x, [x <= 2, x > 2], [lambda x: 5/((3-2*(-x))**2)-((-18+(-x))*(-6+(-x)))/((-x)**4), lambda x: 5/((3-2*x)**2)-((-18+x)*(-6+x))/(x**4)])
plt.streamplot(x, y, U, V, density=[0.5, 1])
plt.show()
Дает нам следующий график: