Code Coverage for nltk.parse

Untested Functions

# Natural Language Toolkit: Parsers
#
# Copyright (C) 2001-2008 NLTK Project
# Author: Steven Bird <[email protected]>
#         Edward Loper <[email protected]>
# URL: <http://nltk.org>
# For license information, see LICENSE.TXT
#

"""
Classes and interfaces for producing tree structures that represent
the internal organization of a text.  This task is known as X{parsing}
the text, and the resulting tree structures are called the text's
X{parses}.  Typically, the text is a single sentence, and the tree
structure represents the syntactic structure of the sentence.
However, parsers can also be used in other domains.  For example,
parsers can be used to derive the morphological structure of the
morphemes that make up a word, or to derive the discourse structure
for a set of utterances.

Sometimes, a single piece of text can be represented by more than one
tree structure.  Texts represented by more than one tree structure are
called X{ambiguous} texts.  Note that there are actually two ways in
which a text can be ambiguous:

    - The text has multiple correct parses.
    - There is not enough information to decide which of several
      candidate parses is correct.

However, the parser module does I{not} distinguish these two types of
ambiguity.

The parser module defines C{ParserI}, a standard interface for parsing
texts; and two simple implementations of that interface,
C{ShiftReduceParser} and C{RecursiveDescentParser}.  It also contains
three sub-modules for specialized kinds of parsing:

  - C{nltk.parser.chart} defines chart parsing, which uses dynamic
    programming to efficiently parse texts.
  - C{nltk.parser.probabilistic} defines probabilistic parsing, which
    associates a probability with each parse.
"""

from api import *
from chart import *
from featurechart import *
from pchart import *
from rd import *
from sr import *
from util import *
from viterbi import *

__all__ = [
    # Parser interface
    'ParserI',

    # Parsers
    'RecursiveDescentParser', 'SteppingRecursiveDescentParser',
    'ShiftReduceParser', 'SteppingShiftReduceParser',
    'EarleyChartParser', 'ChartParser', 'SteppingChartParser',
    'BottomUpChartParser', 'InsideChartParser', 'RandomChartParser',
    'UnsortedChartParser', 'LongestChartParser', 'ViterbiParser',
    'FeatureEarleyChartParser',

    ]

######################################################################
#{ Deprecated
######################################################################
from nltk.internals import Deprecated
class ParseI(ParserI, Deprecated):
    """Use nltk.ParserI instead."""
class AbstractParse(AbstractParser, Deprecated):
    """Use nltk.ParserI instead."""
class RecursiveDescent(RecursiveDescentParser, Deprecated):
    """Use nltk.RecursiveDescentParser instead."""
class SteppingRecursiveDescent(SteppingRecursiveDescentParser, Deprecated):
    """Use nltk.SteppingRecursiveDescentParser instead."""
class ShiftReduce(ShiftReduceParser, Deprecated):
    """Use nltk.ShiftReduceParser instead."""
class SteppingShiftReduce(SteppingShiftReduceParser, Deprecated):
    """Use nltk.SteppingShiftReduceParser instead."""
class EarleyChartParse(EarleyChartParser, Deprecated):
    """Use nltk.EarleyChartParser instead."""
class FeatureEarleyChartParse(FeatureEarleyChartParser, Deprecated):
    """Use nltk.FeatureEarleyChartParser instead."""
class ChartParse(ChartParser, Deprecated):
    """Use nltk.ChartParser instead."""
class SteppingChartParse(SteppingChartParser, Deprecated):
    """Use nltk.SteppingChartParser instead."""
class BottomUpChartParse(BottomUpChartParser, Deprecated):
    """Use nltk.BottomUpChartParser instead."""
class InsideParse(InsideChartParser, Deprecated):
    """Use nltk.InsideChartParser instead."""
class RandomParse(RandomChartParser, Deprecated):
    """Use nltk.RandomChartParser instead."""
class UnsortedParse(UnsortedChartParser, Deprecated):
    """Use nltk.UnsortedChartParser instead."""
class LongestParse(LongestChartParser, Deprecated):
    """Use nltk.LongestChartParser instead."""
class ViterbiParse(ViterbiParser, Deprecated):
    """Use nltk.ViterbiParser instead."""
class GrammarFile(Deprecated):
    """Use nltk.data.load() instead."""
    # [xx] had directives: %start, %kimmo, %tagger_file?
    def __init__(self, filename=None, verbose=False):
        raise ValueError("GrammarFile is no longer supported -- "
                         "use nltk.data.load() instead.")