MinkowskiEngine实用函数和类

sparse_quantize

MinkowskiEngine.utils.sparse_quantize(coords, feats=None, labels=None, ignore_label=- 100, return_index=False, return_inverse=False, quantization_size=None)

给定坐标和特征(optional的标签),函数将生成量化(体素化)坐标。

Args

coordsnumpy.ndarraytorch.Tensor): N×D矩阵大小 ,其中 N 是点数 ,D是维数空间。

featsnumpy.ndarraytorch.Tensor,optional):大小矩阵N×DF ,其中 N 是点数, DF是特征的尺寸。必须与coords具有相同的容器(即,如果coords是torch.Tensor,则feats 也必须是torch.Tensor)。

labelsnumpy.ndarraytorch.IntTensor,optional):与eah坐标关联的整数标签。必须与coords具有相同的容器(即,如果coords是torch.Tensor,则 标签也必须是torch.Tensor)。对于将一组点映射到一个标签的分类,请勿输入标签。

ignore_labelint,optional):IGNORE LABEL的int值。 torch.nn.CrossEntropyLoss(ignore_index=ignore_label)

return_indexbool,optional):如果需要量化坐标的索引,则设置True。默认为False。

return_inversebool,optional):如果希望索引可以恢复离散化的原始坐标,则将其设置为True。默认为False。当return_reverse为True时,return_index必须为True。

例:

>>> unique_map, inverse_map = sparse_quantize(discrete_coords, return_index=True, return_inverse=True)

>>> unique_coords = discrete_coords[unique_map]

>>> print(unique_coords[inverse_map] == discrete_coords)  # True

quantization_sizefloatlist或 numpy.ndarray,optional):网格单元的超矩形各边的长度。

例:

>>> # Segmentation

>>> criterion = torch.nn.CrossEntropyLoss(ignore_index=-100)

>>> coords, feats, labels = MinkowskiEngine.utils.sparse_quantize(

>>>     coords, feats, labels, ignore_label=-100, quantization_size=0.1)

>>> output = net(MinkowskiEngine.SparseTensor(feats, coords))

>>> loss = criterion(output.F, labels.long())

>>>

>>> # Classification

>>> criterion = torch.nn.CrossEntropyLoss(ignore_index=-100)

>>> coords, feats = MinkowskiEngine.utils.sparse_quantize(coords, feats)

>>> output = net(MinkowskiEngine.SparseTensor(feats, coords))

>>> loss = criterion(output.F, labels.long())

batched_coordinates

MinkowskiEngine.utils.batched_coordinatescoords

根据一系列坐标,创建一个ME.SparseTensor坐标

给定numpy或pytorch张量坐标的列表,返回适合ME.SparseTensor的批处理坐标。

Args

coordstorch.Tensornumpy.ndarray的序列):坐标列表。

返回值:

coordstorch.IntTensor):批处理的坐标。

警告

从v0.4开始,批次索引将在所有坐标之前。

sparse_collat​​e

MinkowskiEngine.utils.sparse_collatecoords, feats, labels=None

为稀疏张量文档创建输入参数。

将一组坐标和特征要素转换为批处理坐标和批处理要素。

Args

coords(一组torch.Tensornumpy.ndarray):一组坐标。

feats(一组torch.Tensornumpy.ndarray):一组功能。

labels(一组torch.Tensornumpy.ndarray):与输入关联的一组标签。

batch_sparse_collat​​e

MinkowskiEngine.utils.batch_sparse_collatedata

可以与torch.utils.data.DataLoader结合使用的wrapper包装器函数,为稀疏张量生成输入。

请参阅训练示例以了解用法。

Args

data:(coordinates, features, labels)元组的列表。

稀疏整理

MinkowskiEngine.utils.SparseCollationlimit_numpoints = -1

为coords, feats, labels生成集成功能。

请参阅训练示例以了解用法。

Args

limit_numpoints(int):如果为正整数,则限制批量大小,以使输入坐标的数量低于limit_numpoints。如果为0或False,则连接所有点。默认为-1。

例:

>>> data_loader = torch.utils.data.DataLoader(

>>>     dataset,

>>>     ...,

>>>     collate_fn=SparseCollation())

>>> for d in iter(data_loader):

>>>     print(d)

__init__limit_numpoints = -1

初始化self. See help(type(self))有关准确的签名。

get_coords_map

MinkowskiEngine.utils.get_coords_mapxy

获取稀疏张量1和稀疏张量2之间的映射。

Args

xMinkowskiEngine.SparseTensor):x.tensor_stride <= y.tensor_stride的稀疏张量 。

yMinkowskiEngine.SparseTensor):x.tensor_stride <= y.tensor_stride的稀疏张量 。

返回值:

x_indicestorch.LongTensor):x的索引与返回的y索引相对应。

x_indicestorch.LongTensor):y的索引,它对应于返回的x的索引。

例:

.. code-block:: python

sp_tensor = ME.SparseTensor(features, coords=coordinates)

out_sp_tensor = stride_2_conv(sp_tensor)

ins, outs = get_coords_map(sp_tensor, out_sp_tensor)

for i, o in zip(ins, outs):

print(f"{i} -> {o}")

cat

MinkowskiEngine.cat* sparse_tensors

级联稀疏张量

连接稀疏张量特征。所有稀疏张量必须具有相同的 coords_key(相同的坐标)。要连接具有不同稀疏性模式的稀疏张量,请使用SparseTensor二进制运算或 MinkowskiEngine.MinkowskiUnion

例:

>>> import MinkowskiEngine as ME

