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
180
オッサンの話を聞け!!いにしえの開発話!!
俺の話を聞け!!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
執筆テーマの決め方
sapi_kawahara
1
180
LTの禁じ手
sapi_kawahara
1
810
||とorの違いは登壇して解決した
sapi_kawahara
0
270
Macintosh talk / Macintoshの話
sapi_kawahara
0
130
混合接種してみた / Mixed inoculation
sapi_kawahara
0
87
安くて美味い日本酒 / Great wholesale market
sapi_kawahara
0
290
オフラインもし逢えたなら素敵だね / It would be nice to meet you offline.
sapi_kawahara
0
320
カジュアル面談本の裏側を語る / Casual Information Book Inside story
sapi_kawahara
0
330
推し技術の紹介 / Introduction of pushing technology
sapi_kawahara
0
130
Other Decks in Business
See All in Business
VISASQ: ABOUT DEV TEAM
eikohashiba
1
14k
アジャイルトランスフォーメーションが現場にもたらす価値と超えるべきいくつかの壁/Agile transformation and some impediments
ikuodanaka
4
670
税理士法人チェスター_事務所紹介資料
mabhr
1
3.6k
三井物産のデジタル証券〜浅草・まちなか旅館〜徹底解説セミナースライド(20240408)
c0rp_mdm
0
1.8k
株式会社EventHub 会社紹介資料
eventhub
0
20k
ジンジニアのキャリア ~てぃーびーの場合~ / Tb's career
tbpgr
0
370
株式会社アトラエ|会社紹介資料 / Join us
atrae
11
370k
#CMC_Meetup コミュニティの主体がCSからマーケに変わって気づいた良さの違い
ktkn1129
0
220
タケウチグループRecruit
takeuchigroup
0
8.4k
エムスリーキャリア エンジニア採用資料 / M3C Engineer Guide
m3c
1
76k
第24回クラウド女子会 登壇資料
o2mami
1
1.4k
TOILETHON
takuro_nakajima
PRO
1
1.6k
Featured
See All Featured
Writing Fast Ruby
sferik
621
60k
Raft: Consensus for Rubyists
vanstee
132
6.3k
The World Runs on Bad Software
bkeepers
PRO
61
6.7k
Rebuilding a faster, lazier Slack
samanthasiow
73
8.2k
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
40
4.4k
Code Review Best Practice
trishagee
55
15k
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
221
21k
The Language of Interfaces
destraynor
151
23k
Become a Pro
speakerdeck
PRO
11
4.5k
Clear Off the Table
cherdarchuk
84
310k
Embracing the Ebb and Flow
colly
80
4.1k
Building a Scalable Design System with Sketch
lauravandoore
456
32k
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. 今は、自分はゲームは作っておりませんが、恐らく今も変わらないでしょう。