探秘機器學習核心邏輯:梯度下降的迭代過程 (圖文詳解)

一? 需求解函數

f() 和 g()函數分別為求y值求導數的函數。

目的:求該函數的最小值:

????????y = (x - 3.5)^ 2 - 4.5 * x + 10

?代碼:

import numpy as np
import matplotlib.pyplot as plt f = lambda x : (x - 3.5) ** 2 - 4.5 * x + 10
g = lambda x : 2 * (x - 3.5) - 4.5x = np.linspace(0, 11.5, 100)
y = f(x)plt.plot(x, y) 

二 隨機初始化一個值

在 0 - 12 中隨機取一個值:10

k = np.random.randint(0, 12)
print('隨機取到的值k:', k)  # 10 

三 查看此時的斜率

查看此時的切線方程:

k = 10
g(x) = 8.5   # 斜率
f(x) = 7.5   # y值
# 該點的切線方程:y = 8.5 * x - 77.5plt.plot(x, y) 
plt.scatter(k, f(k), color = 'red', s = 30)# 生成x的范圍
x_values = np.linspace(8, 11.5, 100)# 計算對應的y值
y_values = 8.5 * x_values - 77.5
# 繪制直線
plt.plot(x_values, y_values, color='blue', label='Line')

四 根據斜率和學習率確定下一個點

設置學習率為0.2,與初始點的梯度反向進行下降,如果在上一個點斜率為正,說明需要x需要向左移動才能接近最小值:next_k = k - 學習率*斜率

學習率可以改,設置值比較大移動比較快,設置比較小移動比較慢。

求到的第一個K:8.3

learing_ratio = 0.2
next_k = k - learing_ratio*g(k) plt.plot(x, y) 
plt.scatter(k, f(k), color = 'red', s = 30)
plt.scatter(next_k, f(next_k), color = 'red', s = 30) print(next_k, f(next_k))
# 8.3 -4.309999999999995

五?根據該邏輯繼續計算下一個值

用上一次計算的 8.2 計算一個值:next_k2 = next_k - learing_ratio*g(next_k)?

求到的第二個K:7.28

learing_ratio = 0.2
next_k2 = next_k - learing_ratio*g(next_k) plt.plot(x, y) 
plt.scatter(k, f(k), color = 'red', s = 30)
plt.scatter(next_k, f(next_k), color = 'red', s = 30)
plt.scatter(next_k2, f(next_k2), color = 'red', s = 30)
print(next_k2, f(next_k2))
# 7.28 -8.471599999999995

六 同時查看兩次迭代過程中 y值的變化率

查看兩次迭代過程中 y值的變化率分別為:-11.559999999999995? -4.1616

plt.plot(x, y) 
plt.scatter([k, next_k, next_k2], [f(k), f(next_k), f(next_k2)], color = 'red', s = 30)# 繪制直線
plt.plot(x, [f(k)] * len(x), label='y=5', color='blue', linestyle='--')
plt.plot(x, [f(next_k)] * len(x), label='y=5', color='green', linestyle='--')
plt.plot(x, [f(next_k2)] * len(x), label='y=5', color='red', linestyle='--')print(f(next_k) - f(k), f(next_k2) - f(next_k))  # -11.5599999999-4.1616

七 設置循環,求最接近的目標值

注意:截止條件設置的變化率是x 的變化率,就是當?斜率的變化值足夠小?的時候截止,其實也是y值的變化率乘學習率后的變化值 !!

k = k - learing_ratio*g(k)

設置截止循環條件:precision = 0.0001

learing_ratio = 0.2
last_k = k + 0.1
# 精確度
precision = 0.0001k_ = [k]
count = 0  # 記錄迭代次數while True:if np.abs(k - last_k) < precision:breaklast_k = kcount += 1k = k - learing_ratio*g(k)  # 迭代k_.append(k)print(f'-> 迭代次數cnt:{count:2},更新后的x:{k:0.7f}, 實時的y:{f(k):0.7f}')print(f'梯度下降的次數:{count}')
plt.plot(x, y) 
print('最后的k值:', k)  # 5.75009323204022# 散點圖,轉換為array數組可以用f(x)直接求列表的y值
k_ = np.array(k_)
plt.scatter(k_, f(k_), color = 'red', s = 30)

?

PS:最后的列表直接求y值是先轉換為了 np.array數組!!!

