![JAR search and dependency download from the Maven repository](/logo.png)
net.sf.tweety.arg.prob.semantics.SemiOptimisticPASemantics Maven / Gradle / Ivy
/*
* This file is part of "TweetyProject", a collection of Java libraries for
* logical aspects of artificial intelligence and knowledge representation.
*
* TweetyProject is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3 as
* published by the Free Software Foundation.
*
* This program 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 this program. If not, see .
*
* Copyright 2016 The TweetyProject Team
*/
package net.sf.tweety.arg.prob.semantics;
import java.util.Collection;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import net.sf.tweety.arg.dung.syntax.Argument;
import net.sf.tweety.arg.dung.syntax.DungTheory;
import net.sf.tweety.math.equation.Inequation;
import net.sf.tweety.math.equation.Statement;
import net.sf.tweety.math.probability.Probability;
import net.sf.tweety.math.term.FloatConstant;
import net.sf.tweety.math.term.FloatVariable;
import net.sf.tweety.math.term.Term;
/**
* P is semi-optimistic wrt. AF if P(A) \geq 1 - \sum_{B in Attackers(A)} P(B) for every A in Arg with Attackers(A)!= {}.
* @author Matthias Thimm
*/
public class SemiOptimisticPASemantics extends AbstractPASemantics{
/* (non-Javadoc)
* @see net.sf.tweety.arg.prob.semantics.AbstractPASemantics#satisfies(net.sf.tweety.arg.prob.semantics.ProbabilisticExtension, net.sf.tweety.arg.dung.DungTheory)
*/
@Override
public boolean satisfies(ProbabilisticExtension p, DungTheory theory) {
for(Argument arg: theory){
if(theory.getAttackers(arg).isEmpty())
continue;
double prob = 0;
for(Argument attacker: theory.getAttackers(arg)){
prob += p.probability(attacker).doubleValue();
}
if(p.probability(arg).doubleValue() < 1 - prob - Probability.PRECISION)
return false;
}
return true;
}
/* (non-Javadoc)
* @see net.sf.tweety.arg.prob.semantics.AbstractPASemantics#getSatisfactionStatement(net.sf.tweety.arg.dung.DungTheory, java.util.Map)
*/
@Override
public Collection getSatisfactionStatements(DungTheory theory, Map, FloatVariable> worlds2vars) {
Set stats = new HashSet();
for(Argument arg: theory){
if(theory.getAttackers(arg).isEmpty())
continue;
Term prob = null;
for(Argument attacker: theory.getAttackers(arg)){
if(prob == null)
prob = this.probabilityTerm(attacker, worlds2vars);
else
prob = prob.add(this.probabilityTerm(attacker, worlds2vars));
}
stats.add(new Inequation(this.probabilityTerm(arg, worlds2vars),new FloatConstant(1).minus(prob),Inequation.GREATER_EQUAL));
}
return stats;
}
/* (non-Javadoc)
* @see net.sf.tweety.arg.prob.semantics.AbstractPASemantics#toString()
*/
@Override
public String toString() {
return "Semi-Optimistic Semantics";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy