FrostyDesign
自分用にさまざまなものを作るページです
FrostyCoreArchitecture
- 2012/04/01 (Sun)
- 未選択 |
- CM(0) |
- Edit |
- ▲Top
制御系のアーキテクチャを書いてみたので公開。
まずは制御系ハードウェアのアーキテクチャ
以前に写真で説明しましたが、CPUはSH7145 50MHz 。
このクラスのマイコンボードとしては1MB DRAMとメモリ多めなのが選定ポイントの1つです。
FPGAボードとは16bit 50MHzのバスで接続。
FPGA内にICS3.0仕様のプロトコルモジュールを6ch、
PSコントローラのプロトコル処理もFPGA化しています。
下記は、シーケンス図です。
通常はまずソフトウェアブロック図を示すところですが、
このアーキテクチャでは
純粋なソフトウェアはメインスレッドのみで
通常、スレッド分けて実装する通信処理系をすべてFPGAで実装しています。
メインスレッドからFPGAの通信はレジスタ経由なのでほぼメモリアクセスと同等で読み書きでき、
レジスタマップがAPIという感じです。
メインスレッド1つに通信系のスレッドが7つという感じでしょうか。
ADコンバータもコントローラ側で複数chスキャンしてるので5msに一回まとめてレジスタ読んでます。
メインスレッドは5ms毎のタイマー割り込みでループしていて、これがシステム制御間隔になっており、
センサ情報取得、PSコントローラ受信、サーボ制御、全て5ms周期になっています。
まずは制御系ハードウェアのアーキテクチャ
以前に写真で説明しましたが、CPUはSH7145 50MHz 。
このクラスのマイコンボードとしては1MB DRAMとメモリ多めなのが選定ポイントの1つです。
FPGAボードとは16bit 50MHzのバスで接続。
FPGA内にICS3.0仕様のプロトコルモジュールを6ch、
PSコントローラのプロトコル処理もFPGA化しています。
下記は、シーケンス図です。
通常はまずソフトウェアブロック図を示すところですが、
このアーキテクチャでは
純粋なソフトウェアはメインスレッドのみで
通常、スレッド分けて実装する通信処理系をすべてFPGAで実装しています。
メインスレッドからFPGAの通信はレジスタ経由なのでほぼメモリアクセスと同等で読み書きでき、
レジスタマップがAPIという感じです。
メインスレッド1つに通信系のスレッドが7つという感じでしょうか。
ADコンバータもコントローラ側で複数chスキャンしてるので5msに一回まとめてレジスタ読んでます。
メインスレッドは5ms毎のタイマー割り込みでループしていて、これがシステム制御間隔になっており、
センサ情報取得、PSコントローラ受信、サーボ制御、全て5ms周期になっています。
PR
走行動画
まずは素の特性を良くしてからフィードバックと思っていましたが、改良したらジャイロによるフィードバック無しで最高速まで加速できるようになりました。
300fpsの映像です。一応ちゃんと浮いてます
こっちは加速後、減速して止まるまでの動画
300fpsの映像です。一応ちゃんと浮いてます
こっちは加速後、減速して止まるまでの動画
続・コントローラボード
コントローラの電源を変更した際にばらしたので写真とって見ました。
電源ケーブル込みなこともありますが、
ちょっと重い108.6g
コントローラボードは3段構成になっていて
一番上は
ベステク BTC080 SH7145Fマイコンボード
http://www.besttechnology.co.jp/modules/knowledge/?BTC080%20SH7145F マイコンボード
FPGAとクロック同期するためのクロックのラインがなかったので
CPUの足から取ってます。
一番下は
FPGAボード(ヒューマンデータ XCM-301-200)
http://www.hdl.co.jp/XCM-301/index.html
FPGAで
ICS3.5仕様シリアル通信モジュール6ch
プレステコントローラ通信モジュールを組んでます
ICS3.5仕様シリアル通信モジュール
はISC3.5といってもコマンドは3バイトのみ対応、ボーレートは115kbps固定としています。
(ICS2.0のサーボも使っているため)
FIFOバッファ付でCPUからは複数コマンドを連続書き込み可能で
FPGA側でタイムアウトエラー回避のため1ms間隔で送信します。
受信結果も複数コマンド分レジスタに蓄積し、エラー情報とセットで
連続して読み出せます。
CPU側では多重割り込みを使うことなく6ch×3サーボを5ms毎にタイマー割り込み1回で送受信しています。
中間段は
電源、レベル変換、外部へのコネクタになっています。
電源はDCDCコンバータでRecom R-783.3-1.0
http://www.bellnix.co.jp/pdf/C_R-78.pdf
http://jp.rs-online.com/web/p/dc-dc-converters/6727120/
レベル変換は
サーボの制御信号が5Vの半二重なので方向付5v-3.3v変換で
TI SN74LVC1T45 です。
http://www.tij.co.jp/product/jp/sn74lvc1t45
ちょっとパスコンが多めなのはデバッグ中におまじないで
入れたためで、多分もっと少なくても大丈夫です。
#FPGAのソースコード提供するから
誰か基板起こして小型軽量化してくれないかな~。
電源ケーブル込みなこともありますが、
ちょっと重い108.6g
コントローラボードは3段構成になっていて
一番上は
ベステク BTC080 SH7145Fマイコンボード
http://www.besttechnology.co.jp/modules/knowledge/?BTC080%20SH7145F マイコンボード
FPGAとクロック同期するためのクロックのラインがなかったので
CPUの足から取ってます。
一番下は
FPGAボード(ヒューマンデータ XCM-301-200)
http://www.hdl.co.jp/XCM-301/index.html
FPGAで
ICS3.5仕様シリアル通信モジュール6ch
プレステコントローラ通信モジュールを組んでます
ICS3.5仕様シリアル通信モジュール
はISC3.5といってもコマンドは3バイトのみ対応、ボーレートは115kbps固定としています。
(ICS2.0のサーボも使っているため)
FIFOバッファ付でCPUからは複数コマンドを連続書き込み可能で
FPGA側でタイムアウトエラー回避のため1ms間隔で送信します。
受信結果も複数コマンド分レジスタに蓄積し、エラー情報とセットで
連続して読み出せます。
CPU側では多重割り込みを使うことなく6ch×3サーボを5ms毎にタイマー割り込み1回で送受信しています。
中間段は
電源、レベル変換、外部へのコネクタになっています。
電源はDCDCコンバータでRecom R-783.3-1.0
http://www.bellnix.co.jp/pdf/C_R-78.pdf
http://jp.rs-online.com/web/p/dc-dc-converters/6727120/
レベル変換は
サーボの制御信号が5Vの半二重なので方向付5v-3.3v変換で
TI SN74LVC1T45 です。
http://www.tij.co.jp/product/jp/sn74lvc1t45
ちょっとパスコンが多めなのはデバッグ中におまじないで
入れたためで、多分もっと少なくても大丈夫です。
#FPGAのソースコード提供するから
誰か基板起こして小型軽量化してくれないかな~。
新しい足のリンク構造
新しい足のリンク構造です。
といっても前回のrobo-one 18thですでに更新していて、その公開です。
新しいといっても、基本コンセプトとしては前と同じで、その改良版です。
robo-oneのルールにあわせて足を長くしたことと、
バック宙をできる性能を維持しつつ、省電力化を図っています。
考え方としては、サーボのヒザの屈伸のレシオのカーブを変更し、
足を伸ばしきったときのレシオを下がり過ぎないようにし、その分、バネのプリテンションをあげて
立っているときのバネ加重を上げています。
また、以前は疑似直線リンクとヒザの伸縮のリンクは独立していましたが、
今回は途中で合成する構成にしています。
といっても前回のrobo-one 18thですでに更新していて、その公開です。
新しいといっても、基本コンセプトとしては前と同じで、その改良版です。
robo-oneのルールにあわせて足を長くしたことと、
バック宙をできる性能を維持しつつ、省電力化を図っています。
考え方としては、サーボのヒザの屈伸のレシオのカーブを変更し、
足を伸ばしきったときのレシオを下がり過ぎないようにし、その分、バネのプリテンションをあげて
立っているときのバネ加重を上げています。
また、以前は疑似直線リンクとヒザの伸縮のリンクは独立していましたが、
今回は途中で合成する構成にしています。
robo-one 中止
robo-one中止になってしまいましたね。
今日は予選の徒競走の日。ということで動画あげてみました。
今日は予選の徒競走の日。ということで動画あげてみました。
カレンダー
カテゴリー
プロフィール
最新記事
(06/29)
(05/12)
(05/02)
(02/21)
(07/08)
最新CM
[06/28 Braitaereks]
[08/29 l8xc6xc236]
[06/29 MichaelGek]
[06/18 Michaelted]
[06/14 GeorgeaccoG]