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
sapi_kawahara
March 23, 2018
Business
0
210
オッサンの話を聞け!!いにしえの開発話!!
俺の話を聞け!!LT大会 in Tokyoの発表資料です。
https://orehanatokyo.connpass.com/event/82057/
sapi_kawahara
March 23, 2018
Tweet
Share
More Decks by sapi_kawahara
See All by sapi_kawahara
コマンドラインを見直そう(1995年からタイムリープ)
sapi_kawahara
0
630
今から始める8bits CPU アセンブラ言語
sapi_kawahara
0
980
執筆テーマの決め方
sapi_kawahara
1
380
LTの禁じ手
sapi_kawahara
1
1.2k
||とorの違いは登壇して解決した
sapi_kawahara
0
370
Macintosh talk / Macintoshの話
sapi_kawahara
0
220
混合接種してみた / Mixed inoculation
sapi_kawahara
0
170
安くて美味い日本酒 / Great wholesale market
sapi_kawahara
0
420
オフラインもし逢えたなら素敵だね / It would be nice to meet you offline.
sapi_kawahara
0
470
Other Decks in Business
See All in Business
「発信の依頼」が採用広報活動の立ち上げに効くかもしれない
subroh0508
1
150
会社紹介資料
gatechnologies
2
140k
「回復の場」としてのコミュニティ
emi0726
0
200
「2025年のAI」と「2026年のAI」
masayamoriofficial
1
640
akippa株式会社|Company Deck
akippa
0
520
株式会社メディアドゥ 採用ピッチ資料
mediado
0
930
爆速入力が可能に! つよ〜い味方 Aqua Voice
panchaaan_2
0
210
エンジニアよ痛みを知れ
nobuoooo
0
220
(6枚)プレゼンの技法 ピラミッドストラクチャー PREP法 SDS法 STAR法
nyattx
PRO
2
320
変化を抱擁するシステムの作り方〜「人が増えても速くならない」より
kuranuki
8
2.9k
株式会社Domuz会社紹介資料(採用)
kimpachi_d
0
48k
【素人向け生成AI入門】保健師のチカラにAIをプラス!
minamototeruya
0
200
Featured
See All Featured
Getting science done with accelerated Python computing platforms
jacobtomlinson
0
89
Mobile First: as difficult as doing things right
swwweet
225
10k
AI Search: Implications for SEO and How to Move Forward - #ShenzhenSEOConference
aleyda
1
1.1k
The Language of Interfaces
destraynor
162
26k
Reflections from 52 weeks, 52 projects
jeffersonlam
355
21k
Tips & Tricks on How to Get Your First Job In Tech
honzajavorek
0
410
The untapped power of vector embeddings
frankvandijk
1
1.5k
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.5k
Ethics towards AI in product and experience design
skipperchong
1
160
More Than Pixels: Becoming A User Experience Designer
marktimemedia
2
280
エンジニアに許された特別な時間の終わり
watany
106
220k
BBQ
matthewcrist
89
9.9k
Transcript
オッサンの話を聞け!! いにしえの開発話!! カワハラ ヒデアキ
自己紹介 川原 英明(0x31歳) Twitter @sapi_kawahara Facebook kawahara.hideaki.0204 働いて、来月でいよいよ30年目に突入です、この激動の中で、多くの経験をしてきました。 Web系の仕事では、Perlから始まり、Java、PHP、Pythonなどを駆使し、現在、小さな会社で契 約社員をやり、とある所で仕事してます。
いにしえの開発? みなさんは、 何を思い浮かべますか?
こんなのですかね?
これかな?
唐突ですが、オッサンあるある! 1. フロッピーディスクの話をする。 2. カセットテープの話をする。 3. ハードディスクがMBしか無い時代の話をする。 4. メモリーがMBしか無い時代の話をする。 5.
総称してPC-9801の話をする。 6. インターネットに接続する「モデム」の話をする。 7. パソコン通信時代の話をする。 8. テレホーダイの話をする。 9. 技術系の話では16進数の話をする。 10. DOS(Windowsが登場する前のOS)の話をする。
それを聞いて面白 く無いですよね?
だから、面白くないので、 オッサンあるあるの話はしま せん。
じゃあ? どんな「いにしえの開発話」を するのか?その前に!
自己紹介に追加します Web系の仕事をする前は、コンシューマーゲームのアプリ開発をしていました。 アセンブラでの開発は、6502(ファミコン)、GB80(ゲームボーイ)、Hu6502(PCエンジン)、65816 (スーパーファミコン)、68000(メガドライブ)、SuperH(セガサターン)、R3000(プレイステーショ ン)でしてました。 C言語での開発は、セガサターン、プレイステーションでしてました。 C++での開発は、プレイステーション2でしてました。
と言うことで、 コンシューマーゲームの 開発話をします。
アジェンダ 若い人が多いので、プレイステーションの話をします。 1. 開発側から見た環境についての説明です。 2. バグ多いぞ!プレイステーション! 3. 倍速CDで快適な読み込み、そんなもん夢です。 4. モーションJPEGの悪夢。
プレイステーション開発環境 1. DOS/V機で、OSはWindows95です。 2. IDEは、Visual Cを使ってました。 3. 開発マシンは、ISAバスを2本使います、CD-ROMエミュレーターを合わせると、ISAバスは3 本使います、お値段150万円です。 4.
C言語は、意外と思われますが、gccです。 5. ライブラリーは、ソニー提供です。 6. 基本的なところから、パッドの入力、CDコントロール、音楽再生、動画、2D画像ライブラリー、 3D画像ライブラリー、ほとんどをC言語から呼び出すことが出来ました。 7. ライブラリーマニュアルは、辞書並みに暑くて、タオルを巻いて枕にしてました。
バグ多いぞ!プレイステーション! 1. 盛りだくさんのライブラリー、当然ながらバグも多かったです。 2. バージョン2になるまでは、全てのライブラリーにバグが有ると言っても過言では無いです。 3. 小さなバグでは、音声ボリュームで、音量を下げるというプログラミングすると、音量が上が ると言うシャレみたいなバグまで有りました。 4. 3D画像ライブラリーでは、テクスチャーの裏面とか表示しなくて良いところも、表示するとか
処理速度的にクソな実装が有りました。 5. 一番インパクトが有るバグは、glibcにバグが有りました、なぜインパクトが有るのかと言うと、 glibcはプレイステーション本体のBIOS ROMに焼かれているからです。 6. Glibcのバグで、mfreeが行えないと言うバグは、最初は冗談かと思いました。(Java開発的 に言うと、GCしてもフリーメモリーが増えません)
倍速CDで快適な読み込み、そんなもん 夢です 1. CD−ROMの仕様で最大の欠点は線速度一定(CLV)です、常にCD-ROMの回転速度を変え るためキュルキュル音が鳴り、読み込める速度になるまで、アプリは待たないといけない。 2. セガサターンのGD-ROMはCD-ROMを容量増やして角速度一定(CAV)にしたのでよ読み込 みだけは早かったです。 3. 基本的なCD-ROMのフォーマットで作られておりFATも有り、PCエンジンのCD-ROMのよう
にFATが無い構造よりは、作りやすかったのです。 4. しかし、バグが多いプレイステーション!ここにも罠が有りました!
FATをキャッシュしない! FAT: FILE ALLOCATION TABLE
FATにキャッシュが無いと、どうなる か? 1. アプリがファイル名を指定して、ファイルをオープンする。 2. プレイステーションが、FATを読み見に行く。キュルキュル! 3. アプリがオープンしたファイルのデータを読む。キュルキュル! 4. アプリがファイルをクローズする。
5. アプリが別のファイルをオープンする。 6. プレイステーションがFATを読みに行く。キュルキュル! 7. アプリがオープンしたファイルのデータを読む。キュルキュル! 8. アプリがファイルをクローズする。 9. 以下、ファイルを読みたびに、これの繰り返しです。
この罠の対処方法 1. 初期アプリは、対応してないのが多いので、画面切り替え時、遅くなかったですか?原因は、 これです。 2. 自分は、しょうがないので、独自のFATを持ち、独自のファイル関数を作成して対応しました。 3. 多くの会社で、このような対処をしていたと聞いていますが、ソニーさんは最後まで、この問 題は仕様として対処はしないまま、プレイステーションの歴史が閉じられました。
モーションJPEGの悪夢 1. プレイステーションの動画はモーションJPEGです。 2. 簡単に説明すると、JPEG画像を高速に切り替える、それだけの仕様です。 3. 読み取り速度は、倍速なので、1秒間で0.3MB、300,000B / 30 =
10,000B が一コマに使え ます。 4. ちなみに、今のスマホで写真撮影すると、2MBぐらいです。 5. 320 x 240 の解像度と言っても、かなりタイトなサイズです。 6. 更に、ここにも罠が有りました!
ソニー提供のツールが 使えない!
ソニーは、高圧縮ツール 1. ソニーのツールは、1コマを10,000Bに収めるため、一番圧縮しにくい画像を基準に、圧縮率 が決めらていました。 2. つまり、静止画でも、物凄い高圧縮されます、そのためモアレがひどかったです。 3. 自分たちは、解析の結果、プレイステーションの再生側の圧縮パラメータが可変であること に気づきました。 4.
画像にあった圧縮パラメータで圧縮するツールを作成しました! 5. でも、ツールを作ったのは良いのですが「画像にあった?」と言う部分は、どうしたのか?
時は1996年の春
20世紀の話 1. 1996年当時、今から20年以上の前の話です。 2. 当然ながら、AIとか機械学習なんていう時代の前です。 3. 一応、努力して画像判定などはやりましたが、半分ぐらい、うまくいくぐらいでした。 4. しかも、この当時は、アナログキャプチャーの時代で、どうしても取り込みノイズが出てしま い、これがモアレの原因になりました。
5. そんな時、大人の事情で発売が半年伸びました。 6. せっかくだから、動画をもっと綺麗にしようということなりました。 7. しかし、自分は、既に別のプロジェクトの作業なので、画像判定は、そのままで、どうしても 綺麗にならないところを!
人海戦術で対処!
人海戦術のレシピ 1. 画像1枚1枚を見て、キャプチャーノイズを手作業で除去! 2. 作成された動画と比較して、モアレが出ているところも、手作業で平坦な色に塗り替える! 3. 画像1枚ごと、圧縮後のサイズが最大10,000Bになるように、圧縮パラメータを変更して圧縮 を行う。 4. 1秒30枚なので、3分動画だと、3
x 60 x 30 = 5,400枚 を人海戦術でクリアしました。 5. 自分は、土日に手伝ったなー。
まとめ 1. こんな苦労をして、ゲームのアプリは世の中に出てます。 2. プレイステーション時代は、多人数で開発してたので、人海戦術とか使えました。 3. 今は、自分はゲームは作っておりませんが、恐らく今も変わらないでしょう。