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.5k
【乗り鉄】元駅員が運賃計算プログラムを作ってみた話
MIERUNE
PRO
October 31, 2023
Tweet
Share
More Decks by MIERUNE
See All by MIERUNE
Facade Patternで磨く、コードの可読性と分解力 / MIERUNE BBQ #13
mierune
PRO
0
65
ハザードマップゲームの作り方〜ハザード情報をゲームのパラメーターに落とし込む〜 / FOSS4G 2024 Japan
mierune
PRO
0
160
MIERUNEとQGIS、そしてQGIS事業のご紹介 / FOSS4G 2024 Japan
mierune
PRO
0
150
QGISで実現するもっと分かりやすい森林ゾーニング / FOSS4G 2024 Japan
mierune
PRO
0
140
君はこの色の違いを見ることができるか / MIERUNE BBQ #12
mierune
PRO
0
180
クーダでハニワ / MIERUNE BBQ #12
mierune
PRO
0
140
位置情報とオープンソースがやりたくてMIERUNEに転職した話 〜経歴、事例紹介、GISへのいざない〜 / MIERUNE JCT - Tokyo 2024
mierune
PRO
0
890
クロージング / MIERUNE JCT - Tokyo 2024
mierune
PRO
0
670
オープニング / MIERUNE JCT - Tokyo 2024
mierune
PRO
1
760
Featured
See All Featured
Understanding Cognitive Biases in Performance Measurement
bluesmoon
27
1.5k
The Straight Up "How To Draw Better" Workshop
denniskardys
232
140k
Done Done
chrislema
182
16k
Into the Great Unknown - MozCon
thekraken
34
1.5k
Statistics for Hackers
jakevdp
796
220k
BBQ
matthewcrist
85
9.4k
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
28
9.2k
Code Reviewing Like a Champion
maltzj
521
39k
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
1
120
The MySQL Ecosystem @ GitHub 2015
samlambert
250
12k
RailsConf 2023
tenderlove
29
950
Making Projects Easy
brettharned
116
6k
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北海道・四国・九州の路線の割増運賃制度なども今後は駅(路線)に
メタデータを実装させて持たせたいです
© 地理院地図 全国最新写真(シームレス) 乞うご期待