com.powsybl.metrix.mapping.EquipmentTimeSeriesWriter Maven / Gradle / Ivy
/*
* Copyright (c) 2020, RTE (http://www.rte-france.com)
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
* SPDX-License-Identifier: MPL-2.0
*/
package com.powsybl.metrix.mapping;
import com.google.common.collect.ImmutableSortedSet;
import com.google.common.collect.Range;
import com.powsybl.metrix.mapping.timeseries.TimeSeriesStoreUtil;
import com.powsybl.timeseries.*;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.UncheckedIOException;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.time.ZoneId;
import java.util.*;
/**
* @author Paul Bui-Quang {@literal }
*/
public class EquipmentTimeSeriesWriter {
private static final char SEPARATOR = ';';
private static final String OUTPUT_FILE_EXTENSION = ".csv";
private final Path dir;
private final String filename;
private final Map> doubleTimeSeries = new HashMap<>();
private TimeSeriesIndex index;
public EquipmentTimeSeriesWriter(Path dir, String filename) {
this.dir = Objects.requireNonNull(dir);
this.filename = Objects.requireNonNull(filename);
}
public void addTimeSeries(String timeSeriesName, Range pointRange, double[] values, TimeSeriesIndex index) {
this.index = Objects.requireNonNull(index);
DoubleDataChunk chunk;
if (values.length == 1 && !pointRange.upperEndpoint().equals(pointRange.lowerEndpoint())) {
int length = pointRange.upperEndpoint() + 1;
chunk = new CompressedDoubleDataChunk(pointRange.lowerEndpoint(), length, new double[]{values[0]}, new int[]{length});
} else {
chunk = new UncompressedDoubleDataChunk(pointRange.lowerEndpoint(), values).tryToCompress();
}
doubleTimeSeries.computeIfAbsent(timeSeriesName, k -> new ArrayList<>());
doubleTimeSeries.get(timeSeriesName).add(chunk);
}
public void versionEnd(int version) {
try (BufferedWriter writer = Files.newBufferedWriter(dir.resolve(filename + version + OUTPUT_FILE_EXTENSION), StandardCharsets.UTF_8)) {
List timeSeriesList = new ArrayList<>();
for (Map.Entry> e : doubleTimeSeries.entrySet()) {
String timeSeriesName = e.getKey();
List chunks = e.getValue();
TimeSeriesMetadata metadata = new TimeSeriesMetadata(timeSeriesName, TimeSeriesDataType.DOUBLE, index);
timeSeriesList.add(new StoredDoubleTimeSeries(metadata, chunks));
}
if (!timeSeriesList.isEmpty()) {
ReadOnlyTimeSeriesStoreCache store = new ReadOnlyTimeSeriesStoreCache(timeSeriesList);
TimeSeriesStoreUtil.writeCsv(store, writer, SEPARATOR, ZoneId.of("UTC"), ImmutableSortedSet.of(version), doubleTimeSeries.keySet());
}
} catch (IOException e) {
throw new UncheckedIOException(e);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy