torch.chunk的用法示例——非常清晰

`torch.chunk` 是 PyTorch 中用于将一个张量沿指定维度分割成多个子张量的函数。下面是对其用法的详细解释和示例。

函数定义

```python

torch.chunk(input, chunks, dim=0)

```

  • **`input`**: 要分割的输入张量。

  • **`chunks`**: 要分割成的子张量的数量。

  • **`dim`**: 指定在哪个维度上进行分割,默认为 `0`(第一个维度,即行)。

示例

示例 1: 基本用法

复制代码
import torch

# 创建一个 4x4 的张量
tensor = torch.arange(16).reshape(4, 4)
print("Original Tensor:")
print(tensor)

# 将张量分割成 2 个部分,沿第 0 维(行)
chunks = torch.chunk(tensor, 2, dim=0)

print("\nChunks:")
for i, chunk in enumerate(chunks):
    print(f"Chunk {i}:")
    print(chunk)

**输出**:

```

Original Tensor:

tensor([[ 0, 1, 2, 3],

4, 5, 6, 7\], \[ 8, 9, 10, 11\], \[12, 13, 14, 15\]\]) Chunks: Chunk 0: tensor(\[\[0, 1, 2, 3\], \[4, 5, 6, 7\]\]) Chunk 1: tensor(\[\[ 8, 9, 10, 11\], \[12, 13, 14, 15\]\]) \`\`\`

示例 2: 不同维度分割

复制代码
# 将张量分割成 4 个部分,沿第 1 维(列)
chunks = torch.chunk(tensor, 4, dim=1)

print("\nChunks along dim=1:")
for i, chunk in enumerate(chunks):
    print(f"Chunk {i}:")
    print(chunk)

**输出**:

```

Chunks along dim=1:

Chunk 0:

tensor([[0],

4\], \[8\], \[12\]\]) Chunk 1: tensor(\[\[ 1\], \[ 5\], \[ 9\], \[13\]\]) Chunk 2: tensor(\[\[ 2\], \[ 6\], \[10\], \[14\]\]) Chunk 3: tensor(\[\[ 3\], \[ 7\], \[11\], \[15\]\]) \`\`\`

总结

  • `torch.chunk` 可以方便地将张量按指定维度分割成多个子张量,适用于需要将数据划分为多个部分的情况。

  • 在处理深度学习任务时,这种分割操作可以帮助实现特定的特征处理或聚合策略。

相关推荐
奔跑吧邓邓子5 分钟前
DeepSeek 赋能智能教育知识图谱:从构建到应用的革命性突破
人工智能·知识图谱·应用·deepseek·智能教育
Mantanmu8 分钟前
Python训练day40
人工智能·python·机器学习
ss.li14 分钟前
TripGenie:畅游济南旅行规划助手:个人工作纪实(二十二)
javascript·人工智能·python
小天才才23 分钟前
前沿论文汇总(机器学习/深度学习/大模型/搜广推/自然语言处理)
人工智能·深度学习·机器学习·自然语言处理
新加坡内哥谈技术1 小时前
Meta计划借助AI实现广告创作全自动化
运维·人工智能·自动化
西猫雷婶1 小时前
pytorch基本运算-导数和f-string
人工智能·pytorch·python
Johny_Zhao1 小时前
华为MAAS、阿里云PAI、亚马逊AWS SageMaker、微软Azure ML各大模型深度分析对比
linux·人工智能·ai·信息安全·云计算·系统运维
顽强卖力1 小时前
第二十八课:深度学习及pytorch简介
人工智能·pytorch·深度学习
述雾学java1 小时前
深入理解 transforms.Normalize():PyTorch 图像预处理中的关键一步
人工智能·pytorch·python
武子康1 小时前
大数据-276 Spark MLib - 基础介绍 机器学习算法 Bagging和Boosting区别 GBDT梯度提升树
大数据·人工智能·算法·机器学习·语言模型·spark-ml·boosting