0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Arc ダイアグラムを使って天然ガスの米国からの輸出入を可視化 ‐ Yellowfin と amCharts の連携

Posted at

はじめに

amCharts と連携して、Arc ダイアグラムを作成します。サンキーダイアグラムコードダイアグラムと同様に、モノや情報の流れを可視化する目的に用いられるチャートです。
NaturalGas.gif

1. 事前準備

1-1. 参照データ

米国における、2024 年天然ガス輸出入データを取り扱います。U.S. Energy Information Administration のデータをもとに、以下のテーブルを作成しました。volume の単位は百万立方フィート (1ft : 30.48cm) だそうですが、この数値を聞いても私は全くピンときません。

importexport transport country volume
import Pipeline Canada 3,127,280
import Pipeline Mexico 452
import LNG Trinidad and Tobago 10,444
import LNG Norway 5,037
import LNG Canada 1,000
export Pipeline Mexico 2,343,562
export Pipeline Canada 996,022
export LNG Netherlands 463,769
export LNG France 354,824
export LNG Japan 335,944
export LNG South Korea 289,232
export LNG India 256,045
export LNG Mexico 8,597
  • 2024 年の米国への輸入は、カナダ、トリニダード・トバゴ、メキシコ、ノルウェーの 4 ヶ国からのみでした
  • 一方、輸出先は 46 ヶ国に上るため、輸出量上位 8 ヶ国に絞りました。輸出先上位 8 ヶ国の中には日本も含まれます
  • 陸続きのカナダと米国、メキシコと米国の間には、天然ガスのパイプラインが通っており、特にカナダからは、大量の天然ガスがパイプラインで運ばれてきています
  • それ以外の国との輸出入は、液化天然ガス (LNG) として運ばれていました

1-2. ビューの作成まで

  • 以前の記事 を参考に、『1-2. ビューの作成』 までの作業を実施します

2. グラフの作成

  • 準備が整ったら、グラフの作成に手順を進めます。新規でレポートを作成し、以下の手順に従ってグラフを作成します

2-1. [データ] ステップ

  • importexport、transport、country、volume をテーブルに配置します
    image.png

  • フィルターに transportation を配置します
    image.png

2-2. [グラフ] ステップ

  • [グラフ] ステップに進み、画面右側 [グラフの選択] から [JavaScriptグラフ] を選択します
    image.png
JavaScriptタブ
  • 雛形を全て削除し、以下のコードに置き換えます。コードの処理の内容は後ほど説明します
全容
generateChart = function(options) {
   var $chartDrawDiv = $(options.divSelector);
   var processedData = processData(options.dataset.data);
   doDrawing($chartDrawDiv, processedData);
},

processData = function(dataset) {
    var ds = [];
    for (i=0;i<dataset.transport.length;i++){
        if(dataset.importexport[i].raw_data == 'import'){
            ds.push({
                from: dataset.country[i].raw_data,
                to: 'US',
                value: dataset.volume[i].raw_data,

            });
        } else if(dataset.importexport[i].raw_data == 'export'){
            ds.push({
                from: 'US',
                to: dataset.country[i].raw_data,
                value: dataset.volume[i].raw_data,
            });
        }
    }
    console.log(JSON.stringify(ds));
    return ds;
},

doDrawing = function($chartDrawDiv, ds, obj) {
    require(['https://cdn.amcharts.com/lib/5/index.js',
            'https://cdn.amcharts.com/lib/5/flow.js',
            'https://cdn.amcharts.com/lib/5/themes/Animated.js'], function(){
        var $canvas = $('<div id="chartdiv"></div>');
        $chartDrawDiv.append($canvas);
        
        am5.ready(function() {

            // ルートエレメント設定
            var root = am5.Root.new("chartdiv");
            
            // テーマ設定
            root.setThemes([
              am5themes_Animated.new(root)
            ]);
            
            // シリーズ設定
            var series = root.container.children.push(am5flow.ArcDiagram.new(root, {
              sourceIdField: "from",
              targetIdField: "to",
              valueField: "value",
              orientation: "vertical"
            }));
            
            // ラベル設定
            series.nodes.labels.template.setAll({
              fontSize: "0.85em",
              paddingLeft: 20,
              paddingRight: 20,
              width: 160
            });
            
            // アニメーションの設定
            series.bullets.push(function(_root, _series, dataItem) {
              var bullet = am5.Bullet.new(root, {
                locationY: Math.random(),
                sprite: am5.Circle.new(root, {
                  radius: 5,
                  fill: dataItem.get("source").get("fill")
                })
              });
            
              bullet.animate({
                key: "locationY",
                to: 1,
                from: 0,
                duration: Math.random() * 1000 + 2000,
                loops: Infinity
              });
            
              return bullet;
            });
            
            
            // データセット受渡し
            series.data.setAll(
                ds
            );
            
            // ロード
            series.appear(1000, 100);
        });
})};

