情報系学科OB生が教える学習ロードマップとおすすめ本 ~其ノ二~
はじめに
前回の記事では「情報系学科OB生が教える学習ロードマップ」として基礎的な学問についての学び順とおすすめ教材をまとめました。まだ見ていない方はこの記事の前に以下の記事に目を通していただけると幸いです。なお、今回の内容だけでも有益なようには書くつもりです。
前回の記事ではコンピュータ通信技術までの学び方を執筆しました。実際に情報系の学生も学んでいる順番通りかと思います。(しょぼい図ですみません^^;)
今回はついに応用学問です。コンピュータグラフィックス以降を説明していこうと思います。
「コンピュータグラフィックス・コンピュータビジョン」
まず有名なCG/CVについてです。情報系学生であれば一度は学ぶのではないでしょうか?
コンピュータグラフィックス
プレステ世代でしたので、情報といえばCGという学生も結構いた印象です。学び始めるとわかるのですが、基本的にCGは"物理演算の組み合わせ"ということがわかります。
CGを学びたいのであればとにかく数学からマスターしておくと理解が深まるかと思います。基本的には2DのCGから学ぶのがいいかと思います。特に私が最初に学んだ手法としてレイトレーシングというものがあります。以下のサイトがわかりやすいです。
レイトレーシングがわかると物理的な演算による物体描写がわかるので、今後のグラフィックスの作成に繋がってくるかと思います。CGについては取り組むソフトが大事です。
本についてはCG検定の取得を目標にこれらの教材に取り組むとよいかと思います。
コンピュータビジョン
そもそもコンピュータビジョンとは何か?と思われる方もいらっしゃるかと思います。私が習った際に教授が言っていたことで「CGとCVは逆演算である」という言葉を思い出します。
コンピュータグラフィックスとは基本的には3次元情報から一枚絵を作り出す技術なのですが、これによって出来上がった一枚絵から3次元空間の情報量(例えば奥行きや位置関係など)を復元する技術がコンピュータビジョンだと考えています。
最近ではこれに追加してより多くの補完情報を取得する技術も含められているのでしょう。例えば物体検出などがそれに当たると思います。(専門ではないのでこのくらいで。)
申し訳ありませんが実際に使用したおすすめの本がわかりません。ただ、以下の本が研究室の輪講に使われていた記憶があります。
「データベース (Database)」
応用の続いてのジャンルはデータベースです。データベースという言葉を聞いたことがあるでしょうか?
名前の通り、データを保存しておくソフトウェア(正確にはミドルウェア)です。ミドルウェアという言葉による理解の妨げはないので、ソフトウェアとして学んでいいと思います。
データベースには色々な種類があるので、Webアプリエンジニアになりたての人たちは混乱すると思います。特にMongoDBなどのデータベースは非常に知名度が高いので、これらのソフトがデータベースの例だと思っている方もいらっしゃるでしょう。
ただ、私はまず学ぶべきは**リレーショナルデータベース(RDB)**であると思います。実際に、情報系の学生も必ずこれから学びます。
リレーショナルデータベース(RDB)とは関係性をあらかじめ記述し、その関係性のデータ集合体のためのデータバングと思ってください。例えばExcelで生徒のデータを管理する時に、各列に項目名(id, 名前, 年齢, 学年など)を設定し、細かい実際のデータを記述すると思いますが、あれを想像してください。
このリレーショナルデータベース(RDB)からデータを取得するための専用言語を**SQL(Structured Query Language)**と呼びます。WebエンジニアでもアプリケーションエンジニアでもSQLを知らないと笑われると思いますのでここは絶対にものにしておきたいところです。
私の時には先生のスライドで学んだのですが、学習書としては以下のものでいいでしょう。また、これらの学習書を学んだ後、PHPなどのプログラミング言語を使い、簡単なWebアプリケーション(DBからのデータ呼び出し/保存/編集/削除操作が必要なもの)を作成してみるといいでしょう。
ただこの辺はイケてるプログラマの方々はすでに新技術を採用している方も多いと思いますので、すこしその後の技術展望の話をします。
RDBにはその性質ゆえ課題(特にビッグデータを扱う用途で、分散環境を考慮しだすと..)もありました。それらの課題に直面した結果RDB/SQLを脱しようという志のもの開発されているのがNoSQL(Not Only SQL)です。
GAFAなどの会社がこぞって運用していたので、一気に知名度が上がりました。
リレーショナルデータベースのデータ管理方法が悪いのではなく、あくまで起源RDBが保持する性質を踏まえた際の課題であり、これらの性質を緩めることでRDBの形のまま進化させようとしているNewSQLというものも出ているようです。
構造化されたデータを扱うのがRDB/SQLなのに対して、Image/Movie/Audioデータなどの非構造データ保存のユースケースが増加したため、周知を加速させた背景もあるのかもしれません。
賛否両論あると思いますが、私自身はよほどのことがない限り通常のアプリ開発のデータベースの第一候補はリレーショナルデータベースだと思っています。SQLは絶対に学びましょう。
おわりに
今回は前回記事の続編として、応用学問について扱ってみました。
次回は応用の分野であるパターン認識やインターフェースを紹介します。
コメントなどお待ちしております。執筆の励みとなりますので、ぜひお願い致します!