Skip to content

SchedulerExampleAgent

Jereme Haack edited this page Sep 25, 2014 · 3 revisions

The SchedulerExampleAgent demonstrates how to use the scheduling feature of the ActuatorAgent as well as how to send a command. This agent publishes a request for a reservation on a (fake) device then takes an action when it's scheduled time appears.

Note: Since there is no actual device, an error is produced when the agent attempts to take its action.

    @periodic(settings.SCHEDULE_PERIOD)
    def publish_schedule(self):
        '''Periodically publish a schedule request'''
        headers = {
                    'AgentID': self._agent_id,
                    'type': 'NEW_SCHEDULE',
                    'requesterID': self._agent_id, #The name of the requesting agent.
                    'taskID': self._agent_id + "-ExampleTask", 
                    #The desired task ID for this task. It must be unique among all other scheduled tasks.
                    'priority': 'LOW', #The desired task priority, must be 'HIGH', 'LOW', or 'LOW_PREEMPT'
                } 
        
        start = str(datetime.datetime.now())
        end = str(datetime.datetime.now() + datetime.timedelta(minutes=1))


        msg = [
               ['campus/building/unit',start,end]
            ]
        self.publish_json(topics.ACTUATOR_SCHEDULE_REQUEST, headers, msg)

The agent listens to schedule announcements from the actuator

    @matching.match_exact(topics.ACTUATOR_SCHEDULE_ANNOUNCE(campus='campus',
                                         building='building',unit='unit'))
    @matching.match_headers({headers_mod.REQUESTER_ID: agent_id})
    def actuate(self, topic, headers, message, match):
        '''Match the announce for our fake device with our ID
        Then take an action. Note, this command will fail since there is no 
        actual device'''
        headers = {
                    'requesterID': self._agent_id,
                   }
        self.publish_json(topics.ACTUATOR_SET(campus='campus',
                                         building='building',unit='unit',
                                         point='point'),
                                 headers, str(0.0))

Wiki Home

Quick Start Guide

Getting VOLTTRON

VOLTTRON Community

VOLTTRON Core Services

Historians

Drivers

Instance Management

Applications
  • ...
Examples
Developers
HOWTOS

VOLTTRON Versions and Features

Transactional Network Platform Overview

Platform Services

Volttron Restricted

Information Exchange Standards

FAQ

Project Home

Clone this wiki locally