Class9簡潔實現

Class9簡潔實現

%matplotlib inline
import torch
from torch import nn
from d2l import torch as d2l
# 初始化訓練樣本、測試樣本、樣本特征維度和批量大小
n_train,n_test,num_inputs,batch_size = 20,100,200,5
# 設置真實權重和偏置
true_w,true_b = torch.ones((num_inputs,1)) * 0.01,0.05
# 生成訓練數據
# d2l.synthetic_data():函數生成模擬的訓練數據
# synthetic_data()L返回三元組(features,labels)
train_data = d2l.synthetic_data(true_w,true_b,n_train)
# 數據封裝為訓練數據迭代器
# d2l.load_array():把數據打包成一個笑屁劉昂迭代器,便于后續訓練
# batch_size=5:每次迭代返回5個樣本
train_iter = d2l.load_array(train_data,batch_size)
# 生成測試數據
test_data = d2l.synthetic_data(true_w,true_b,n_test)
# 數據封裝為測試數據迭代器
test_iter = d2l.load_array(test_data,batch_size,is_train=False)
# 實現帶權重衰減(L2正則)線性回歸模型訓練
# wd:L2正則化系數lambd
def train_concise(wd):# 構建一個全連接層,輸入為num_inputs,輸出為1net = nn.Sequential(nn.Linear(num_inputs, 1))for param in net.parameters():# 將參數用正態分布隨機初始化param.data.normal_()# 樣本的均方誤差不求平均loss = nn.MSELoss(reduction='none')# 定義訓練輪數和學習率num_epochs, lr = 100, 0.003# 使用隨機梯度下降優化器trainer = torch.optim.SGD([# 權重參數,應用L2正則{"params":net[0].weight,'weight_decay': wd},# 偏置參數,不加正則{"params":net[0].bias}], lr=lr)# 定義可視化工具animator = d2l.Animator(xlabel='epochs', ylabel='loss', yscale='log',xlim=[5, num_epochs], legend=['train', 'test'])# 循環訓練for epoch in range(num_epochs):for X, y in train_iter:# 清空梯度,防止梯度累加trainer.zero_grad()# 計算每個樣本的MSELossl = loss(net(X), y)# 進行反向傳播l.mean().backward()# 更新模型參數trainer.step()# 每5輪評估訓練集和測試集的loss損失函數if (epoch + 1) % 5 == 0:# 將當前loss加入到動態圖中animator.add(epoch + 1,(d2l.evaluate_loss(net, train_iter, loss),d2l.evaluate_loss(net, test_iter, loss)))# 打印輸出L2范數print('w的L2范數:', net[0].weight.norm().item())
train_concise(0)
train_concise(3)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/91544.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/91544.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/91544.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

ELK日志分析,涉及logstash、elasticsearch、kibana等多方面應用,必看!

目錄 ELK日志分析 1、下載lrzsc 2、下載源包 3、解壓文件,下載elasticsearch、kibana、 logstash 4、配置elasticsearch 5、配種域名解析 6、配置kibana 7、配置logstash 8、進行測試 ELK日志分析 1、下載lrzsc [rootlocalhost ~]# hostnamectl set-hostname elk ##…

終極剖析HashMap:數據結構、哈希沖突與解決方案全解

