近似曲線は、特定のデータ系列の勾配(または傾向)を示す補助線であり、最適曲線とも呼ばれます。
近似曲線は、現在のデータに基づいて将来の値を予測できるため、データを分析するときに役立ちます。
線形、指数、対数、多項式、累乗、移動平均など、チャート用に6種類の近似曲線を作成できます。
線形: データ系列の値が一定の比率で変更されてことを示し、データの将来の近似値を提供する最適直線です。
指数: データ値の変化率が急速に増加または減少した後、横ばい状態になる場合に適しています。
対数: データ値の変化率が急速に増加または減少した後、横ばい状態になる場合に最適な曲線です。
多項式: データが変動するときに使用される曲線です。多項式の次数プロパティに基づき、大きなデータセットの損益を分析する場合に便利です。
累乗: 一定の割合で増加する計測値を比較するのに使われる曲線です。
移動平均: 近似曲線の変動を減らしてより滑らかなパターンで表示させる場合によく使用されます。指定されている期間数の平均値を計算した傾向を表示する場合に使用されます。
チャートに近似曲線を追加する際、次のチャートの種類がサポートされています:
縦棒チャート
横棒チャート
折れ線チャート
散布図
面チャート
次のコードを使用して、近似曲線をカスタマイズできます:
カスタマイズ
order: 多項式の次数を指定します。 次数は2~6の範囲内の正の整数です。
intercept: 線形、指数、多項式の近似曲線の切片を指定します。
displayEquation および displayRSquared:近似曲線に方程式またはR-2乗値を使用するかどうかを指定します。
forward および backward: 前方捕外または後方捕外を指定します。
displayEquation、displayRSquared、forward、backwardは、線形、指数、対数、多項式、累乗をサポートします。
style: 色、幅、破線など、近似曲線のスタイルを指定します。
name: 近似曲線の名前を指定します。 名前が指定されていない場合は、組み込みの名前が使用されます。
Period: 移動平均の近似曲線の期間を指定します。期間は2からデータセットカウント-1の整数の範囲です。
var advData = [
['Advertising', 'Items sold'],
[28, 17],
[34, 19],
[41, 18],
[47, 20],
[52, 24],
[59, 26],
[65, 29],
[72, 31],
[80, 34],
[87, 39],
[94, 40],
[102, 42],
];
var salesData = [
['', 'Sales'],
['Jan', 54],
['Feb', 60],
['Mar', 86],
['Apr', 92],
['May', 112],
['Jun', 157],
['Jul', 202],
['Aug', 195],
['Sep', 187],
['Oct', 194],
['Nov', 238],
['Dec', 289],
];
window.onload = function () {
var spread = new GC.Spread.Sheets.Workbook(document.getElementById("ss"), { sheetCount: 2 });
initSheet1(spread);
initSheet2(spread);
};
function initSheet1(spread) {
var sheet1 = spread.getSheet(0);
sheet1.name('Basic');
sheet1.setArray(0, 0, advData);
sheet1.setArray(18, 0, salesData);
for (var i = 0; i < 12; i ++) {
sheet1.getCell(i + 1, 0).formatter('$#,##0');
}
// Choose a suitable trendline type from GC.Spread.Sheets.Charts.TrendlineType to fit your chart
var chart1 = sheet1.charts.add("chart1", GC.Spread.Sheets.Charts.ChartType.xyScatter, 130, 5, 500, 350, "A1:B13", GC.Spread.Sheets.Charts.RowCol.columns);
var axes = chart1.axes();
axes.primaryValue.title.text = 'Items sold';
axes.primaryCategory.title.text = 'Advertising';
axes.primaryCategory.majorGridLine.visible = true;
axes.primaryCategory.majorUnit = 10;
chart1.axes(axes);
var targetSeriesIndex = 0;
var targetSeries = chart1.series().get(targetSeriesIndex);
var linearTrendline = {
type: GC.Spread.Sheets.Charts.TrendlineType.linear,
style: {
color: 'red',
width: 2
}
};
targetSeries.trendlines = [ linearTrendline ];
chart1.series().set(targetSeriesIndex, targetSeries);
var chart2 = sheet1.charts.add("chart2", GC.Spread.Sheets.Charts.ChartType.columnClustered, 130, 360, 500, 350, "A19:B31", GC.Spread.Sheets.Charts.RowCol.columns);
var targetSeriesIndex = 0;
var targetSeries = chart2.series().get(targetSeriesIndex);
var exponentialTrendline = {
type: GC.Spread.Sheets.Charts.TrendlineType.exponential,
style: {
color: 'orange',
width: 2,
dashStyle: GC.Spread.Sheets.Charts.LineDashStyle.dash
}
};
targetSeries.trendlines = [ exponentialTrendline ];
chart2.series().set(targetSeriesIndex, targetSeries);
}
function initSheet2(spread) {
// More settings
var sheet2 = spread.getSheet(1);
sheet2.name('Advance');
sheet2.setArray(0, 0, advData);
sheet2.setArray(18, 0, salesData);
for (var i = 0; i < 12; i ++) {
sheet2.getCell(i + 1, 0).formatter('$#,##0');
}
// Change the order(the highest power for the independent variable) of polynomial trendline to adjust R-squared value
// Also you could show the equation and R-squared value in chart area if you want
var chart3 = sheet2.charts.add("chart3", GC.Spread.Sheets.Charts.ChartType.xyScatter, 130, 5, 500, 350, "A1:B13", GC.Spread.Sheets.Charts.RowCol.columns);
var axes = chart3.axes();
axes.primaryValue.title.text = 'Items sold';
axes.primaryCategory.title.text = 'Advertising';
axes.primaryCategory.majorGridLine.visible = true;
axes.primaryCategory.majorUnit = 10;
chart3.axes(axes);
var targetSeriesIndex = 0;
var targetSeries = chart3.series().get(targetSeriesIndex);
var polynomialTrendline = {
type: GC.Spread.Sheets.Charts.TrendlineType.polynomial,
order: 4,
displayEquation: true,
displayRSquared: true,
style: {
color: 'red',
width: 2
}
};
targetSeries.trendlines = [ polynomialTrendline ];
chart3.series().set(targetSeriesIndex, targetSeries);
// Set a value in the Forward and Backward fields to project your data into the future.
var chart4 = sheet2.charts.add("chart4", GC.Spread.Sheets.Charts.ChartType.columnClustered, 130, 360, 500, 350, "A19:B31", GC.Spread.Sheets.Charts.RowCol.columns);
var targetSeriesIndex = 0;
var targetSeries = chart4.series().get(targetSeriesIndex);
var exponentialTrendline = {
type: GC.Spread.Sheets.Charts.TrendlineType.exponential,
forward: 3,
style: {
color: 'orange',
width: 2,
dashStyle: GC.Spread.Sheets.Charts.LineDashStyle.dash
}
};
targetSeries.trendlines = [ exponentialTrendline ];
chart4.series().set(targetSeriesIndex, targetSeries);
}
<!doctype html>
<html style="height:100%;font-size:14px;">
<head>
<meta name="spreadjs culture" content="ja-jp" />
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<link rel="stylesheet" type="text/css" href="$DEMOROOT$/ja/purejs/node_modules/@mescius/spread-sheets/styles/gc.spread.sheets.excel2013white.css">
<script src="$DEMOROOT$/ja/purejs/node_modules/@mescius/spread-sheets/dist/gc.spread.sheets.all.min.js" type="text/javascript"></script>
<script src="$DEMOROOT$/ja/purejs/node_modules/@mescius/spread-sheets-shapes/dist/gc.spread.sheets.shapes.min.js" type="text/javascript"></script>
<script src="$DEMOROOT$/ja/purejs/node_modules/@mescius/spread-sheets-charts/dist/gc.spread.sheets.charts.min.js" type="text/javascript"></script>
<script src="$DEMOROOT$/ja/purejs/node_modules/@mescius/spread-sheets-resources-ja/dist/gc.spread.sheets.resources.ja.min.js" type="text/javascript"></script>
<script src="$DEMOROOT$/spread/source/js/license.js" type="text/javascript"></script>
<script src="app.js" type="text/javascript"></script>
<link rel="stylesheet" type="text/css" href="styles.css">
</head>
<body>
<div class="sample-tutorial">
<div class="sample-tutorial">
<div id="ss" class="sample-spreadsheets"></div>
</div>
</div>
</body>
</html>
.sample-tutorial {
position: relative;
height: 100%;
overflow: hidden;
}
.sample-spreadsheets {
width: 100% ;
height: 100%;
overflow: hidden;
float: left;
}
body {
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
}