人工智能神经网络就是用来找规律的

致谢:赵越人工智能AI开发课(Python+PyCharm+PyTorch)。 
人人都能听懂的课,参见原视频课赵越人工智能AI开发课(Python+PyCharm+PyTorch)-学习视频教程-腾讯课堂

# coding=utf-8
import torch
from torch import optim
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from torch import nn
# 解决中文乱码方法
from pylab import mpl

'''
---解决OMP: Error #15: Initializing libiomp5md.dll, but found libiomp5md.dll already initialized. OMP: Hi
'''
import os
os.environ['KMP_DUPLICATE_LIB_OK'] = 'TRUE'
#---end

mpl.rcParams['font.sans-serif'] = ['KaiTi'] # 指定默认字体FangSong仿宋
mpl.rcParams['axes.unicode_minus'] = False # 解决保存图像是负号'-'显示为方块的问题
#标准化
def normalize(data):
    mu =  torch.mean(data)
    std = torch.std(data)
    return (data - mu)/std

#归一化
def guiyimaxmin(x):
   min = torch.min(x)
   max = torch.max(x)
   return (x - min) / (max - min)

npx=np.random.randint(0,100,(1000,1))
npy=np.power(npx,4)/3+npx*8+80
#实现矩阵拼接
npxy=np.concatenate((npx,npy),axis=1)
#DataFrame是一种数据框结构,相当于是一个矩阵形式,单元格可以存放数值、字符串等,这和excel表很像;
pdx=pd.DataFrame(npxy,columns=['x','y'])
#生成1data.xlsx
pdx.to_excel('1data.xlsx',sheet_name='Sheet1',header=True,index=False)
#sheetname='Sheet1'表示第一张sheet
# header=True,把列标也就是‘x’显示出来
# index=False,不需要添加行标
#读取1data.xlsx
pdxy = pd.read_excel('1data.xlsx')
#sheetname=0表示第一张sheet
# header=0,第一行作为各列名
# index_col=0 去掉添加的列标

#转为张量数据
data = torch.tensor(pdxy.values,dtype=torch.float)

#训练数据行
train_rows=900
#预测数据行
test_rows=100

x=data[0:train_rows,0:-1]
x=guiyimaxmin(x)
y=data[0:train_rows,[-1]]
x1 = data[train_rows:train_rows+test_rows, 0:-1]
x1=guiyimaxmin(x1)
y1 = data[train_rows:train_rows+test_rows, [-1]]

class Net(torch.nn.Module):
    def __init__(self):
        super(Net, self).__init__()
        self.conv1 = nn.Sequential(
         #线性层(下同)
           nn.Linear(1,20),
           #激活函数(下同)
           nn.ReLU(),
           nn.Linear(20,10),
           nn.ReLU(),
           nn.Linear(10, 5),
           nn.ReLU(),
           nn.Linear(5,1)
        )
   #前向传播
    def forward(self, x):
        x = self.conv1(x)
        return x

#指定设备类型,可以是CPU,也可以是GPU
# device=torch.device('cpu')
device = torch.device('cuda:0' if torch.cuda.is_available() else 'cpu')
#前向传播求出预测的值
model = Net().to(device)
#损失函数
criteon = nn.MSELoss().to(device)
#优化器
optimizer = optim.Adam(model.parameters(), lr=0.3)
trainlosslist=[]
testlosslist=[]
plt.ion()
#训练次数,采用梯度下降法
for epoch in range(401):
   model.train()
   x, y = x.to(device), y.to(device)
   logits = model(x)
   #求loss
   loss = criteon(logits, y)
   #梯度置零,也就是把loss关于权重的导数变成0
   optimizer.zero_grad()
   #反向传播求梯度
   loss.backward()
   #更新所有参数
   optimizer.step()
   # print(epoch, 'loss:', loss.item())  # loss.item()将一个零维张量转换成浮点数
   trainlosslist.append(loss.item())
   model.eval()
   #不需要计算梯度,也不会进行反向传播
   with torch.no_grad():  # test
      x1, y1 = x1.to(device), y1.to(device)
      logits = model(x1)
      testloss = criteon(logits, y1)
      testlosslist.append(testloss.item())
   #'''
   if epoch % 20 == 0:
      plt.cla()
      l3=plt.scatter(np.arange(y1.shape[0]),y1.to(device='cpu'))
      l4=plt.scatter(np.arange(logits.shape[0]),logits.to(device='cpu'))
      plt.legend([l3, l4], ['%d个值的真实结果'% y1.shape[0], '%d个值的预测结果'% y1.shape[0]], loc='upper right')
      plt.text(0.5, 0, '训练次数=%d' % epoch, fontdict={'size': 20, 'color': 'red'})
      plt.pause(0.2)
   #'''
'''
在交互模式下:
1、plt.plot(x)或plt.imshow(x)是直接出图像,不需要plt.show()
2、如果在脚本中使用ion()命令开启了交互模式,没有使用ioff()关闭的话,则图像会一闪而过,并不会常留。要想防止这种情况,需要在plt.show()之前加上ioff()命令。

在阻塞模式下:
1、打开一个窗口以后必须关掉才能打开下一个新的窗口。这种情况下,默认是不能像Matlab一样同时开很多窗口进行对比的。
2、plt.plot(x)或plt.imshow(x)是直接出图像,需要plt.show()后才能显示图像
'''
plt.ioff()
   #l1 = plt.plot(trainlosslist)
   #l2 = plt.plot(testlosslist)
   #plt.legend([l1,l2],['tranloss','testloss'],loc='best')
   #plt.xlabel('epochs')
plt.show()
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
人工智能是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门新的技术科学。它是计算机科学的一个分支,旨在了解智能的本质,并生产出一种能以人类智能相似的方式做出反应的智能机器。人工智能的研究包括机器人、语言识别、图像识别、自然语言处理和专家系统等。 神经网络是一种在生物神经网络的启示下建立的数据处理模型,通常由大量的人工神经元相互连接进行计算。神经网络根据外界的信息改变自身的结构,主要通过调整神经元之间的权值对输入的数据进行建模,从而具备解决实际问题的能力。神经网络模拟了人类大脑的工作原理,通过模拟神经元之间的连接和信息传递,实现了类似人类的智能行为。 综上所述,人工智能神经网络是紧密相关的概念。人工智能是研究和开发能够模拟人类智能的系统和技术,而神经网络则是人工智能的一种具体实现方式,模拟了人类大脑的神经网络结构和工作原理。在人工智能的研究和应用中,神经网络被广泛应用于解决复杂的模式识别、分类和决策等问题,为人工智能系统提供了强大的计算和学习能力。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [神经网络人工智能](https://blog.csdn.net/qq_41860637/article/details/88781740)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值