Reverse

Description

This operation reverses an FST. If A transduces string x to y with weight a, then the reverse of A transduces the reverse of x to the reverse of y with weight a.Reverse().

Typically, a = a.Reverse() and Arc = RevArc (e.g. for TropicalWeight or LogWeight). In general, e.g., when the weights only form a left or right semiring, the output arc type must match the input arc type except having the reversed Weight type.

Usage

template<class Arc, class RevArc>
void Reverse(const Fst<Arc> &ifst, MutableFst<RevArc> *ofst);
doc
fstreverse a.fst out.fst
 

Examples

A:

reverse1.jpg

Reverse of A:

reverse2.jpg

Reverse(&A);
fstreverse a.fst out.fst

Complexity

Reverse:

  • Time: O(V + E)
  • Space: O(V + E)
where V = # of states and E = # of arcs.

-- MichaelRiley - 03 Jul 2007

Topic attachments
I Attachment Action Size Date Who Comment
jpgjpg reverse1.jpg manage 14.3 K 03 Jul 2007 - 01:19 MichaelRiley  
jpgjpg reverse2.jpg manage 18.5 K 03 Jul 2007 - 01:19 MichaelRiley  
Topic revision: r2 - 03 Mar 2009 - 21:52:13 - MichaelRiley
 
This site is powered by the TWiki collaboration platformCopyright &© by the contributing authors. All material on this collaboration platform is the property of the contributing authors.
Ideas, requests, problems regarding TWiki? Send feedback