- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在Python中,我应该使用负指数还是除法?例:
>>> num = 2.0**-1
>>> num = 1/2.0
import dis
def exp_test(x):
return x**-1
def div_test(x):
return 1/x
print "Exp Test:"
dis.dis(exp_test)
print "Div Test:"
dis.dis(div_test)
Exp Test:
2 0 LOAD_FAST 0 (x)
3 LOAD_CONST 1 (-1)
6 BINARY_POWER
7 RETURN_VALUE
Div Test:
2 0 LOAD_CONST 1 (1)
3 LOAD_FAST 0 (x)
6 BINARY_DIVIDE
7 RETURN_VALUE
最佳答案
如果您正在计算Python float
x
的倒数,我想不出任何理由更喜欢x**-1.0
而不是1.0/x
。从主观上讲,我认为后者更容易阅读。客观地讲,它可能会更快(因为它包装了一条简单的CPU指令,而不是对C库的pow函数的调用),并且更加准确(出于几乎相同的原因)。
请注意,我在两个表达式中都故意使用了1.0
而不是1
,这都是因为这样可以避免在x
为浮点数的情况下进行额外的从int到float的转换,并且这将保证我在x
恰好是一个int的情况下,在Python 2.7上获得一个适当的浮点除法而不是一个地板除法。
为了支持“更快”的主张,这是我的机器上的一些时间安排,包括同时具有1
和1.0
的变体。这是在Python 2.7下实现的,但结果在Python 3.4下却类似。
>>> import timeit
>>> timeit.timeit('x**-1', 'x=12.34')
0.08957314491271973
>>> timeit.timeit('x**-1.0', 'x=12.34')
0.08102011680603027
>>> timeit.timeit('1/x', 'x=12.34')
0.06166410446166992
>>> timeit.timeit('1.0/x', 'x=12.34')
0.04489898681640625
1.0
代替
1
可以明显提高速度。您的结果可能会有所不同。
2**-1
或
1.0/2.0
这样的定时表达式的陷阱。可以通过Python的窥孔优化器将这些表达式优化为编译时的常量,因此最终需要花费的时间就是检索常量
0.5
的时间。您可以使用标准库中的
dis
模块查看此内容:
>>> def half_via_pow(): return 2.0**-1.0
...
>>> def half_via_div(): return 1.0/2.0
...
>>> import dis
>>> dis.dis(half_via_pow)
1 0 LOAD_CONST 3 (0.5)
3 RETURN_VALUE
>>> dis.dis(half_via_div)
1 0 LOAD_CONST 1 (1.0)
3 LOAD_CONST 2 (2.0)
6 BINARY_DIVIDE
7 RETURN_VALUE
2.0**-1.0
被优化为一个常数,而除法
1.0/2.0
不是。在Python 3.4中,两者都被优化为一个常数。我怀疑Python 2.7窥孔优化器会避免优化除法,以便不必担心需要提高
ZeroDivisionError
的情况。无论哪种方式,对
2.0**-1.0
计时
1.0/2.0
都不能准确反映
1.0/x
与
x**-1.0
的速度。将
1.0/x
与
x**-1.0
相对应,并在设置步骤中为
x
提供一个值。
1.0/x
将解析为一条机器指令,几乎可以肯定的是,它将为您提供四舍五入的结果。相反,
pow
的库实现非常糟糕,并且经常会给出未正确舍入的结果。即使在最好的情况下,数学库的
pow
操作正确舍入,它仍然不会比除法结果更准确。
1.0 / x
和
x ** -1.0
的随机
x
值:
>>> import random
>>> while True:
... x = random.random()
... print(repr(x))
... assert 1.0/x == x**-1.0
<around 200 lines of output omitted>
0.16606458447273365
0.6466363135038045
0.8650060330740814
Traceback (most recent call last):
File "<stdin>", line 4, in <module>
AssertionError
x
值,我得到:
>>> x = 0.8650060330740814
>>> 1.0 / x
1.1560613010364489
>>> x ** -1.0
1.1560613010364487
1.0 / x
的结果是否在此正确舍入,我们可以将浮点数转换为
Fraction
(进行精确转换),将倒数作为
Fraction
,然后转换回
float
到
Fraction
的转换已正确舍入,并且不使用浮点算术来计算结果,因此在此检查中我们不依赖于浮点除法的精度。
>>> from fractions import Fraction
>>> float(1 / Fraction(x))
1.1560613010364489
float
的精确倒数,计算为25个有效数字,是
x
。我们从
1.156061301036448774438694
取回的值,以相同的精度计算,是
1.0 / x
,而
1.156061301036448885071195
的值是< cc>,因此
x ** -1.0
仅比
1.156061301036448663026590
更接近真实值,但更接近。)
1.0 / x
易于阅读,并且不需要花费很多心思即可解析。
x ** -1.0
形式。
关于python - Python负指数与除法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26185205/
我正在尝试编写一个简单的除法函数,但出现错误 PS C:\Users\john> Function Div($x, $y) { $x / $y } PS C:\Users\john> Div (1,
试图找出这个伪代码。以下假设...... 我只能使用无符号和有符号整数(或长整数)。 除法返回一个没有余数的实数。 MOD 返回一个实数。 不处理分数和小数。 INT I = 41828; INT C
如果我有以下表格并且我在关系代数中执行 R1/R2,结果会是一个具有 A 值 1 和 3 的表格吗?我有点困惑,因为我知道 3 将是一个结果,因为它包含 5 和 1,但结果 1 除了匹配的值之外还有
//Declare and intialize variables - programmer to provide initial values Scanner in = new Scanne
除法运算符在 scala BigDecimal 上有什么用? val d1 = BigDecimal(2) val d2 = BigDecimal(3) val div = d1 / d2 //thr
这个问题在这里已经有了答案: How can I divide properly using BigDecimal (2 个答案) 关闭 6 年前。 我在这里做错了什么?很确定这是正确的,我能够打印
好的 - 已经为此苦苦挣扎了一段时间。我刚刚开始学习 Python,所以非常新。 我有一个元组列表,需要按每个元组中值的比率进行排序。 输入: L = [(1,3), (1,7), (4,8)] 返回
我有一个奇怪的问题,我收到计算机生成的方程式(作为字符串),其中偶尔会出现零或一和零的乘法/除法。这些等式将以字符串形式呈现给用户。 我知道我可以通过实现一种解析器来删除等式中的这些冗余部分,但我很好
我有两个变量:count,这是我过滤的对象的数量,以及每页的常量值。我想将计数除以 per_page 并获得整数值,但无论我尝试什么 - 我都得到 0 或 0.0: >>> count = frien
我尝试在 Go 中获得 2.4/0.8 == 3 w:=float64(2.4) fmt.Println(math.Floor(w/0.8),math.Floor(2.4/0.8) ) 它给了我“2
程序清单: # val_caculate.py a = 10 # a是整数 print('10/3 = ',10/3) print('9/3 = ',9/3) pri
我是 java 新手,所以我需要你对我正在进行的项目的帮助!我定义了一些计数器,这些是我将使用的: int[] acceptCounters = {}; int[] acceptFailCounter
我正在除 2 个 BigInteger 值 N = 9440056782685472448790983739834832785827768777249804302814308027414135716
我的应用程序中有使用 array.reduce 将数字相乘的代码。它看起来像这样: // Private function to multiply field values together func
我目前创建了一个名为 Array Math 的类,它将乘法加载到 10x10 数组中,如代码下显示的图像所示,但是我想要做的是在乘法后将每个位置除以 2。换句话说,(行 * 列)/2 目前我只是将这些
我正在使用代表货币金额的 BigDecimal 值。我需要将此金额分成 6 个费率,前 5 个费率四舍五入为 5,其余的为第 6 个费率。 BigDecimal numberOfRates = new
这个问题必须使用递归来解决。 我尝试使用 “else” 之后的代码来使用 int temp 计算商,该 temp 计算可以除以多少次 (temp = dividend - divisor)。 int
我知道这一定是有史以来最简单的事情,但我是这里的初学者。为什么我运行时会出现语法错误 document.write(10 / 2 + ""); //Divide 10 by 5 to get 2
这应该是一个非常基本的东西,但不知何故我没有看到问题。 #include template inline void i2c(const int & ind, int & i, int &j) {
我正在做课本中的一些家庭作业,并且有一些关于某些算术运算的浮点舍入/精度的问题。 如果我像这样从 int 中转换 double : int x = random(); double dx = (dou
我是一名优秀的程序员,十分优秀!