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

ml.comet.experiment.context.ExperimentContext Maven / Gradle / Ivy

There is a newer version: 1.1.14
Show newest version
package ml.comet.experiment.context;

import lombok.Data;
import lombok.NonNull;
import org.apache.commons.lang3.StringUtils;

import java.util.Objects;

/**
 * Describes context of the {@link ml.comet.experiment.Experiment}.
 */
@Data
public final class ExperimentContext {
    private Long step;
    private Long epoch;
    private String context;

    ExperimentContext() {
    }

    /**
     * Creates new instance with specified parameters.
     *
     * @param step    the current step of the experiment.
     * @param epoch   the current epoch of the experiment.
     * @param context the current context identifier of the data log operation.
     */
    public ExperimentContext(long step, long epoch, String context) {
        this.step = step;
        this.epoch = epoch;
        this.context = context;
    }

    /**
     * Creates new instance with specified parameters.
     *
     * @param step  the current step of the experiment.
     * @param epoch the current epoch of the experiment.
     */
    public ExperimentContext(long step, long epoch) {
        this(step, epoch, StringUtils.EMPTY);
    }

    /**
     * Creates new instance with specified parameters.
     *
     * @param step the current step of the experiment.
     */
    public ExperimentContext(long step) {
        this(step, 0);
    }

    /**
     * The copy constructor.
     *
     * @param other the other {@link ExperimentContext} to be used as source.
     */
    public ExperimentContext(ExperimentContext other) {
        this.step = other.step;
        this.epoch = other.epoch;
        this.context = other.context;
    }

    /**
     * Merges not empty values from other context into this one.
     *
     * @param other the context to be merged into this.
     */
    public void mergeFrom(@NonNull ExperimentContext other) {
        if (this == other) {
            return;
        }

        if (Objects.nonNull(other.step)) {
            this.step = other.step;
        }
        if (Objects.nonNull(other.epoch)) {
            this.epoch = other.epoch;
        }
        if (StringUtils.isNotBlank(other.context)) {
            this.context = other.context;
        }
    }

    /**
     * The factory to return empty {@link ExperimentContext} instance.
     *
     * @return the empty {@link ExperimentContext}
     */
    public static ExperimentContext empty() {
        return new ExperimentContext();
    }

    /**
     * Returns builder to create populated instance of the {@link ExperimentContext}.
     *
     * @return the builder to create populated instance of the {@link ExperimentContext}.
     */
    public static ExperimentContextBuilder builder() {
        return new ExperimentContextBuilder();
    }

    /**
     * Builder to create populated instance of the {@link ExperimentContext}.
     */
    public static final class ExperimentContextBuilder {
        private final ExperimentContext context;

        ExperimentContextBuilder() {
            this.context = new ExperimentContext();
        }

        /**
         * Populates context with specified step of the experiment.
         *
         * @param step the experiment's step.
         * @return the instance of this builder.
         */
        public ExperimentContextBuilder withStep(long step) {
            this.context.step = step;
            return this;
        }

        /**
         * Populates context with specified epoch of the experiment.
         *
         * @param epoch the epoch of the experiment.
         * @return the instance of this builder.
         */
        public ExperimentContextBuilder withEpoch(long epoch) {
            this.context.epoch = epoch;
            return this;
        }

        /**
         * Populates context with specified context identifier string.
         *
         * @param context the context identifier string.
         * @return the instance of this builder.
         */
        public ExperimentContextBuilder withContext(String context) {
            this.context.context = context;
            return this;
        }

        /**
         * Creates fully initialized {@link ExperimentContext} instance.
         *
         * @return the fully initialized {@link ExperimentContext} instance.
         */
        public ExperimentContext build() {
            return this.context;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy