![JAR search and dependency download from the Maven repository](/logo.png)
nl.trivento.albero.parsers.groovy.model.Condition.groovy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of albero-parsers-groovy Show documentation
Show all versions of albero-parsers-groovy Show documentation
A bank decides using various criteria whether a customer wil receive a loan. An insurer uses specific information to determine which insurance product is most suitable for its customer.
A municipality makes decisions based on yet other information, to determine whether it will grant permits or if a citizen is entitled to a public transport pass. Decision trees are frequently used in order to make such decisions or recommendations.
Albero is a new generation decision tree solution. It is simple, fast, and flexible. Further, Albero is easily adaptable and can integrate easily into any environment.
The newest version!
/* Copyright 2011-2012 Profict Holding
*
* Licensed 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 nl.trivento.albero.parsers.groovy.model
import nl.trivento.albero.model.Context
abstract class Condition {
abstract Boolean evaluate(Context context)
Condition inverted() {
def condition = this
[evaluate: {map ->
truthTable([
[null]: null,
[Boolean.FALSE]: Boolean.TRUE,
[Boolean.TRUE]: Boolean.FALSE
], [condition.evaluate(map)])
}] as Condition
}
Condition or(Condition otherCondition) {
def condition = this
[evaluate: {map ->
truthTable([
[null, null]: null,
[null, Boolean.FALSE]: null,
[null, Boolean.TRUE]: Boolean.TRUE,
[Boolean.FALSE, Boolean.FALSE]: Boolean.FALSE,
[Boolean.FALSE, Boolean.TRUE]: Boolean.TRUE,
[Boolean.TRUE, Boolean.TRUE]: Boolean.TRUE
], [condition.evaluate(map), otherCondition.evaluate(map)])
}] as Condition
}
Condition and(Condition otherCondition) {
def condition = this
[evaluate: {map ->
truthTable([
[null, null]: null,
[null, Boolean.FALSE]: null,
[null, Boolean.TRUE]: null,
[Boolean.FALSE, Boolean.FALSE]: Boolean.FALSE,
[Boolean.FALSE, Boolean.TRUE]: Boolean.FALSE,
[Boolean.TRUE, Boolean.TRUE]: Boolean.TRUE
], [condition.evaluate(map), otherCondition.evaluate(map)])
}] as Condition
}
protected Boolean truthTable(Map table, List key) {
table.containsKey(key) ? table[key] : table[key.reverse()]
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy