はじめに
WebエンジニアがFPGAを触ってみて感じたことを書いてみました。
結果的には理解が難しく、思うような習得には至らなかったのですが、その中でもわかったことと、今回の反省を活かして再挑戦する際のロードマップを考えてみたのでまとめることにしました。
なぜやってみようと思ったか
全く未経験の分野ではあるが、IoTデバイスやエッジAI開発に興味が出てきたのと、エンジニアとして知識の幅を広げる為に、これまで触れてこなかったハードの知見もFPGA学習の中で付けていきたいと思い学習することにしました。
FPGAとは
FPGA とは Field Programmable Gate Array の略で直訳すると、「現場で書き換え可能な論理回路の多数配列」となります。
簡単に言うと論理回路設計を間違えても即座にその場でハードウェア言語にて修正ができるデバイスということです。
ちなみに「即座にその場で」できるというのが FPGA の特徴です。
学習方法
FPGAプログラミング大全 Xilinx編 第2版で学習を進めることにしました。
こちらの書籍と選択した理由としては以下。
- 実際の開発ソフトを使いながらハンズオンでFPGA開発を学ぶことできる。
- ハンズオン形式での書籍の中では内容が比較的新しく、現在販売されているXilinx製FPGAボードが使える。(FPGA関連の書籍は結構古いものが多く、解説されている開発ソフトのバージョンが現在のバージョンとかけ離れていたり、対象のFPGAボード自体が製造中止で入手できないものも多々ある。)
所感
結果的には書籍を一回通すだけでは理解できなかったが、今回の学習を通してわかったこともあるので、これからの学習に活かしていきたい。
わかったこと①:FPGAの前にハードの知見が足りない
CPUやコンピュータの関する知識がなかったので、メモリ、レジスタ、アドレス、クロック周波数など普段の開発では使わない知識が必要になり理解に苦しみました。
ハードウェア開発の経験がないエンジニアが挑戦するには、なかなか高いハードルだと感じました。
わかったこと②:C言語やHDLの知見が必要
開発言語ももちろん違うので、書籍に記載されているコードが読めずこちらも苦戦しました。
中身のコードまで理解するには、別途C言語や、Verilogの学習が必要になります。
わかったこと③:開発PCのスペックが足りない
今回した使用したPCは、メモリ16GB SSD500GBだったが、開発ツール「Vivado」「Vitis」のインストールでハードディスクが200GB弱使用され、元々結構使っていたのもあり他のアプリケーションを消さざる終えませんでした。
本格的に仕事で使用するには、開発ツールを複数のバージョンを同時に持っておく必要もありそうなので、SSD 1TBくらいはあったほうがいいと思います。
「Vivado」「Vitis」の動作が16GBでも動くものの結構重いので、メモリも32GBくらいあると良さそうな感じはしました。(公式ドキュメントでも推奨32GBでした)
上記の反省点からロードマップを作成
もう一回書籍を通しても理解が進まないと感じたため、ハードの初歩的なところから学習する必要がある。
ステップ①:コンピュータやCPUの仕組みを理解する
コンピュータやCPUとは何なのか、どんな仕組みかを把握していないとCPU/GPU/FPGAの違いも理解できないので、まずはCPUについて全体的に理解する必要がある。
参考になりそうな書籍↓
コンピュータシステムの理論と実装 ―モダンなコンピュータの作り方
プロセッサを支える技術 --果てしなくスピードを追求する世界
ステップ②:CPUを作ってみる
実際に手を動かしてCPUを作りながら、周辺知識やHDLコードに触れる。
ついでにC言語にも触れて軽くでも読めるようになっておく良さそう。
参考になりそうな書籍↓
動かしてわかる CPUの作り方10講
ステップ④:「FPGAプログラミング大全 Xilinx編」をやってみる
1回目では理解できなかった FPGAプログラミング大全 Xilinx編 第2版の内容をハンズオンで動かしてみる。
ステップ①〜③である程度知識がついて来ているはずなので、最初に触った時と比べて理解できる部分は多くなっているはず。
それと同時にFPGAボードの公式ドキュメントも読んで、ボードの仕様やIOピンの配置など読み取れるように訓練しておく。
ステップ⑤:作りたいものを作ってみる
結局は自分で作りたいものを決めて、試行錯誤しながら覚えていくのが一番身になるので、何かオリジナルで作ってみる。
環境構築〜アプリケーション実行までの手順はこちらの記事がとても参考になりそうでした。
ZYBO (Zynq) 初心者ガイド (1) 開発環境の準備
〜(省略)
ZYBO (Zynq) 初心者ガイド (18)(完) IoT化してスマホからLチカ
まとめ
まだまだ使いこなせるようになるには長い道のりになりそうですが、今後も他の学習と並行して継続していきたいと思う。
おすすめの学習方法などありましたら、教えていただけますと大変嬉しいです。