/*
* @(#)EngineTrainer.java 8/01/2005
*
* Copyright (c) 2004, 2005 jASEN.org
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the distribution.
*
* 3. The names of the authors may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* 4. Any modification or additions to the software must be contributed back
* to the project.
*
* 5. Any investigation or reverse engineering of source code or binary to
* enable emails to bypass the filters, and hence inflict spam and or viruses
* onto users who use or do not use jASEN could subject the perpetrator to
* criminal and or civil liability.
*
* THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JASEN.ORG,
* OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
*/
package org.jasen.tools;
import org.jasen.core.engine.JasenTrainer;
/**
* <p>
* The EngineTrainer simply uses the JasenTrainer class to train the engine and produce a token map.
* </p>
* @see org.jasen.core.engine.JasenTrainer
* @author Jason Polites
*/
public final class EngineTrainer {
/**
* Runs the trainer.
* <p>
* This class takes 4 arguments:
* <ol>
* <li>Spam Corpus Path - The full path to the spam corpus directory</li>
* <li>Ham Corpus Path - The full path to the ham corpus directory</li>
* <li>Map Path - The full path to the file containing the map data</li>
* <li>
* Command - One of:
* <ul>
* <li>new - Creates a new map and saves it to the designated path (default)</li>
* <li>load - Loads an existing map from the designated path and appends to it</li>
* </ul>
* </li>
* </ol>
* </p>
* @param args
*/
public static void main(String[] args) {
try
{
if(args == null || args.length < 4) {
System.out.println ("Usage: JasenTrainer <spam corpus path> <ham corpus path> <store path> <command> (one of 'new' or 'load')");
}
else
{
JasenTrainer trainer = new JasenTrainer();
String spamPath = args[0];
String hamPath = args[1];
String mapPath = args[2];
String command = args[3];
trainer.setSpamCorpusPath(spamPath);
trainer.setHamCorpusPath(hamPath);
trainer.setStorePath(mapPath);
if(command.toLowerCase().trim().startsWith("load")) {
trainer.setLoad(true);
}
trainer.init();
trainer.train();
}
}
catch (Exception e)
{
e.printStackTrace ();
}
}
}