/******************************************************************************* * Copyright (C) 2009-2012 Dominik Jain. * * This file is part of ProbCog. * * ProbCog is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * ProbCog is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with ProbCog. If not, see <http://www.gnu.org/licenses/>. ******************************************************************************/ package probcog.srl.mln.inference; import java.util.ArrayList; import probcog.logic.GroundAtom; import probcog.logic.sat.weighted.WeightedClausalKB; import probcog.srl.mln.MarkovRandomField; /** * MC-SAT inference wrapper. * @author Dominik Jain */ public class MCSAT extends InferenceAlgorithm { probcog.logic.sat.weighted.MCSAT sampler; public MCSAT(MarkovRandomField mrf) throws Exception { super(mrf); WeightedClausalKB wckb = new WeightedClausalKB(mrf, true); sampler = new probcog.logic.sat.weighted.MCSAT(wckb, mrf.getWorldVariables(), mrf.getDb()); paramHandler.addSubhandler(sampler.getParameterHandler()); } @Override public double getResult(GroundAtom ga) { return sampler.getResult(ga); } @Override public ArrayList<InferenceResult> infer(Iterable<String> queries) throws Exception { sampler.setDebugMode(debug); sampler.run(maxSteps); return getResults(queries); } public String getAlgorithmName() { return sampler.getAlgorithmName(); } }