/*
 * AP_Loop.pde
 * Copyright (C) James Goppert 2010 <james.goppert@gmail.com>
 *
 * This file is free software: you can redistribute it and/or modify it
 * under the terms of the GNU General Public License as published by the
 * Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This file is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * See the GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License along
 * with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

#include "AP_Loop.h"

Loop::Loop(float _frequency, void (*fptr)(void *), void * data) :
    _fptr(fptr),
    _data(data),
    _period(1.0e6/_frequency),
    _subLoops(),
    _timeStamp(micros()),
    _load(0),
    _dt(0)
{
}

void Loop::update()
{
    // quick exit if not ready
    if (micros() - _timeStamp < _period) return;

    // update time stamp
    uint32_t timeStamp0 = _timeStamp;
    _timeStamp = micros();
    _dt = (_timeStamp - timeStamp0)/1.0e6;

    // update sub loops
    for (uint8_t i=0; i<_subLoops.getSize(); i++) _subLoops[i]->update();

    // callback function
    if (_fptr) _fptr(_data);

    // calculated load with a low pass filter
    _load = 0.9*_load + 10*(float(micros()-_timeStamp)/(_timeStamp-timeStamp0));
}

// vim:ts=4:sw=4:expandtab