コード

generateChart
generateChart
generateChart = function(options) {
   var $chartDrawDiv = $(options.divSelector);
   var processedData = processData(options.dataset.data);
   doDrawing($chartDrawDiv, processedData);
},
  • JavaScript グラフの処理において、最初に呼び出されるのが generateChart = function(options) です
  • [データ] ステップでテーブルに追加した情報が options に格納されて、メソッドに受け渡されます
  • processData でデータ処理を行うメソッドを呼び出し、doDrawingで描画するメソッドをそれぞれ呼び出しています。各メソッドで実行する具体的な処理は後述します
processData
  • 輸出 (from U.S.) と輸入 (to U.S.) に関する、以下のデータを生成する必要があります
ds
[
  {"from":"Canada","to":"US","value":3127280},
  {"from":"US","to":"Mexico","value":2343562},
  
]
  • そのための処理が以下です
processData2023
processData = function(dataset) {
    var ds = [];
    for (i=0;i<dataset.transport.length;i++){
        if(dataset.importexport[i].raw_data == 'import'){
            ds.push({
                from: dataset.country[i].raw_data,
                to: 'US',
                value: dataset.volume[i].raw_data,

            });
        } else if(dataset.importexport[i].raw_data == 'export'){
            ds.push({
                from: 'US',
                to: dataset.country[i].raw_data,
                value: dataset.volume[i].raw_data,
            });
        }
    }
    console.log(JSON.stringify(ds));
    return ds;
},
  • 生成されるデータの中身を確認したい場合は、console.log(JSON.stringify(ds)) で、データをコンソールに出力しておくと便利です
CSS
  • CSS タブに下記を記述します。後ほど、定義した id を JavaScript から呼び出します
css
#chartdiv{
    height: 600px;
    width: 650px;
}
doDrawing
  • チャートの描画に関わる処理を記述します
doDrawing
doDrawing = function($chartDrawDiv, ds, obj) {
    require(['https://cdn.amcharts.com/lib/5/index.js','https://cdn.amcharts.com/lib/5/flow.js','https://cdn.amcharts.com/lib/5/themes/Animated.js'], function(){
        var $canvas = $('<div id="chartdiv"></div>');
        $chartDrawDiv.append($canvas);
        
        am5.ready(function() {

            // ルートエレメント設定
            var root = am5.Root.new("chartdiv");
            
            // テーマ設定
            root.setThemes([
              am5themes_Animated.new(root)
            ]);
            
            // シリーズ設定
            var series = root.container.children.push(am5flow.ArcDiagram.new(root, {
              sourceIdField: "from",
              targetIdField: "to",
              valueField: "value",
              orientation: "vertical"
            }));
            
            // ラベル設定
            series.nodes.labels.template.setAll({
              fontSize: "0.85em",
              paddingLeft: 20,
              paddingRight: 20,
              width: 160
            });
            
            // アニメーションの設定
            series.bullets.push(function(_root, _series, dataItem) {
              var bullet = am5.Bullet.new(root, {
                locationY: Math.random(),
                sprite: am5.Circle.new(root, {
                  radius: 5,
                  fill: dataItem.get("source").get("fill")
                })
              });
            
              bullet.animate({
                key: "locationY",
                to: 1,
                from: 0,
                duration: Math.random() * 1000 + 2000,
                loops: Infinity
              });
            
              return bullet;
            });
            
            // データセット受渡し
            series.data.setAll(
                ds
            );
            
            // ロード
            series.appear(1000, 100);
    });
})};
  • require[] の中で、JavaScriptライブラリの場所を指定します。上記の例では CDN のアドレスを指定していますが、JS ライブラリをダウンロードして利用することも可能です
  • var root = am5.Root.new("chartdiv") で、CSS で定義した id を指定します
  • それ以降の処理では、テーマシリーズラベルアニメーションを設定した後、データセットを受け渡して、最後にチャートをロードしています。それぞれの設定箇所は、コメントアウト行をご確認下さい

3. 動作確認

  • チャートを表示してみると、2024 年の年間の輸出入の流れと量が確認できます

  • 丸の大きさが量、Arc が流れを示します。両国間にパイプラインが通っているカナダとメキシコとのやり取りが、他の国々と比較して大きいことが分かります
    All.gif

  • フィルターで LNG に絞り込みをかけます。欧州やアジアには、LNG で輸出されていることが分かります。日本にもたくさん輸出されていますね
    LNG.gif

最後に

モノや情報の流れを把握する時、やはり動きのあるチャートで表現すると分かりやすいですね。
サンキーダイアグラムコードダイアグラムと比較すると、一般的な認知度が低い感じはしますが、Arc ダイアグラムも結構データの流れを分かりやすく表現すると感じました。あと、なにも操作しなくてもちょこまかと動いてくれるし。

では皆様、良いデータ分析を!

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?