Merged in the Blinky app's functionality

Publishes data when the timer of 1s awakes, not when samplesize > samplerate,
as empty measurements are skipped, which can lead to a change in
publishing time.
master
denes 6 years ago
parent fa3a52a200
commit 327c431a8e

@ -1,14 +1,18 @@
#include "MovesenseExerciseService.h" #include "MovesenseExerciseService.h"
#include "app-resources/resources.h" #include "app-resources/resources.h"
#include "common/core/debug.h" #include "common/core/debug.h"
#include "meas_acc/resources.h" #include "meas_acc/resources.h"
#include "whiteboard/builtinTypes/UnknownStructure.h" #include "whiteboard/builtinTypes/UnknownStructure.h"
#include "ui_ind/resources.h"
#include <float.h> #include <float.h>
#include <math.h> #include <math.h>
const char* const MovesenseExerciseService::LAUNCHABLE_NAME = "SampleA"; const char* const MovesenseExerciseService::LAUNCHABLE_NAME = "MExercise";
#define SAMPLE_RATE 13 #define SAMPLE_RATE 13
const size_t BLINK_PERIOD_MS = 1000;
static const whiteboard::ExecutionContextId sExecutionContextId = static const whiteboard::ExecutionContextId sExecutionContextId =
WB_RES::LOCAL::EXERCISE_SUMVECTOR_DENES::EXECUTION_CONTEXT; WB_RES::LOCAL::EXERCISE_SUMVECTOR_DENES::EXECUTION_CONTEXT;
@ -16,11 +20,27 @@ static const whiteboard::LocalResourceId sProviderResources[] = {
WB_RES::LOCAL::EXERCISE_SUMVECTOR_DENES::LID, WB_RES::LOCAL::EXERCISE_SUMVECTOR_DENES::LID,
}; };
namespace {
whiteboard::FloatVector3D SumVectorAverage(const std::vector<whiteboard::FloatVector3D>& v)
{
whiteboard::FloatVector3D sum;
for (size_t i = 0; i < v.size(); i++)
{
whiteboard::FloatVector3D fv = v[i];
sum += fv;
}
return sum / (float)v.size();
}
}
MovesenseExerciseService::MovesenseExerciseService() MovesenseExerciseService::MovesenseExerciseService()
: ResourceClient(WBDEBUG_NAME(__FUNCTION__), sExecutionContextId), : ResourceClient(WBDEBUG_NAME(__FUNCTION__), sExecutionContextId),
ResourceProvider(WBDEBUG_NAME(__FUNCTION__), sExecutionContextId), ResourceProvider(WBDEBUG_NAME(__FUNCTION__), sExecutionContextId),
LaunchableModule(LAUNCHABLE_NAME, sExecutionContextId), LaunchableModule(LAUNCHABLE_NAME, sExecutionContextId),
isRunning(false) isRunning(false),
mLastTimeStamp(0),
mTimer(whiteboard::ID_INVALID_TIMER),
mMaxAccelerationData(SAMPLE_RATE)
{ {
} }
@ -50,9 +70,21 @@ bool MovesenseExerciseService::startModule()
{ {
mModuleState = WB_RES::ModuleStateValues::STARTED; mModuleState = WB_RES::ModuleStateValues::STARTED;
// Start LED timer. true = trigger repeatedly
mTimer = ResourceClient::startTimer(BLINK_PERIOD_MS, true);
return true; return true;
} }
void MovesenseExerciseService::stopModule()
{
mModuleState = WB_RES::ModuleStateValues::STOPPED;
// Stop LED timer
ResourceClient::stopTimer(mTimer);
mTimer = whiteboard::ID_INVALID_TIMER;
}
void MovesenseExerciseService::onUnsubscribeResult(whiteboard::RequestId requestId, void MovesenseExerciseService::onUnsubscribeResult(whiteboard::RequestId requestId,
whiteboard::ResourceId resourceId, whiteboard::ResourceId resourceId,
whiteboard::Result resultCode, whiteboard::Result resultCode,
@ -86,10 +118,6 @@ whiteboard::Result MovesenseExerciseService::startRunning(whiteboard::RequestId&
DEBUGLOG("MovesenseExerciseService::startRunning()"); DEBUGLOG("MovesenseExerciseService::startRunning()");
// Reset max acceleration members
mMaxAccelerationSq = FLT_MIN;
mSamplesIncluded = 0;
wb::Result result = getResource("Meas/Acc/13", mMeasAccResourceId); wb::Result result = getResource("Meas/Acc/13", mMeasAccResourceId);
if (!wb::RETURN_OKC(result)) if (!wb::RETURN_OKC(result))
{ {
@ -157,36 +185,11 @@ void MovesenseExerciseService::onNotify(whiteboard::ResourceId resourceId, const
const whiteboard::Array<whiteboard::FloatVector3D>& arrayData = linearAccelerationValue.arrayAcc; const whiteboard::Array<whiteboard::FloatVector3D>& arrayData = linearAccelerationValue.arrayAcc;
uint32_t relativeTime = linearAccelerationValue.timestamp; mLastTimeStamp = linearAccelerationValue.timestamp;
for (size_t i = 0; i < arrayData.size(); i++) for (size_t i = 0; i < arrayData.size(); i++)
{ {
mSamplesIncluded++; mMaxAccelerationData.push_back(arrayData[i]);
whiteboard::FloatVector3D accValue = arrayData[i];
float accelerationSq = accValue.mX * accValue.mX +
accValue.mY * accValue.mY +
accValue.mZ * accValue.mZ;
if (mMaxAccelerationSq < accelerationSq)
mMaxAccelerationSq = accelerationSq;
}
// 13Hz 5sec
if (mSamplesIncluded > 5 * 13)
{
// Reset counter and notify our subscribers
WB_RES::SampleDataValue sampleDataValue;
sampleDataValue.relativeTime = relativeTime;
sampleDataValue.value = sqrtf(mMaxAccelerationSq);
// Reset members
mSamplesIncluded = 0;
mMaxAccelerationSq = FLT_MIN;
// and update our WB resource. This causes notification to be fired to our subscribers
updateResource(WB_RES::LOCAL::EXERCISE_SUMVECTOR_DENES(),
ResponseOptions::Empty, sampleDataValue);
} }
} }
break; break;
@ -250,3 +253,30 @@ void MovesenseExerciseService::onClientUnavailable(whiteboard::ClientId clientId
DEBUGLOG("MovesenseExerciseService::onClientUnavailable()"); DEBUGLOG("MovesenseExerciseService::onClientUnavailable()");
stopRunning(); stopRunning();
} }
void MovesenseExerciseService::onTimer(whiteboard::TimerId timerId)
{
if (timerId != mTimer)
{
return;
}
uint16_t indicationType = 2; // SHORT_VISUAL_INDICATION, defined in ui/ind.yaml
// Make PUT request to trigger led blink
asyncPut(WB_RES::LOCAL::UI_IND_VISUAL::ID, AsyncRequestOptions::Empty, indicationType);
// Notify our subscribers
/// @todo The timestamp is the last measurement's timestamp and not the current time.
WB_RES::SampleDataValue sampleDataValue;
sampleDataValue.relativeTime = mLastTimeStamp;
sampleDataValue.value = SumVectorAverage(mMaxAccelerationData);
// Reset members
mLastTimeStamp = 0;
mMaxAccelerationData.clear();
// and update our WB resource. This causes notification to be fired to our subscribers
updateResource(WB_RES::LOCAL::EXERCISE_SUMVECTOR_DENES(),
ResponseOptions::Empty, sampleDataValue);
}

@ -7,6 +7,8 @@
#include "wb-resources/resources.h" #include "wb-resources/resources.h"
#include <vector>
class MovesenseExerciseService FINAL : private whiteboard::ResourceClient, class MovesenseExerciseService FINAL : private whiteboard::ResourceClient,
private whiteboard::ResourceProvider, private whiteboard::ResourceProvider,
public whiteboard::LaunchableModule public whiteboard::LaunchableModule
@ -18,6 +20,14 @@ public:
MovesenseExerciseService(); MovesenseExerciseService();
~MovesenseExerciseService(); ~MovesenseExerciseService();
protected:
/**
* Timer callback.
*
* @param timerId Id of timer that triggered
*/
virtual void onTimer(whiteboard::TimerId timerId) OVERRIDE;
private: private:
/** @see whiteboard::ILaunchableModule::initModule */ /** @see whiteboard::ILaunchableModule::initModule */
virtual bool initModule() OVERRIDE; virtual bool initModule() OVERRIDE;
@ -29,7 +39,7 @@ private:
virtual bool startModule() OVERRIDE; virtual bool startModule() OVERRIDE;
/** @see whiteboard::ILaunchableModule::stopModule */ /** @see whiteboard::ILaunchableModule::stopModule */
virtual void stopModule() OVERRIDE { mModuleState = WB_RES::ModuleStateValues::STOPPED; } virtual void stopModule() OVERRIDE;
/** /**
* Subscribe notification callback. * Subscribe notification callback.
@ -118,6 +128,10 @@ private:
whiteboard::RequestMap<2, void> mOngoingRequests; // For storing relations of incoming & outgoing requests whiteboard::RequestMap<2, void> mOngoingRequests; // For storing relations of incoming & outgoing requests
bool isRunning; bool isRunning;
whiteboard::TimerId mTimer;
size_t mSamplesIncluded; size_t mSamplesIncluded;
float mMaxAccelerationSq; std::vector<whiteboard::FloatVector3D> mMaxAccelerationData;
uint32_t mLastTimeStamp;
}; };

@ -55,7 +55,6 @@ definitions:
format: uint32 format: uint32
x-unit: millisecond x-unit: millisecond
Value: Value:
description: Sample Data Value (in practice max absolute acceleration, over about 5 seconds when subscribed) description: Average acceleration, over 1 second
type: number $ref: 'http://localhost:9000/builtinTypes.yaml#/definitions/FloatVector3D'
format: float
x-unit: m/s^2 x-unit: m/s^2

Loading…
Cancel
Save