/* Copyright 2009 by the Oxford University Computing Laboratory This file is part of HermiT. HermiT is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. HermiT 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 Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with HermiT. If not, see <http://www.gnu.org/licenses/>. */ package org.semanticweb.HermiT.debugger.commands; import java.io.CharArrayWriter; import java.io.PrintWriter; import org.semanticweb.HermiT.debugger.Debugger; import org.semanticweb.HermiT.tableau.Node; public class ModelStatsCommand extends AbstractCommand { public ModelStatsCommand(Debugger debugger) { super(debugger); } public String getCommandName() { return "modelStats"; } public String[] getDescription() { return new String[] { "","prints statistics about a model" }; } public void printHelp(PrintWriter writer) { writer.println("usage: modelStats"); writer.println(" Prints statistics about the current model."); } public void execute(String[] args) { int noNodes=0; int noUnblockedNodes=0; int noDirectlyBlockedNodes=0; int noIndirectlyBlockedNodes=0; Node node=m_debugger.getTableau().getFirstTableauNode(); while (node!=null) { noNodes++; if (node.isDirectlyBlocked()) noDirectlyBlockedNodes++; else if (node.isIndirectlyBlocked()) noIndirectlyBlockedNodes++; else noUnblockedNodes++; node=node.getNextTableauNode(); } CharArrayWriter buffer=new CharArrayWriter(); PrintWriter writer=new PrintWriter(buffer); writer.println(" Model statistics"); writer.println("================================================"); writer.println(" Number of nodes: "+noNodes); writer.println(" Number of unblocked nodes: "+noUnblockedNodes); writer.println(" Number of directly blocked nodes: "+noDirectlyBlockedNodes); writer.println(" Number of indirectly blocked nodes: "+noIndirectlyBlockedNodes); writer.println("================================================"); writer.flush(); showTextInWindow(buffer.toString(),"Model statistics"); selectConsoleWindow(); } }