Loading...
首页问答详情

PyTorch---感知机 损失函数计算的数值一直没变化

   
Bingo~
Bingo~  发布于  2020-09-29 14:31:43
采纳率 0%
16个问答

在训练过程中,损失函数的值一直没有变化,这是为啥啊?恳请大佬指点一下问题出在哪儿

pyTorch —-> 感知机

激活函数为 sign函数

import torch
import pandas
from torch import nn, optim
from torch.autograd import Variable

def get_data(path): # 将 csv 中的 每一条数据,放进一个列表中 —>每个列表为一个样本点 , y单独 放进一个列表中
data_x1 = pandas.read_csv(path)[‘x1’] # 特征 x1
data_x2 = pandas.read_csv(path)[‘x2’] # 特征 x2
target = pandas.read_csv(path)[‘y’] # 所属分类
target = list(target)
data_train = []
for i in range(len(target)):
if target[i] == 0:
target[i] = -1
for i in range(len(data_x1)):
temp_data = []
temp_data.append(data_x1[i])
temp_data.append(data_x2[i])
data_train.append(temp_data)
return data_train, target

def trans_list_variable(data_train, target): # list 转成 Tensor 再转成 Variable

# 列表转成Tensor
data_train = torch.Tensor(data_train)
target = [target]
target = torch.Tensor(target)
target =target.T
# Tensor 转成 Variable
data_train = Variable(data_train, requires_grad=True)
target = Variable(target, requires_grad=True)
return data_train, target

class LineRegression(nn.Module):
def init(self):
super(LineRegression, self).init()
self.linear_function = nn.Linear(2, 1)
def forward(self, data_train):
result = []
for i in data_train:
out = self.linear_function(i)
out = torch.sign(out)
result.append(out)

    # 将列表转换成 Variable
    result = [result]
    result = torch.Tensor(result)
    result = result.T
    result = Variable(result)

    return result

def train(data_train, target):
model = LineRegression()
loss_Model = nn.MSELoss()
optimizer = optim.SGD(model.parameters(), lr=0.1)

epoch = 40000
for i in range(epoch):  # 训练40000次

    result = model(data_train)            
    loss_function = loss_Model(result, target)
    optimizer.zero_grad()
    loss_function.backward()
    optimizer.step()

    if (i+1) % 200 == 0:
        out = loss_function.item()
        print(out)

if name == ‘main‘:
path = r’C:\Users\sel\Desktop\ML_data.csv’
data_train, target = get_data(path) # 获得数据
data_train, target = trans_list_variable(data_train, target)
train(data_train, target)

我来回答
701
0
0
回答
0个

Markdown 语法

  • 加粗 **内容**
  • 斜体 *内容*
  • 删除线 ~~内容~~
  • 引用 > 引用内容
  • 代码 `代码`
  • 代码块 ```编程语言↵代码```
  • 链接 [链接标题](url)
  • 无序列表 - 内容
  • 有序列表 1. 内容
  • 缩进 内容
  • 图片 ![alt](url)

Markdown 语法

  • 加粗 **内容**
  • 斜体 *内容*
  • 删除线 ~~内容~~
  • 引用 > 引用内容
  • 代码 `代码`
  • 代码块 ```编程语言↵代码```
  • 链接 [链接标题](url)
  • 无序列表 - 内容
  • 有序列表 1. 内容
  • 缩进 内容
  • 图片 ![alt](url)
+ 添加网盘链接/附件
或将文件直接拖到这里
悬赏:
EBC
网盘
* 网盘链接:
* 提取码:
悬赏:
EBC
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
数据导入
* 昵称
* 密码
如有疑问请联系易百纳客服微信: x460910098
取消
提交
易百纳技术社区
确定要删除此文章、专栏、评论吗?
确定
取消
易百纳技术社区
取消
确定
在专栏模块发布专栏,可获得其他E友的打赏
回答悬赏问答,被题主采纳后即可获得悬赏金
在上传资料时,有价值的资料可设置为付费资源
达到一定金额,收益即可提现~
收益也可用来充值ebc,下载资料、兑换礼品更容易