2 * Copyright (c) 2010-2021 Contributors to the openHAB project
4 * See the NOTICE file(s) distributed with this work for additional
7 * This program and the accompanying materials are made available under the
8 * terms of the Eclipse Public License 2.0 which is available at
9 * http://www.eclipse.org/legal/epl-2.0
11 * SPDX-License-Identifier: EPL-2.0
13 package org.openhab.binding.smhi.internal;
15 import java.math.BigDecimal;
16 import java.math.RoundingMode;
17 import java.util.List;
18 import java.util.Optional;
20 import org.eclipse.jdt.annotation.NonNullByDefault;
23 * @author Anders Alfredsson - Initial contribution
26 public class ForecastAggregator {
27 public static Optional<BigDecimal> max(TimeSeries timeSeries, int dayOffset, String parameter) {
28 List<Forecast> dayForecasts = timeSeries.getDay(dayOffset);
29 return dayForecasts.stream().map(forecast -> forecast.getParameter(parameter)).filter(Optional::isPresent)
30 .map(Optional::get).max(BigDecimal::compareTo);
33 public static Optional<BigDecimal> min(TimeSeries timeSeries, int dayOffset, String parameter) {
34 List<Forecast> dayForecasts = timeSeries.getDay(dayOffset);
35 return dayForecasts.stream().map(forecast -> forecast.getParameter(parameter)).filter(Optional::isPresent)
36 .map(Optional::get).min(BigDecimal::compareTo);
39 public static Optional<BigDecimal> total(TimeSeries timeSeries, int dayOffset, String parameter) {
40 List<Forecast> dayForecasts = timeSeries.getDay(dayOffset);
41 BigDecimal sum = dayForecasts.stream().map(forecast -> forecast.getParameter(parameter))
42 .filter(Optional::isPresent).map(Optional::get).reduce(BigDecimal::add).orElse(BigDecimal.ZERO);
43 BigDecimal mean = sum.divide(BigDecimal.valueOf(dayForecasts.size()), RoundingMode.HALF_UP);
44 return Optional.of(mean.multiply(BigDecimal.valueOf(24)));