aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAleš Justin <ales.justin@gmail.com>2024-01-11 09:48:27 +0100
committerGitHub <noreply@github.com>2024-01-11 09:48:27 +0100
commit965e852ba7e9c153d6690d5aa195b3f673d79966 (patch)
tree9120b34547167a601254a47849398595e7e3940b
parent4a5eda70fd6a71b012f59c3ea9168fb2643280f6 (diff)
Simple, slow but very short. :-) (#240)
* Simple, slow but very short. :-) * Fix sync on DSS::accept.
-rwxr-xr-xcalculate_average_alesj.sh23
-rw-r--r--src/main/java/dev/morling/onebrc/CalculateAverage_alesj.java46
2 files changed, 69 insertions, 0 deletions
diff --git a/calculate_average_alesj.sh b/calculate_average_alesj.sh
new file mode 100755
index 0000000..2f0536d
--- /dev/null
+++ b/calculate_average_alesj.sh
@@ -0,0 +1,23 @@
+#!/bin/sh
+#
+# Copyright 2023 The original authors
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+
+# Uncomment below to use sdk
+# source "$HOME/.sdkman/bin/sdkman-init.sh"
+# sdk use java 21.0.1-graal 1>&2
+
+JAVA_OPTS=""
+time java $JAVA_OPTS --class-path target/average-1.0.0-SNAPSHOT.jar dev.morling.onebrc.CalculateAverage_alesj
diff --git a/src/main/java/dev/morling/onebrc/CalculateAverage_alesj.java b/src/main/java/dev/morling/onebrc/CalculateAverage_alesj.java
new file mode 100644
index 0000000..5dff006
--- /dev/null
+++ b/src/main/java/dev/morling/onebrc/CalculateAverage_alesj.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2023 The original authors
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package dev.morling.onebrc;
+
+import java.nio.file.Files;
+import java.nio.file.Paths;
+import java.util.DoubleSummaryStatistics;
+import java.util.Map;
+import java.util.TreeMap;
+import java.util.concurrent.ConcurrentHashMap;
+import java.util.stream.Stream;
+
+public class CalculateAverage_alesj {
+ public static void main(String[] args) throws Exception {
+ Map<String, DoubleSummaryStatistics> stations = new ConcurrentHashMap<>();
+ try (Stream<String> stream = Files.lines(Paths.get("./measurements.txt")).parallel()) {
+ stream.forEach(line -> {
+ String[] split = line.split(";");
+ stations.computeIfAbsent(split[0], k -> new DoubleSummaryStatistics() {
+ public synchronized void accept(double value) {
+ super.accept(value);
+ }
+
+ public String toString() {
+ return String.format("%.1f/%.1f/%.1f", getMin(), getAverage(), getMax());
+ }
+ })
+ .accept(Double.parseDouble(split[1]));
+ });
+ }
+ System.out.println(new TreeMap<>(stations));
+ }
+}