All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.alapierre.func.Reductors Maven / Gradle / Ivy

package io.alapierre.func;

import org.jetbrains.annotations.Contract;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;

import java.util.Comparator;
import java.util.Optional;
import java.util.function.BinaryOperator;
import java.util.stream.Stream;

/**
 * @author Adrian Lapierre {@literal }
 */
@SuppressWarnings("unused")
public class Reductors {

    /**
     * Returns min ane max value from given stream as a Pair
     *
     * @param stream input stream
     * @param comparator comparator for type of data in stream
     * @param  type od data
     * @return min and max value as Optional
     */
    public static  @NotNull Optional> minMax(@NotNull Stream stream, @NotNull Comparator comparator) {
        return stream
                .map(i -> new Pair<>(i /* "min" */, i /* "max" */))
                .reduce((a, b) -> new Pair<>(
                        // The min of the min elements.
                        comparator.compare(a.getKey(), b.getKey()) < 0 ? a.getKey() : b.getKey(),
                        // The max of the max elements.
                        comparator.compare(a.getValue(), b.getValue()) > 0 ? a.getValue() : b.getValue()));
    }

    /**
     * Returns min ane max value from given stream of comparable data as a Pair
     *
     * @param stream input stream of comparable objects
     * @param  type od data
     * @return min and max value as Optional
     */
    public static > @NotNull Optional> minMax(@NotNull Stream stream) {
        return stream
                .map(i -> new Pair<>(i /* "min" */, i /* "max" */))
                .reduce(minMax());
    }

    /**
     * Convenient way to get min value from given two comparable objects with null handling.
     *
     * @param a first value
     * @param b second value
     * @param  type od data
     * @return 'b' if 'a' is null or 'a' if 'b' is null or min from 'a' and 'b'
     */
    public static > T min(@Nullable T a, @Nullable T b) {
        return a == null ? b : (b == null ? a : (a.compareTo(b) < 0 ? a : b));
    }

    /**
     * Max value from given two comparable objects
     *
     * @param a first value
     * @param b second value
     * @param  type od data
     * @return 'b' if 'a' is null or 'a' if 'b' is null or max from 'a' and 'b'
     */
    public static > T max(@Nullable T a, @Nullable T b) {
        return a == null ? b : (b == null ? a : (a.compareTo(b) > 0 ? a : b));
    }

    @Contract(pure = true)
    private static > @NotNull BinaryOperator> minMax() {
        return (a, b) -> new Pair<>(
                // The min of the min elements.
                a.getKey().compareTo(b.getKey()) < 0 ? a.getKey() : b.getKey(),
                // The max of the max elements.
                a.getValue().compareTo(b.getValue()) > 0 ? a.getValue() : b.getValue());
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy