cs231n作業1——SVM

參考文章:cs231n assignment1——SVM

SVM

訓練階段,我們的目的是為了得到合適的 𝑊 和 𝑏 ,為實現這一目的,我們需要引進損失函數,然后再通過梯度下降來訓練模型。
在這里插入圖片描述
在這里插入圖片描述

def svm_loss_naive(W, X, y, reg):  #梯度矩陣初始化dW = np.zeros(W.shape)  # initialize the gradient as zero# compute the loss and the gradient#計算損失和梯度num_classes = W.shape[1]num_train = X.shape[0]loss = 0.0for i in range(num_train):#W*Xiscore = X[i].dot(W)correct_score = score[y[i]]for j in range(num_classes):#預測正確if j == y[i]:continue#W*Xi-Wyi*Xi+1margin = score[j] - correct_score + 1  # 拉格朗日if margin > 0:loss += margin#平均損失loss /= num_train#加上正則化λ||W||2# Add regularization to the loss.loss += reg * np.sum(W * W)		dW /= num_traindW += reg * W	return loss, dW

向量形式計算損失函數
在這里插入圖片描述

def svm_loss_vectorized(W, X, y, reg):loss = 0.0dW = np.zeros(W.shape)num_train=X.shape[0]classes_num=X.shape[1]score = X.dot(W)#矩陣大小變化,大小不同的矩陣不可以加減correct_scores = score[range(num_train), list(y)].reshape(-1, 1) #[N, 1]margin = np.maximum(0, score - correct_scores + 1)margin[range(num_train), list(y)] = 0#正則化loss = np.sum(margin) / num_trainloss += 0.5 * reg * np.sum(W * W)#大于0的置1,其余為0margin[margin>0] = 1margin[range(num_train),list(y)] = 0margin[range(num_train),y] -= np.sum(margin,1)dW=X.T.dot(margin)dW=dW/num_traindW=dW+reg*Wreturn loss, dW

SGD優化損失函數
使用批量隨機梯度下降法來更新參數,每次隨機選取batchsize個樣本用于更新參數 𝑊 和 𝑏 。

 for it in range(num_iters):X_batch = Noney_batch = Noidxs = np.random.choice(num_train, batch_size, replace=True)X_batch = X[idxs]y_batch = y[idxloss, grad = self.loss(X_batch, y_batch, reg)loss_history.append(losself.W -= learning_rate * grif verbose and it % 100 == 0:print("iteration %d / %d: loss %f" % (it, num_iters, loss))return loss_history

交叉驗證調整超參數
為了獲取最優的超參數,我們可以將整個訓練集劃分為訓練集和驗證集,然后選取在驗證集上準確率最高的一組超參數。

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

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

相關文章

【Qt】Qt概述

目錄 一. 什么是Qt 二. Qt的優勢 三. Qt的應用場景 四. Qt行業發展方向 一. 什么是Qt Qt是一個跨平臺的C圖形用戶界面應用程序框架,為應用程序開發者提供了建立藝術級圖形界面所需的所有功能。 Qt是完全面向對象的,很容易擴展,同時Qt為開發…

從打印到監測:納米生物墨水助力3D生物打印與組織監測平臺?

從打印到監測:納米生物墨水助力3D生物打印與組織監測平臺? 在 3D 組織工程中,納米生物墨水是將納米材料與 ECM 水凝膠結合,以提高其打印性和功能性的重要策略。納米生物墨水可以增強水凝膠的機械性能、導電性、生物活性&#xff…

汽車報價資訊app小程序模板源碼

藍色實用的汽車報價,汽車新聞資訊,最新上市汽車資訊類小程序前端模板。包含:選車、資訊列表、榜單、我的主頁、報價詳情、資訊詳情、詢底價、登錄、注冊、車貸,油耗、意見反饋、關于我們等等。這是一款非常全的汽車報價小程序模板…

MNIST 數據集 ubyte 格式介紹

train-images-idx1-ubyte 文件是用于存儲 MNIST 數據集中手寫數字圖像數據的文件。與標簽文件類似,這個文件使用的是一種簡單而緊湊的二進制格式。具體的文件格式如下: 文件頭(Header): 文件頭部分包含了一些描述文件內…

Ubuntu 20版本安裝Redis教程,以及登陸

第一步 切換到root用戶,使用su命令,進行切換。 輸入: su - 第二步 使用apt命令來搜索redis的軟件包,輸入命令:apt search redis 第三步 選擇需要的redis版本進行安裝,本次選擇默認版本,redis5.…

Emacs 的優點及與 DE 的比較

一、引言 在編程領域,對于工具的選擇一直是開發者們熱議的話題。今天,我們來探討一下 Emacs 及其所具有的優點,并思考使用 Emacs 寫程序是否真的比使用集成開發環境(IDE)更方便。 二、Emacs 的優點 高度可定制性 可以…

mac如何安裝nvm

? vue項目開發,熱更新,webpack,前輩造的輪子:各類的工具,庫,像axios,qs,cookie等輪子在npm上可以拿來直接用,需要node作為環境支撐。 開發時同時有好幾個項目,每個項目的需求不同…

Tornado:高性能異步Web框架詳解

文章目錄 引言官網鏈接Tornado 原理1. 非阻塞I/O2. 異步編程3. 事件循環4. 輕量級 使用方法安裝Tornado創建一個簡單的Web服務器 優缺點優點缺點 結論 引言 在Web開發的廣闊領域中,處理高并發和實時性需求一直是開發者們面臨的挑戰。Tornado,作為一個由…

威綸通創建項目創建(輸入,輸出,畫面切換使用)

創建一個項目 1,打開軟件 2,創建項目,設置系統參數 增加設備,選擇好對應型號(有市面上80%設備) 3,修改頁面,選擇參數 4,創建新頁面 不能在已經編輯的頁面進行新增 5&a…

【HTML入門】第三課 - 標題、段落、空格

這一小節,我們說一些比較零散的知識,HTML課程中呢,其實就是一些標簽,正是這些標簽組成了前端網頁的各種元素,所以你也可以叫他們標簽元素。 像前兩節我們說的,html head body title meta style 。這些都是…

【考研】南郵歷年復試上機試題目與題解

【考研】南郵歷年復試上機試題目與題解 文章目錄 【考研】南郵歷年復試上機試題目與題解個人題目難度評估歷年上機題目PROB1002 求最值問題PROB1003 新對稱素數問題PROB1004 進制轉換PROB1005 涂色問題 (待補)PROB1006 最大公約數和最小公倍數PROB1007 斐波那契數列PROB1008 回…

解決Spring Boot中的數據庫連接池問題

解決Spring Boot中的數據庫連接池問題 大家好,我是微賺淘客系統3.0的小編,也是冬天不穿秋褲,天冷也要風度的程序猿! 1. 理解數據庫連接池的重要性 數據庫連接池在任何使用數據庫的應用程序中都起著至關重要的作用。它們管理和維…

解析Java中的動態代理與靜態代理的區別

解析Java中的動態代理與靜態代理的區別 大家好,我是微賺淘客系統3.0的小編,也是冬天不穿秋褲,天冷也要風度的程序猿! 1. 引言 代理模式是軟件開發中常用的一種設計模式,用于控制對其它對象的訪問。在Java中&#xf…

C#中的Task.Delay(2000).Wait() 與await Task.Delay(2000)

Task.Delay(2000).Wait() 和 await Task.Delay(2000) 在功能上看似相似,都用于等待一段時間(在這個例子中是2000毫秒),但它們在使用方式和背后的行為上存在一些關鍵差異。 .Result 是 Task 類的一個屬性,它用于獲取任務…

算法刷題筆記 滑動窗口(C++實現,非常詳細)

文章目錄 題目描述基本思路實現代碼 題目描述 給定一個大小為n ≤ 10^6的數組。有一個大小為k的滑動窗口,它從數組的最左邊移動到最右邊。你只能在窗口中看到k個數字。每次滑動窗口向右移動一個位置。以下是一個例子: 該數組為 [1 3 -1 -3 5 3 6 7]&…

用HttpURLConnection復現http響應碼405

目錄 使用GET方法,訪問GET接口,服務端返回405使用GET方法,訪問POST接口,服務端返回405使用POST方法,訪問GET接口,服務端返回405 使用GET方法,訪問GET接口,服務端返回405 發生場景&a…

Linux shell編程學習筆記63:free命令 獲取內存使用信息

0 前言 在系統安全檢查中,內存使用情況也是一塊可以關注的內容。Linux提供了多個獲取內存信息的命令很多。今天我們先研究free命令。 1 free命令的功能、用法和選項說明 1.1 free命令的功能 free 命令可以顯示系統內存的使用情況,包括物理內存、交換…

Java多語言跨境電商外貿商城源碼 tiktok商城系統源碼 跨境電商源碼

Java多語言跨境電商外貿商城源碼 tiktok商城系統源碼 跨境電商源碼 技術棧 PC端使用:vueelementui 用戶端使用:uniapp 管理端使用:vueelementui 后臺服務使用:springbootmybatisplusmysql 功能描述: 對接PayPal…

【面試題】字節一面面試題

自我介紹,項目介紹MQ的使用場景,不同的MQ之前的區別,為什么使用公司的MQ數據庫怎么部署的(應該是問節點,庫表)事務隔離級別innodb為什么選可重復讀作為隔離級別數據庫三大日志,保存先后順序undo…

vue3+electron項目搭建,遇到的坑

我主要是寫后端,所以對前端的vue啊vue-cli只是知其然,不知其所以然 這樣也導致了我在開發前端時候遇到了很多的坑 第一個坑, vue2升級vue3始終升級不成功 第二個坑, vue add electron-builder一直卡進度,進度條走完就是不出提示succes 第一個坑的解決辦法: 按照網上說的升級v…