博客
关于我
pytorch loss = loss_func(output, label) 报错
阅读量:313 次
发布时间:2019-03-03

本文共 639 字,大约阅读时间需要 2 分钟。

在运行损失函数时,当执行 loss = loss_func(output, label) 时,出现了两个错误。以下是详细的解决方法:

1. 数据类型错误

错误信息: RuntimeError: Expected object of scalar type Long but got scalar type Float for argument #2 'target'

问题分析: 这是因为标签 label 必须是 LongTensor 类型,而之前的代码中将其转换为浮点数类型了。具体来说,image[1] 是字符串类型,在转换为浮点数后,再将其转换为 LongTensor 类型。

解决方法: 将标签转换为 LongTensor 类型:

label = t.tensor(float(image[1])).long()

这样可以确保标签是正确的整数类型。

2. 类别标签范围错误

错误信息: Assertioncur_target >= 0 && cur_target < n_classes’ failed`

问题分析: 这是因为数据集的类别是从 1 开始的,但在计算损失函数时,默认是从 0 开始的。因此需要将标签减去 1。

解决方法: 将标签调整为减去 1:

label = t.tensor(float(image[1]) - 1).long()

这样可以确保标签的范围是从 0 开始的,符合损失函数的预期。

通过以上修改,可以解决以上两个错误,确保训练过程顺利进行。

转载地址:http://wncq.baihongyu.com/

你可能感兴趣的文章
ref 和out 区别
查看>>
php JS 导出表格特殊处理
查看>>
php json dom解析
查看>>
ReentrantReadWriteLock读写锁解析
查看>>
php laravel实现依赖注入原理(反射机制)
查看>>
php laravel请求处理管道(装饰者模式)
查看>>
ReentrantReadWriteLock读写锁底层实现、StampLock详解
查看>>
PHP mongoDB 操作
查看>>
ReentrantLock读写锁
查看>>
ReentrantLock的公平锁与非公平锁
查看>>
php mysql procedure获取多个结果集
查看>>
php mysql query 行数,PHP和MySQL:返回的行数
查看>>
php mysql session_php使用MySQL保存session会话
查看>>
PHP mysql_real_escape_string() 函数防SQL注入
查看>>
php mysql优化方法_MySQL优化常用方法
查看>>
PHP OAuth 2.0 Server
查看>>
php odbc驱动,php常用ODBC函数集(详细)
查看>>
php openssl aes ecb,php openssl_encrypt AES-128-ECB iOS
查看>>
php paypal rest api,PayPal REST API指定网络配置文件PHP
查看>>
php pcntl 多进程学习
查看>>