翻譯|使用教程|編輯:楊鵬連|2020-08-03 11:54:45.760|閱讀 441 次
概述:在本教程中,我們將向您展示如何在Javascript中創建交互式內核密度估計并使用Highcharts庫繪制結果。
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關鏈接:
Highcharts是一款純JavaScript編寫的圖表庫,為你的Web網站、Web應用程序提供直觀、交互式圖表。當前支持折線、曲線、區域、區域曲線圖、柱形圖、條形圖、餅圖、散點圖、角度測量圖、區域排列圖、區域曲線排列圖、柱形排列圖、極坐標圖等幾十種圖表類型。
內核密度估計是一種有用的統計方法,用于估計隨機變量分布的總體形狀。換句話說,核密度估計(也稱為KDE)可幫助我們“平滑”和探索不遵循任何典型概率密度分布(例如正態分布,二項式分布等)的數據。
在本教程中,我們將向您展示如何在Javascript中創建交互式內核密度估計并使用Highcharts庫繪制結果。
讓我們首先探索KDE圖;然后我們將深入研究代碼。
下面的演示顯示了隨機數據集的高斯核密度估計:
基本上,對于每個紅色數據點,我們用橙色繪制一個高斯核函數,然后將所有核函數求和在一起,以藍色創建密度估計值(請參見demo):
現在,您對內核密度估計的外觀有了一個想法,讓我們看一下其背后的代碼。
代碼中有四個主要步驟:
以下代碼表示高斯內核函數:
function GaussKDE(xi, x) { return (1 / Math.sqrt(2 * Math.PI)) * Math.exp(Math.pow(xi - x, 2) / -2); }其中x表示主要數據(觀測值),xi表示繪制內核的范圍和密度估計函數。在我們的情況下,xi范圍是88到107,以確保覆蓋93到102的觀測數據范圍。
密度估算點
以下循環使用GaussKDE()數組表示的函數和范圍創建密度估計點
xiData:
//Create the density estimate
for (i = 0; i < xiData.length; i++) {
let temp = 0;
kernel.push([]);
kernel[i].push(new Array(dataSource.length));
for (j = 0; j < dataSource.length; j++) {
temp = temp + GaussKDE(xiData[i], dataSource[j]);
kernel[i][j] = GaussKDE(xiData[i], dataSource[j]);
}
data.push([xiData[i], (1 / N) * temp]);
}
內核點
僅當您想要顯示內核點(橙色圖表)時才需要執行此步驟。否則,您已經對密度估算步驟很滿意。這是處理每個內核的數據點的代碼:
//Create the kernels for (i = 0; i < dataSource.length; i++) { kernelChart.push([]); kernelChart[i].push(new Array(kernel.length)); for (j = 0; j < kernel.length; j++) { kernelChart[i].push([xiData[j], (1 / N) * kernel[j][i]]); } }基本上,此循環僅是將范圍添加xiData到kernel在密度估計步驟中已處理的每個陣列。
繪制點
處理完所有數據點后,就可以使用Highcharts渲染系列了。密度估計和核是樣條圖類型,而觀測值則繪制為散點圖:
Highcharts.chart("container", { chart: { type: "spline", animation: true }, title: { text: "Gaussian Kernel Density Estimation (KDE)" }, yAxis: { title: { text: null } }, tooltip: { valueDecimals: 3 }, plotOptions: { series: { marker: { enabled: false }, dashStyle: "shortdot", color: "#ff8d1e", pointStart: xiData[0], animation: { duration: animationTime } } }, series: [ { type: "scatter", name: "Observation", marker: { enabled: true, radius: 5, fillColor: "#ff1e1f" }, data: dataPoint, tooltip: { headerFormat: "{series.name}:", pointFormat: "<b>{point.x}</b>" }, zIndex: 9 }, { name: "KDE", dashStyle: "solid", lineWidth: 2, color: "#1E90FF", data: data }, { name: "k(" + dataSource[0] + ")", data: kernelChart[0] },... ] });現在,您準備使用核密度估計圖的功能來探索自己的數據。
本站文章除注明轉載外,均為本站原創或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn
文章轉載自: