網(wǎng)站首頁 編程語言 正文
前言
飛槳(PaddlePaddle)是集深度學(xué)習(xí)核心框架、工具組件和服務(wù)平臺為一體的技術(shù)先進(jìn)、功能完備的開源深度學(xué)習(xí)平臺
1. 任務(wù)描述
- 乘坐出租車的時候,會有一個10元的起步價,只要上車就需要收取該起步價。
- 出租車每行駛1公里,需要再支付2元的行駛費用(2元/公里)
- 當(dāng)一個乘客做完出租車之后,車上的計價器需要算出來該乘客需要支付的乘車費用。
如果以數(shù)學(xué)模型的角度可以很容易的解除該題的線性關(guān)系,及?Y=2x+10Y=2x+10,其中YY?為最終所需費用,xx?為行駛公里數(shù)。
試想,我們用機(jī)器學(xué)習(xí)的方法進(jìn)行訓(xùn)練是不是也可以解決該問題呢,讓機(jī)器來給我們推算出?YY?與?xx?的關(guān)系。即:知道乘客乘坐公里數(shù)和支付費用,但是并不知道每公里行駛費和起步價。
2. 代碼演練
首先,我們以數(shù)學(xué)模型建立關(guān)系式,定義計價收費函數(shù)。該函數(shù)用來生成機(jī)器學(xué)習(xí)的數(shù)據(jù)集。定義好函數(shù)以后,接下來,我們傳入6個數(shù)據(jù)(x),該函數(shù)可以計算出對應(yīng)的Y值(也就是機(jī)器學(xué)習(xí)訓(xùn)練用到的真實值)。
def calculate_fee(distance_travelled):
return 10+ 2*distance_travelled
for x in [1.0, 3.0, 5.0, 9.0, 10.0, 20.0]:
print(calculate_fee(x))
接下來開始搭建線性回歸。
2.1 數(shù)組轉(zhuǎn)張量
將輸入數(shù)據(jù)與輸出結(jié)果數(shù)組轉(zhuǎn)為張量:
import paddle
import numpy
x_data = paddle.to_tensor([[1.0], [3.0], [5.0], [9.0], [10.0], [20.0]])
y_data = paddle.to_tensor([[12.0],[16.0],[20.0],[28.0],[30.0],[50.0]])
linear = paddle.nn.Linear(in_features=1,out_features=1)
# 隨機(jī)初始化w,b
w_before_opt = linear.weight.numpy().item()
b_before_opt = linear.bias.numpy().item()
# 打印初始w,b
print(w_before_opt,b_before_opt)
mse_loss = paddle.nn.MSELoss()
sgd_optimizer = paddle.optimizer.SGD(learning_rate=0.001, parameters=linear.parameters())
total_epoch = 5000
for i in range(total_epoch):
y_predict = linear(x_data)
loss = mse_loss(y_predict,y_data)
# 反向傳播(求梯度)
loss.backward()
# 優(yōu)化器往前走一步:求出的梯度給優(yōu)化器用調(diào)參
sgd_optimizer.step()
# 優(yōu)化器把調(diào)完參數(shù)所用的梯度去清掉,下次再去求
sgd_optimizer.clear_gradients()
# 打印信息
if i % 1000 == 0:
print(i,loss.numpy())
print("finish training, loss = {}".format(loss.numpy()) )
w_after_opt = linear.weight.numpy().item()
b_after_opt = linear.bias.numpy().item()
print(w_after_opt,b_after_opt)
原文鏈接:https://juejin.cn/post/7129528216800198664
相關(guān)推薦
- 2022-07-29 Redis?key-value亂碼的解決_Redis
- 2022-06-14 Pycharm安裝第三方庫的超詳細(xì)步驟_python
- 2023-02-15 Python進(jìn)行ffmpeg推流和拉流rtsp、rtmp實例詳解_python
- 2022-06-20 Python使用ffmpeg合成視頻、音頻的實現(xiàn)方法_python
- 2022-12-24 一文帶你輕松學(xué)會Go語言動態(tài)調(diào)用函數(shù)_Golang
- 2022-08-23 C++簡明分析inline函數(shù)的使用_C 語言
- 2021-12-06 C語言練習(xí)之?dāng)?shù)組中素數(shù)交換_C 語言
- 2022-09-03 Python實現(xiàn)計算AUC的示例代碼_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支