99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁精彩閱讀R語言學(xué)習(xí)之矩陣
R語言學(xué)習(xí)之矩陣
2017-05-11
收藏

R語言學(xué)習(xí)之矩陣

很多人是在線性代數(shù)課學(xué)的矩陣,當(dāng)時什么問題都沒有,除了一個問題:學(xué)習(xí)矩陣到底有什么用呢?矩陣是一個集合,它里面可以存放很多對象,比如一個行就是一個對象(或者說記錄),每一個對象又有很多(屬性)列。如果把一組對象~屬性表示成矩陣,我們就能很容易取出每個對象對應(yīng)的某個屬性了,并且根據(jù)線性代數(shù)方法考察兩個對象之間的聯(lián)系(相似性)。矩陣的行列數(shù)我們一般稱作維數(shù)。
對于矩陣而言,我們當(dāng)然想實(shí)現(xiàn)以下操作與功能:
    矩陣的加減、乘除運(yùn)算
    矩陣的行列切片
    最值的快速獲取
    線性代數(shù)運(yùn)算

好在R語言中的矩陣可以很輕易幫我們實(shí)現(xiàn)這些功能,有了這一神兵利器,我們就可以游刃有余地操作應(yīng)該算是數(shù)據(jù)分析的基本單位——矩陣了。
    創(chuàng)建矩陣

R中直接調(diào)用函數(shù)matrix()可以快速自定義矩陣,下面一行命令可以快速創(chuàng)建一個4行3列的矩陣:
>a<-matrix(c(1:12),nrow=4,ncol=3,byrow=TRUE)

> a

     [,1] [,2] [,3]
[1,]    1    2    3
[2,]    4    5    6
[3,]    7    8    9
[4,]   10   11   12

這里相當(dāng)于先創(chuàng)建一個向量,再將其轉(zhuǎn)化為一個4x3的矩陣,bynow=TRUE表示會按照把第一行排滿,接著排第二行。

還有一些其它小技巧,比如有時候我們需要初始化一個矩陣,以便于后面對其進(jìn)行賦值:
> a1<-matrix(0,3,4)
> a1
     [,1] [,2] [,3] [,4]
[1,]    0    0    0    0
[2,]    0    0    0    0
[3,]    0    0    0    0
    矩陣行、列、元素的選取(切片)
取第一行第二列元素
> a[1,2]
[1] 2
取第一行元素,這與Matlab很相像
> a[1,]
[1] 1 2 3
取第一行除了第二個元素之外的元素
> a[1,-2]
[1] 1 3
取第一列元素
> a[,1]
[1]  1  4  7 10
取第一列除了第二個元素之外的元素
> a[-2,1]
[1]  1  7 10
矩陣全部元素
> a[,]
     [,1] [,2] [,3]
[1,]    1    2    3
[2,]    4    5    6
[3,]    7    8    9
[4,]   10   11   12
    矩陣的基本運(yùn)算
這里創(chuàng)建一個新的矩陣b、c1,b與a的維數(shù)相同,c1的列、行數(shù)與a的行、列數(shù)分別相等,便于做實(shí)驗(yàn)。
> b<-matrix(c(13:24),nrow=4,ncol=3,byrow = TRUE)
> b
     [,1] [,2] [,3]
[1,]   13   14   15
[2,]   16   17   18
[3,]   19   20   21
[4,]   22   23   24

> c1<-matrix(c(13:24),nrow=3,ncol=4,byrow = TRUE)
> c1
     [,1] [,2] [,3] [,4]
[1,]   13   14   15   16
[2,]   17   18   19   20
[3,]   21   22   23   24
獲取矩陣維數(shù)
> dim(a)
[1] 4 3
加減法運(yùn)算
矩陣的加減法運(yùn)算表示兩個矩陣對應(yīng)元素分別進(jìn)行加減法運(yùn)算,返回兩個矩陣對應(yīng)元素分別進(jìn)行加減法運(yùn)算的矩陣。當(dāng)然了,矩陣加減法運(yùn)算前提是兩個矩陣的維數(shù)必須一樣,否則會報錯。
> a+b
     [,1] [,2] [,3]
[1,]   14   16   18
[2,]   20   22   24
[3,]   26   28   30
[4,]   32   34   36
乘除法運(yùn)算
矩陣的乘除法運(yùn)算表示兩個矩陣對應(yīng)元素分別進(jìn)行乘除法運(yùn)算,返回兩個矩陣對應(yīng)元素分別進(jìn)行乘除法運(yùn)算的矩陣。當(dāng)然了,矩陣乘除法運(yùn)算前提是兩個矩陣的維數(shù)必須一樣,否則會報錯。
> a*b
     [,1] [,2] [,3]
[1,]   13   28   45
[2,]   64   85  108
[3,]  133  160  189
[4,]  220  253  288
還有就是矩陣的乘法,要求是前面矩陣的列數(shù)等于后面矩陣的列數(shù),返回一個左邊矩陣行數(shù)x右邊矩陣列數(shù)的矩陣。
> a%*%c1
     [,1] [,2] [,3] [,4]
[1,]  110  116  122  128
[2,]  263  278  293  308
[3,]  416  440  464  488
[4,]  569  602  635  668
線性代數(shù)運(yùn)算
R語言提供了很多用于線性代數(shù)運(yùn)算的函數(shù),常用的列出如下:
eigen() #求特征值和特征向量

solve() #求逆矩陣

chol() #Choleski分解

svd() #奇異值分解

qr() #QR分解

det() #求行列式

dim() #給出行列數(shù)

t() #矩陣轉(zhuǎn)置
    矩陣的拼接
R語言矩陣的拼接主要用到兩個函數(shù),rbind()、cbind()
按行拼接要求兩個矩陣列數(shù)要相同rbind()
> rbind(a,b)
     [,1] [,2] [,3]
[1,]    1    2    3
[2,]    4    5    6
[3,]    7    8    9
[4,]   10   11   12
[5,]   13   14   15
[6,]   16   17   18
[7,]   19   20   21
[8,]   22   23   24
按列拼接要求兩個矩陣行數(shù)要相同cbind()
> cbind(c1,matrix(c(1:6),nrow = 3,byrow = TRUE))
     [,1] [,2] [,3] [,4] [,5] [,6]
[1,]   13   14   15   16    1    2
[2,]   17   18   19   20    3    4
[3,]   21   22   23   24    5    6
    其它函數(shù)的靈活結(jié)合
矩陣相關(guān)計算求法還可以靈活應(yīng)用其它函數(shù),比如求和函數(shù)sum(),平均值函數(shù)mean(),最值函數(shù)max()等。
> a
     [,1] [,2] [,3]
[1,]    1    2    3
[2,]    4    5    6
[3,]    7    8    9
[4,]   10   11   12

> max(a)
[1] 12
第一行最大值
>max(a[1,])
[1] 3
> max(a[,1])
[1] 10
對第一行求和
> sum(a[1,])
[1] 6
> mean(a[,1])
[1] 5.5
還有就是結(jié)合apply()函數(shù),后面會講到。
用法,舉個例子。apply(Matrix,1,FUN=mean),這里,F(xiàn)UN=mean計算矩陣Matrix每一行的平均值,以向量的形式返回,中間的參數(shù)‘1’表示求每一行均值,如果是‘2’,表示求每一列均值
比如:
求a每一行平均值
> apply(a,1,mean)
[1]  2  5  8 11
對a每一列分別求和
> apply(a,2,sum)
[1] 22 26 30
好了,關(guān)于矩陣就講到這里,希望對你們有用。

數(shù)據(jù)分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機(jī)數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進(jìn)行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個參數(shù)驗(yàn)證碼對象,之后可以使用它調(diào)用相應(yīng)的接口 initGeetest({ // 以下 4 個配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗(yàn)服務(wù)器是否宕機(jī) new_captcha: data.new_captcha, // 用于宕機(jī)時表示是新驗(yàn)證碼的宕機(jī) product: "float", // 產(chǎn)品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說明請參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計時完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }