Skip to content

Commit

Permalink
Extract minimum from uniform sampling
Browse files Browse the repository at this point in the history
  • Loading branch information
alexbeattie42 committed Nov 27, 2024
1 parent 761264b commit c8c7bab
Showing 1 changed file with 12 additions and 8 deletions.
20 changes: 12 additions & 8 deletions OpenSim/Common/TableUtilities.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@
#include "PiecewiseLinearFunction.h"
#include "Signal.h"
#include "Storage.h"
#include <algorithm>
#include <numeric>
#include <vector>

Expand Down Expand Up @@ -122,7 +123,7 @@ int TableUtilities::findStateLabelIndexInternal(const std::string* begin,
}

template <typename T>
bool isUniform(const std::vector<T>& x) {
std::pair<bool,T> isUniform(const std::vector<T>& x) {

// Initialize step as NaN
T step = std::numeric_limits<T>::quiet_NaN();
Expand Down Expand Up @@ -154,8 +155,13 @@ bool isUniform(const std::vector<T>& x) {
if (!tf && x.size() == 2) {
tf = true; // Handle special case for two elements
}
if (tf) {
step = mean_step;
} else {
step = *std::min_element(results.begin()+1, results.end());
}

return tf;
return {tf, step};
}

void TableUtilities::filterLowpass(
Expand All @@ -172,15 +178,13 @@ void TableUtilities::filterLowpass(
const auto& time = table.getIndependentColumn();

double dtMin = SimTK::Infinity;
for (int irow = 1; irow < numRows; ++irow) {
double dt = time[irow] - time[irow - 1];
if (dt < dtMin) dtMin = dt;
}
const auto uniform = isUniform(time);
const auto &uniformlySampled = uniform.first;
dtMin = uniform.second;

OPENSIM_THROW_IF(
dtMin < SimTK::Eps, Exception, "Storage cannot be resampled.");

const bool uniformlySampled = isUniform(time);

// Resample if the sampling interval is not uniform.
if (!uniformlySampled) {
table = resampleWithInterval(table, dtMin);
Expand Down

0 comments on commit c8c7bab

Please sign in to comment.