com.joliciel.talismane.machineLearning.features.OrFeature Maven / Gradle / Ivy
///////////////////////////////////////////////////////////////////////////////
//Copyright (C) 2014 Joliciel Informatique
//
//This file is part of Talismane.
//
//Talismane is free software: you can redistribute it and/or modify
//it under the terms of the GNU Affero General Public License as published by
//the Free Software Foundation, either version 3 of the License, or
//(at your option) any later version.
//
//Talismane 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 Affero General Public License for more details.
//
//You should have received a copy of the GNU Affero General Public License
//along with Talismane. If not, see .
//////////////////////////////////////////////////////////////////////////////
package com.joliciel.talismane.machineLearning.features;
import com.joliciel.talismane.TalismaneException;
/**
* Combines two boolean features using a boolean OR. If any feature returns
* null, will return a null.
*
* @author Assaf Urieli
*
*/
public class OrFeature extends AbstractCachableFeatureimplements BooleanFeature {
BooleanFeature[] booleanFeatures;
@SafeVarargs
public OrFeature(BooleanFeature... booleanFeatures) {
super();
this.booleanFeatures = booleanFeatures;
String name = "Or(";
boolean firstFeature = true;
for (BooleanFeature booleanFeature : booleanFeatures) {
if (!firstFeature)
name += ",";
name += booleanFeature.getName();
firstFeature = false;
}
name += ")";
this.setName(name);
}
@Override
public FeatureResult checkInternal(T context, RuntimeEnvironment env) throws TalismaneException {
FeatureResult featureResult = null;
boolean hasNull = false;
boolean booleanResult = false;
for (BooleanFeature booleanFeature : booleanFeatures) {
FeatureResult result = booleanFeature.check(context, env);
if (result == null) {
hasNull = true;
break;
}
booleanResult = booleanResult || result.getOutcome();
// not breaking out as soon as we hit a true,
// since if any single feature returns a null, we want to return a
// null
}
if (!hasNull) {
featureResult = this.generateResult(booleanResult);
}
return featureResult;
}
public BooleanFeature[] getBooleanFeatures() {
return booleanFeatures;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy