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
History of WaterFall
Search
semiyashin
June 21, 2012
Technology
15
12k
History of WaterFall
20120621
semiyashin
June 21, 2012
Tweet
Share
More Decks by semiyashin
See All by semiyashin
Backlog Talk part1
semiyashin
0
81
Backlog Talk part2
semiyashin
0
120
sales_strategy
semiyashin
0
110
dancing_dev
semiyashin
0
73
develop_process
semiyashin
0
94
start_producer
semiyashin
0
210
eds_strategy
semiyashin
0
170
shibuyarb20130515
semiyashin
1
220
TokyoRUbyKaigi_10
semiyashin
0
250
Other Decks in Technology
See All in Technology
Goss: Faiss向けの新しい本番環境対応 Goバインディング #coefl_go_jp
bengo4com
1
1.4k
コスト削減の基本の「キ」~ コスト消費3大リソースへの対策 ~
smt7174
2
290
実践データベース設計 ①データベース設計概論
recruitengineers
PRO
4
1.8k
Kubernetes における cgroup v2 でのOut-Of-Memory 問題の解決
pfn
PRO
0
420
スプリントレトロスペクティブはチーム観察の宝庫? 〜チームの衝突レベルに合わせたアプローチ仮説!〜
electricsatie
1
130
AIとTDDによるNext.js「隙間ツール」開発の実践
makotot
6
790
Vault meets Kubernetes
mochizuki875
0
140
Preferred Networks (PFN) とLLM Post-Training チームの紹介 / 第4回 関東Kaggler会 スポンサーセッション
pfn
PRO
1
290
Nstockの一人目エンジニアが 3年間かけて向き合ってきた セキュリティのこととこれから〜あれから半年〜
yo41sawada
0
100
カミナシ社の『ID管理基盤』製品内製 - その意思決定背景と2年間の進化 #AWSUnicornDay / Kaminashi ID - The Big Whys
kaminashi
3
640
知られざるprops命名の慣習 アクション編
uhyo
11
2.8k
実運用で考える PGO
kworkdev
PRO
0
120
Featured
See All Featured
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
34
3.1k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.5k
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
51
5.6k
Navigating Team Friction
lara
189
15k
Balancing Empowerment & Direction
lara
3
600
How GitHub (no longer) Works
holman
315
140k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
252
21k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
29
1.9k
Embracing the Ebb and Flow
colly
87
4.8k
Designing for humans not robots
tammielis
253
25k
Large-scale JavaScript Application Architecture
addyosmani
512
110k
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.4k
Transcript
最近アジャイル界隈で よく聞く話
「自分の現場がウォーター フォールで全然ダメで それをアジャイルなら 変えられないかと思って」
いったい誰と戦って いるんだ・・・・・
ちょっと待て
「自分の現場がウォーター フォールで全然ダメで それをアジャイルなら 変えられないかと思って」
そもそも
ウォーターフォールって だめなの?
なんでそんなものを みんな使っているの?
というか ウォーターフォールって なに?
いつどこで 生まれたものなの?
ということで我々は ウォーターフォールの 起源に迫ってみることにした
None
History of WaterFall 瀬宮 新
ウォーターフォールだと 思われているもの
・よくある仕様変更 ・手戻りしない直列的な工程 ・大量の書類 ・絶対固定の納期と予算 →そしてデスマーチへ
本当の ウォーターフォール ってそもそもなに?
ウォーターフォールの起源 Winston.W.Royce Managing the Development of Large Software Systems という論文(5ページくらい)
分析 実装
要求 分析 設計 実装 運用 試験
2回実施せよ (プロトタイプ) テストを計画せよ (設計よりも前に) 顧客をまきこめ (反復的なチェック) Royceは言った(1)
当初のRoyce案では ウォーターフォールを 反復型開発として して提案していた
仕様変更があったら 費用/納期を追加しろ 仕様変更があったら もう一回やりなおせ Royceは言った(2)
つまり
ここさぁなんかイメージと 違うんだよね
すると
おかわり=反復的な開発
なるほどなるほど
それでは
どうしてこうなった
None
時は1980年代
・システム開発は大規模化 ・税金による予算化に 「おかわり」は不向き ・予算と納期の追加が続発 →「おかわり」しすぎ!
再発防止策が必要だな
ということで
DOD-STD-2167(1985.6) (文書をいっぱい作ろう!) DOD-STD-2167A(1988.2) (工程の反復の否定 ウォーターフォールは 「おかわり」禁止!)
反復型開発が否定され 直列的ウォーターフォール が生まれた
DOD-STD-2167A(1988.2) を真に受けると ・ウォーターフォール (絶対に「おかわり」禁止) ・ほかの開発手法 (大規模開発に不向き) の二択
そして滝は詰まり始めた
None
一方、日本では
1985. 日本電信電話 設立 1988. NTTデータ 設立 1990. バブル崩壊 (システム要員の外注化)
日本ではSIが発達し同時に 開発手法もアメリカから 輸入された
システム開発の普及 ・大規模システム = ウォーターフォール ・書類が山盛り ・「おかわり」禁止 がデファクトスタンダードに
None
輸入された経緯はわかった
日本では今でも ウォーターフォールが 炎上している
それではアメリカでは 炎上しなかったの?
None
もちろん大炎上したよ
大炎上する案件が複数発生
再発防止策が必要だな
DOD-STD-2167A(1988.2) ↓ MIL-STD-498(1994.12) (頻繁な顧客レビューの推奨) DOD 5000.2(2000) (反復型および スパイラル型を推奨)
開発は反復型重視へ 回帰した
さらに
XP 白本(1999) アジャイルマニフェスト (2001.2) (1993.のJacob Nielsen のUIテスト あたりをみても業界全体が 反復的開発と頻繁なFBに 傾いている)
反復型開発の復活
つまりダメな ウォーターフォールに 嵌り込んでいたのは・・ 日本だけ!
嵌っている・・首まで・・
つまりダメな ウォーターフォールに 嵌り込んでいたのは・・ 日本だけ!
これを知った時、私は
こう思いました
調達標準は反復型重視へ 回帰した
None
ではウォーターフォールは どうあるべき?
・プロトタイプを作る ・頻繁な顧客フィードバック ・反復的で機能追加型の開発 にシフトすべき
None
そもそも ウォーターフォール <<< <(壁)<<アジャイル なのか?
(一面の真実) 仕様変更が許容範囲に収まる場合 ウォーターフォールのほうが アジャイルよりも安いし早い 完全にアジャイルに進めると 対象やドメインモデルが複雑だと 破綻する可能性が高い
ではどちらを選択すべきか?
慣れた人に任せるべきだ (Martin Fawler)
None
では日本のソフトウェア開発は これからどうなる
・反復型ウォーターフォール ・アジャイル ・そのほか に分かれると思う 残念なウォーターフォールも残るだろう
None
ご清聴ありがとうございました