Hi Geoff:<br>Thank you for your explanation. <br>It clarifies a lot !<br><br>Just to double check that I understood correctly. <br><br>If I have two components ConsoleIn and ConsoleOut, <br>there will be one buffer on each side of the connection between these two components when I use New publisher, <br>
but there is only one buffer on the receiving end, when I use Flush publisher since it will block and write to the buffer before it continues again while New publisher forks a process out to handle the writing<br><br><br>
By adjusting the InPort buffer length on ConsoleOut to 1<br>and setting buffer full policy to overwrite<br>I can make sure that no matter how much faster ConsoleIn is sending data to the port on ConsoleOut than ConsoleOut can receive. ConsoleOut will always get the latest value from ConsoleIn (but only the latest value).<br>
<br><br>For policy on controlling what to do when the buffer is empy, <br>does Readback policy mean that the previous data will be read, and Block will block the process of receiving component until there is a new data in the buffer, but what does do_nothing policy do? <br>
<br>and I understand these policy settings can only be set through a config file? ('coz I can't see them in RT System editor)<br>You attached a picture on data port connector profile in your answer to one of the questions in the ML, but I couldn't find that setting in my RT system editor. <br>
<br>PS I attached the screenshot you posted. <br><br>Thanks heaps <br>Tony<br><br>
<br><br><div class="gmail_quote">On 12 October 2010 13:17, Geoffrey Biggs <span dir="ltr"><<a href="mailto:geoffrey.biggs@aist.go.jp">geoffrey.biggs@aist.go.jp</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;">
Hi Tony,<br>
<br>
There are three types of publisher provided by default in OpenRTM-aist:<br>
<br>
- Flush<br>
<br>
As soon as you write data to the port, the data is written to the<br>
connected ports. The write occurs in the thread of whoever calls<br>
write(). This means that, if a write takes a while, it will delay your<br>
component's execution. Do not use this publisher for components that<br>
must meet their execution deadlines.<br>
<br>
- New<br>
<br>
Similar to the Flush publisher, but the write takes place in a separate<br>
process. This publisher supports push policies (ALL, FIFO, SKIP and<br>
NEW), because the task that performs the write may get its execution<br>
time after several calls to write() have occurred. The ALL policy means<br>
to push all available data in the buffer, one after another. The FIFO<br>
policy will send one item from the buffer. The SKIP policy will skip a<br>
certain number of items in the buffer, allowing (for example) every 5th<br>
value to be sent. The NEW policy will send the newest value in the<br>
buffer, ignoring any written previously.<br>
<br>
- Periodic<br>
<br>
This publisher runs a separate task performing the write at a configured<br>
frequency. It will write data from the buffer according to the push<br>
policy (see New, above) each time.<br>
<br>
<br>
In addition, you can also control the buffer on the receiving end. This<br>
is useful if the values will arrive faster than your component can<br>
handle them. In the configuration file for your component (e.g.<br>
mycomp.conf), add lines like the following:<br>
<br>
# InPort's name is "in". OutPort's name is "out".<br>
# The default length of the InPort’s buffer is 8.<br>
port.inport.in.buffer.length: 1<br>
<br>
# Policy controlling what to do when the buffer is empty:<br>
# readback (default), do_nothing, block<br>
port.inport.in.buffer.read.empty_policy: block<br>
<br>
<br>
You will need to add lines to the rtc.conf file to tell it that this<br>
configuration file is for your component:<br>
<br>
comp_category.comp_name.config_file: mycomp.conf<br>
<br>
<br>
For your situation, I recommend using either the Flush or New publisher<br>
(use New if your component cannot be allowed to block) and setting the<br>
buffer on the receiving end to 1. You could also use a pull connection,<br>
but this will delay the receiving component while the data is transferred.<br>
<br>
Don't forget that you can also write your own publishers and load them<br>
as plugins.<br>
<br>
Geoff<br>
<div><div></div><div class="h5"><br>
<br>
On 10/10/10 11:55, Tony Kuo wrote:<br>
> Dear OpenRTM ML:<br>
><br>
> I have always been using the default flush subscription type when i<br>
> connect my components in RTSystemEditor.<br>
> But I don't know how is it different to the "new" subscription type?<br>
><br>
> I found a slide that explains that but is not clear.<br>
> slide 19 on<br>
> <a href="http://www.openrtm.org/OpenRTM-aist/download/resume/070523/070523-01.pdf" target="_blank">http://www.openrtm.org/OpenRTM-aist/download/resume/070523/070523-01.pdf</a><br>
><br>
> What I actually want to do is,<br>
> I wanna make sure whenever I read data in from one of the data port in<br>
> my component, I get the newest data no matter how many data are already<br>
> in the connector buffer (i.e. discard all except the newest one)<br>
><br>
> If you can point me in the right direction,<br>
> it's very much appreciated!<br>
><br>
> Thanks<br>
> Tony<br>
><br>
<br>
</div></div></blockquote></div><br>