Pytorch中range和arange方法有什么区别?

前言:

在官方文档中,我们可以在这里查到这两个方法的API(可能需要一些手段才能点开),如果你点开不了,那我帮你看一下这两个方法有哪些区别。

1.range()

torch.range(start=0, end, step=1, *, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor

range返回的数量是到 ⌊ e n d − s t a r t s t e p ⌋ + 1 \lfloor \frac{end−start}{step} \rfloor +1 stependstart+1
第二个参数减去第一个参数向下取整+1
例如:

x1 = torch.range(1, 10, 3) # (10-1)/3向下取整+1等于4
print(x1)

输出是:

tensor([ 1.,  4.,  7., 10.]) # 输出4个数

基本上常用的就是三个参数

x1 = torch.range(1, 10, 2)
print(x1)

输出结果是:

tensor([1., 3., 5., 7., 9.])

2.arange()

torch.arange(start=0, end, step=1, *, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor

可以看到arange方法和range在用法和参数上是完全一样的。
但是他返回的个数是 ⌈ e n d − s t a r t s t e p ⌉ \lceil \frac{end-start}{step} \rceil stependstart
如果还是上面的那个例子,我们看看会产生什么结果:

x1 = torch.arange(1, 10, 3)
print(x1)

输出结果:

tensor([1, 4, 7])

可以看到输出的个数只有三个。

3.总结

因此我们得出结论:

1.range和arange返回个数可能会不一样,一个向下取整加一,一个是向上取整

2.range返回的是浮点型,arange返回的是整型(arange如果步长等于小数,也会返回浮点型的值,例如torch.arange(1, 2.5, 0.5),输出是:tensor([ 1.0000, 1.5000, 2.0000]))

最重要的是range方法官方表示已经被抛弃了,未来不久会完全删除掉,因为它的行为与Python的内置范围不一致,我猜测Python内置范围也是向上取整

官方解释如下:

This function is deprecated and will be removed in a future release because its behavior is inconsistent with Python’s range builtin. Instead, use torch.arange(), which produces values in [start, end).
from:https://pytorch.org/docs/stable/generated/torch.range.html#torch.range

技术有限,如有纰漏或错误欢迎大佬指正,感谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Bean冷的心

你的鼓励将是我前进的动力~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值