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
manifes2018_PDL.pdf
Search
MakKi
September 03, 2018
1
120
manifes2018_PDL.pdf
MakKi
September 03, 2018
Tweet
Share
More Decks by MakKi
See All by MakKi
標準ライブラリの動向とイテレータのパフォーマンス
makki_d
3
520
range over funcのエラー処理
makki_d
1
1.3k
GoとテストとインプロセスDB
makki_d
3
490
君は古の言語M4を知っているか (LT)
makki_d
0
320
型パラメータが使えるようになったのでLINQを実装してみた
makki_d
2
1.3k
mallocしただけでメモリが確保できるって本当ですか?
makki_d
0
190
ホットリロードツールの作り方
makki_d
0
1k
JavaプログラムをGoに移植するためのテクニック――継承と例外
makki_d
1
1.6k
JavaプログラムをGoに移植するためのテクニック――継承と例外
makki_d
4
4k
Featured
See All Featured
[RailsConf 2023] Rails as a piece of cake
palkan
52
4.9k
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
8
860
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
33
1.9k
Mobile First: as difficult as doing things right
swwweet
222
8.9k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
109
49k
4 Signs Your Business is Dying
shpigford
180
21k
Product Roadmaps are Hard
iamctodd
PRO
49
11k
GitHub's CSS Performance
jonrohan
1030
460k
Designing Experiences People Love
moore
138
23k
What's new in Ruby 2.0
geeforr
343
31k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
4
370
Embracing the Ebb and Flow
colly
84
4.5k
Transcript
PDL ― 移植駆動学習 KLab株式会社 牧内大輔
早速ですが質問です
何を考えますか?
今日のお話について • 移植駆動学習 • 機械学習のお話ではありません • 人間学習のお話です
移植駆動学習(PDL)とは Porting-Driven Learning. 何らかのプログラムを 別の言語に移植することにより そのプログラムと対象技術領域について 自然と学習することができる学習方法のこと。 ― Makiuchi, D.
(2018)
実例 移植対象:ZXing https://github.com/zxing/zxing • 1D/2Dバーコードリーダー ◦ QRコードやDataMatrix、各種バーコード • Javaによる実装 ◦ Androidでよく使われている
移植先:gozxing https://github.com/makiuchi-d/gozxing • Go言語に移植 • QRコード、UPC/EANバーコードを移植済み
学習前の私
学習後の私 BCH符号 JIS X 0510 ISO/IEC 18004 8つのマスクパターン GB2312 バージョン1〜40
ガロア拡大体 Alphanumeric Mode ReedSolomon符号 ISO-8859-1 構造的連接 þ(ソーン) AIM Inc. Position Pattern 拡張チャネル解釈 中华人民共和国国家标准 デンソーウェーブ
圧倒的成長!!
PDLの進め方
PDLの進め方 1. 学習したいプログラムを探す 2. そのコードを眺めながら 3. 移植先の言語に書き換えていく 4. 移植完了
PDLの進め方 1. 学習したいプログラムを探す 2. そのコードを眺めながら 3. 移植先の言語に書き換えていく 4. 移植完了 理解していなくてもできてしまう
これだけでは学習にならない
PDLに必要なもの
テスト!テスト!テスト!
カバレッジ ほぼ 100%
カバレッジ100%を目指す • テストケースがすべての分岐を網羅している ◦ 分岐1つ1つの意味まで理解する必要がある • エッジケースをひたすら考える ◦ 規格書などの資料と照らし合わせながら このようにしてコードの理解を深めていく
= 学習
学習以外の効果 テストをしっかり書くことで • 単純なミスを防げる ◦ 書き間違い ◦ 言語仕様の違いの考慮漏れ • 修正が楽になる
◦ あとから設計を直したいとき ◦ 動作が変わっていないことを保証できる つまり、一般的なテストの効果
テストケースを思いつかないとき • 手が進まないとモチベーションが低下 • 学習も止まってしまう そんなときは • 元のコードを動かしてみる • 入出力のペアを得る
• そのままテストケースにする
gozxingのカバレッジ • 8/22現在 97.92% 右図について • 円の階層=ディレクトリとファイル • 弧の長さ(割合)=行数 •
緑=カバレッジ100% ◦ 赤に近いほどカバレッジが低い オレンジの場所はReedSolomonDecoder まだ理解が不十分なことがわかる https://codecov.io/gh/makiuchi-d/gozxing
PDLまとめ
PDLまとめ 移植駆動学習(Porting-Driven Learning) 1. 学習したいプログラムを探す 2. そのコードを眺めながら 3. 移植先の言語に書き換えていく 4.
カバレッジ100%を目指してテストを書く 5. 移植完了 隅々まで理解することで学習できる
ぜひお試しください
おまけ
その他のメリット • 元コードのバグを見つけることがある • プロジェクトに報告、修正を提案(PR) • コントリビューターになれる!