当前位置: 首页 > news >正文

网站开发 明细百度账号登陆

网站开发 明细,百度账号登陆,做甜品台的网站,wordpress迁hexo十、项目实战 鲍勃开了自己的手机公司。他想与苹果、三星等大公司展开硬仗。 他不知道如何估算自己公司生产的手机的价格。在这个竞争激烈的手机市场,你不能简单地假设事情。为了解决这个问题,他收集了各个公司的手机销售数据。 鲍勃想找出手机的特性(例…

十、项目实战

鲍勃开了自己的手机公司。他想与苹果、三星等大公司展开硬仗。
他不知道如何估算自己公司生产的手机的价格。在这个竞争激烈的手机市场,你不能简单地假设事情。为了解决这个问题,他收集了各个公司的手机销售数据。
鲍勃想找出手机的特性(例如:RAM、内存等)和售价之间的关系。但他不太擅长机器学习。所以他需要你帮他解决这个问题。
在这个问题中,你不需要预测实际价格,而是要预测一个价格区间,表明价格多高。

需要注意的是: 在这个问题中,我们不需要预测实际价格,而是一个价格范围,它的范围使用 0、1、2、3 来表示,所以该问题也是一个分类问题。

数据说明:https://tianchi.aliyun.com/dataset/157241 Mobile Price Classification

推荐专业的数据集平台:https://www.kaggle.com/datasets/iabhishekofficial/mobile-price-classification

字段说明
battery_power电池容量(mAh)
blue是否支持蓝牙
clock_speed微处理器执行指令的速度
dual_sim是否支持双卡
fc前置摄像头分辨率(百万像素)
four_g是否支持4G
int_memory存储内存(GB)
m_dep手机厚度(厘米)
mobile_wt重量
n_cores核心数
pc主摄像头分辨率(百万像素)
px_height屏幕分辨率高度(像素)
px_width屏幕分辨率宽度(像素)
ram运行内存(MB)
sc_h屏幕长度(厘米)
sc_w屏幕宽度(厘米)
talk_time单次充电最长通话时间
three_g是否支持3G
touch_screen是否是触摸屏
wifi是否支持WIFI
price_range价格区间

1. 构建数据集

数据共有 2000 条, 其中 1600 条数据作为训练集, 400 条数据用作测试集。 我们使用 sklearn 的数据集划分工作来完成。并使用 PyTorch 的 TensorDataset 来将数据集构建为 Dataset 对象,方便构造数据集加载对象。

# 构建数据集
def create_dataset():data = pd.read_csv('data/手机价格预测.csv')# 特征值和目标值x, y = data.iloc[:, :-1], data.iloc[:, -1]x = x.astype(np.float32)y = y.astype(np.int64)# 数据集划分x_train, x_valid, y_train, y_valid=train_test_split(x, y, train_size=0.8, random_state=88, stratify=y)# 构建数据集train_dataset = TensorDataset(torch.from_numpy(x_train.values), torch.tensor(y_train.values))valid_dataset = TensorDataset(torch.from_numpy(x_valid.values), torch.tensor(y_valid.values))return train_dataset, valid_dataset, x_train.shape[1], len(np.unique(y))train_dataset, valid_dataset, input_dim, class_num = create_dataset()

2. 构建分类网络模型

我们构建的用于手机价格分类的模型叫做全连接神经网络。它主要由三个线性层来构建,在每个线性层后,我们使用的时 sigmoid 激活函数。

# 构建网络模型
class PhonePriceModel(nn.Module):def __init__(self, input_dim, output_dim):super(PhonePriceModel, self).__init__()self.linear1 = nn.Linear(input_dim, 128)self.linear2 = nn.Linear(128, 256)self.linear3 = nn.Linear(256, output_dim)def _activation(self, x):return torch.sigmoid(x)def forward(self, x):x = self._activation(self.linear1(x))x = self._activation(self.linear2(x))output = self.linear3(x)return output

3. 编写训练函数

网络编写完成之后,我们需要编写训练函数。所谓的训练函数,指的是输入数据读取、送入网络、计算损失、更新参数的流程,该流程较为固定。我们使用的是多分类交叉生损失函数、使用 SGD 优化方法。最终,将训练好的模型持久化到磁盘中。

def train():# 固定随机数种子torch.manual_seed(0)# 初始化模型model = PhonePriceModel(input_dim, class_num)# 损失函数criterion = nn.CrossEntropyLoss()# 优化方法optimizer = optim.SGD(model.parameters(), lr=1e-3)# 训练轮数num_epoch = 50for epoch_idx in range(num_epoch):# 初始化数据加载器dataloader = DataLoader(train_dataset, shuffle=True, batch_size=8)# 训练时间start = time.time()# 计算损失total_loss = 0.0total_num = 1# 准确率correct = 0for x, y in dataloader:output = model(x)# 计算损失loss = criterion(output, y)# 梯度清零optimizer.zero_grad()# 反向传播loss.backward()# 参数更新optimizer.step()total_num += len(y)total_loss += loss.item() * len(y)print('epoch: %4s loss: %.2f, time: %.2fs' %(epoch_idx + 1, total_loss / total_num, time.time() - start))# 模型保存torch.save(model.state_dict(), 'model/phone-price-model.bin')

4. 编写评估函数

评估函数、也叫预测函数、推理函数,主要使用训练好的模型,对未知的样本的进行预测的过程。我们这里使用前面单独划分出来的测试集来进行评估。

def test():# 加载模型model = PhonePriceModel(input_dim, class_num)model.load_state_dict(torch.load('model/phone-price-model.bin'))# 构建加载器dataloader = DataLoader(valid_dataset, batch_size=8, shuffle=False)# 评估测试集correct = 0for x, y in dataloader:output = model(x)y_pred = torch.argmax(output, dim=1)correct += (y_pred == y).sum()print('Acc: %.5f' % (correct.item() / len(valid_dataset)))

5. 网络性能调优

我们前面的网络模型在测试集的准确率为: 0.54750, 我们可以通过以下方面进行调优:

  1. 对输入数据进行标准化
  2. 调整优化方法
  3. 调整学习率
  4. 增加批量归一化层
  5. 增加网络层数、神经元个数
  6. 增加训练轮数
  7. 等等…

我进行下如下调整:

  1. 优化方法由 SGD 调整为 Adam
  2. 学习率由 1e-3 调整为 1e-4
  3. 对数据数据进行标准化
  4. 增加网络深度, 即: 增加网络参数量

网络模型在测试集的准确率由 0.5475 上升到 0.9625

import torch
import torch.nn as nn
import torch.nn.functional as F
import pandas as pd
from sklearn.model_selection import train_test_split
from torch.utils.data import TensorDataset
from torch.utils.data import DataLoader
import torch.optim as optim
import numpy as np
import time
from sklearn.preprocessing import StandardScaler# 构建数据集
def create_dataset():data = pd.read_csv('data/手机价格预测.csv')# 特征值和目标值x, y = data.iloc[:, :-1], data.iloc[:, -1]x = x.astype(np.float32)y = y.astype(np.int64)# 数据集划分x_train, x_valid, y_train, y_valid = \train_test_split(x, y, train_size=0.8, random_state=88, stratify=y)# 数据标准化transfer = StandardScaler()x_train = transfer.fit_transform(x_train)x_valid = transfer.transform(x_valid)# 构建数据集train_dataset = TensorDataset(torch.from_numpy(x_train), torch.tensor(y_train.values))valid_dataset = TensorDataset(torch.from_numpy(x_valid), torch.tensor(y_valid.values))return train_dataset, valid_dataset, x_train.shape[1], len(np.unique(y))train_dataset, valid_dataset, input_dim, class_num = create_dataset()# 构建网络模型
class PhonePriceModel(nn.Module):def __init__(self, input_dim, output_dim):super(PhonePriceModel, self).__init__()self.linear1 = nn.Linear(input_dim, 128)self.linear2 = nn.Linear(128, 256)self.linear3 = nn.Linear(256, 512)self.linear4 = nn.Linear(512, 128)self.linear5 = nn.Linear(128, output_dim)def _activation(self, x):return torch.sigmoid(x)def forward(self, x):x = self._activation(self.linear1(x))x = self._activation(self.linear2(x))x = self._activation(self.linear3(x))x = self._activation(self.linear4(x))output = self.linear5(x)return output# 编写训练函数
def train():# 固定随机数种子torch.manual_seed(0)# 初始化模型model = PhonePriceModel(input_dim, class_num)# 损失函数criterion = nn.CrossEntropyLoss()# 优化方法optimizer = optim.Adam(model.parameters(), lr=1e-4)# 训练轮数num_epoch = 50for epoch_idx in range(num_epoch):# 初始化数据加载器dataloader = DataLoader(train_dataset, shuffle=True, batch_size=8)# 训练时间start = time.time()# 计算损失total_loss = 0.0total_num = 1# 准确率correct = 0for x, y in dataloader:output = model(x)# 计算损失loss = criterion(output, y)# 梯度清零optimizer.zero_grad()# 反向传播loss.backward()# 参数更新optimizer.step()total_num += len(y)total_loss += loss.item() * len(y)print('epoch: %4s loss: %.2f, time: %.2fs' %(epoch_idx + 1, total_loss / total_num, time.time() - start))# 模型保存torch.save(model.state_dict(), 'model/phone-price-model.bin')def test():# 加载模型model = PhonePriceModel(input_dim, class_num)model.load_state_dict(torch.load('model/phone-price-model.bin'))# 构建加载器dataloader = DataLoader(valid_dataset, batch_size=8, shuffle=False)# 评估测试集correct = 0for x, y in dataloader:output = model(x)y_pred = torch.argmax(output, dim=1)correct += (y_pred == y).sum()print('Acc: %.5f' % (correct.item() / len(valid_dataset)))if __name__ == '__main__':train()test()

文章转载自:
http://demiseason.hkpn.cn
http://cycloplegic.hkpn.cn
http://creator.hkpn.cn
http://youth.hkpn.cn
http://alan.hkpn.cn
http://trapt.hkpn.cn
http://lustful.hkpn.cn
http://dyeline.hkpn.cn
http://dihedron.hkpn.cn
http://kanagawa.hkpn.cn
http://unreal.hkpn.cn
http://iodopsin.hkpn.cn
http://esprit.hkpn.cn
http://fictionist.hkpn.cn
http://aluminium.hkpn.cn
http://stearate.hkpn.cn
http://vinasse.hkpn.cn
http://voluntarily.hkpn.cn
http://harmonistic.hkpn.cn
http://persecution.hkpn.cn
http://merchandising.hkpn.cn
http://orchestration.hkpn.cn
http://drabble.hkpn.cn
http://angledozer.hkpn.cn
http://ratification.hkpn.cn
http://shtetl.hkpn.cn
http://russophobia.hkpn.cn
http://sbc.hkpn.cn
http://sken.hkpn.cn
http://pndb.hkpn.cn
http://sightsee.hkpn.cn
http://wiretapping.hkpn.cn
http://endocardium.hkpn.cn
http://reallocate.hkpn.cn
http://nictitate.hkpn.cn
http://auriscope.hkpn.cn
http://psychologic.hkpn.cn
http://aerocraft.hkpn.cn
http://mangle.hkpn.cn
http://festilogy.hkpn.cn
http://antifreeze.hkpn.cn
http://palladous.hkpn.cn
http://convolute.hkpn.cn
http://rebate.hkpn.cn
http://neutralist.hkpn.cn
http://hindu.hkpn.cn
http://dilacerate.hkpn.cn
http://introverted.hkpn.cn
http://sexagesima.hkpn.cn
http://lassitude.hkpn.cn
http://magnetofluiddynamic.hkpn.cn
http://berliozian.hkpn.cn
http://custodes.hkpn.cn
http://unzip.hkpn.cn
http://glut.hkpn.cn
http://marlburian.hkpn.cn
http://euryoky.hkpn.cn
http://bargaining.hkpn.cn
http://yt.hkpn.cn
http://spree.hkpn.cn
http://polygene.hkpn.cn
http://mineralogy.hkpn.cn
http://parallelity.hkpn.cn
http://baotou.hkpn.cn
http://reunion.hkpn.cn
http://geopotential.hkpn.cn
http://comique.hkpn.cn
http://lewdster.hkpn.cn
http://meshugana.hkpn.cn
http://marlburian.hkpn.cn
http://dextrane.hkpn.cn
http://crucis.hkpn.cn
http://gandhism.hkpn.cn
http://invisibly.hkpn.cn
http://intelligential.hkpn.cn
http://udometric.hkpn.cn
http://ripping.hkpn.cn
http://cobbler.hkpn.cn
http://ferule.hkpn.cn
http://anesthesia.hkpn.cn
http://hexameral.hkpn.cn
http://sialolithiasis.hkpn.cn
http://disrelish.hkpn.cn
http://versemonger.hkpn.cn
http://candiot.hkpn.cn
http://on.hkpn.cn
http://prequisite.hkpn.cn
http://superorganic.hkpn.cn
http://unshakeable.hkpn.cn
http://francophobe.hkpn.cn
http://spurtle.hkpn.cn
http://qube.hkpn.cn
http://collembolan.hkpn.cn
http://coniform.hkpn.cn
http://europeanist.hkpn.cn
http://sponsorial.hkpn.cn
http://typewritten.hkpn.cn
http://ethnohistory.hkpn.cn
http://gisborne.hkpn.cn
http://rama.hkpn.cn
http://www.hrbkazy.com/news/58889.html

相关文章:

  • 一个公司设计网站怎么做大数据分析培训机构
  • 做网站服务器要什么系统360seo排名点击软件
  • 深圳代理记账行业协会seo关键词优化培训
  • 用国外的服务器做黄色网站违法吗比较成功的网络营销案例
  • 外贸推广用中文网站网站seo优化案例
  • 怎么做套版网站网站设计与网页制作
  • 武汉哪家做营销型网站好网站seo诊断报告怎么写
  • 网站制作将栏目分类现在推广用什么平台
  • 昆明做网站那家好郑州网
  • 网站建设合同 简单黄页网站推广
  • 做高端品牌生产商的网站seo零基础入门教程
  • 网站被墙 做301跳转今日的重大新闻
  • 企业网站建设报价链接买卖价格
  • 网站界面友好搜索引擎优化策略
  • wordpress增加分页功能揭阳seo推广公司
  • wordpress如何限制账号访问北京seo做排名
  • 临沂网网站建设谷歌网页
  • 手工做皮具国外的网站软文广告营销
  • 网站建设怎么在图片上加字2023年5月疫情爆发
  • 惠民建设局网站是哪个线上营销模式
  • 商标注册45大类明细湖南长沙seo教育
  • 怎么做干果网站微营销软件
  • 织梦dedecms女性时尚门户网站模板软文代发布
  • 某市政府信息网站建设方案识图搜索在线 照片识别
  • 东阿县住房和城乡建设局网站百度推广助手下载
  • 深圳网站制作公司流程网站域名在哪买
  • 建设银行网站怎么查自己账号吗seo关键词查询
  • 安徽省建设法制协会网站庆云网站seo
  • 建设企业网站前市场分析济南特大最新消息
  • 企业网站管理系统破解版二级域名网站免费建站