Vectorizing a function (Python)(向量化函数(Python))
本文介绍了向量化函数(Python)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我是Python新手,正在尝试执行硬件分配,它不断向我抛回此错误(在IPython笔记本中):
"TypeError: unsupported operand type(s) for ** or pow(): 'list' and 'float'"
这里是我试图模仿的公式:h(X)=(1/√2π)*e^−(1/2)^x^2
import numpy as np
import math
from math import *
def h_scalar(x):
return (1 / sqrt(2 * pi)) * exp(-.50** x ** 2.00)
我正在努力取得和我老师一样的成绩。
l = [-10.0, -1.0, 0.0, 1.0, 10.0] #
print h_scalar(l)
>>> [1.4867195147342977e-06, 0.24197072451914337, 0.3989422804014327,
0.24197072451914337, 1.4867195147342977e-06]
这是老师们的问题btw:
首先,编写一个名为h_scalar的函数。该函数应该期待一个列表(或者通常是一个可迭代的项)。它将期望该列表包含浮点值。它应该返回一个新的浮点数列表,这些浮点数是输入列表中每个x值的h(X)。您应该将函数命名为h_scalar()
推荐答案
使用numpy
的sqrt
和exp
将获得更好的性能,它们将按元素运行:
import numpy as np
from numpy import sqrt, exp, pi
def h_scalar(x):
x = np.array(x)
return (1/sqrt(2*pi)) * exp(-0.50*x**2)
您可以这样使用:
x = [-10.0, -1.0, 0.0, 1.0, 10.0]
h_scalar(x)
这篇关于向量化函数(Python)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:向量化函数(Python)


猜你喜欢
- 使用Heroku上托管的Selenium登录Instagram时,找不到元素';用户名'; 2022-01-01
- python check_output 失败,退出状态为 1,但 Popen 适用于相同的命令 2022-01-01
- 如何在 Python 的元组列表中对每个元组中的第一个值求和? 2022-01-01
- python-m http.server 443--使用SSL? 2022-01-01
- 分析异常:路径不存在:dbfs:/databricks/python/lib/python3.7/site-packages/sampleFolder/data; 2022-01-01
- padding='same' 转换为 PyTorch padding=# 2022-01-01
- pytorch 中的自适应池是如何工作的? 2022-07-12
- 如何在 python3 中将 OrderedDict 转换为常规字典 2022-01-01
- 沿轴计算直方图 2022-01-01
- 如何将一个类的函数分成多个文件? 2022-01-01