Saya telah mencoba memplot kurva kupu-kupu dengan python dan ini adalah kode saya.

import math
r = np.arange(0, 2, 0.01)
theta = 2 * np.pi * r
r_of_theta=math.exp(np.sin(theta))-2*np.cos(4*theta)+sin((2*theta-np.pi)/24)**5
t_of_theta.astype(int)
ax = plt.subplot(projection='polar')
ax.plot(theta,t,color='blue')
ax.set_rticks([0.5, 1, 1.5, 2]) 
ax.set_rlabel_position(-22.5)
plt.show()

Tapi saya terus mendapatkan kesalahan ini

TypeError                                 Traceback (most recent call last)
<ipython-input-66-876098af4358> in <module>()
      2 r = np.arange(0, 2, 0.01)
      3 theta = 2 * np.pi * r
----> 4 r_of_theta=math.exp(np.sin(theta))-2*np.cos(4*theta)+sin((2*theta-np.pi)/24)**5
      5 t_of_theta.astype(int)
      6 ax = plt.subplot(projection='polar')

TypeError: only size-1 arrays can be converted to Python scalars

Dapatkah seseorang membantu saya? Terima kasih sebelumnya.

1
Nivedhitha 14 Januari 2020, 18:38

2 jawaban

Jawaban Terbaik

Lihat, Anda memiliki beberapa kesalahan pengetikan. Anda harus menggunakan np. di mana-mana.

import numpy as np
import matplotlib.pyplot as plt

r = np.arange(0, 2, 0.01)

theta = 2 * np.pi * r
r_of_theta = []
r_of_theta = np.exp(np.sin(theta[:]))-2*np.cos(4*theta[:])+np.sin((2*theta[:]-np.pi)/24)**5
r_of_theta.astype(int)

ax = plt.subplot(projection='polar')
ax.plot(r_of_theta,color='blue')
ax.set_rticks([0.5, 1, 1.5, 2]) 
ax.set_rlabel_position(-22.5)
plt.show()
1
OverLordGoldDragon 5 Februari 2020, 02:00

math.exp bekerja pada satu nilai, dan Anda memberinya array. Anda dapat membuat vektorisasi fungsi menggunakan np.vectorize, meskipun:

import math
r = np.arange(0, 2, 0.01)
theta = 2 * np.pi * r
vec_exp = np.vectorize(math.exp)
r_of_theta=vec_exp(np.sin(theta))-2*np.cos(4*theta)+np.sin((2*theta-np.pi)/24)**5

Sekarang kode Anda akan berjalan hingga setidaknya baris itu.

1
Juan C 14 Januari 2020, 15:43