當前位置: 首頁>>代碼示例>>Java>>正文


Java Observation.getPhenomenonTime方法代碼示例

本文整理匯總了Java中de.fraunhofer.iosb.ilt.sta.model.Observation.getPhenomenonTime方法的典型用法代碼示例。如果您正苦於以下問題:Java Observation.getPhenomenonTime方法的具體用法?Java Observation.getPhenomenonTime怎麽用?Java Observation.getPhenomenonTime使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在de.fraunhofer.iosb.ilt.sta.model.Observation的用法示例。


在下文中一共展示了Observation.getPhenomenonTime方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: isValid

import de.fraunhofer.iosb.ilt.sta.model.Observation; //導入方法依賴的package包/類
@Override
public boolean isValid(Observation obs) throws ProcessException {
    try {
        Instant latest;
        Datastream ds = obs.getDatastream();
        if (ds == null) {
            MultiDatastream mds = obs.getMultiDatastream();
            if (mds == null) {
                throw new ProcessException("Observation has no Datastream of Multidatastream set!");
            }
            latest = getTimeForMultiDatastream(mds);
        } else {
            latest = getTimeForDatastream(ds);
        }
        TimeObject phenomenonTime = obs.getPhenomenonTime();
        Instant obsInstant;
        if (phenomenonTime.isInterval()) {
            obsInstant = phenomenonTime.getAsInterval().getStart();
        } else {
            obsInstant = phenomenonTime.getAsDateTime().toInstant();
        }
        return latest.isBefore(obsInstant);
    } catch (ServiceFailureException ex) {
        throw new ProcessException("Failed to validate.", ex);
    }
}
 
開發者ID:hylkevds,項目名稱:SensorThingsProcessor,代碼行數:27,代碼來源:ValidatorNewer.java

示例2: getTimeForDatastream

import de.fraunhofer.iosb.ilt.sta.model.Observation; //導入方法依賴的package包/類
private Instant getTimeForDatastream(Datastream ds) throws ServiceFailureException {
    Id dsId = ds.getId();
    Instant latest = datastreamCache.get(dsId);
    if (latest == null) {
        Observation firstObs = ds.observations().query().select("@iot.id", "phenomenonTime").orderBy("phenomenonTime desc").first();
        if (firstObs == null) {
            latest = Instant.MIN;
        } else {
            TimeObject phenomenonTime = firstObs.getPhenomenonTime();
            if (phenomenonTime.isInterval()) {
                latest = phenomenonTime.getAsInterval().getStart();
            } else {
                latest = phenomenonTime.getAsDateTime().toInstant();
            }
        }
        datastreamCache.put(dsId, latest);
    }
    return latest;
}
 
開發者ID:hylkevds,項目名稱:SensorThingsProcessor,代碼行數:20,代碼來源:ValidatorNewer.java

示例3: getTimeForMultiDatastream

import de.fraunhofer.iosb.ilt.sta.model.Observation; //導入方法依賴的package包/類
private Instant getTimeForMultiDatastream(MultiDatastream mds) throws ServiceFailureException {
    Id dsId = mds.getId();
    Instant latest = multiDatastreamCache.get(dsId);
    if (latest == null) {
        Observation firstObs = mds.observations().query().select("@iot.id", "phenomenonTime").orderBy("phenomenonTime desc").first();
        if (firstObs == null) {
            latest = Instant.MIN;
        } else {
            TimeObject phenomenonTime = firstObs.getPhenomenonTime();
            if (phenomenonTime.isInterval()) {
                latest = phenomenonTime.getAsInterval().getStart();
            } else {
                latest = phenomenonTime.getAsDateTime().toInstant();
            }
        }
        multiDatastreamCache.put(dsId, latest);
    }
    return latest;
}
 
開發者ID:hylkevds,項目名稱:SensorThingsProcessor,代碼行數:20,代碼來源:ValidatorNewer.java

示例4: getDefinedProperties

import de.fraunhofer.iosb.ilt.sta.model.Observation; //導入方法依賴的package包/類
private Set<DataArrayValue.Property> getDefinedProperties(Observation o) {
    Set<DataArrayValue.Property> value = new HashSet<>();
    value.add(DataArrayValue.Property.Result);
    if (o.getPhenomenonTime() != null) {
        value.add(DataArrayValue.Property.PhenomenonTime);
    }
    if (o.getResultTime() != null) {
        value.add(DataArrayValue.Property.ResultTime);
    }
    if (o.getResultQuality() != null) {
        value.add(DataArrayValue.Property.ResultQuality);
    }
    if (o.getParameters() != null) {
        value.add(DataArrayValue.Property.Parameters);
    }
    if (o.getValidTime() != null) {
        value.add(DataArrayValue.Property.ValidTime);
    }
    return value;
}
 
開發者ID:hylkevds,項目名稱:SensorThingsProcessor,代碼行數:21,代碼來源:Service.java

示例5: isValid

import de.fraunhofer.iosb.ilt.sta.model.Observation; //導入方法依賴的package包/類
@Override
public boolean isValid(Observation obs) throws ProcessException {
    TimeObject phenomenonTime = obs.getPhenomenonTime();
    Instant obsInstant;
    if (phenomenonTime.isInterval()) {
        obsInstant = phenomenonTime.getAsInterval().getStart();
    } else {
        obsInstant = phenomenonTime.getAsDateTime().toInstant();
    }
    return refTime.isBefore(obsInstant);
}
 
開發者ID:hylkevds,項目名稱:SensorThingsProcessor,代碼行數:12,代碼來源:ValidatorAfter.java

示例6: isValid

import de.fraunhofer.iosb.ilt.sta.model.Observation; //導入方法依賴的package包/類
@Override
public boolean isValid(Observation obs) throws ProcessException {
    TimeObject phenomenonTime = obs.getPhenomenonTime();
    Instant obsInstant;
    if (phenomenonTime.isInterval()) {
        obsInstant = phenomenonTime.getAsInterval().getStart();
    } else {
        obsInstant = phenomenonTime.getAsDateTime().toInstant();
    }
    return refTime.isAfter(obsInstant);
}
 
開發者ID:hylkevds,項目名稱:SensorThingsProcessor,代碼行數:12,代碼來源:ValidatorBefore.java

示例7: calculateAggregates

import de.fraunhofer.iosb.ilt.sta.model.Observation; //導入方法依賴的package包/類
private void calculateAggregates(AggregateCombo combo) throws ServiceFailureException, ProcessException {
    Observation lastAggObs = combo.getLastForTarget();

    Instant calcIntervalStart;
    if (lastAggObs == null) {
        Observation firstSourceObs = combo.getFirstForSource();
        if (firstSourceObs == null) {
            LOGGER.debug("No source observations at all for {}.", combo);
            return;
        }
        Instant firstSourceStart = getPhenTimeStart(firstSourceObs);

        ZonedDateTime atZone = firstSourceStart.atZone(combo.getZoneId());
        ZonedDateTime firstIntStart = combo.level.toIntervalStart(atZone);
        if (atZone.isEqual(firstIntStart)) {
            calcIntervalStart = firstIntStart.toInstant();
        } else {
            calcIntervalStart = firstIntStart.plus(combo.level.duration).toInstant();
        }

    } else {
        TimeObject lastAggPhenTime = lastAggObs.getPhenomenonTime();
        calcIntervalStart = lastAggPhenTime.getAsInterval().getEnd();
    }
    Observation lastSourceObs = combo.getLastForSource();
    if (lastSourceObs == null) {
        LOGGER.debug("No source observations at all for {}.", combo);
        return;
    }
    Instant lastSourcePhenTime = getPhenTimeEnd(lastSourceObs);

    boolean more = true;
    while (more) {
        Instant calcIntervalEnd = calcIntervalStart.plus(combo.level.duration);

        if (lastSourcePhenTime.isBefore(calcIntervalEnd)) {
            LOGGER.info("Nothing (more) to do for {}.", combo);
            return;
        }

        calculateAggregate(combo, Interval.of(calcIntervalStart, calcIntervalEnd));
        calcIntervalStart = calcIntervalEnd;
    }

}
 
開發者ID:hylkevds,項目名稱:SensorThingsProcessor,代碼行數:46,代碼來源:ProcessorBatchAggregate.java

示例8: getPhenTimeStart

import de.fraunhofer.iosb.ilt.sta.model.Observation; //導入方法依賴的package包/類
private static Instant getPhenTimeStart(Observation obs) {
    TimeObject phenTime = obs.getPhenomenonTime();
    return getPhenTimeStart(phenTime);
}
 
開發者ID:hylkevds,項目名稱:SensorThingsProcessor,代碼行數:5,代碼來源:ProcessorBatchAggregate.java

示例9: getPhenTimeEnd

import de.fraunhofer.iosb.ilt.sta.model.Observation; //導入方法依賴的package包/類
private static Instant getPhenTimeEnd(Observation obs) {
    TimeObject phenTime = obs.getPhenomenonTime();
    return getPhenTimeEnd(phenTime);
}
 
開發者ID:hylkevds,項目名稱:SensorThingsProcessor,代碼行數:5,代碼來源:ProcessorBatchAggregate.java


注:本文中的de.fraunhofer.iosb.ilt.sta.model.Observation.getPhenomenonTime方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。