c++ libtorch 切片 torch::indexing::Slice()的含义

在LibTorch中,torch::indexing::Slice() 是一个辅助函数,用于创建一个切片对象,这个对象可以用于对Tensor进行切片操作。切片操作允许你选取Tensor中的一个子区域,而不需要复制数据。

torch::indexing::Slice() 函数可以接受几个参数,它们定义了切片的开始、结束和步长。以下是该函数的一些常见用法:

  1. torch::indexing::Slice(start):从索引 start 开始,直到Tensor的末尾。
  2. torch::indexing::Slice(start, end):从索引 start 开始,到索引 end(但不包括 end)。
  3. torch::indexing::Slice(start, end, step):从索引 start 开始,到索引 end(但不包括 end),以 step 为步长。

下面是使用 torch::indexing::Slice() 的一个例子:

cpp 复制代码
#include <torch/torch.h>
#include <iostream>

int main() {
    // 创建一个维度为 [5, 5] 的Tensor
    torch::Tensor tensor = torch::rand({ 5, 5 });
    std::cout << "Original Tensor:\n" << tensor << std::endl;

    // 使用 Slice() 进行切片操作
    // 选取第二行到第四行,所有列
    torch::Tensor slice1 = tensor.index({torch::indexing::Slice(1, 4)});
    std::cout << "Slice 1:\n" << slice1 << std::endl;

    // 选取所有行,第三列到第五列
    torch::Tensor slice2 = tensor.index({torch::indexing::Slice(), torch::indexing::Slice(2, 5)});
    std::cout << "Slice 2:\n" << slice2 << std::endl;

    // 选取第一行,第二列
    torch::Tensor slice3 = tensor.index({torch::indexing::Slice(0, 1), torch::indexing::Slice(1, 2)});
    std::cout << "Slice 3:\n" << slice3 << std::endl;

    return 0;
}

在上面的例子中,我们首先创建了一个5x5的Tensor,然后使用 torch::indexing::Slice() 来进行不同的切片操作:

  • slice1 选取了第二行到第四行,所有的列。
  • slice2 选取了所有的行,第三列到第五列。
  • slice3 选取了第一行,第二列的一个元素。

需要注意的是,切片操作不会改变原始Tensor的数据,而是返回一个新的Tensor,该Tensor与原始Tensor共享相同的数据。

相关推荐
hetao17338377 小时前
2025-12-12~14 hetao1733837的刷题笔记
数据结构·c++·笔记·算法
椰子今天很可爱7 小时前
五种I/O模型与多路转接
linux·c语言·c++
程序员zgh8 小时前
C++ 互斥锁、读写锁、原子操作、条件变量
c语言·开发语言·jvm·c++
獭.獭.10 小时前
C++ -- STL【unordered_set和unordered_map的使用】
c++·stl·unordered_map·unordered_set
star _chen11 小时前
C++ std::move()详解:从小白到高手
开发语言·c++
福尔摩斯张11 小时前
C++核心特性精讲:从C语言痛点出发,掌握现代C++编程精髓(超详细)
java·linux·c语言·数据结构·c++·驱动开发·算法
charlie11451419111 小时前
如何快速在 VS2026 上使用 C++ 模块 — 完整上手指南
开发语言·c++·笔记·学习·现代c++
报错小能手12 小时前
STL_unordered_map
开发语言·c++·哈希算法
历程里程碑12 小时前
C++ 9 stack_queue:数据结构的核心奥秘
java·开发语言·数据结构·c++·windows·笔记·算法
仰泳的熊猫13 小时前
1108 Finding Average
数据结构·c++·算法·pat考试