[ Foro de Python ]
Hola, estoy aprendiendo a programar en python y quiero graficar una funcion implicita F(x,y,z)=0, en python pero no lo consigo, sigo un ejemplo de f(x,y)=0.
El proceso es el siguiente:
Defino las variables para la malla en x,y ,z
fig = plt.figure()
ax = fig.gca(projection='3d')
X = np.arange(-5, 5, 0.25)
Y = np.arange(-5, 5, 0.25)
Z = np.arange(-5, 5, 0.25)
X, Y = np.meshgrid(X, Y)
def f(X, Y, Z):
return (-(X**2)*(Z**3)-(9/80)*(Y**2)*(Z**3))+((X**2)+(9/4)*(Y**2)+(Z**2)-1)**3
#esto pinta un corazon en 3D
ax.plot_surface(X, Y, f(X, Y, Z), rstride=1, cstride=1, cmap='hot')
plt.show(f(X, Y, Z))
sigo los paso para el caso de z=f(x,y) e intento adaptarlo al nuevo caso, pero no lo consigo, podrian colaborarme con el codigo?
Incluye el ejemplo de cómo has hecho el caso de f(x,y), para poder comparar y ver qué puede estar fallando
Hola Nacho, mi base es esta:
from matplotlib import cm
from matplotlib.ticker import LinearLocator
import matplotlib.pyplot as plt
import numpy as np
fig = plt.figure()
ax = fig.gca(projection='3d')
X = np.arange(-5, 5, 0.25)
xlen = len(X)
Y = np.arange(-5, 5, 0.25)
ylen = len(Y)
X, Y = np.meshgrid(X, Y)
R = np.sqrt(X**2 + Y**2)
Z = np.sin(R)
colortuple = ('y', 'b')
colors = np.empty(X.shape, dtype=str)
for y in range(ylen):
for x in range(xlen):
colors[x, y] = colortuple[(x + y) % len(colortuple)]
surf = ax.plot_surface(X, Y, Z, rstride=1, cstride=1, facecolors=colors,
linewidth=0, antialiased=False)
ax.set_zlim3d(-1, 1)
ax.w_zaxis.set_major_locator(LinearLocator(6))
plt.show()
gracias por tu interes y ayuda!!
(No se puede continuar esta discusión porque tiene más de dos meses de antigüedad. Si tienes dudas parecidas, abre un nuevo hilo.)