aima.core.logic.propositional.parsing.ast.Connective Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aima-core Show documentation
Show all versions of aima-core Show documentation
AIMA-Java Core Algorithms from the book Artificial Intelligence a Modern Approach 3rd Ed.
The newest version!
package aima.core.logic.propositional.parsing.ast;
import java.util.Set;
import aima.core.util.Util;
/**
* Artificial Intelligence A Modern Approach (3rd Edition): page 244.
*
*
*
* Logical Connectives: There are five connectives in common use:
* 1. ~ (not).
* 2. & (and).
* 3. | (or).
* 4. => (implication).
* 5. <=> (biconditional).
*
* Note: We use ASCII characters that commonly have the same meaning to those
* symbols used in the book.
*
* OPERATOR PRECEDENCE: ~, &, |, =>, <=>
*
*
* @author Ciaran O'Reilly
*
*/
public enum Connective {
NOT("~", 10), // i.e. highest to lowest precedence.
AND("&", 8),
OR("|", 6),
IMPLICATION("=>", 4),
BICONDITIONAL("<=>", 2);
/**
*
* @return the symbol for this connective.
*/
public String getSymbol() {
return symbol;
}
/**
*
* @return the precedence associated with this connective.
*/
public int getPrecedence() {
return precedence;
}
@Override
public String toString() {
return getSymbol();
}
/**
* Determine if a given symbol is representative of a connective.
*
* @param symbol
* a symbol to be tested whether or not is represents a
* connective.
* @return true if the symbol passed in is representative of a connective.
*/
public static boolean isConnective(String symbol) {
if (NOT.getSymbol().equals(symbol)) {
return true;
} else if (AND.getSymbol().equals(symbol)) {
return true;
} else if (OR.getSymbol().equals(symbol)) {
return true;
} else if (IMPLICATION.getSymbol().equals(symbol)) {
return true;
} else if (BICONDITIONAL.getSymbol().equals(symbol)) {
return true;
}
return false;
}
/**
* Get the connective associated with the given symbolic representation.
*
* @param symbol
* a symbol for which a corresponding connective is wanted.
* @return the connective associated with a given symbol.
* @throws IllegalArgumentException
* if a connective cannot be found that matches the given
* symbol.
*/
public static Connective get(String symbol) {
if (NOT.getSymbol().equals(symbol)) {
return NOT;
} else if (AND.getSymbol().equals(symbol)) {
return AND;
} else if (OR.getSymbol().equals(symbol)) {
return OR;
} else if (IMPLICATION.getSymbol().equals(symbol)) {
return IMPLICATION;
} else if (BICONDITIONAL.getSymbol().equals(symbol)) {
return BICONDITIONAL;
}
throw new IllegalArgumentException(
"Not a valid symbol for a connective: " + symbol);
}
/**
* Determine if the given character is at the beginning of a connective.
*
* @param ch
* a character.
* @return true if the given character is at the beginning of a connective's
* symbolic representation, false otherwise.
*/
public static boolean isConnectiveIdentifierStart(char ch) {
return _connectiveLeadingChars.contains(ch);
}
/**
* Determine if the given character is part of a connective.
*
* @param ch
* a character.
* @return true if the given character is part of a connective's symbolic
* representation, false otherwise.
*/
public static boolean isConnectiveIdentifierPart(char ch) {
return _connectiveChars.contains(ch);
}
//
// PRIVATE
//
private static final Set _connectiveLeadingChars = Util.createSet('~', '&', '|', '=', '<');
private static final Set _connectiveChars = Util.createSet('~', '&', '|', '=', '<', '>');
private final String symbol;
private final int precedence;
private Connective(String symbol, int precedence) {
this.symbol = symbol;
this.precedence = precedence;
}
}