【Python/Pytorch - 网络模型】-- TV Loss损失函数

在这里插入图片描述

文章目录

00 写在前面

在医学图像重建过程中,经常在代价方程中加入TV 正则项,该正则项作为去噪项,对于重建可以起到很大帮助作用。但是对于一些纹理细节要求较高的任务,加入TV 正则项,在一定程度上可能会降低纹理细节。

对于连续函数,其表达式为:
在这里插入图片描述

对于图片而言,即为离散的数值,求每一个像素和横向下一个像素的差的平方,加上纵向下一个像素的差的平方,再开β/2次根:
在这里插入图片描述

01 基于Pytorch版本的TV Loss代码

import torch
from torch.autograd import Variable


class TVLoss(torch.nn.Module):
    """
    TV loss
    """

    def __init__(self, weight=1):
        super(TVLoss, self).__init__()
        self.weight = weight

    def forward(self, x):
        batch_size = x.size()[0]
        h_x = x.size()[2]
        w_x = x.size()[3]
        count_h = self._tensor_size(x[:, :, 1:, :])
        count_w = self._tensor_size(x[:, :, :, 1:])
        h_tv = torch.pow((x[:, :, 1:, :] - x[:, :, :h_x - 1, :]), 2).sum()
        w_tv = torch.pow((x[:, :, :, 1:] - x[:, :, :, :w_x - 1]), 2).sum()
        return self.weight * 2 * (h_tv / count_h + w_tv / count_w) / batch_size

    def _tensor_size(self, t):
        return t.size()[1] * t.size()[2] * t.size()[3]


if __name__ == "__main__":
    x = Variable(
        torch.FloatTensor([[[1, 2, 3], [4, 5, 6], [7, 8, 9]], [[1, 2, 3], [4, 5, 6], [7, 8, 9]]]).view(1, 2, 3, 3),
        requires_grad=True)
    tv = TVLoss()
    result = tv(x)
    print(result)

02 论文下载

Understanding Deep Image Representations by Inverting Them

相关推荐

  1. pytorch-10 神经网络损失函数

    2024-06-17 07:46:01       19 阅读
  2. 神经网络中的损失函数(上)——回归任务

    2024-06-17 07:46:01       26 阅读
  3. 神经网络中的损失函数(下)——分类任务

    2024-06-17 07:46:01       29 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-17 07:46:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-17 07:46:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-17 07:46:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-17 07:46:01       18 阅读

热门阅读

  1. python 异常处理、随机数、

    2024-06-17 07:46:01       10 阅读
  2. AI学习指南机器学习篇-KNN算法实现

    2024-06-17 07:46:01       8 阅读
  3. linux 搭建一台自己的DNS服务器

    2024-06-17 07:46:01       8 阅读
  4. [AIGC] 选择LeetCode刷题的编程语言

    2024-06-17 07:46:01       11 阅读
  5. 比特币通用API服务

    2024-06-17 07:46:01       6 阅读
  6. Flink Watermark详解

    2024-06-17 07:46:01       7 阅读
  7. 矩阵补全IGMC 学习笔记

    2024-06-17 07:46:01       7 阅读
  8. ComfyUI

    ComfyUI

    2024-06-17 07:46:01      6 阅读
  9. 外键的基本概念

    2024-06-17 07:46:01       6 阅读
  10. C++多态

    2024-06-17 07:46:01       5 阅读