實際值:5.75

循環21次,最后求到的k值:5.75009323204022

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

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

相關文章

架構LAMP

目錄 1.什么是LAMP 2.LAMP組成及作用 3.搭建Apache httpd服務 4.編譯安裝mysqld 服務 5.編譯安裝PHP 解析環境 6.安裝論壇 1.什么是LAMP LAMP架構是目前成熟的企業網站應用模式之一&#xff0c;指的是協同工作的一整套系統和相關軟件&#xff0c;能夠提供動態Web站點服務…

MATLAB算法實戰應用案例精講-【人工智能】漫談自動駕駛

目錄 常用數據集 一、自動駕駛領域數據集 1. KITTI數據集 2.CityScapes數據集 3.BDD100K數據集

go與ioc

在Go開發服務端程序時&#xff0c;使用IoC&#xff08;Inversion of Control&#xff09;機制并不像在Java等語言中那樣普遍。Go語言的設計哲學傾向于簡潔和直接&#xff0c;更注重代碼的可讀性和可維護性。 在Go中&#xff0c;通常會使用依賴注入&#xff08;Dependency Inje…

【Python】視頻剪輯小程序

近期遇到一些錄制的視頻需要剪輯。 手機上剪輯操作很耗時&#xff0c;有幾個G的視頻&#xff0c;花了一天的空余時間去剪輯。電腦上也有格式工廠&#xff0c;有很方便。 可是學了Pthon&#xff0c;又無意中了解到了moviepy這個庫&#xff0c;于是自己寫了個簡單的視頻剪輯程序。…

Windows安裝kafka

壓縮包下載地址&#xff1a;https://www.apache.org/dyn/closer.cgi?path/kafka/3.6.1/kafka_2.13-3.6.1.tgz 啟動kafka步驟 zookeeper-server-start.bat rem 閉命令提示符窗口的命令回顯&#xff0c;這樣在運行腳本時不會顯示腳本的具體命令內容 echo offrem 命令行啟動未…

Proteus仿真--8×8LED點陣屏仿電梯數字滾動顯示

本文介紹基于88LED點陣屏仿電梯數字滾動顯示設計&#xff08;完整仿真源文件及代碼見文末鏈接&#xff09; 仿真圖如下 其中K1-K5的5個按鍵分別代表不同樓層&#xff0c;摁下按鍵后在8X8LED上便會顯示到對應樓層的跳變信息&#xff0c;模擬電梯的運作 仿真運行視頻 Proteus仿…

nodejs多線程,fork和Worker

一、前言 javascript是單線程執行的&#xff0c;如果想要多線程執行&#xff0c;那么相當于再運行一個node,其實不該理解成多線程&#xff0c;更像是多進程。 二、Worker(‘worker_threads’模塊) worker有點類似exec&#xff0c;直接再cmd執行node命令&#xff0c;不同的是兩…

《安富萊嵌入式周報》第328期:自主微型機器人,火星探測器發射前失誤故障分析,微軟推出12周24期免費AI課程,炫酷3D LED點陣設計,MDK5.39發布

周報匯總地址&#xff1a;嵌入式周報 - uCOS & uCGUI & emWin & embOS & TouchGFX & ThreadX - 硬漢嵌入式論壇 - Powered by Discuz! 更新一期視頻教程&#xff1a; 【實戰技能】 單步運行源碼分析&#xff0c;一期視頻整明白FreeRTOS內核源碼框架和運行…

【STM32】TIM定時器基本定時功能

第一部分&#xff1a;定時器基本定時的功能&#xff1b; 第二部分&#xff1a;定時器的輸出比較功能&#xff1b; 第三部分&#xff1a;定時器輸入捕獲的功能&#xff1b; 第四部分&#xff1a;定時器的編碼接口。 1 TIM簡介 TIM&#xff08;Timer&#xff09;定時器&#…

在OpenCV基于深度學習的超分辨率模型實踐

1. 引言 OpenCV是一個開源的計算機視覺庫&#xff0c;擁有大量優秀的算法。基于最新的合并&#xff0c;OpenCV包含一個易于使用的接口&#xff0c;主要用于實現基于深度學習方法的超分辨率&#xff08;SR&#xff09;。該接口包含預先訓練的模型&#xff0c;這些模型可以非常容…

redis中使用事務保護數據完整性

