Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
【乗り鉄】元駅員が運賃計算プログラムを作ってみた話
Search
MIERUNE
PRO
October 31, 2023
0
1.3k
【乗り鉄】元駅員が運賃計算プログラムを作ってみた話
MIERUNE
PRO
October 31, 2023
Tweet
Share
More Decks by MIERUNE
See All by MIERUNE
君はこの色の違いを見ることができるか / MIERUNE BBQ #12
mierune
PRO
0
33
クーダでハニワ / MIERUNE BBQ #12
mierune
PRO
0
12
位置情報とオープンソースがやりたくてMIERUNEに転職した話 〜経歴、事例紹介、GISへのいざない〜 / MIERUNE JCT - Tokyo 2024
mierune
PRO
0
630
クロージング / MIERUNE JCT - Tokyo 2024
mierune
PRO
0
470
オープニング / MIERUNE JCT - Tokyo 2024
mierune
PRO
1
540
QGISで簡単にDEMを可視化 - ElevationTile4JP & QuickDEM4JP プラグインのアップデート / FOSS4G TOKAI 2024
mierune
PRO
0
250
ゼロから始める点群可視化 feat.QGIS
mierune
PRO
0
240
MIERUNE BBQにおけるユーザー中心設計()
mierune
PRO
1
710
MIERUNE BBQ #10 in 札幌時計台 オープニング・クロージング
mierune
PRO
0
600
Featured
See All Featured
What’s in a name? Adding method to the madness
productmarketing
PRO
22
3.1k
Designing for Performance
lara
604
68k
BBQ
matthewcrist
85
9.3k
Why You Should Never Use an ORM
jnunemaker
PRO
53
9k
A better future with KSS
kneath
237
17k
Done Done
chrislema
181
16k
Why Our Code Smells
bkeepers
PRO
334
57k
Building Applications with DynamoDB
mza
90
6k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
32
1.7k
Side Projects
sachag
452
42k
Docker and Python
trallard
40
3k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
159
15k
Transcript
【乗り鉄】元駅員が運賃計算 プログラムを作ってみた話 Yuen
©OpenStreetMap contributors 01 使った技術 02 JRの運賃制度 03 今回使ったコード 04 今後の予定 目次
©OpenStreetMap contributors 01 使った技術
© 地理院地図 全国最新写真(シームレス) 位置情報の会社ですが、 今回は位置情報を使いません
©Project PLATEAU / MLIT Japan 技術 •Python •networkx •運賃と営業距離についてはデータがないので、昔お下がりでいただい た時刻表を元に手入力しました
使った技術
©OpenStreetMap contributors 02 JRの運賃制度について
©Project PLATEAU / MLIT Japan 運賃制度 •当たり前ですが、距離に応じて、長く乗れば長く乗るほど高いです JRの運賃制度について 都会は駅が多いから適当でいいや
©Project PLATEAU / MLIT Japan 運賃制度 JRの運賃制度について 田舎の電車は誰も乗ってな いから、運賃を高くしたい 北海道は除雪費用がかかるから、
運賃を高くしたい
©Project PLATEAU / MLIT Japan 運賃制度 JRの運賃制度について •稚内-豊富(43.5km) 1,130円 •室蘭-白老(43.4km) 970円 •大阪-山科(48.3km) 860円
©OpenStreetMap contributors 03 運賃計算のプログラム化
©Project PLATEAU / MLIT Japan 運賃制度 •経路の計算もかなり複雑です 経路計算は複雑です
©Project PLATEAU / MLIT Japan 運賃制度 経路の計算 •経路計算のロジックとネットワークをシステムに導入する方法 ◦ 経路をシステムに導入する際に使ったのはネットワーク解析用ラ
イブラリのnetworkx
©Project PLATEAU / MLIT Japan 運賃制度 経路の計算 •networkxというライブラリでは点(Node)を線(Edge)で繋ぐこと で多数の点と線で構成されたネットワークを作成している
©Project PLATEAU / MLIT Japan 運賃制度 経路の計算 •Nodeではメタデータ(例:山手線内、札幌市内など)を持たせており、 Edgeにはメタデータ(例:路線名)と重みつけ(今回では距離)の属性 を付与しました
©Project PLATEAU / MLIT Japan 運賃制度 経路の計算 •路線の読み込みではひたすら紙の時刻表から駅名・路線名と駅間距離 をCSVファイルに移し、その後Networkxで駅の情報をNode、路線 情報をEdge形式で読み込みました
©Project PLATEAU / MLIT Japan 運賃制度 経路の計算
©Project PLATEAU / MLIT Japan 運賃制度 経路の計算 •そしてNetworkxでは読み込んだ駅と営業距離でひたすら最短距離 を計算しようとしていた dist
= nx.shortest_path_length(G, source=start, target=dest, weight="weight")
©Project PLATEAU / MLIT Japan 運賃制度 経路の計算 •駅と駅の間の最短距離を取得して、それとJRの運賃表と照合すること で、「駅と駅の距離を単純に計算した場合の運賃」を取得できました
©Project PLATEAU / MLIT Japan 運賃制度 経路の計算
©Project PLATEAU / MLIT Japan 運賃制度 経路の計算 •ネックになった「品川 - 熱海」
©Project PLATEAU / MLIT Japan 運賃制度 経路の計算 •結果的には条件分岐を改める形になってしまいました •具体的にはまずは「特定都区市内」の駅に入っているか判断し →
基準 駅で距離を計算 → 距離が200km (100km)を超えていない場合、 再度入力された駅で計算することに
©OpenStreetMap contributors 04 今後の予定
©Project PLATEAU / MLIT Japan 今後 今後の予定 •networkxがデフォルトで提供している方法を使えば、経路を指定し ての検索もできます •しかし、時間が足りないので、大都市近郊区間についての開発ができ
ませんでした •そして、実は今対応しているのは東海道本線と山陽本線だけです、、、
©Project PLATEAU / MLIT Japan 今後 今後の予定 •今後はいつか時間があれば対応している路線数を増やしてAPI化した いと思っています(やるとは言ってない) •JR北海道・四国・九州の路線の割増運賃制度なども今後は駅(路線)に
メタデータを実装させて持たせたいです
© 地理院地図 全国最新写真(シームレス) 乞うご期待