文章目錄 引言 一、HashMap底層數據結構:三維存儲架構 1. 核心存儲層(硬件優化設計) 2. 內存布局對比 二、哈希沖突的本質與數學原理 1. 沖突產生的必然性 2. 沖突概率公式 三、哈希沖突解決方案全景圖 1. 鏈地址法(Hash…

1.1.5 模塊與包——AI教你學Django

1.1.5 模塊與包(Django 基礎學習細節) 模塊和包是 Python 項目組織和代碼復用的基礎。Django 項目本質上就是由多個模塊和包組成。理解和靈活運用模塊與包機制,是寫好大型項目的關鍵。 一、import、from-import、as 的用法 1. import 用于導入…

UE5 相機后處理材質與動態參數修改

一、完整實現流程1. 創建后處理材質材質設置:在材質編輯器中,將材質域(Material Domain)設為后處理(Post Process)設置混合位置(Blendable Location)(如After Tonemapping)創建標量/向量參數(如Intensity, ColorTint&a…

Django基礎(三)———模板

前言 在之前的文章中,視圖函數只是直接返回文本,而在實際生產環境中其實很少這樣用,因為實際的頁面大多是帶有樣式的HTML代碼,這可以讓瀏覽器渲染出非常漂亮的頁面。目前市面上有非常多的模板系統,其中最知名最好用的…

mysql6表清理跟回收空間

mysql6表清理跟回收空間 文章目錄mysql6表清理跟回收空間1.清理表2.備份表或者備份庫3.回收表空間4.查看5.驗證業務1.清理表 ## 登錄 C:\Program Files\MySQL\MySQL Server 5.6\bin>mysql -uroot -p Enter password: ****** Welcome to the MySQL monitor. Commands end w…

Java-74 深入淺出 RPC Dubbo Admin可視化管理 安裝使用 源碼編譯、Docker啟動

點一下關注吧!!!非常感謝!!持續更新!!! 🚀 AI篇持續更新中!(長期更新) AI煉丹日志-30-新發布【1T 萬億】參數量大模型!K…

VSCode同時支持Vue2和Vue3開發的插件指南

引言 隨著Vue生態系統的演進,許多開發者面臨著在同一開發環境中同時處理Vue 2和Vue 3項目的需求。Visual Studio Code (VSCode)作為最受歡迎的前端開發工具之一,其插件生態對Vue的支持程度直接影響開發效率。本文將深入探討如何在VSCode中配置插件組合&a…

卷積神經網絡CNN的Python實現

一、環境準備與庫導入 在開始實現卷積神經網絡之前,需要確保開發環境已正確配置,并導入必要的Python庫。常用的深度學習框架有TensorFlow和PyTorch,本示例將基于Keras(可使用TensorFlow后端)進行實現,因為K…

js是實現記住密碼自動填充功能

記住密碼自動填充使用js實現記住密碼功能,在下次打開登陸頁面的時候進行獲取并自動填充到頁面【cookie和localStorage】使用js實現記住密碼功能,在下次打開登陸頁面的時候進行獲取并自動填充到頁面【cookie和localStorage】 //添加功能----記住上一個登陸…

【Java】文件編輯器

代碼:(SimpleEditor.java)import java.awt.Color; import java.awt.Font; import java.awt.Insets; import java.awt.BorderLayout;import java.awt.event.ActionEvent; import java.awt.event.ActionListener;import java.io.BufferedReader…

PyTorch中torch.topk()詳解:快速獲取最大值索引

torch.topk(similarities, k=2).indices 是什么意思 torch.topk(similarities, k=2).indices 是 PyTorch 中用于獲取張量中最大值元素及其索引的函數。在你的代碼中,它的作用是從 similarities 向量里找出得分最高的2個元素的位置索引。 1. 核心功能:找出張量中最大的k個值…

快速搭建本地HTTP服務器:`python -m http.server`詳解

文章目錄 一、什么是 http.server? 二、基礎使用 1. 啟動服務器 2. 指定端口 3. 綁定特定IP 三、實際應用場景 1. 本地前端開發 2. 文件共享 3. 啟用CGI腳本(高級) 四、目錄瀏覽詳解* 五、安全注意事項 六、進階技巧 1. 后臺運行(Linux/macOS) 2. 自定義錯誤頁面 3. 結合其…

運維技術教程之Jenkins上的known_hosts文件

在Jenkins中,known_hosts文件用于存儲已驗證的遠程節點主機密鑰,避免每次連接時重復驗證。以下是基于不同場景的解決方案:1. 創建并配置 known_hosts 文件 若Jenkins提示 No Known Hosts file 或找不到文件,需手動創建并配置&…

leetcode 3201. 找出有效子序列的最大長度 I 中等

給你一個整數數組 nums。nums 的子序列 sub 的長度為 x ,如果其滿足以下條件,則稱其為 有效子序列:(sub[0] sub[1]) % 2 (sub[1] sub[2]) % 2 ... (sub[x - 2] sub[x - 1]) % 2返回 nums 的 最長的有效子序列 的長度。一個 子序列 指的…

Java并發編程第三篇(深入解析Synchronized)

1. Synchronized簡介:一個常見的并發“陷阱” 在正式開始學習新知識前,我們不妨先來看一個現象,這是一個很多并發編程新手都會遇到的“陷阱”: public class SynchronizedDemo implements Runnable {// 共享變量private static in…

Chatbox AI|多模型多模態交互+MCP,一個工具打造你的全能私人助手

ChatBoxAI集成GPT-4、Claude等頂尖模型,支持Windows/macOS/Linux多平臺,具備隱私加密、文件智能解析(PDF/代碼/圖片)及開發者友好特性。其應用覆蓋自媒體創作、代碼實時預覽、AI繪圖(封面/表情包)及聯網搜索…

在Autodl服務器中使用VNC建立圖形界面

在Autodl服務器中使用VNC建立圖形界面**AutoDL 3D 圖形桌面搭建教程****第一步:安裝桌面和 VNC****第二步:進行一次性配置****第三步:日常啟動與使用**AutoDL 3D 圖形桌面搭建教程 目標: 在你的 AutoDL 環境上,以最少的步驟搭建一…

CD54.【C++ Dev】vector和list的反向迭代器的實現

目錄 1.反向迭代器的功能 2.算法 方法1:新寫一個類用于反向迭代器 方法2:封裝正向迭代器實現反向迭代器 解析operator* 正向迭代器和反向迭代器的關系 返回 *--tmp的原因 3.為自制的vector和list編寫反向迭代器 編寫統一的反向迭代器 修改vector頭文件 修改list頭文…

如何解決pip安裝報錯ModuleNotFoundError: No module named ‘django’問題

【Python系列Bug修復PyCharm控制臺pip install報錯】如何解決pip安裝報錯ModuleNotFoundError: No module named ‘django’問題 摘要 在日常 Django 項目開發中,最常見的“攔路虎”之一就是 ModuleNotFoundError: No module named django。該異常通常在以下場景出…