>>> sin = ME.SparseTensor(feats, coords)

>>> sin2 = ME.SparseTensor(feats2, coords_key=sin.coords_key, coords_man=sin.coords_man)

>>> sout = UNet(sin)  # Returns an output sparse tensor on the same coordinates

>>> sout2 = ME.cat(sin, sin2, sout)  # Can concatenate multiple sparse tensors

MinkowskiEngine实用函数和类的更多相关文章

  1. 你真的会玩SQL吗?实用函数方法汇总

    你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...

  2. Python中函数、类、模块和包的调用

    初学python阶段,大多数人对函数.类.模块和包的调用都搞得不是很清楚,这篇随笔就简单的进行说明. (1)函数 当函数定义好之后,可以直接调用. 比如:def summ(add1,add2),那么 ...

  3. 转:Delphi 6 实用函数

    来自: daocaoren0824, 时间: -- ::, ID: 再给你一份 程序员实用函数 {▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎} {▎ ▎} {▎ 大 ...

  4. DLL导出函数和类的定义区别 __declspec(dllexport)

    DLL导出函数和类的定义区别 __declspec(dllexport) 是有区别的, 请看 : //定义头文件的使用方,是导出还是导入 #if defined(_DLL_API) #ifndef D ...

  5. python描述符(descriptor)、属性(property)、函数(类)装饰器(decorator )原理实例详解

     1.前言 Python的描述符是接触到Python核心编程中一个比较难以理解的内容,自己在学习的过程中也遇到过很多的疑惑,通过google和阅读源码,现将自己的理解和心得记录下来,也为正在为了该问题 ...

  6. 不可或缺 Windows Native (20) - C++: 友元函数, 友元类

    [源码下载] 不可或缺 Windows Native (20) - C++: 友元函数, 友元类 作者:webabcd 介绍不可或缺 Windows Native 之 C++ 友元函数 友元类 示例演 ...

  7. 3.2 STL中的函数对象类模板

    *: STL中有一些函数对象类模板,如下所示: 1)例如要求两个double类型的x 和y 的积,可以: multiplies<double>()(x,y); 该表达式的值就是x*y的值. ...

  8. Python 中的函数与类的方法

    注:本文转译自 Stackoverflow 上 Adding a Method to an Existing Object 的最佳回答. 在 python 中,def 定义的函数与类中的方法有很大的不 ...

  9. 你真的会玩SQL吗?实用函数方汇总

    http://www.cnblogs.com/zhangs1986/p/4917800.html 实用函数方法 由于有些知识很少被用到,但真需要用时却忘记了又焦头烂额的到处找. 现在将这些‘冷门“却有 ...

随机推荐

  1. hdu1247 字典树或者hash

    题意:      给你一些串,问你哪些串是由其他两个串连接成的. 思路:        我用了两种方法,一个是hash,hash的时候用map实现的,第二种方法是字典树,字典树我们枚举每个一字符串,查 ...

  2. Sqlmap的使用详解

    目录 Sqlmap Sqlmap的简单用法 探测指定URL是否存在SQL注入漏洞 查看数据库的所有用户 查看数据库所有用户名的密码 查看数据库当前用户 判断当前用户是否有管理权限 列出数据库管理员角色 ...

  3. Tomcat管理弱口令页面Getshell

    目录 弱口令Getshell 利用Burpsuite对tomcat账号密码进行爆破 弱口令Getshell Tomcat安装完成后会有如下页面,点击该页面的 Manager App 处会弹出输入用户名 ...

  4. NTDDK 从两个最简单的驱动谈起

    第 1 章 从两个最简单的驱动谈起 Windows 驱动程序的编写,往往需要开发人员对 Windows 内核有深入了解和大量的内 核调试技巧,稍有不慎,就会造成系统的崩溃.因此,初次涉及 Window ...

  5. [CTF]摩斯电码

    摩尔斯电码 -----------转载 https://morse.supfree.net/ 摩尔斯电码定义了包括:英文字母A-Z(无大小写区分)十进制数字0-9,以及"?"&qu ...

  6. Andrew Ng机器学习算法入门((六):多变量线性回归方程求解

    多变量线性回归 之前讨论的都是单变量的情况.例如房价与房屋面积之前的关系,但是实际上,房价除了房屋面积之外,还要房间数,楼层等因素相关.那么此时就变成了一个多变量线性回归的问题.在实际问题中,多变量的 ...

  7. (Py练习)日期格式转换

    #将日期转换为易读的格式 #使用dateuti包 from dateutil import parser dt = parser.parse("Mar 6 2019 12:00AM" ...

  8. Blazor实现未登录重定向到登录页的方法

    今天研究了一下blazor,发现他默认启动就是类似于后台管理系统的界面,看到这个页面我就想给他写个登录,有登录就涉及到未登录重定向的问题,但是我没有找到blazor全局路由的设置,知道的老哥可以告诉我 ...

  9. 【技术博客】使用iview的Tree组件写一棵文件树

    本次项目的前端部分使用vue框架+iview组件构建,其中IDE的文件树部分使用了iview的Tree组件,但是Tree组件本身的接口功能极其有限,网上的相关资料也不多,在使用时费了一番功夫才摸索清楚 ...

  10. 在微信框架模块中,基于Vue&Element前端的后台管理功能介绍

    微信开发包括公众号.企业微信.微信小程序等方面的开发内容,需要对腾信的微信API接口进行封装:包括事件.菜单.订阅用户.多媒体文件.图文消息.消息群发.微信支付和企业红包.摇一摇设备.语义理解.微信小 ...