事務是指一個執行過程&#xff0c;要么全部執行成功&#xff0c;要么失敗什么都不改變。不會存在一部分成功一部分失敗的情況&#xff0c;也就是事務的ACID四大特性&#xff08;原子性、一致性、隔離性、持久性&#xff09;。但是redis中的事務并不是嚴格意義上的事務&#xff…

使用flutter_native_splash替換啟動圖片,iOS端替換不成功

使用flutter_native_splash替換啟動圖片&#xff0c;iOS端替換不成功 1、刪除App重啟手機&#xff1b;2、重新創建一個新的LaunchScreen.storyboard&#xff0c;比如命名為NewLaunchScreen.storyboard&#xff0c;在General里面設置Launch Screen File為這個新的NewLaunchScree…

藍橋杯 day01 奇怪的數列

題目描述 奇怪的數列 從 X 星截獲一份電碼&#xff0c;是一些數字&#xff0c;如下&#xff1a; 13 1113 3113 132113 1113122113 ?? YY 博士經徹夜研究&#xff0c;發現了規律&#xff1a; 第一行的數字隨便是什么&#xff0c;以后每一行都是對上一行"讀出來…

智能優化算法應用:基于蝗蟲算法3D無線傳感器網絡(WSN)覆蓋優化 - 附代碼

智能優化算法應用&#xff1a;基于蝗蟲算法3D無線傳感器網絡(WSN)覆蓋優化 - 附代碼 文章目錄 智能優化算法應用&#xff1a;基于蝗蟲算法3D無線傳感器網絡(WSN)覆蓋優化 - 附代碼1.無線傳感網絡節點模型2.覆蓋數學模型及分析3.蝗蟲算法4.實驗參數設定5.算法結果6.參考文獻7.MA…

【數據挖掘】國科大蘇桂平老師數據庫新技術課程作業 —— 第二次作業

1 設 F { A B → C , B → D , C D → E , C E → G H , G → A } F\{AB\rightarrow C,B\rightarrow D, CD\rightarrow E, CE\rightarrow GH, G\rightarrow A \} F{AB→C,B→D,CD→E,CE→GH,G→A}&#xff0c;用推理的方法證明 F ∣ A B → G F\;|AB\rightarrow G F∣AB→…

持續集成交付CICD:使用Maven命令上傳Nexus制品

目錄 一、實驗 1.使用Maven命令上傳Nexus制品&#xff08;第一種方式&#xff09; 2.使用Maven命令上傳Nexus制品&#xff08;第二種方式&#xff09; 一、實驗 1.使用Maven命令上傳Nexus制品&#xff08;第一種方式&#xff09; &#xff08;1&#xff09;指定一個 hoste…

說說React jsx轉換成真實DOM的過程?

在React中&#xff0c;JSX&#xff08;JavaScript XML&#xff09;是一種語法糖&#xff0c;用于描述用戶界面的結構和組件關系。當你編寫React組件并包含JS JSX解析&#xff1a;React中的JSX代碼首先會被解析成JavaScript對象。這個過程通常是通過Babel等工具進行的&#xff0…

Flutter視頻播放器在iOS端和Android端都能實現全屏播放

Flutter開發過程中&#xff0c;對于視頻播放的三方組件有很多&#xff0c;在Android端適配都挺好&#xff0c;但是在適配iPhone手機的時候&#xff0c;如果設置了UIInterfaceOrientationLandscapeLeft和UIInterfaceOrientationLandscapeRight都為false的情況下&#xff0c;無法…

pytorch 筆記:dist 和 cdist

1 dist 1.1 基本使用方法 torch.dist(input, other, p2) 計算兩個Tensor之間的p-范數 1.2 主要參數 input輸入張量other另一個輸入張量p范數 input 和 other的形狀需要是可廣播的 1.3 舉例 import torchxtorch.randn(4) x #tensor([ 1.2698, -0.1209, 0.0462, -1.3271…

基于PaddleOCR銀行卡識別實現(四)之uni-app離線插件

目的 在前三篇文章中完成了銀行卡識別整個模型訓練等工作&#xff0c;通過了解PaddleOCR的端側部署&#xff0c;我們也可以將銀行卡號檢測模型和識別模型移植到手機中&#xff0c;做成一款uni-app手機端離線銀行卡號識別的應用。 準備工作 為了不占用過多篇幅&#xff0c;這…