python计算球坐标系的积分_python – n球面坐标系到笛卡尔坐标系

您可以通过记忆中间产品来加速您的原始代码,即

def ct_dynamic(r,alpha):

"""alpha: the n-2 values between [0,2\pi)

"""

x = np.zeros(len(alpha) + 1)

s = 1

for e,a in enumerate(alpha):

x[e] = s*np.cos(a)

s *= np.sin(a)

x[len(alpha)] = s

return x*r

但仍然在速度上失去基于numpy的方法

def ct(r,arr):

a = np.concatenate((np.array([2*np.pi]),arr))

si = np.sin(a)

si[0] = 1

si = np.cumprod(si)

co = np.cos(a)

co = np.roll(co,-1)

return si*co*r

>>> n = 10

>>> c = np.random.random_sample(n)*np.pi

>>> all(ct(1,c) == ct_dynamic(1,c))

True

>>> timeit.timeit('from __main__ import coord_transform_n as f,c; f(2.4,c)',number=10000)

2.213547945022583

>>> timeit.timeit('from __main__ import ct_dynamic as f,number=10000)

0.9227950572967529

>>> timeit.timeit('from __main__ import ct as f,number=10000)

0.5197498798370361

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值