Class

gstlib.InnerTree

Node

Related Doc: package InnerTree

Permalink

sealed abstract class Node extends AnyRef

A node of a tree.

Linear Supertypes
AnyRef, Any
Known Subclasses
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Node
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Abstract Value Members

  1. abstract def add[Alphabet](child: NonRootNode, start: (NonRootNode) ⇒ Either[Alphabet, TerminalSymbol]): Unit

    Permalink
  2. abstract def childrenMap: Nodes

    Permalink
  3. abstract def parents(): List[NonRootNode]

    Permalink
  4. abstract def pathLabel: List[NonRootNode]

    Permalink

    Computes the path label as a list of NonRootNode

    Computes the path label as a list of NonRootNode

    Beware, labels of these nodes might include special upper limits such as the END constant.

  5. abstract def pathSingleLabel(getSequenceLengthBy: (SequenceID) ⇒ Int): List[SingleLabel]

    Permalink

    Computes the path label as a list of definitive labels given a function to get the length of a sequence from its ID

  6. abstract def remove[Alphabet](child: NonRootNode, start: (NonRootNode) ⇒ Either[Alphabet, TerminalSymbol]): Unit

    Permalink
  7. abstract def size(): Int

    Permalink
  8. abstract def walkDownUntilUnmatch[Alphabet](s: Walkable[Either[Alphabet, TerminalSymbol]], startIndex: Int, endIndex: Int)(start: (NonRootNode) ⇒ Either[Alphabet, TerminalSymbol], getEdgeLabelItem: (NonRootNode, Int) ⇒ Either[Alphabet, TerminalSymbol], labelLength: (NonRootNode) ⇒ Int): Option[(NonRootNode, Int, Int)]

    Permalink

    Walks down the tree following the sequence until a mismatch occurs

    Walks down the tree following the sequence until a mismatch occurs

    It dissociates the following cases:

    1. the sequence is not in the tree, even partially (returns None) 2. the sequence is partially in the tree...
      1. ... and it stops on a non-root node (returns Some(node, int > 0, 0)) b. ... and it stops in a middle of an edge (returns Some(node, int > 0, int > 0)) 3. the sequence is entirely in the tree...
      2. ... and it stops on a non-root node (returns Some(node, 0, 0)) b. ... and it stops in a middle of an edge (returns Some(node, 0, int > 0))
    s

    the searched sequence

    startIndex

    the first index of search in the sequence (inclusive)

    endIndex

    the last index of search in the sequence (inclusive)

    start

    retrieves efficiently the first item in the edge label to the given node

    getEdgeLabelItem

    retrieves efficiently the ith item in the edge label to the given node

    labelLength

    computes efficiently the length of the edge label to the given node

    returns

    None if the sequence is not partially in the tree, else a triple containing 1) the non-root node at or below the unmatch or the end of the sequence happened, 2) the number of character left in the given sequence and 3) the number of character left to reach the non-root node (0 means "perfect match")

Concrete Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  5. def childStartingWith[Alphabet](item: Either[Alphabet, TerminalSymbol]): Option[NonRootNode]

    Permalink

    Computes the child node of this node which edge-label starts with the given item

  6. def children: List[NonRootNode]

    Permalink
  7. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  8. var dfs: Int

    Permalink

    Depth-first number

  9. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  10. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  11. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  12. def findPathEndContaining[Alphabet](s: Walkable[Either[Alphabet, TerminalSymbol]], startIndex: Int, endIndex: Int)(start: (NonRootNode) ⇒ Either[Alphabet, TerminalSymbol], getEdgeLabelItem: (NonRootNode, Int) ⇒ Either[Alphabet, TerminalSymbol], labelLength: (NonRootNode) ⇒ Int): Option[(NonRootNode, Int)]

    Permalink

    Finds the path end following a sequence (given as a global sequence, the starting and end indexes of the subsequence to search) from the root node if it exists

    Finds the path end following a sequence (given as a global sequence, the starting and end indexes of the subsequence to search) from the root node if it exists

    s

    the global sequence that contains the searched subsequence

    startIndex

    the start index in the global sequence of the first character of the searched subsequence

    endIndex

    the end index in the global sequence of the last character of the searched subsequence

    start

    a function that given a NonRootNode retrieves efficiently the first item of the edge-label conducting to the given node in the tree

    getEdgeLabelItem

    a function that retrieves efficiently the ith item in the edge label to the given node

    labelLength

    a function that given a NonRootNode computes the length of the edge-label conducting to this node in the tree

    returns

    an optional pair containing the NonRootNode which path-label includes the searched subsequence along with the number of item that are in the path-label and not in the searched subsequence (i.e., the gap between the end of the search subsequence in the path-label to reach the node)

  13. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  14. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  15. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  16. def leaves(): List[LeafNode]

    Permalink
  17. def leavesHelper(currentNode: Node): List[LeafNode]

    Permalink
    Attributes
    protected
  18. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  19. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  20. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  21. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  22. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  23. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  24. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  25. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  26. def walkDown[Alphabet](s: Walkable[Either[Alphabet, TerminalSymbol]], startIndex: Int, endIndex: Int, currentEnd: Int)(start: (NonRootNode) ⇒ Either[Alphabet, TerminalSymbol], labelLength: (NonRootNode) ⇒ Int): (NonRootNode, Int)

    Permalink

    Walks down from this node following the given sequence

    Walks down from this node following the given sequence

    s

    the searched sequence

    startIndex

    the first index of search in the sequence (inclusive)

    endIndex

    the last index of search in the sequence (inclusive)

    currentEnd

    current index of the end (i in suffix S[j..i] of phase i)

    start

    computes the first item of a label

    returns

    a pair (node, length) containing the node which path label contains sequence s, and the number of items left in the path to arrive to the node (0 means a perfect match)

    Note

    walkDown is overriden by 'NonRootNode'

Inherited from AnyRef

Inherited from Any

Ungrouped