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

熱線電話:13121318867

登錄
首頁精彩閱讀R語言數(shù)據(jù)可視化之散點圖
R語言數(shù)據(jù)可視化之散點圖
2016-05-05
收藏

R語言數(shù)據(jù)可視化散點圖

散點圖簡介

散點圖通常是用來表述兩個連續(xù)變量之間的關(guān)系,圖中的每個點表示目標數(shù)據(jù)集中的每個樣本。

同時散點圖中常常還會擬合一些直線,以用來表示某些模型。

繪制基本散點圖

本例選用如下測試數(shù)據(jù)集:

數(shù)據(jù)集

繪制方法是首先調(diào)用ggplot函數(shù)選定數(shù)據(jù)集,并在aes參數(shù)中指明橫軸縱軸。然后調(diào)用散點圖函數(shù)geom_point()便可繪制出基本散點圖R語言示例代碼如下:

<a href='/map/sandiantu/' style='color:#000;font-size:inherit;'>散點圖</a>代碼

運行結(jié)果:

<a href='/map/sandiantu/' style='color:#000;font-size:inherit;'>散點圖</a>結(jié)果

基于顏色和點形對數(shù)據(jù)進行分組

本例選用如下測試數(shù)據(jù)集:

分組數(shù)據(jù)集

繪制方法是在基礎(chǔ)散點圖之上再在基函數(shù)的美學參數(shù)集里設(shè)置一個美學變量??芍付╟olour或者shape兩種參數(shù),分別將不同分組以不同顏色/點形表述。R語言示例代碼(基于顏色分組)如下:

數(shù)據(jù)集代碼

運行結(jié)果:

分組結(jié)果

R語言示例代碼(基于點形分組)如下:

分組

運行結(jié)果:

散點

說明:可自定義點形,共有大概36種點形可供選擇。具體請參考R語言ggplot2手冊。


映射連續(xù)型變量

本例選用如下測試數(shù)據(jù)集:

變量數(shù)據(jù)集

上一個示例中,映射到分組的變量是離散型變量。而對于除了橫軸縱軸之外的連續(xù)型變量,也可以映射到散點圖的色深和點大小上。R語言示例代碼(綁定顏色)如下:

<a href='/map/sandiantu/' style='color:#000;font-size:inherit;'>散點圖</a>代碼

運行結(jié)果:

R語言示例代碼(綁定大小)如下:


運行結(jié)果:

處理散點重疊

本例選用如下測試數(shù)據(jù)集:

處理散點

如果圖中的散點重疊現(xiàn)象比較嚴重,可以在散點圖中設(shè)置散點的透明度來進行可視化。R語言示例代碼如下:

散點代碼

運行結(jié)果:

散點結(jié)果

添加回歸模型擬合線

本例選用如下測試數(shù)據(jù)集:

擬合線數(shù)據(jù)

如果需要網(wǎng)散點圖中添加回歸模型擬合線,最主要是調(diào)用stat_smooth()函數(shù)。R語言示例代碼如下:

模擬回歸代碼

運行結(jié)果:

模擬結(jié)果

線段為曲線是因為參與擬合模型為局部線性回歸模型。往geom_smooth()函數(shù)中加入”method = lm”即可擬合經(jīng)典線性回歸。結(jié)果如下圖:線性結(jié)果 

添加自定義模型擬合線

本例選用如下測試數(shù)據(jù)集:

自定義模擬

上面一小節(jié)展示了用全局/局部回歸模型擬合樣本點并展示擬合線段,它使用ggplot2提供的geom_smooth()函數(shù)自動擬合并完成繪制。

但在更多時候,我們會使用其他包的模型(非ggplot2內(nèi)置模型)擬合。針對這種情況,我們需要自定義一個函數(shù)。該函數(shù)接受模型、橫縱軸名、橫軸范圍、橫軸樣本點數(shù)量等參數(shù),輸出一個包含預測變量和預測值的數(shù)據(jù)框。R語言實現(xiàn)代碼如下:

自定義模擬代碼

在使用其他模型建模好之后,將新的模型等各參數(shù)傳遞進上述函數(shù),便得到預測結(jié)果數(shù)據(jù)集。最后將新的數(shù)據(jù)集輸出為折線圖即可。

下面展示一個略微復雜的例子,它將數(shù)據(jù)集根據(jù)不同性別分為兩組,分別建立回歸模型并繪制其擬合線。R語言實現(xiàn)代碼如下:

模擬代碼

運行結(jié)果:

結(jié)果 

散點圖添加邊際地毯

本例選用如下測試數(shù)據(jù)集:

散點數(shù)據(jù)集

方法很簡單,在原先散點圖繪制函數(shù)的基礎(chǔ)上增加邊際地毯函數(shù)就行。R語言實現(xiàn)代碼如下:

散點代碼

運行結(jié)果:

散點結(jié)果 

散點圖添加標簽

本例選用如下測試數(shù)據(jù)集:

散點標簽散點圖中添加標簽的方法也很簡單,在原有散點圖函數(shù)的基礎(chǔ)上增加文本函數(shù)即可。R語言實現(xiàn)代碼如下:

散點標簽代碼

運行結(jié)果:

運行結(jié)果

PS:該示例中我們在文本繪制函數(shù)中重定義了美學特征集。之后文本繪制函數(shù)將使用新的美學特征集,但其他繪制函數(shù)的不變。

數(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(), // 加隨機數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個參數(shù)驗證碼對象,之后可以使用它調(diào)用相應的接口 initGeetest({ // 以下 4 個配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗服務器是否宕機 new_captcha: data.new_captcha, // 用于宕機時表示是新驗證碼的宕機 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); }