blob: 9d2fb946ff6b5eb2275c772db052e3404517cb70 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 opennlp.tools.doccat;
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import opennlp.tools.util.BaseToolFactory;
import opennlp.tools.util.InvalidFormatException;
import opennlp.tools.util.ext.ExtensionLoader;
/**
* The factory that provides Doccat default implementations and resources.
*/
public class DoccatFactory extends BaseToolFactory {
private static final String FEATURE_GENERATORS = "doccat.featureGenerators";
private FeatureGenerator[] featureGenerators;
/**
* Instantiates a {@link DoccatFactory} that provides the default implementation of
* the resources.
*/
public DoccatFactory() {}
/**
* Instantiates a {@link DoccatFactory} that provides the default implementation of
* the resources.
*
* @param featureGenerators The {@link FeatureGenerator featureGenerators} to use.
*/
public DoccatFactory(final FeatureGenerator[] featureGenerators) {
init(featureGenerators);
}
protected void init(FeatureGenerator[] featureGenerators) {
this.featureGenerators = featureGenerators;
}
@Override
public Map<String, String> createManifestEntries() {
Map<String, String> manifestEntries = super.createManifestEntries();
if (getFeatureGenerators() != null) {
manifestEntries.put(FEATURE_GENERATORS, featureGeneratorsAsString());
}
return manifestEntries;
}
private String featureGeneratorsAsString() {
List<FeatureGenerator> fgs = Arrays.asList(getFeatureGenerators());
Iterator<FeatureGenerator> iter = fgs.iterator();
StringBuilder sb = new StringBuilder();
if (iter.hasNext()) {
sb.append(iter.next().getClass().getCanonicalName());
while (iter.hasNext()) {
sb.append(',').append(iter.next().getClass().getCanonicalName());
}
}
return sb.toString();
}
@Override
public void validateArtifactMap() throws InvalidFormatException {
// nothing to validate
}
/**
* Factory method the framework uses create a new {@link DoccatFactory}.
*
* @param subclassName The name of the class implementing the {@link DoccatFactory}.
* @param featureGenerators The {@link FeatureGenerator featureGenerators} to use.
*
* @return A valid {@link DoccatFactory} instance.
*
* @throws InvalidFormatException Thrown if the {@link ExtensionLoader} mechanism failed to
* create the factory associated with {@code subclassName}.
*/
public static DoccatFactory create(String subclassName, FeatureGenerator[] featureGenerators)
throws InvalidFormatException {
if (subclassName == null) {
// will create the default factory
return new DoccatFactory(featureGenerators);
}
try {
DoccatFactory theFactory = ExtensionLoader.instantiateExtension(
DoccatFactory.class, subclassName);
theFactory.init(featureGenerators);
return theFactory;
} catch (Exception e) {
String msg = "Could not instantiate the " + subclassName
+ ". The initialization threw an exception.";
throw new InvalidFormatException(msg, e);
}
}
private FeatureGenerator[] loadFeatureGenerators(String classNames) {
String[] classes = classNames.split(",");
FeatureGenerator[] fgs = new FeatureGenerator[classes.length];
for (int i = 0; i < classes.length; i++) {
fgs[i] = ExtensionLoader.instantiateExtension(FeatureGenerator.class,
classes[i]);
}
return fgs;
}
/**
* @return Retrieves the {@link FeatureGenerator generators} used.
*/
public FeatureGenerator[] getFeatureGenerators() {
if (featureGenerators == null) {
if (artifactProvider != null) {
String classNames = artifactProvider
.getManifestProperty(FEATURE_GENERATORS);
if (classNames != null) {
this.featureGenerators = loadFeatureGenerators(classNames);
}
}
if (featureGenerators == null) { // could not load using artifact provider
// load bag of words as default
this.featureGenerators = new FeatureGenerator[]{new BagOfWordsFeatureGenerator()};
}
}
return featureGenerators;
}
/**
* @param featureGenerators The {@link FeatureGenerator featureGenerators} to use.
*/
public void setFeatureGenerators(FeatureGenerator[] featureGenerators) {
this.featureGenerators = featureGenerators;
}
}