Payload Scheduling with Dynamic (Re)Tasking

Payload Scheduling with Dynamic (Re)Tasking

<p>Tasking Information for Spring 2006 UCD Math Clinic</p><p>Dynamic Scheduling of Prioritized Tasks Tasking and Allocation information using commercial remote sensing satellite tasking as a real-world example</p><p>Task Data A task represents a user’s request for the satellite to perform some activity. In the context of the 2006 Math Clinic, a task represents a request to perform remote sensing of the Earth (e.g. to take a picture). A more accurate term for task is Collection Requirement (CR). In some systems, the CR is the external request and the Task is the translation of the collection requirement into a software object that the mission scheduling system can interpret. For our purposes the two terms can be used interchangeably.</p><p>The format for a task will be an ASCII text file in XML format. There are freeware libraries that support XML parsing, such as Xerces (for both Java and C++, at http://xml.apache.org) or xmltools.m (for Matlab Release R13, at http://mathworks.com/matlabcentral/ under the File Exchange link do a search for “xml parsing”). XML parsing can also be done natively within Matlab if you know JAXP.</p><p>XML is a text format that holds elements and attributes. An element is defined with angle brackets (<ElementName>) to indicate the start of the definition and angle brackets with a preceding slash (</ElementName>) to indicate the end of the definition. Elements can have attributes and contain child elements. For example, <SomeElement> <SomeChildElement1>This is text for this child element.</SomeChildElement1> <SomeChildElement2 attribute1=”abc” attribute2=”xyz”> </SomeChildElement2> </SomeElement> All XML documents start with a special element, with at least one special version attribute. You don’t have to worry about this, just know that it needs to be there to be considered a valid XML document. It looks like this, <?xml version=1.0” encoding=”UTF-8” ?></p><p>For our XML tasking document, it will have this basic structure, <CollectionRequirements> <CollectionRequirement TaskID=”xxx” duration=”N” effectiveEnd=”DD-MMM-YYYY HH:mm:SS effectiveStart=” DD-MMM-YYYY HH:mm:SS preferEnd=” DD-MMM-YYYY HH:mm:SS preferStart=” DD-MMM-YYYY HH:mm:SS priority=”nnn” strategy=”simple | monitor” minRevisit=”nn” maxRevisit=”nn” timeCritcal=”true|false” quality=”n.n” requester=”xxx”> <Target TargetID=”xxx” latitude=”nn.nnn” longitude=”nn.nnn”> </Target> </CollectionRequirement> </CollectionRequirements> Obviously there will be one or more CollectionRequirement elements as child elements to the CollectionRequirements root element. All attributes are quoted strings. You can ignore the timeCritical, quality and requester attributes. The duration attribute will always be a fixed value of 5 for all CRs and its </p><p>1 Tasking Information for Spring 2006 UCD Math Clinic units are in seconds. The priority is an integer (0 – 999), and latitude and longitude are units of degrees (expressed as a float or double). The strategy is either simple or monitor. If the strategy is monitor, then the sensor must periodically revisit the same target. All the monitor collections must be within the preferred window (hard constraint) and the min/max revisit values will be greater than zero. The minRevisit attribute will specify the minimum number of collections that must take place on the target, and the maxRevisit specifies the maximum number of collections that could take place on the target. Scheduling more than the minRevisit and less or equal to the maxRevisit is a bonus (objective function incentive). Scheduling more monitor collections than the maxRevisit is a soft constraint violation (a waste of the resource). The rule of thumb for monitor tasks is that they should be evenly distributed across the preferred (surveillance) window.</p><p>Soft Constraint Violation</p><p>Preferred Interval Effective Interval Simple Task</p><p>Hard Constraint Violation</p><p>Preferred Interval Effective Interval Monitor Task</p><p><CollectionRequirements> <CollectionRequirement TaskID="ABC1" duration="5" effectiveEnd="01- Sep-2005 14:30:00" effectiveStart="01-Sep-2005 13:30:00" preferEnd="01-Sep-2005 14:25:02" preferStart="01-Sep-2005 13:45:43" priority="7" timeCritical="false" quality="0.6" requester="User_A" type="SIMPLE"> <Target TargetID="ABC1target" latitude="32.16884781892938" longitude="41.37348292288451" /> </CollectionRequirement> <CollectionRequirement TaskID="ABC2" duration="5" effectiveEnd="01- Sep-2005 14:30:00" effectiveStart="01-Sep-2005 13:30:00" preferEnd="01-Sep-2005 14:25:44" preferStart="01-Sep-2005 13:30:22" priority="23" minRevisit="3" maxRevisit="10" requester="User_A" timeCritical="false" quality="1.0" type="MONITOR"> <Target TargetID="ABC2target" latitude="31.23661352959109" longitude="42.649705157290526" /> </CollectionRequirement> </CollectionRequirements></p><p>2 Tasking Information for Spring 2006 UCD Math Clinic</p><p>Allocation Data To schedule a task means that you have “allocated” that task to a resource, or that you have created an “allocation”. The allocations you produce, that represent your schedule, should have the following format: ID a string that identifies this allocation TaskID a string that references the associated task ID State a single digit (0-2) that indicates NEW/MODIFY/DELETE StartTime a date + time, down to the second EndTime a date + time, down to the second Your schedule could be held in memory, a flat file or a database. If it is held in memory for some number of runs, then there should be a facility to eventually persist the schedule to a flat file or database for post analysis.</p><p>3</p>

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    3 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us