bool Rythmos::isInRange_cc(const TimeRange<TimeType> &tr, const TimeType &p) { return ( compareTimeValues(p,tr.lower()) >= 0 && compareTimeValues(p,tr.upper()) <= 0 ); }
static int compareAlarmEntries (const void *newItem, const void *existingItem, void *queueData) { const AlarmEntry *newAlarm = newItem; const AlarmEntry *existingAlarm = existingItem; return compareTimeValues(&newAlarm->time, &existingAlarm->time) < 0; }
int asyncExecuteAlarmCallback (AsyncAlarmData *ad, long int *timeout) { if (ad) { Queue *alarms = ad->alarmQueue; if (alarms) { Element *element = processQueue(alarms, testInactiveAlarm, NULL); if (element) { AlarmEntry *alarm = getElementItem(element); TimeValue now; long int milliseconds; getMonotonicTime(&now); milliseconds = millisecondsBetween(&now, &alarm->time); if (milliseconds <= 0) { AsyncAlarmCallback *callback = alarm->callback; const AsyncAlarmCallbackParameters parameters = { .now = &now, .data = alarm->data }; logSymbol(LOG_CATEGORY(ASYNC_EVENTS), callback, "alarm starting"); alarm->active = 1; if (callback) callback(¶meters); alarm->active = 0; if (alarm->reschedule) { adjustTimeValue(&alarm->time, alarm->interval); getMonotonicTime(&now); if (compareTimeValues(&alarm->time, &now) < 0) alarm->time = now; requeueElement(element); } else { alarm->cancel = 1; } if (alarm->cancel) deleteElement(element); return 1; } if (milliseconds < *timeout) { *timeout = milliseconds; logSymbol(LOG_CATEGORY(ASYNC_EVENTS), alarm->callback, "next alarm: %ld", *timeout); } } } } return 0; }
void assertBaseInterpolatePreconditions( const typename DataStore<Scalar>::DataStoreVector_t &data_in, const Array<Scalar> &t_values, typename DataStore<Scalar>::DataStoreVector_t *data_out ) { TEUCHOS_TEST_FOR_EXCEPTION( data_in.size()==0, std::logic_error, "Error, data_in.size() == 0!\n" ); Array<Scalar> time_vec; dataStoreVectorToVector<Scalar>(data_in, &time_vec, 0, 0, 0); assertTimePointsAreSorted<Scalar>(time_vec); assertTimePointsAreSorted<Scalar>(t_values); if (data_in.size() == 1) { TEUCHOS_TEST_FOR_EXCEPTION( t_values.size()>1, std::logic_error, "Error, data_in.size() == 1, but t_values.size() > 1!\n" ); TEUCHOS_TEST_FOR_EXCEPTION( compareTimeValues(t_values[0],data_in[0].time)!=0, std::logic_error, "Error, data_in.size) == 1, but t_values[0] = " << t_values[0] << " != " << data_in[0].time << " = data_in[0].time!\n" ); } TimeRange<Scalar> range(data_in.front().time,data_in.back().time); for (int i=0; i<Teuchos::as<int>(t_values.size()) ; ++i) { TEUCHOS_TEST_FOR_EXCEPTION( !range.isInRange(t_values[i]), std::out_of_range, "Error, t_values[" << i << "] = " << t_values[i] << " is not in range of data_in = " << range << "!\n" ); } TEUCHOS_TEST_FOR_EXCEPTION( data_out == 0, std::logic_error, "Error, data_out = NULL!\n" ); }