MinkowskiEngine实用函数和类
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:
coords(numpy.ndarray或torch.Tensor): N×D矩阵大小 ,其中 N 是点数 ,D是维数空间。
feats(numpy.ndarray或torch.Tensor,optional):大小矩阵N×DF ,其中 N 是点数, DF是特征的尺寸。必须与coords具有相同的容器(即,如果coords是torch.Tensor,则feats 也必须是torch.Tensor)。
labels(numpy.ndarray或torch.IntTensor,optional):与eah坐标关联的整数标签。必须与coords具有相同的容器(即,如果coords是torch.Tensor,则 标签也必须是torch.Tensor)。对于将一组点映射到一个标签的分类,请勿输入标签。
ignore_label(int,optional):IGNORE LABEL的int值。 torch.nn.CrossEntropyLoss(ignore_index=ignore_label)
return_index(bool,optional):如果需要量化坐标的索引,则设置True。默认为False。
return_inverse(bool,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_size(float,list或 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_coordinates(coords)
根据一系列坐标,创建一个ME.SparseTensor坐标
给定numpy或pytorch张量坐标的列表,返回适合ME.SparseTensor的批处理坐标。
Args:
coords(torch.Tensor或numpy.ndarray的序列):坐标列表。
返回值:
coords(torch.IntTensor):批处理的坐标。
警告
从v0.4开始,批次索引将在所有坐标之前。
sparse_collate
MinkowskiEngine.utils.sparse_collate(coords, feats, labels=None)
为稀疏张量文档创建输入参数。
将一组坐标和特征要素转换为批处理坐标和批处理要素。
Args:
coords(一组torch.Tensor或numpy.ndarray):一组坐标。
feats(一组torch.Tensor或numpy.ndarray):一组功能。
labels(一组torch.Tensor或numpy.ndarray):与输入关联的一组标签。
batch_sparse_collate
MinkowskiEngine.utils.batch_sparse_collate(data)
可以与torch.utils.data.DataLoader结合使用的wrapper包装器函数,为稀疏张量生成输入。
请参阅训练示例以了解用法。
Args:
data:(coordinates, features, labels)元组的列表。
稀疏整理
类MinkowskiEngine.utils.SparseCollation(limit_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_map(x,y)
获取稀疏张量1和稀疏张量2之间的映射。
Args:
x(MinkowskiEngine.SparseTensor):x.tensor_stride <= y.tensor_stride的稀疏张量 。
y(MinkowskiEngine.SparseTensor):x.tensor_stride <= y.tensor_stride的稀疏张量 。
返回值:
x_indices(torch.LongTensor):x的索引与返回的y索引相对应。
x_indices(torch.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实用函数和类的更多相关文章
- 你真的会玩SQL吗?实用函数方法汇总
你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...
- Python中函数、类、模块和包的调用
初学python阶段,大多数人对函数.类.模块和包的调用都搞得不是很清楚,这篇随笔就简单的进行说明. (1)函数 当函数定义好之后,可以直接调用. 比如:def summ(add1,add2),那么 ...
- 转:Delphi 6 实用函数
来自: daocaoren0824, 时间: -- ::, ID: 再给你一份 程序员实用函数 {▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎} {▎ ▎} {▎ 大 ...
- DLL导出函数和类的定义区别 __declspec(dllexport)
DLL导出函数和类的定义区别 __declspec(dllexport) 是有区别的, 请看 : //定义头文件的使用方,是导出还是导入 #if defined(_DLL_API) #ifndef D ...
- python描述符(descriptor)、属性(property)、函数(类)装饰器(decorator )原理实例详解
1.前言 Python的描述符是接触到Python核心编程中一个比较难以理解的内容,自己在学习的过程中也遇到过很多的疑惑,通过google和阅读源码,现将自己的理解和心得记录下来,也为正在为了该问题 ...
- 不可或缺 Windows Native (20) - C++: 友元函数, 友元类
[源码下载] 不可或缺 Windows Native (20) - C++: 友元函数, 友元类 作者:webabcd 介绍不可或缺 Windows Native 之 C++ 友元函数 友元类 示例演 ...
- 3.2 STL中的函数对象类模板
*: STL中有一些函数对象类模板,如下所示: 1)例如要求两个double类型的x 和y 的积,可以: multiplies<double>()(x,y); 该表达式的值就是x*y的值. ...
- Python 中的函数与类的方法
注:本文转译自 Stackoverflow 上 Adding a Method to an Existing Object 的最佳回答. 在 python 中,def 定义的函数与类中的方法有很大的不 ...
- 你真的会玩SQL吗?实用函数方汇总
http://www.cnblogs.com/zhangs1986/p/4917800.html 实用函数方法 由于有些知识很少被用到,但真需要用时却忘记了又焦头烂额的到处找. 现在将这些‘冷门“却有 ...
随机推荐
- 你注意到了吗?修改API文档也需要规范!
关于API接口文档的内容和格式规范的文章,之前也有写过,网上也有不少写的比我还好的,就不赘述了,今天想说的是一个很容易被忽略的点,修改API文档的规范:版本控制. 示例 拿Eolinker来演示一下流 ...
- (邹博ML)矩阵和线性代数
主要内容 矩阵 特征值和特征向量 矩阵求导 矩阵 SVD的提法 奇异值分解(Singular Value Decomposition)是一种重要的矩阵分解方法,可以看做对称方阵在任意矩阵上的推广. 假 ...
- 5分钟,教你用Python每天跟女朋友说1000遍土味情话!
- net5学习笔记---依赖注入
小王的故事 小王去上班 小王是个程序员,每个工作日他都要去上班,诸多交通工具他最喜欢的交通工具是骑电车.在骑行的过程中放空自己使他很快. 突然有一天天气预报说近期有很大的雨,小王再想骑电车去上 ...
- SQL Server强制使用特定索引 、并行度、锁
SQL Server强制使用特定索引 .并行度 修改或删除数据前先备份,先备份,先备份(重要事情说三遍) 很多时候你或许为了测试.或许为了规避并发给你SQL带来的一些问题,常常需要强制指定目标sql选 ...
- ffmpeg实践
将mov视频解码300帧,并保存为1024:576分辨率,yuv420格式 ffmpeg -i Community_SneakAttack.mov -aspect 16:9 -vf scale=102 ...
- 基于虹软人脸识别,实现RTMP直播推流追踪视频中所有人脸信息(C#)
前言 大家应该都知道几个很常见的例子,比如在张学友的演唱会,在安检通道检票时,通过人像识别系统成功识别捉了好多在逃人员,被称为逃犯克星:人行横道不遵守交通规则闯红灯的路人被人脸识别系统抓拍放在大屏上以 ...
- 进程Queue和线程Queue区别
进程Queue from multiprocessing import Queue q=Queue() 线程Queue import queue q=queue.Queue()
- volatile关键字的作用-respect
volatile关键字的含义? volatile定义的变量可能会意外的改变,改变它的情况有很多(例如:操作系统,硬件,线程),编译就不会去假设这个值,也就是说每次访问这个变量时,系统就会小心翼翼的去从 ...
- [c++] STL 标准算法
_if 1 #include <iostream> 2 #include <vector> 3 #include <algorithm> 4 using names ...