public class Token extends GraphNode implements TokenNode, DependencyNode, PhraseStructureNode
Modifier and Type | Field and Description |
---|---|
protected DependencyNode |
component
a reference to a node where the node is part of a component.
|
protected java.util.SortedSet<DependencyNode> |
heads |
protected int |
index |
protected java.util.SortedSet<DependencyNode> |
leftDependents |
protected PhraseStructureNode |
parent |
protected TokenNode |
predecessor
the previous terminal node in the linear precedence
|
protected int |
rank |
protected java.util.SortedSet<DependencyNode> |
rightDependents |
protected TokenNode |
successor
the next terminal node in the linear precedence
|
incomingEdges, outgoingEdges
Constructor and Description |
---|
Token() |
Modifier and Type | Method and Description |
---|---|
void |
addHeadEdgeLabel(LabelSet labelSet) |
void |
addHeadEdgeLabel(SymbolTable table,
int code) |
void |
addHeadEdgeLabel(SymbolTable table,
java.lang.String symbol) |
void |
addIncomingEdge(Edge in) |
void |
addOutgoingEdge(Edge out) |
void |
clear()
Resets the graph element.
|
int |
compareTo(ComparableNode that) |
boolean |
equals(java.lang.Object obj) |
DependencyNode |
findComponent() |
DependencyNode |
getAncestor() |
DependencyNode |
getClosestLeftDependent()
Returns the closest left dependent to the node it self, if not found
null is returned. |
DependencyNode |
getClosestRightDependent()
Returns the closest right dependent to the node it self, if not found
null is returned. |
int |
getCompareToIndex()
Returns the index of the node (only used internal by compareTo).
|
DependencyNode |
getComponent() |
protected void |
getDependencyDominationSet(java.util.SortedSet<DependencyNode> dominationSet) |
int |
getDependencyNodeDepth()
Returns the depth of the node.
|
DependencyNode |
getHead()
Returns the head dependency node if it exists, otherwise null.
|
Edge |
getHeadEdge()
Returns the edge between the head and the node if it exists, otherwise null.
|
int |
getHeadEdgeLabelCode(SymbolTable table) |
LabelSet |
getHeadEdgeLabelSet() |
java.lang.String |
getHeadEdgeLabelSymbol(SymbolTable table) |
java.util.Set<SymbolTable> |
getHeadEdgeLabelTypes() |
java.util.Set<Edge> |
getHeadEdges() |
java.util.Set<DependencyNode> |
getHeads() |
int |
getIndex()
Returns the index of the node.
|
DependencyNode |
getLeftDependent(int index)
Returns the left dependent at the position
index , where index==0 equals the left most dependent. |
int |
getLeftDependentCount()
Return the number of left dependents
|
java.util.SortedSet<DependencyNode> |
getLeftDependents()
Returns a sorted set of left dependents.
|
DependencyNode |
getLeftmostDependent() |
ComparableNode |
getLeftmostDescendant()
Returns the left-most terminal descendant node.
|
ComparableNode |
getLeftmostProperDescendant()
Returns the left-most proper terminal descendant node (excluding itself).
|
DependencyNode |
getLeftSibling()
Returns the left sibling if it exists, otherwise
null |
java.util.List<DependencyNode> |
getListOfDependents() |
java.util.List<DependencyNode> |
getListOfLeftDependents() |
java.util.List<DependencyNode> |
getListOfRightDependents() |
PhraseStructureNode |
getParent() |
Edge |
getParentEdge() |
int |
getParentEdgeLabelCode(SymbolTable table) |
java.lang.String |
getParentEdgeLabelSymbol(SymbolTable table) |
DependencyNode |
getPredecessor()
Returns the predecessor dependency node in the linear order of the token nodes.
|
DependencyNode |
getProperAncestor() |
int |
getRank() |
DependencyNode |
getRightDependent(int index) |
int |
getRightDependentCount()
Return the number of right dependents
|
java.util.SortedSet<DependencyNode> |
getRightDependents()
Returns a sorted set of right dependents.
|
DependencyNode |
getRightmostDependent() |
ComparableNode |
getRightmostDescendant()
Returns the right-most terminal descendant node.
|
ComparableNode |
getRightmostProperDescendant()
Returns the right-most proper terminal descendant node (excluding itself).
|
DependencyNode |
getRightSibling()
Returns the right sibling if it exists, otherwise
null |
DependencyNode |
getSameSideLeftSibling()
Returns the left sibling at the same side of head as the node it self.
|
DependencyNode |
getSameSideRightSibling()
Returns the right sibling at the same side of head as the node it self.
|
DependencyNode |
getSuccessor()
Returns the successor dependency node in the linear order of the token nodes.
|
TokenNode |
getTokenNodePredecessor()
Returns the predecessor terminal node in the linear order of the terminal nodes.
|
TokenNode |
getTokenNodeSuccessor()
Returns the successor terminal node in the linear order of the terminal nodes.
|
boolean |
hasAncestorInside(int left,
int right) |
boolean |
hasAtMostOneHead()
Returns true if the node has at most one head, otherwise false.
|
boolean |
hasDependent() |
int |
hashCode() |
boolean |
hasHead()
Returns true if the node has one or more head(s), otherwise false.
|
boolean |
hasHeadEdgeLabel(SymbolTable table) |
boolean |
hasLeftDependent()
Returns
true if the node has one or more left dependents, otherwise false . |
boolean |
hasParentEdgeLabel(SymbolTable table) |
boolean |
hasRightDependent()
Returns
true if the node has one or more right dependents, otherwise false . |
boolean |
isHeadEdgeLabeled() |
boolean |
isProjective()
Returns true if the head edge is projective, otherwise false.
|
boolean |
isRoot()
Returns true if the node is a root node, otherwise false.
|
int |
nHeadEdgeLabels() |
void |
removeIncomingEdge(Edge in) |
void |
removeOutgoingEdge(Edge out) |
void |
setComponent(DependencyNode x) |
void |
setIndex(int index) |
void |
setPredecessor(TokenNode predecessor)
Sets the predecessor terminal node in the linear order of the terminal nodes.
|
void |
setRank(int r) |
void |
setSuccessor(TokenNode successor)
Sets the predecessor terminal node in the linear order of the terminal nodes.
|
java.lang.String |
toString() |
getIncomingEdgeIterator, getIncomingSecondaryEdges, getInDegree, getLeftmostDescendantIndex, getLeftmostProperDescendantIndex, getOutDegree, getOutgoingEdgeIterator, getOutgoingSecondaryEdges, getRightmostDescendantIndex, getRightmostProperDescendantIndex
addLabel, addLabel, addLabel, compareTo, getBelongsToGraph, getLabelCode, getLabelSet, getLabelSymbol, getLabelTypes, hasLabel, isLabeled, nLabels, removeLabel, removeLabels, setBelongsToGraph
addObserver, clearChanged, countObservers, deleteObserver, deleteObservers, hasChanged, notifyObservers, notifyObservers, setChanged
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
getIncomingSecondaryEdges, getInDegree, getLeftmostDescendantIndex, getLeftmostProperDescendantIndex, getOutDegree, getOutgoingSecondaryEdges, getRightmostDescendantIndex, getRightmostProperDescendantIndex
addLabel, addLabel, addLabel, getBelongsToGraph, getLabelCode, getLabelSet, getLabelSymbol, getLabelTypes, hasLabel, isLabeled, nLabels, removeLabel, removeLabels, setBelongsToGraph
protected TokenNode predecessor
protected DependencyNode component
protected int rank
protected int index
protected PhraseStructureNode parent
protected final java.util.SortedSet<DependencyNode> heads
protected final java.util.SortedSet<DependencyNode> leftDependents
protected final java.util.SortedSet<DependencyNode> rightDependents
public Token() throws MaltChainedException
MaltChainedException
public void setPredecessor(TokenNode predecessor)
setPredecessor
in interface TokenNode
predecessor
- the predecessor terminal nodepublic void setSuccessor(TokenNode successor)
setSuccessor
in interface TokenNode
successor
- the successor terminal nodepublic TokenNode getTokenNodePredecessor()
getTokenNodePredecessor
in interface TokenNode
public TokenNode getTokenNodeSuccessor()
getTokenNodeSuccessor
in interface TokenNode
public DependencyNode getPredecessor()
DependencyNode
getPredecessor
in interface DependencyNode
public DependencyNode getSuccessor()
DependencyNode
getSuccessor
in interface DependencyNode
public int getRank()
getRank
in interface DependencyNode
public void setRank(int r)
setRank
in interface DependencyNode
public DependencyNode findComponent()
findComponent
in interface DependencyNode
public DependencyNode getComponent()
getComponent
in interface DependencyNode
public void setComponent(DependencyNode x)
setComponent
in interface DependencyNode
public void addIncomingEdge(Edge in) throws MaltChainedException
addIncomingEdge
in interface Node
addIncomingEdge
in class GraphNode
MaltChainedException
public void removeIncomingEdge(Edge in) throws MaltChainedException
removeIncomingEdge
in interface Node
removeIncomingEdge
in class GraphNode
MaltChainedException
public void addOutgoingEdge(Edge out) throws MaltChainedException
addOutgoingEdge
in interface Node
addOutgoingEdge
in class GraphNode
MaltChainedException
public void removeOutgoingEdge(Edge out) throws MaltChainedException
removeOutgoingEdge
in interface Node
removeOutgoingEdge
in class GraphNode
MaltChainedException
public void setIndex(int index) throws MaltChainedException
setIndex
in interface Node
setIndex
in class GraphNode
MaltChainedException
public int getIndex()
ComparableNode
getIndex
in interface ComparableNode
getIndex
in class GraphNode
public int getCompareToIndex()
ComparableNode
getCompareToIndex
in interface ComparableNode
public boolean isRoot()
ComparableNode
isRoot
in interface ComparableNode
isRoot
in class GraphNode
public DependencyNode getAncestor() throws MaltChainedException
getAncestor
in interface DependencyNode
MaltChainedException
public DependencyNode getProperAncestor() throws MaltChainedException
getProperAncestor
in interface DependencyNode
MaltChainedException
public ComparableNode getLeftmostProperDescendant() throws MaltChainedException
ComparableNode
getLeftmostProperDescendant
in interface ComparableNode
MaltChainedException
public ComparableNode getRightmostProperDescendant() throws MaltChainedException
ComparableNode
getRightmostProperDescendant
in interface ComparableNode
MaltChainedException
public ComparableNode getLeftmostDescendant() throws MaltChainedException
ComparableNode
getLeftmostDescendant
in interface ComparableNode
MaltChainedException
public ComparableNode getRightmostDescendant() throws MaltChainedException
ComparableNode
getRightmostDescendant
in interface ComparableNode
MaltChainedException
public PhraseStructureNode getParent()
getParent
in interface PhraseStructureNode
public Edge getParentEdge() throws MaltChainedException
getParentEdge
in interface PhraseStructureNode
MaltChainedException
public java.lang.String getParentEdgeLabelSymbol(SymbolTable table) throws MaltChainedException
getParentEdgeLabelSymbol
in interface PhraseStructureNode
MaltChainedException
public int getParentEdgeLabelCode(SymbolTable table) throws MaltChainedException
getParentEdgeLabelCode
in interface PhraseStructureNode
MaltChainedException
public boolean hasParentEdgeLabel(SymbolTable table) throws MaltChainedException
hasParentEdgeLabel
in interface PhraseStructureNode
MaltChainedException
public boolean hasAtMostOneHead()
DependencyNode
hasAtMostOneHead
in interface DependencyNode
public boolean hasAncestorInside(int left, int right) throws MaltChainedException
hasAncestorInside
in interface DependencyNode
MaltChainedException
public java.util.Set<Edge> getHeadEdges() throws MaltChainedException
getHeadEdges
in interface DependencyNode
MaltChainedException
public java.util.Set<DependencyNode> getHeads() throws MaltChainedException
getHeads
in interface DependencyNode
MaltChainedException
public boolean hasHead()
DependencyNode
hasHead
in interface DependencyNode
public DependencyNode getHead() throws MaltChainedException
DependencyNode
getHead
in interface DependencyNode
MaltChainedException
public Edge getHeadEdge() throws MaltChainedException
DependencyNode
getHeadEdge
in interface DependencyNode
MaltChainedException
public void addHeadEdgeLabel(SymbolTable table, java.lang.String symbol) throws MaltChainedException
addHeadEdgeLabel
in interface DependencyNode
MaltChainedException
public void addHeadEdgeLabel(SymbolTable table, int code) throws MaltChainedException
addHeadEdgeLabel
in interface DependencyNode
MaltChainedException
public void addHeadEdgeLabel(LabelSet labelSet) throws MaltChainedException
addHeadEdgeLabel
in interface DependencyNode
MaltChainedException
public boolean hasHeadEdgeLabel(SymbolTable table) throws MaltChainedException
hasHeadEdgeLabel
in interface DependencyNode
MaltChainedException
public java.lang.String getHeadEdgeLabelSymbol(SymbolTable table) throws MaltChainedException
getHeadEdgeLabelSymbol
in interface DependencyNode
MaltChainedException
public int getHeadEdgeLabelCode(SymbolTable table) throws MaltChainedException
getHeadEdgeLabelCode
in interface DependencyNode
MaltChainedException
public boolean isHeadEdgeLabeled() throws MaltChainedException
isHeadEdgeLabeled
in interface DependencyNode
MaltChainedException
public int nHeadEdgeLabels() throws MaltChainedException
nHeadEdgeLabels
in interface DependencyNode
MaltChainedException
public java.util.Set<SymbolTable> getHeadEdgeLabelTypes() throws MaltChainedException
getHeadEdgeLabelTypes
in interface DependencyNode
MaltChainedException
public LabelSet getHeadEdgeLabelSet() throws MaltChainedException
getHeadEdgeLabelSet
in interface DependencyNode
MaltChainedException
public boolean hasDependent()
hasDependent
in interface DependencyNode
public boolean hasLeftDependent()
true
if the node has one or more left dependents, otherwise false
.hasLeftDependent
in interface DependencyNode
true
if the node has one or more left dependents, otherwise false
.public DependencyNode getLeftDependent(int index)
index
, where index==0
equals the left most dependent.getLeftDependent
in interface DependencyNode
index
- the indexindex
, where index==0
equals the left most dependentpublic int getLeftDependentCount()
getLeftDependentCount
in interface DependencyNode
public java.util.SortedSet<DependencyNode> getLeftDependents()
DependencyNode
getLeftDependents
in interface DependencyNode
public DependencyNode getLeftSibling() throws MaltChainedException
null
getLeftSibling
in interface DependencyNode
null
MaltChainedException
public DependencyNode getSameSideLeftSibling() throws MaltChainedException
null
is returnedgetSameSideLeftSibling
in interface DependencyNode
null
is returnedMaltChainedException
public DependencyNode getClosestLeftDependent()
null
is returned.getClosestLeftDependent
in interface DependencyNode
null
is returned.public DependencyNode getLeftmostDependent()
getLeftmostDependent
in interface DependencyNode
public DependencyNode getRightDependent(int index)
getRightDependent
in interface DependencyNode
public int getRightDependentCount()
getRightDependentCount
in interface DependencyNode
public java.util.SortedSet<DependencyNode> getRightDependents()
getRightDependents
in interface DependencyNode
public DependencyNode getRightSibling() throws MaltChainedException
null
getRightSibling
in interface DependencyNode
null
MaltChainedException
public DependencyNode getSameSideRightSibling() throws MaltChainedException
null
is returnedgetSameSideRightSibling
in interface DependencyNode
null
is returnedMaltChainedException
public DependencyNode getClosestRightDependent()
null
is returned.getClosestRightDependent
in interface DependencyNode
null
is returned.public DependencyNode getRightmostDependent()
getRightmostDependent
in interface DependencyNode
public java.util.List<DependencyNode> getListOfDependents()
getListOfDependents
in interface DependencyNode
public java.util.List<DependencyNode> getListOfLeftDependents()
getListOfLeftDependents
in interface DependencyNode
public java.util.List<DependencyNode> getListOfRightDependents()
getListOfRightDependents
in interface DependencyNode
protected void getDependencyDominationSet(java.util.SortedSet<DependencyNode> dominationSet)
public boolean hasRightDependent()
true
if the node has one or more right dependents, otherwise false
.hasRightDependent
in interface DependencyNode
true
if the node has one or more right dependents, otherwise false
.public boolean isProjective() throws MaltChainedException
DependencyNode
isProjective
in interface DependencyNode
MaltChainedException
public int getDependencyNodeDepth() throws MaltChainedException
DependencyNode
getDependencyNodeDepth
in interface DependencyNode
MaltChainedException
public void clear() throws MaltChainedException
GraphElement
clear
in interface Element
clear
in class GraphNode
MaltChainedException
public int compareTo(ComparableNode that)
compareTo
in interface java.lang.Comparable<ComparableNode>
compareTo
in class GraphNode
Copyright 2007-2017 Johan Hall, Jens Nilsson and Joakim Nivre.