/******************************************************************************* * Copyright 2012 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; import static org.junit.Assert.*; import java.util.Arrays; import org.junit.Test; import com.analog.lyric.dimple.factorfunctions.core.FactorFunction; import com.analog.lyric.dimple.model.core.FactorGraph; import com.analog.lyric.dimple.model.factors.Factor; import com.analog.lyric.dimple.model.values.Value; import com.analog.lyric.dimple.model.variables.Bit; public class FactorFunctionWithConstantTest extends DimpleTestBase { protected static boolean debugPrint = true; // Test getting the list of directed edges from a factor-function with constants // This is a bit tricky since the list must exclude constant entries and renumber the remaining ones // to match the numbering of the remaining non-constant variable edges @Test public void test1() { int numBits = 10; Bit[] b = new Bit[numBits]; for (int i = 0; i < numBits; i++) b[i] = new Bit(); FactorGraph fg = new FactorGraph(); Factor f1 = fg.addFactor(new FF1(), b); Factor f2 = fg.addFactor(new FF1(), b[0], b[1], b[2], b[3], b[4], b[5], b[6], b[7], b[8], b[9]); Factor f3 = fg.addFactor(new FF1(), 0, b[1], b[2], b[3], b[4], b[5], 0, b[7], b[8], b[9]); Factor f4 = fg.addFactor(new FF1(), b[0], 0, b[2], 0, b[4], 0, 0, 0, b[8], b[9]); Factor f5 = fg.addFactor(new FF1(), b[0], b[1], b[2], 0, 0, b[5], b[6], b[7], b[8], b[9]); Factor f6 = fg.addFactor(new FF1(), b[0], b[1], b[2], 0, 0, b[5], b[6], b[7], b[8], 0); fg.initialize(); int[] d1 = f1.getDirectedTo(); int[] d2 = f2.getDirectedTo(); int[] d3 = f3.getDirectedTo(); int[] d4 = f4.getDirectedTo(); int[] d5 = f5.getDirectedTo(); int[] d6 = f6.getDirectedTo(); assertTrue(Arrays.equals(d1, new int[]{1, 3, 5, 6, 7})); assertTrue(Arrays.equals(d2, new int[]{1, 3, 5, 6, 7})); assertTrue(Arrays.equals(d3, new int[]{0, 2, 4, 5})); assertTrue(Arrays.equals(d4, new int[]{})); assertTrue(Arrays.equals(d5, new int[]{1, 3, 4, 5})); assertTrue(Arrays.equals(d6, new int[]{1, 3, 4, 5})); } public static class FF1 extends FactorFunction { @Override public final double evalEnergy(Value[] input) { return 0; } @Override public boolean isDirected() {return true;} @Override public int[] getDirectedToIndices(int numEdges) { return new int[]{1, 3, 5, 6, 7}; } } }