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

org.chocosolver.solver.variables.view.ViewDeltaMonitor Maven / Gradle / Ivy

There is a newer version: 4.10.17
Show newest version
/*
 * This file is part of choco-solver, http://choco-solver.org/
 *
 * Copyright (c) 2022, IMT Atlantique. All rights reserved.
 *
 * Licensed under the BSD 4-clause license.
 *
 * See LICENSE file in the project root for full license information.
 */
package org.chocosolver.solver.variables.view;

import gnu.trove.list.array.TIntArrayList;
import org.chocosolver.solver.exception.ContradictionException;
import org.chocosolver.solver.variables.delta.IIntDeltaMonitor;
import org.chocosolver.util.procedure.IntProcedure;
import org.chocosolver.util.procedure.SafeIntProcedure;

/**
 * A delta monitor dedicated to views
 * 
* * @author Charles Prud'homme * @since 11/01/13 */ public abstract class ViewDeltaMonitor implements IIntDeltaMonitor { private class Filler implements SafeIntProcedure { @Override public void execute(int i) { values.add(i); } } private final IIntDeltaMonitor deltamonitor; private final TIntArrayList values; private final Filler filler; public ViewDeltaMonitor(IIntDeltaMonitor deltamonitor) { this.deltamonitor = deltamonitor; values = new TIntArrayList(8); filler = new Filler(); } @Override public void startMonitoring() { this.deltamonitor.startMonitoring(); } @Override public void forEachRemVal(SafeIntProcedure proc) { values.resetQuick(); deltamonitor.forEachRemVal(filler); for (int i = 0; i < values.size(); i++) { proc.execute(transform(values.getQuick(i))); } } @Override public void forEachRemVal(IntProcedure proc) throws ContradictionException { values.resetQuick(); deltamonitor.forEachRemVal(filler); for (int i = 0; i < values.size(); i++) { proc.execute(transform(values.getQuick(i))); } } @Override public int sizeApproximation() { return deltamonitor.sizeApproximation(); } protected abstract int transform(int value); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy