機(jī)器學(xué)習(xí)筆記 線性回歸 2018-07-24

從最簡單的線性回歸開始。
線性回歸求參數(shù)w和b瘸味,有直接快速的最小二乘法宫仗,但是這里用到的是梯度下降法。
設(shè)損失函數(shù)為平方損失函數(shù)旁仿,即所有預(yù)測y值與訓(xùn)練真實y值之差的平方之和藕夫。
那么即可根據(jù)梯度下降公式a = a - η*(?L/?a) 來更新參數(shù)。
注意,學(xué)習(xí)速率η過大會導(dǎo)致震蕩而不收斂毅贮;過小則會導(dǎo)致收斂過慢办悟。
代碼如下。

import numpy as np

class Linear_Regression(object):
    def __init__(self, learning_rate=0.001, max_iter=1000, init_w=0.0, init_b=0.0):
        self.learning_rate = learning_rate
        self.max_iter = max_iter
        self.w = init_w
        self.b = init_b    

    def fit(self, train_X, train_Y):
        for i in range(self.max_iter):
            predict_Y = self.w * train_X + self.b
            loss_a = np.sum(np.square(train_Y - predict_Y))    #更新參數(shù)前的損失 
            dldw = np.sum((train_Y - predict_Y) * (-1) * train_X)    #損失函數(shù)對參數(shù)w求導(dǎo)
            dldb = np.sum((train_Y - predict_Y) * (-1))        #損失函數(shù)對參數(shù)b求導(dǎo)
            temp_w = self.w - self.learning_rate * dldw    #梯度下降更新參數(shù)w
            temp_b = self.b - self.learning_rate * dldb    #梯度下降更新參數(shù)b
            predict_Y = temp_w * train_X + temp_b
            loss_b = np.sum(np.square(train_Y - predict_Y))     #更新參數(shù)后的損失
            if loss_b - loss_a > 0:
                break    #如果更新參數(shù)后損失變大了, 說明要么已經(jīng)收斂, 要么學(xué)習(xí)速率過大出現(xiàn)震蕩
            else:
                self.w = temp_w    #否則, 確認(rèn)本次參數(shù)更新
                self.b = temp_b

    def get_parameters(self):
        print("w = %.3f, b = %.3f"%(self.w, self.b))
        return self.w, self.b   
     
    def predict(self, test_X):
        predict_Y = self.w * test_X + self.b
        print(predict_Y)
        return predict_Y
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末滩褥,一起剝皮案震驚了整個濱河市病蛉,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌铸题,老刑警劉巖铡恕,帶你破解...
    沈念sama閱讀 211,561評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異丢间,居然都是意外死亡探熔,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,218評論 3 385
  • 文/潘曉璐 我一進(jìn)店門烘挫,熙熙樓的掌柜王于貴愁眉苦臉地迎上來诀艰,“玉大人,你說我怎么就攤上這事饮六∑渎ⅲ” “怎么了?”我有些...
    開封第一講書人閱讀 157,162評論 0 348
  • 文/不壞的土叔 我叫張陵卤橄,是天一觀的道長绿满。 經(jīng)常有香客問我,道長窟扑,這世上最難降的妖魔是什么喇颁? 我笑而不...
    開封第一講書人閱讀 56,470評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮嚎货,結(jié)果婚禮上橘霎,老公的妹妹穿的比我還像新娘。我一直安慰自己殖属,他們只是感情好姐叁,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,550評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著洗显,像睡著了一般外潜。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上挠唆,一...
    開封第一講書人閱讀 49,806評論 1 290
  • 那天橡卤,我揣著相機(jī)與錄音,去河邊找鬼损搬。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的巧勤。 我是一名探鬼主播嵌灰,決...
    沈念sama閱讀 38,951評論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼颅悉!你這毒婦竟也來了沽瞭?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,712評論 0 266
  • 序言:老撾萬榮一對情侶失蹤剩瓶,失蹤者是張志新(化名)和其女友劉穎驹溃,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體延曙,經(jīng)...
    沈念sama閱讀 44,166評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡豌鹤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,510評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了枝缔。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片布疙。...
    茶點(diǎn)故事閱讀 38,643評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖愿卸,靈堂內(nèi)的尸體忽然破棺而出灵临,到底是詐尸還是另有隱情,我是刑警寧澤趴荸,帶...
    沈念sama閱讀 34,306評論 4 330
  • 正文 年R本政府宣布儒溉,位于F島的核電站,受9級特大地震影響发钝,放射性物質(zhì)發(fā)生泄漏顿涣。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,930評論 3 313
  • 文/蒙蒙 一笼平、第九天 我趴在偏房一處隱蔽的房頂上張望园骆。 院中可真熱鬧,春花似錦寓调、人聲如沸锌唾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,745評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽晌涕。三九已至,卻和暖如春痛悯,著一層夾襖步出監(jiān)牢的瞬間余黎,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,983評論 1 266
  • 我被黑心中介騙來泰國打工载萌, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留惧财,地道東北人巡扇。 一個月前我還...
    沈念sama閱讀 46,351評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像垮衷,于是被迫代替她去往敵國和親厅翔。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,509評論 2 348

推薦閱讀更多精彩內(nèi)容