Filtered-popping recursive transition network

A filtered-popping recursive transition network (FPRTN), or simply filtered-popping network (FPN), is a recursive transition network (RTN) extended with a map of states to keys where returning from a subroutine jump requires the acceptor and return states to be mapped to the same key. RTNs are finite-state machines that can be seen as finite-state automata extended with a stack of return states; as well as consuming transitions and $$\varepsilon$$-transitions, RTNs may define call transitions. These transitions perform a subroutine jump by pushing the transition's target state onto the stack and bringing the machine to the called state. Each time an acceptor state is reached, the return state at the top of the stack is popped out, provided that the stack is not empty, and the machine is brought to this state.

Throughout this article we refer to filtered-popping recursive transition networks as FPNs, though this acronym is ambiguous (e.g.: fuzzy Petri nets). Filtered-popping networks and FPRTNs are unambiguous alternatives.

Formal Definition
A FPN is a structure $$(Q, K, \Sigma, \delta, \kappa, Q_I, F)$$ where


 * $$Q$$ is a finite set of states,
 * $$K$$ is a finite set of keys,
 * $$\Sigma$$ is a finite input alphabet,
 * $$\delta: Q \times (\Sigma \cup \{\varepsilon\} \cup Q) \to Q$$ is a partial transition function, $$\varepsilon$$ being the empty symbol,
 * $$\kappa: Q \to K$$ is a map of states to keys,
 * $$Q_I \subseteq Q$$ is the set of initial states, and
 * $$F \subseteq Q$$ is the set of acceptance states.

Transitions
Transitions represent the possibility of bringing the FPN from a source state $$q_s$$ to a target state $$q_t$$ by possibly performing an additional action. Depending on this action, we distinguish the following types of explicitly-defined transitions:


 * $$\varepsilon$$-transitions are transitions of the form $$\delta(q_s,\varepsilon) \to q_t$$ and perform no additional action,
 * consuming transitions are transitions of the form $$\delta(q_s, \sigma) \to q_t$$ and consume an input symbol $$\sigma$$, and
 * call transitions are transitions of the form $$\delta(q_s, q_c) \to q_t$$ and perform a subroutine jump to called state $$q_c$$ before reaching $$q_t$$.

The behaviour of call transitions is governed by two kinds of implicitly-defined transitions:


 * for each call transition $$\delta(q_s, q_c) \to q_t$$ the FPN implicitly defines a push transition that brings the machine from $$q_s$$ to $$q_c$$ by pushing $$q_t$$ onto the stack, and
 * for each pair of states $$(q_f, q_r) \in F \times Q$$ the FPN implicitly defines a pop transition that brings the machine from $$q_f$$ to $$q_r$$ by popping $$q_r$$ from the stack iff $$q_r$$ is the state at the top of the stack and $$\kappa(q_f) = \kappa(q_r)$$.

Push transitions initialize subroutine jumps and pop transitions are equivalent to return statements.

Purpose
A (natural language) text can be enriched with meta-information by the application of a RTN with output; for instance, a RTN inserting XML tags can be used for transforming a plain text into a structured XML document. A RTN with output representing a natural language grammar would delimit and add the syntactic structure of each text sentence (see parsing). Other RTNs with output could simply mark text segments containing relevant information (see information extraction). The application of a RTN with output representing an ambiguous grammar results in a set of possible translations or interpretations of the input. Computing this set has an exponential worst-case cost, even for an Earley parser for RTNs with output, due to cases in which the number of translations increases exponentially w.r.t. the input length; for instance, the number of interpretations of a natural language sentence increases exponentially w.r.t. the number of unresolved prepositional phrase attachments:
 * in sentence the girl saw the monkey with the telescope, it is unknown whether the girl used the telescope or the monkey was holding it (21 interpretations),
 * in sentence the girl saw the monkey with the telescope in the garden, it is also unknown whether the monkey was in the garden or the action took place in the garden (22 interpretations),
 * in sentence the girl saw the monkey with the telescope in the garden under the tree, it is unknown as well whether the monkey was under the tree or the action took place under the tree (23 interpretations),
 * etc.

FPNs serve as a compact representation of this set of translations, allowing to compute it in cubic time by means of an Earley-like parser. FPN states correspond to execution states (see instruction steps) of an Earley-parser for RTNs without output, and FPN transitions correspond to possible translations of input symbols. The $$\kappa$$ map of the resulting FPN gives the correspondence between the represented output segments and the recognized input segments: given a recognized input sequence $$\sigma_1\ldots\sigma_l$$ and a FPN path $$p$$ starting at a state $$q$$ and ending at a state $$q^\prime$$, $$p$$ represents a possible translation of input segment $$\sigma_{\kappa(q)+1}\ldots\sigma_{\kappa(q^\prime)}$$. The filtered-popping feature is required in order to avoid FPN paths to represent translations of disconnected or overlapping input segments: a FPN call may contain several translation paths from the called state to an acceptor state, where the input segments they correspond to share the same start point but do not necessarily have the same length. Only return states corresponding to the same input point than the acceptor state finishing the call are valid return states.