[openrtm-users 01650] Re: NXTRTCについて
Ando Noriaki
n-ando @ aist.go.jp
2011年 3月 3日 (木) 23:34:13 JST
安藤です
いえ、nxtOSEKしかだめということはないと思いますが。。。
ただ、OpenRTM-aistの開発チームの方では、NXTについては
それほど深く理解しているわけではないので、今のところ
nxtOSEKでやる方法しかわかりません。
他にいい方法を見つけられたら、ぜひMLで教えてください。
よろしくお願いいたします。
2011年3月3日22:52 <trhr1104 @ yahoo.co.jp>:
> 安藤様
>
> 加藤です。
>
> nxtOSEKしか無理ですかー。
> 了解です。
>
> 前に一度インストールしたので、機会があれば勉強したいと思います。
>
> ありがとうございました。
> Ando Noriaki <n-ando @ aist.go.jp> wrote:
>
> 加藤様
>
> 安藤です
>
> NXTRTCでは基本的に、デフォルトのファームウエアでnxtpython
> から操作することを前提としているので、カスタムファームウエアでは
> 動作しないと思います。
>
> ただし、カスタムファームウエアで、nxtpythonとも通信し、独自の
> ロジックも実装して動作するようなプログラムを作成すれば加藤さんの
> やりたいようなことも実現可能だとは思います。
>
> 例えば、以下のNXTwayをRTCから動作させている例もありますが、
> これはNXT側で倒立振子の制御をしつつ、BluetoothでRTCからの
> 指令を受け取ってNXTwayを動かしています。
> http://www.openrtm.org/openrtm/ja/node/268
>
> ただ、NXTwayについても、nxtOSEKで開発されたプログラムを
> 流用しただけですので、詳細についてはnxtOSEKのページ等を
> ご覧ください。
> http://lejos-osek.sourceforge.net/jp/nxtway_gs.htm
>
> #もしかすると、nxtOSEKをよくご存じのかたがこのMLを見ているかもしれませんね。
> #どなたかいらっしゃいませんか?
>
>
> 2011年3月3日19:50 :
>> 栗原様
>>
>> 加藤です。
>>
>> ありがとうございます。
>> とても勉強になります。
>> 今後もNXTRTCは利用していきたいのでよく覚えておきます。
>>
>> しかし今回やりたいのが、LEGO Mindstorms自体のプログラムを実行しながらなおかつパソコンから制御ができないか、ということです。
>>
>>
>> 当方NXTRTCについては勉強を始めたばかりでプログラムについてあまり分からない点が多いので、少し前からやっている mindstorms のプログラムを併用できないかと思いました。
>>
>> 超音波センサが反応したときにモータCを動かし、地面の色が変わったときにモータCを元に戻すというプログラムを LEGO mindstorms
>> にロードし実行してみました。
>>
>> (希望では、TkJoystickCompとNXTRTCをeclipceで結線しモータA,Bを動かし、 LEGO mindstorms
>> のほうのプログラムでモータCと超音波センサと光学センサを制御するといった形です)
>>
>> しかし実行してすぐ液晶画面に「error」と表示され、system diagram ではNXTRTCが緑色から赤色に代わりエラーとなりました。
>>
>> 一応、 mindstorms
>>
>> 上のプログラムはモータA,BやPORT3の光学センサとPORT4の超音波センサに関するプログラムは一切しておりません(PORT2とPORT1に各センサあり)。
>>
>> パソコンとNXTをbluetoothで繋ぎながらNXT自体に別のプログラムを実行させるのはできないのでしょうか。
>>
>> お時間いただければご教授お願いします。
>> kurihara shinji wrote:
>>
>> 加藤様
>>
>> 栗原です。
>>
>>> 繋いだ先のNXT自体に別のプログラムを実行させておくことはできますでしょうか?
>> 「別のプログラムを実行させておく」がどのような方法(別スレッド?)で実行されている
>> のかはわかりませんが、別のモータを制御する事は可能です。
>>
>> NXTRTC.pyの"def onExecute(self,ec_idl):"内にあります以下の行
>> vel_[self._mapping[self._map[0][0]]] = self._d_vel.data[0]
>> vel_[self._mapping[self._map[0][1]]] = self._d_vel.data[1]
>> を、以下のようにして頂くことで、NXTのCのポートに接続されている
>> モータを動かす事ができます。
>> vel_[0] = self._d_vel.data[0]
>> vel_[1] = self._d_vel.data[1]
>> vel_[2] = self._d_vel.data[1] # ここに”別のモータ”の速度を入力する。
>>
>> ”別のモータ”の速度を独自に変更したい場合は、速度を計算した
>> 結果を"vel_[2] = "の行のself._d_vel.data[1]のところと置き
>> 換えてみて下さい。
>>
>> ちなみに、上記のように変更した場合、InPortに新しいデータが
>> 届いた時のみモータが動きます。
>>
>> 上記の変更を行ったNXTRTC.pyを添付させて頂いております。
>>
>>
>> 以上、宜しくお願い致します。
>>
>>
>>
>> On Thu, 3 Mar 2011 14:16:26 +0900 (JST)
>> wrote:
>>
>>> 専門学校生 加藤です。
>>>
>>> パソコンからNXTRTCに繋ぎ制御することができました。
>>> ありがとうございました。
>>>
>>> 一つ質問があります。
>>> 繋いだ先のNXT自体に別のプログラムを実行させておくことはできますでしょうか?
>>> 一度やってみたのですがエラーが発生してしまいました。
>>>
>>> パソコンからモータA,Bを動かすプログラムを送信し、NXT側でモータA,Bが動いたときに別のモータを動かす。
>>>
>>> のような動作をさせたいです。
>>> 可能でしょうか?
>>>
>>> お時間頂けたらご教授お願いします。
>>>
>>>
>>
>>
>> --
>> ----------
>> 栗原 眞二
>>
>> 独立行政法人産業技術総合研究所
>> 知能システム研究部門 統合知能研究グループ
>> 〒305-8568
>> 茨城県つくば市梅園1-1-1 中央第2
>>
>> TEL: 029-861-5956
>> #!/usr/bin/env python
>> # -*- coding:shift_jis -*-
>> # -*- Python -*-
>>
>> import sys
>> import time
>> sys.path.append(".")
>>
>> # Import RTM module
>> import OpenRTM
>> import RTC
>>
>>
>> # import NXTBrick class
>> import NXTBrick
>>
>>
>> # This module's spesification
>> #
>> nxtrtc_spec = ["implementation_id", "NXTRTC",
>> "type_name", "NXTRTC",
>> "description", "NXT sample component",
>> "version", "0.1",
>> "vendor", "AIST",
>> "category", "example",
>> "activity_type", "DataFlowComponent",
>> "max_instance", "10",
>> "language", "Python",
>> "lang_type", "SCRIPT",
>> "conf.default.map", "A,B",
>> ""]
>>
>> #
>>
>> class NXTRTC(OpenRTM.DataFlowComponentBase):
>> def __init__(self, manager):
>> OpenRTM.DataFlowComponentBase.__init__(self, manager)
>>
>> # DataPorts initialization
>> #
>> self._d_vel = RTC.TimedFloatSeq(RTC.Time(0,0),[])
>> self._velIn = OpenRTM.InPort("vel", self._d_vel,
>> OpenRTM.RingBuffer(8))
>> self.registerInPort("vel",self._velIn)
>> self._d_pos = RTC.TimedFloatSeq(RTC.Time(0,0),[])
>> self._posOut = OpenRTM.OutPort("pos", self._d_pos,
>> OpenRTM.RingBuffer(8))
>> self.registerOutPort("pos",self._posOut)
>> self._d_sens = RTC.TimedFloatSeq(RTC.Time(0,0),[])
>> self._sensOut = OpenRTM.OutPort("sens", self._d_sens,
>> OpenRTM.RingBuffer(8))
>> self.registerOutPort("sens",self._sensOut)
>>
>> # initialize of configuration-data.
>> #
>> self._map = [['A', 'B']]
>> self._nxtbrick = None
>> self._mapping = {'A':0,'B':1,'C':2}
>>
>> def onInitialize(self):
>> # Bind variables and configuration variable
>> #
>> self.bindParameter("map", self._map, "A,B")
>>
>> # create NXTBrick object
>> try:
>> print "Connecting to NXT brick ...."
>> self._nxtbrick = NXTBrick.NXTBrick()
>> print "Connection established."
>> except:
>> print "NXTBrick connection failed."
>> return RTC.RTC_ERROR
>>
>> return RTC.RTC_OK
>>
>> def onFinalize(self):
>> self._nxtbrick.close()
>>
>> def onActivated(self, ec_id):
>> self._nxtbrick.setMotors([0,0,0])
>> # reset NXTBrick's position.
>> self._nxtbrick.resetPosition()
>> return RTC.RTC_OK
>>
>> def onDeactivated(self, ec_id):
>> self._nxtbrick.setMotors([0,0,0])
>> # reset NXTBrick's position.
>> self._nxtbrick.resetPosition()
>>
>> return RTC.RTC_OK
>>
>> def onExecute(self, ec_id):
>> # check new data.
>> if self._velIn.isNew():
>> # read velocity data from inport.
>> self._d_vel = self._velIn.read()
>> vel_ = [0,0,0]
>> #vel_[self._mapping[self._map[0][0]]] = self._d_vel.data[0]
>> #vel_[self._mapping[self._map[0][1]]] = self._d_vel.data[1]
>> vel_[0] = self._d_vel.data[0]
>> vel_[1] = self._d_vel.data[1]
>> vel_[2] = self._d_vel.data[1]
>> # set velocity
>> self._nxtbrick.setMotors(vel_)
>>
>> # get sensor data.
>> sensor_ = self._nxtbrick.getSensors()
>> if sensor_:
>> self._d_sens.data = sensor_
>> # write sensor data to outport.
>> self._sensOut.write()
>>
>> # get position data.
>> position_ = self._nxtbrick.getMotors()
>> if position_:
>> self._d_pos.data = \
>> [position_[self._mapping[self._map[0][0]]][9], \
>> position_[self._mapping[self._map[0][1]]][9]]
>> # write position data to outport.
>> self._posOut.write()
>>
>> return RTC.RTC_OK
>>
>>
>>
>> def MyModuleInit(manager):
>> profile = OpenRTM.Properties(defaults_str=nxtrtc_spec)
>> manager.registerFactory(profile,
>> NXTRTC,
>> OpenRTM.Delete)
>>
>> # Create a component
>> comp = manager.createComponent("NXTRTC")
>>
>>
>>
>> def main():
>> mgr = OpenRTM.Manager.init(len(sys.argv), sys.argv)
>> #mgr = OpenRTM.Manager.init(sys.argv)
>> mgr.setModuleInitProc(MyModuleInit)
>> mgr.activateManager()
>> mgr.runManager()
>>
>> if __name__ == "__main__":
>> main()
>>
>>
>>
>>
>
>
>
> --
> 安藤慶昭@独立行政法人産業技術総合研究所 知能システム研究部門
> 統合知能研究グループ 主任研究員, 博士(工学)
> 〒305-8568 つくば市梅園1-1-1 中央第2
> e-mail: n-ando @ aist.go.jp, web: http://staff.aist.go.jp/n-ando
> OpenRTM-aist: http://www.openrtm.org
>
> Noriaki Ando, Ph.D.
> Senior Research Scientist, RT-Synthesis R.G., ISRI, AIST
> AIST Tsukuba Central 2, Tsukuba, Ibaraki 305-8568 JAPAN
> e-mail: n-ando @ aist.go.jp, web: http://staff.aist.go.jp/n-ando
> OpenRTM-aist: http://www.openrtm.org
>
>
>
--
安藤慶昭@独立行政法人産業技術総合研究所 知能システム研究部門
統合知能研究グループ 主任研究員, 博士(工学)
〒305-8568 つくば市梅園1-1-1 中央第2
e-mail: n-ando @ aist.go.jp, web: http://staff.aist.go.jp/n-ando
OpenRTM-aist: http://www.openrtm.org
Noriaki Ando, Ph.D.
Senior Research Scientist, RT-Synthesis R.G., ISRI, AIST
AIST Tsukuba Central 2, Tsukuba, Ibaraki 305-8568 JAPAN
e-mail: n-ando @ aist.go.jp, web: http://staff.aist.go.jp/n-ando
OpenRTM-aist: http://www.openrtm.org
openrtm-users メーリングリストの案内