Mission monitor sequencer
From Rsewiki
(Difference between revisions)
(New page: ===Introduction=== This plug-in implements a a language that is a mixture of a rule-based and a sequential based language. The idea is that a number of situations need permanent - or semi...) |
(→Introduction) |
||
Line 1: | Line 1: | ||
===Introduction=== | ===Introduction=== | ||
− | This plug-in implements a a language that is a mixture of a rule-based and a sequential based language. The idea is that a number of situations need permanent - or semi permanent - monitoring to get a good situation awareness for the root, | + | This plug-in implements a a language that is a mixture of a rule-based and a sequential based language. The idea is that a number of situations need permanent - or semi permanent - monitoring to get a good situation awareness for the root, and at the same time a large number of the robot tasks are better described by a sequential language. |
This implementation attempts to cover this gab. | This implementation attempts to cover this gab. |
Revision as of 06:56, 15 August 2008
Introduction
This plug-in implements a a language that is a mixture of a rule-based and a sequential based language. The idea is that a number of situations need permanent - or semi permanent - monitoring to get a good situation awareness for the root, and at the same time a large number of the robot tasks are better described by a sequential language.
This implementation attempts to cover this gab.
Language
An example function could look like this:
<?xml version="1.0" ?> <plan name="planB" full="true"> <init> gateFound = false <plan name="straight" if="not gateFound and odoPose.tripB < 100.0"> odoPose.tripB = odoPose.tripB + 15.1; if (odoPose.tripB > 80.0) break "planB" </plan> </init> print("started") enable("straight") # active - or until disabled. odoPose.tripB = 100.1 wait(1) : false; odoPose.tripB = 0.4 wait(99) : gateFound print("wait expired!!! - block print") <commands to="smr.send"> # through gate, turn right and re-find line near wall 'followline "bm" @v0.3: ($drivendist >0.37)' 'turn 90' + ' slut' </commands> <post> print("finsihed gate-on-the-loose") </post> </plan>
<plan name="planMain" full="default"> <init> powHi = 13.9 powLo = powHi - 3.5 <plan name="powerMon" if="power.low()"> print("Stopping - out of power") break pit </plan> energy = 66; </init> enable("powerMon") <commands to="print"> # through gate, turn right and re-find line near wall 'followline "bm" @v0.3: ($drivendist >0.37)' 'turn 90' + ' slut' </commands> wait(20) : false planB() <post> print("finished OK") </post> </plan>
A number of these plans can be started (enabled) simultaniously, an can in principle be total independant. I.e.one can control the robot arm whele another controls the navigation.