<div dir="ltr">梅谷先生<div><br></div><div>安藤です</div><div><br></div><div>1.1.2のBuilderで自動生成されるPythonの以下のコードですが、</div><div>基本的には、Builderで生成直後のRTCを実行時にエラーを出さないためだけ</div><div>のコードとお考え下さい。</div><div><br></div><div><div><span class="gmail-Apple-tab-span" style="white-space:pre"> </span>outdata_arg = [None] * ((len(RTC._d_TimedLong) - 4) / 2)</div><div><span class="gmail-Apple-tab-span" style="white-space:pre"> </span>self._d_outdata = RTC.TimedLong(*outdata_arg)</div></div><div><br></div><div>ですので、</div><div><br></div><div><div><div><span class="gmail-Apple-tab-span" style="white-space:pre"> # </span>outdata_arg = [None] * ((len(RTC._d_TimedLong) - 4) / 2)</div><div><span class="gmail-Apple-tab-span" style="white-space:pre"> </span>self._d_outdata = RTC.TimedLong(RTC.TIme(0,0), 0)</div></div></div><div><br></div><div>のように修正してお使いください。</div><div><br></div><div>なぜこのようになっているかといいますと、TimedLong くらいの簡単な構造体</div><div>であれば、RTC.TimedLong(RTC.TIme(0,0), 0) のような単純な初期化でいいのですが、</div><div>CameraIMage等では</div><div><br></div><div>self._d_camera = RTC.CameraImage(RTC.Time(0,0), 640, 480, 24, "bitmap", 1.0, [])<br></div><div><br></div><div>TimedPose2Dなどでは、</div><div><br></div><div>self._d_currentPose = RTC.TimedPose2D(RTC.Time(0,0),RTC.Pose2D(RTC.Point2D(0,0), 0))<br></div><div><br></div><div>のように、型ごとに特有の初期化をする必要があります。</div><div><br></div><div>これをBuilderで画一的に回避するために、データポートのデータ型の第1階層をすべてNone</div><div>で初期化しているのが、1.1.2のBuilderが生成するコードです。</div><div><br></div><div>setTimestamp() 関数では、データポートのデータ型の tm フィールドが RTC.Time型で</div><div>あることを前提として、 tm.sec, tm.nsec に時間を代入しようとしますが、</div><div>上記の自動的な初期化では None が代入されており、RTC.Timeオブジェクトとして</div><div>情報が入っておりませんので、sec, nsec のフィールドが無く、代入時にエラーとなります。</div><div><br></div><div>次のバージョンでは初期化コード部分に分かりやすいようにコメントを入れたいと思います。</div><div>分かりにくい変更、また説明不足で申し訳ございません。</div><div><br></div><div>以上、よろしくお願いいたします。</div><div><br></div><div><br></div><div><br></div><div><br></div><div class="gmail_extra"><div class="gmail_quote">2016年12月23日 16:20 Tomohiro UMETANI <span dir="ltr"><<a href="mailto:umetani@konan-u.ac.jp" target="_blank">umetani@konan-u.ac.jp</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">openrtm-users メーリングリストのみなさま<br>
<br>
甲南大学の梅谷です.<br>
先日のRTミドルウェアコンテスト2016では<br>
大変お世話になりました.<br>
<br>
現在,OpenRTM-aist-1.1.2-RELEASE (Python)の,<br>
Ver. 1.1.2 Windows用インストーラ (32bit版)をインストールし,<br>
使用しております.<br>
インストール元は以下のところのものです.<br>
<a href="http://www.openrtm.org/openrtm/ja/node/6034" rel="noreferrer" target="_blank">http://www.openrtm.org/<wbr>openrtm/ja/node/6034</a><br>
<br>
OpenRTM-aist-1.1.2 付属のOpenRTP でのRTC Builder で<br>
データポートがあるPythonのコンポーネントのコードを出力<wbr>したのですが,<br>
自動出力されるデータポートのコードがver. 1.1.2 では,<br>
以下のように変更されていました.<br>
<br>
ここから<br>
=====<br>
outdata_arg = [None] * ((len(RTC._d_TimedLong) - 4) / 2)<br>
self._d_outdata = RTC.TimedLong(*outdata_arg)<br>
"""<br>
"""<br>
self._data_outOut = OpenRTM_aist.OutPort("data_<wbr>out", self._d_outdata)<br>
=====<br>
ここまで<br>
<br>
自動出力される変数の名前が変わっているのは良いのですが,<br>
特に上2行に関しては,ver. 1.1.0 では,TimedLong型の場合<br>
=====<br>
self._d_outdata = RTC.TimedLong(RTC.Time(0,0),0)<br>
=====<br>
<br>
のように出力されていたと認識しています.<wbr>TimedLongSeq型の場合は<br>
RTC.TimedLongSeq(RTC.Time(0,0)<wbr>,[])<br>
でした.<br>
<br>
このためかどうかわかりませんが,<br>
1.1.0時代のコードを手掛かりに,<wbr>データポートから値を出力させるプログラムを<br>
1.1.2で出力されたコードに1.1.0と同じ方法で,<br>
タイムスタンプを付けるコードをそのまま書くと,<br>
Execute時にエラーが出てしまいます.<br>
<br>
実行時のrtc ログの抜粋(一部)を以下に示します<br>
====<br>
2016-12-23 15:16:26,710 SdoServiceAdmin WARNING No available SDO service in the factory: IDL:OpenRTM/ComponentObserver:<wbr>1.0<br>
2016-12-23 15:16:26,710 SdoServiceAdmin ERROR type 90c1ad6d-06bc-4969-b10e-<wbr>306291cf0653 already exists.<br>
2016-12-23 15:16:28,378 rtobject ERROR Traceback (most recent call last):<br>
File "C:\Python27\lib\site-<wbr>packages\OpenRTM_aist\<wbr>RTObject.py", line 1560, in on_execute<br>
ret = self.onExecute(ec_id)<br>
File "C:\Users\umetani\workspace\<wbr>DataPortSample\DataPortSample.<wbr>py", line 187, in onExecute<br>
OpenRTM_aist.setTimestamp(<wbr>self._d_outdata)<br>
File "C:\Python27\lib\site-<wbr>packages\OpenRTM_aist\OutPort.<wbr>py", line 51, in setTimestamp<br>
data.tm.sec = tm.sec<br>
AttributeError: 'NoneType' object has no attribute 'sec'<br>
<br>
2016-12-23 15:16:32,388 ec_worker ERROR State of the RTC is not ACTIVE_STATE.<br>
2016-12-23 15:16:32,411 ec_worker WARNING ExecutionContext is already stopped.<br>
2016-12-23 15:16:32,411 ec_base ERROR Invoking on_shutdown() for each RTC failed.<br>
====<br>
<br>
添付ファイルには,数が多く紛らわしくて申し訳ありませんが,<br>
以下のものを添付いたします.<br>
=====<br>
1. 確認したRTコンポーネントのXMLファイル RTC.xml<br>
2. 実行時のログ rtc1164.log<br>
3. RTC Builder で自動出力したコード DataPortSample_output.py<br>
4. エラーが出ることを確認したコード <a href="http://DataPortSample_1.1.2.py" rel="noreferrer" target="_blank">DataPortSample_1.1.2.py</a><br>
5. データポートの宣言を1.1.0の方法に修正したもの <a href="http://DataPortSample_1.1.0.py" rel="noreferrer" target="_blank">DataPortSample_1.1.0.py</a><br>
(これは正しく動作します)<br>
=====<br>
<br>
RTミドルウェアコンテストでのコンポーネント改良時,<br>
1.1.2で自動生成したテンプレートをもとに<br>
コンポーネントを作成しているときに,<wbr>このエラーに遭遇しました.<br>
<br>
不勉強で申し訳ありませんが,<br>
データポートの宣言部分(自動生成される部分です)<wbr>を修正せずに,<br>
現行の1.1.2 のバージョンで,正しくタイムスタンプを付けることができる<br>
コードの書き方をご教示いただけないでしょうか.<br>
よろしくお願い申し上げます.<br>
<br>
この場合「サンプルのコードを読むように」<wbr>と良くいわれるのですが,<br>
インストール時に入っている examples のコードは<br>
<br>
RTC.TimedLong(RTC.Time(0,0),0)<br>
<br>
で宣言されており,現行のバージョンで自動出力されたコードの<br>
書き方とは異なっております.そのため,困ってしまいました.<br>
最終的には,RTミドルウェアコンテストの他の参加者の方が<br>
アップロードされていたコードを参考に,<br>
1.1.0でのデータポート宣言方法にコードを修正して,<br>
実行できるようになった次第です.<br>
<br>
#バグを生む原因になりますので,<br>
#自動生成されるコードを修正することは避けたいです.<br>
<br>
なにとぞよろしくお願い申し上げます.<br>
<span class="HOEnZb"><font color="#888888"><br>
--<br>
Tomohiro UMETANI<br>
E-mail: <a href="mailto:umetani@konan-u.ac.jp">umetani@konan-u.ac.jp</a><br>
</font></span><br>______________________________<wbr>_________________<br>
openrtm-users mailing list<br>
<a href="mailto:openrtm-users@openrtm.org">openrtm-users@openrtm.org</a><br>
<a href="http://www.openrtm.org/mailman/listinfo/openrtm-users" rel="noreferrer" target="_blank">http://www.openrtm.org/<wbr>mailman/listinfo/openrtm-users</a><br>
<br></blockquote></div><br></div></div>