/*******************************************************************************
* Copyright 2014 Analog Devices, Inc.
*
* 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 com.analog.lyric.dimple.test.options;
import static org.junit.Assert.*;
import org.junit.Test;
import com.analog.lyric.dimple.environment.DimpleEnvironment;
import com.analog.lyric.dimple.model.core.FactorGraph;
import com.analog.lyric.dimple.options.BPOptions;
import com.analog.lyric.dimple.options.SolverOptions;
import com.analog.lyric.dimple.solvers.core.SFactorGraphBase;
import com.analog.lyric.dimple.solvers.core.multithreading.MultiThreadingManager;
import com.analog.lyric.dimple.test.DimpleTestBase;
import com.analog.lyric.dimple.test.dummySolver.DummyFactorGraph;
/**
* Tests behavior of {@link SolverOptions} on {@link SFactorGraphBase}.
* <p>
* There are test cases for createFactorTableOnInit and maxAutomaticFactorTableSize in
* the TestSTableFactorBase test.
*/
public class TestSolverOptions extends DimpleTestBase
{
@Test
public void test()
{
// Test default values
assertEquals(1, BPOptions.iterations.defaultIntValue());
assertEquals(false, SolverOptions.enableMultithreading.defaultBooleanValue());
assertEquals(Integer.MAX_VALUE, SolverOptions.maxAutomaticFactorTableSize.defaultIntValue());
DimpleEnvironment env = DimpleEnvironment.active();
env.setOption(BPOptions.iterations, 42);
assertEquals((Integer)42, env.getOption(BPOptions.iterations));
env.setOption(SolverOptions.enableMultithreading, true);
assertEquals(true, env.getOption(SolverOptions.enableMultithreading));
FactorGraph fg = new FactorGraph();
assertEquals((Integer)42, fg.getOption(BPOptions.iterations));
assertEquals(true, fg.getOption(SolverOptions.enableMultithreading));
DummyFactorGraph sfg = new DummyFactorGraph(fg);
// Set manager so that calling useMultithreading(boolean) won't barf.
sfg.setMultithreadingManager(new MultiThreadingManager(sfg));
// Test pre-initialization state. Most if not all options are not updated until
// initialize() is called.
assertEquals((Integer)42, sfg.getOption(BPOptions.iterations));
assertEquals(1, sfg.getNumIterations());
assertEquals(true, sfg.getOption(SolverOptions.enableMultithreading));
assertFalse(sfg.useMultithreading());
// Test post-initialization state.
sfg.initialize();
assertEquals(42, sfg.getNumIterations());
assertTrue(sfg.useMultithreading());
// Make sure set* methods update option setting.
assertNull(sfg.getLocalOption(BPOptions.iterations));
sfg.setNumIterations(23);
assertEquals(23, sfg.getNumIterations());
assertEquals((Integer)23, sfg.getLocalOption(BPOptions.iterations));
assertNull(sfg.getLocalOption(SolverOptions.enableMultithreading));
sfg.useMultithreading(false);
assertFalse(sfg.useMultithreading());
assertEquals(false, sfg.getLocalOption(SolverOptions.enableMultithreading));
}
}