「RaspberryPi でPythonでモータ制御するための情報」
を既に書いた。
Pythonでのモータ制御に関心をもっている理由を以下に示します。
モーター制御のプログラムを書ける人を増やして、楽しい組み込みをしましょう。
(以下の記述の中で、この記事の著者は、C++のライブラリを十分に知っていないので、誤解している可能性があります。)
Pythonでは、シリアルポート、socketベースでのネットワーク、スレッドなどの制御にかかわりやすいライブラリが、Windows、Linux/Unixで共通のライブラリが使えるようになっており、開発の楽なマシンで開発をある程度進めておいてから、ターゲットマシンに移植することが容易に行いやすい。
主張: RaspberryPiで、しかもPythonベースで制御できることは、モータ制御をできる人の層を増やします。
従来:
「C/C++でLinux(あるいはTRON、あるいはOSレス)プログラムが書ける人」
かつ「LinuxのIOのデバイスドライバが書ける人」
かつ「モーター制御の電気系がわかる人」
かつ「駆動対象の物体に働く力、外乱などのメカニクスがわかる人」
という条件が必要になってしまう。
現在:
「C/C++なんて知らないよ。コンパイルなんてやったことがないよ。」という人々にサンプルスクリプトを実行してまねてみることができます。
インタプリタ上で、スクリプトを動作させると、正常に動作できる範囲まで、スクリプトが実行できます。
完全に出来ていない状況でも少しずつ開発することができます。
そのプログラムの実行中のスコープでの変数の値を、Spyder(Python統合環境の1つ)で、[Variable explorer]でデータの値を見ることができます。
結果を保存し、それをSpyderなどでMATLAB並みのデータ解析・グラフの作成をするのが、LinuxやWindowsの種類によらずできます。
主張: RaspberryPi、Pythonでシリアルインタフェースのプログラムを書けば、windows,Linuxの違いを少なくしてプログラミングの開発ができる。
従来のC/C++:
WindowsとUnix/Linuxで共通性の高いコーディングをする標準的な方法はなかった。
Windows 3. Windows でのシリアル通信 [3-5]
Linux Linux一般でのシリアルプログラミングについて
Python:
pyserial 3.0
記事 「Pythonとハードウェア ー PythonでRS232Cを利用する -」
現在のC++:
Boost Serial Ports
記事 Boost.Asioでシリアル通信してみる
主張: RaspberryPi、Pythonでsocketプログラムを書けば、Windows,Linuxの違いを少なくしてプログラミングの開発ができる。
従来のC/C++:
LinuxとWindowsで基本となるライブラリに大きな違いがあり、LinuxとWindowsで共通に動作するプログラムを作りにくかった。
Unix,LinuxのSocketのライブラリは、IPv6以前、マルチスレッド時代以前、unicode以前の太古の時代からのライブラリであり、使用しているUnix,Linuxでのライブラリがどうなっているのかは、私は理解していない。
Unix [C言語]Socket間通信 echoサーバを作る
Windows winsockを使ってTCPによる通信をする方法
Python:
Pythonのsocketライブラリは、Pythonの標準ライブラリにあるので、OSの種類によらず共通のプログラムが書ける。Pythonのネットワークライブラリはwebサーバーを書けるほど充実している。
Python 標準ライブラリ 7.2. socket — 低レベルネットワークインターフェース
記事 python で echo サーバ作ってみた
SocketServer というライブラリがあるので、使ってみた。
Python初心者がScikit-imageの例題を自分用に使うためのヒント5 ネットワークアプリに組み込む
現在のC++の場合:
BoostのAsioライブラリがWindows,Linuxで共通性の高いソースコードが書ける。
Boost.Asio
Boost.Asio A collection of simple clients and servers
SlideShare Asioを使おう!
主張: RaspberryPi、Pythonでマルチスレッドプログラムを書けば、Windows,Linuxの違いを少なくしてプログラミングの開発ができる。
従来のC/C++:
従来のC/C++のマルチスレッドは、OSの種類によらない記述方法がなかった。マルチスレッドでプログラムを書き出したときに、その関数の中で使用している関数が、スレッドセーフであるかどうかは、必ずしも容易な確認はできない。
Python:
Pythonにはマルチスレッドが標準のライブラリに含まれている。
Python標準ライブラリ 16.2. threading — 高水準のスレッドインタフェース
記事 「Pythonでマルチスレッド処理」
記事 画像の読み込みを別スレッドにしてみる(OpenCV-Python)
現在のC++:
C++11では、マルチスレッドのライブラリが標準化されているので、OS依存性のないマルチスレッドのプログラムが書きやすくなっているらしい。
記事 画像の読み込みを別スレッドにしてみる(C++版)
参考したURL
1:C++で簡単非同期処理(std::thread,std::async)
http://qiita.com/termoshtt/items/d3cb7fe226cdd498d2ef
2:C++入門 std::async
http://kaworu.jpn.org/cpp/std::async
主張: Pythonでプログラムを書けば、特定のOSに固有の機能を使うことが少なくなり、Windows,Linuxで共通に動くプログラムが作りやすい。
主張:Pythonでも書き方次第で、昔より速く動作する。
従来のPython:
動的な型チェック、配列の範囲外へのチェックのため、遅くなる。
従来のPythonへの拡張:
標準ドキュメンテーションの和訳「C や C++ による Python の拡張」
現在のPython(Cython):
Cythonの基本的な使用方法は公式のドキュメントをご覧下さい
http://docs.cython.org/
日本語版
http://docscythonja.zouri.jp/