线性模型(线性回归,对数几率回归,线性判别分析)

1,线性回归学习

基本形式

给定d个属性描述的示列 X =(X1,X2,.....Xn)然后线性模型试图学习通过属性组合来进行预测的函数


一般用向量形式表示


过程处理

现在假设有数据集{(X1,Y1),(X2,Y2),.......,(Xn,Yn)}

写成以下向量新形式


损失函数

如何确定w和b,关键在于衡量f(x)和y之间的差别,均方误差是回归任务中最常用的性能度量,使其最小


当矩阵满秩情况下求导为0


当矩阵不满秩情况下用梯度下降(解决直接运算性能问题)

批量梯度下降BGD

按照传统的思想,我们需要对上述风险函数中的每个

求其偏导数,得到每个theta所对应的梯度


这里X(i,j)表示第i个样本点

的第j分量,即h(θ)中的

接下来由于我们要最小化风险函数,故按照每个参数

的负梯度方向来更新每一个

线性回归梯度下降

apltha表示每一步步长。从上面公式可以注意到,它得到的是一个全局最优解,但是每迭代一步,都要用到训练集所有的数据,如果m很大,那么可想而知这种方法的迭代速度!!所以,这就引入了另外一种方法,随机梯度下降。

随机梯度下降


家下来我们对每个样本的损失函数,对每个theta求偏导数,得到每个theta所对应的偏导数

然后根据每个参数thetaj的负梯度来更新每一个theta

对比其优劣点如下:

批量梯度下降:

优点:全局最优解;易于并行实现;总体迭代次数不多

缺点:当样本数目很多时,训练过程会很慢,每次迭代需要耗费大量的时间。

随机梯度下降:

优点:训练速度快,每次迭代计算量不大

缺点:准确度下降,并不是全局最优;不易于并行实现;总体迭代次数比较多。


对数几率回归                                                                                                                                                               线性回归分类

上面讲到的是对数据结果的一个预测,我们需要分类的话,引进Signoid函数


做一些简化,可以得到:


在只考率二分类的情况下,将Y换成后验概率P(Y=1|x),则1-y用P(Y=0|x)来表示。


看到上面,我们通过极大似然估计来估计w和b


为表述方便,使用一个新矩阵β来表示ω和b,令β={ωb}。  同时也要给x矩阵补上一列1,令x′={x1}。因为要对应参数b,补上1,保证结果不变。  那么,ωTx+b=βTx′。  由于是二分类,即只有y=0和y=1的情况,那么可以将似然项重写为y=0和y=1的情况相加:


将上式代入极大似然的公式中然后求解



线性判别分析LDA

常被用于数据预处理中的降维(dimensionality reduction)步骤。LDA在保证良好的类别区分度的前提下,将数据集向更低维空间投影,以求在避免过拟合(“维数灾难”)的同时,减小计算消耗。将d维特征降到只有一维,而又要保证类别能够“清晰”地反映在低维数据上,也就是这一维就能决定每个样例的类别,大概就是说,通过拟合一条直线,使得同类样例的投影点尽可能的近不同类的中心距离尽可能的远

基本概念:

协方差矩阵

相关系数

相关系数也可以看成是一种标准差。它消除了两个变量变化幅度的影响,而只是单纯地反映两个变量每单位变化时的相似程度。。 相关系数的取值范围是-1 到 1。相关系数为1 说明两个变量为正相关,且为线性关系,即X增大一倍,Y也会增大一倍,X减小一倍,Y也会减小一倍;相关系数为0,说明两个变量相互独立,不存在相关关系。相关系数为-1时,说明两个变量为负相关,且为线性关系,即X增大一倍,Y也会减小一倍,X减小一倍,Y会增大一倍

我们知道协方差只能处理二维问题,维数多了就需要多个协方差,所以就有协方差矩阵,以三维数据为例子

散布矩阵又称散度矩阵,将协方差矩阵乘以系数(n-1)就得到了散布矩阵,n表述数据的维度

给定数据集D={(Xi,Yi)}(i=1...m)表示有M条数据,yi={0.1},令Xi,ui,Ci分表表示第i类实列的集合,均值向量,协方差矩阵,若将数据投影到直线w上,则两类样本的中心在直线上的投影将分别是trac(w)u0和trac(w)u1,若将所有的样本都投影在直线上,则两类i样本的协方差分别是trac(w)C0w和trac(w)C1w。

要使同类样例的投影点尽可能的近,即可让同类样例的的协方差尽可能的小。                                                    即trac(w)C0w+trac(w)C1w尽可能小,同时考虑让||trac(w)u0-trac(w)u1||的二次范式的平方尽可能大                      通过这得到最大化目标

接下里就是通过上面的J函数找到满足条件的一对w和b


实战代码                                                                                                                                                        

最小二乘法代码实现

最小二乘法矩阵化所确定的斜率

实现目标 Y=wX+b w和b的求解包含在上面(n+1,1)矩阵当中后N个是w的值,第一个表示截距b

```python

import numpyas np

from numpy.linalgimport  inv

from numpyimport dot

from numpyimport mat

import matplotlib.pyplotas plt

a = [[1,2,3],

    [1,9,12],

    [1,4,2],

    [1,7,2],

    [1,4,1],

    [1,6,2]]

b = mat(a)

y = [1,2,3,4,5,6]

theta = dot(dot(inv(dot(b.T,b)),b.T),y)

print(theta)

运行结果:


梯度下降法代码:

#get_ipython().run_line_magic('matplotlib', 'inline')

import matplotlib.pylabas plt

import numpyas np

from sklearnimport datasets

class LinearRegression():

def __init__(self):

self.w =None

    def fit(self, X, y):

# Insert constant ones for bias weights

        print("first:", X.shape)

# 在第0项,插入 1,让x0项为1

        X = np.insert(X, 0, 1, axis=1)

print("second:", X.shape)

# inv(): 对当前值取逆, dot():矩阵计算

        X_ = np.linalg.inv(X.T.dot(X))

# 算出来 最好的 一组参数 theta

        self.w = X_.dot(X.T).dot(y)

def predict(self, X):

# Insert constant ones for bias weights

        X = np.insert(X, 0, 1, axis=1)

y_pred = X.dot(self.w)

return y_pred

def mean_squared_error(y_true, y_pred):

mse = np.mean(np.power(y_true - y_pred, 2))

return mse

def main():

# load the diabetes dataset

    diabetes = datasets.load_diabetes()

# Use only one feature

    X = diabetes.data[:, np.newaxis, 2]

print(X.shape)

# split the data into training/testing sets

    x_train, x_test = X[:-20], X[-20:]

# Split the targets into training/testing sets

    y_train, y_test = diabetes.target[:-20], diabetes.target[-20:]

clf = LinearRegression()

clf.fit(x_train, y_train)

y_pred = clf.predict(x_test)

# Print the mean squared error

    print("Mean Squared Error:", mean_squared_error(y_test, y_pred))

# Plot the results

    plt.scatter(x_test[:, 0], y_test, color='black')

plt.plot(x_test[:, 0], y_pred, color="blue", linewidth=3)

plt.show()

```

main()

实验结果:

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容