Embodiment described herein relate generally to an information processing device, an information processing method and a computer program product.
A finite state automaton (FSA) is used in various fields such as natural language processing and speech recognition. For example, the FSA has uses such as searching a specific character string or a specific pattern of character string in text. The FSA may also be referred to as a finite automaton (FA) or a finite state machine (FSM).
There is an extended model of the FSA such as a finite state transducer (FST) that outputs, when an input symbol is input thereto, an output symbol corresponding to the input symbol in a case where output symbols are present in addition to input symbols, for example. The FST may be used for a lexicon in speech recognition, for example. Such a lexicon is constituted as an FST that outputs, when a pronunciation is input thereto, a word corresponding to the pronunciation. In addition, there are also a weighted finite state automaton (WFSA) taking weights for handling probabilities and distances into account in addition to input symbols, and a weighted finite state transducer (WFST) that is a model including both the FST and the WFSA. The WFSA and the WFST may be used as a model for expressing a lexicon or a model necessary for speech recognition such as a language model in speech recognition or may be used for statistical machine translation.
For using the FSA or a model that is an extended version thereof as described above in actual applications thereof, necessary information needs to be converted into the FSA or the extended version thereof. In this case, if using a transition moving to a next state without an input symbol, the conversion can be facilitated in some cases. Such a transition is called an ε-transition. The ε-transition is assigned with an empty symbol sequence (also referred to as an empty symbol, an empty character string or an empty input) instead of an input symbol. Such an empty symbol sequence is represented by ε. A set of states that can be reached only through 0 or more ε-transitions from a certain state is called an ε-closure. A process of removing ε-transitions is called ε-removal. The ε-removal is performed for the purpose of decreasing the number of unnecessary transitions to reduce the processing time, for example. In order to reduce the amount of memory and the processing time, processing desirably results in as small the number of transitions after ε-removal as possible.
U.S. Pat. No. 7,027,988 proposes a technique for removing an ε-transition included in a WFSA, an FST and a WFST. In a method of related art including U.S. Pat. No. 7,027,988, the ε-removal is realized by obtaining an ε-closure in a certain state q and setting an outgoing transition from a state included in the ε-closure to an outgoing transition from the state q. When a weight or an output symbol is assigned to a transition, a weight or an output symbol of a transition that is newly generated as a result of the ε-removal out of the outgoing transitions from the state q is obtained taking the weight or the output symbol on the transition into account.
In the method for ε-removal in related art, however, there is a dependence on the processing direction. Specifically, if the method of the related art is used with the directions of automaton transitions to be processed all reversed, the same result as that before the directions are reversed is not always obtained. This is because states included in ε-closure vary. In order to make the number of transitions as small as possible in performing ε-removal by using the method of the related art, a method of performing ε-removal in both directions and then selecting one with a smaller number of transitions can be considered. In this case, the processing time increases because it is necessary to perform the ε-removal in both directions. It is thus desirable to perform ε-removal without depending on the direction of ε-transition.
According to an embodiment, an information processing device includes a first set generating unit, a second set generating unit, a combination generating unit, and a removing unit. The first set generating unit is configured to generate a first set representing a set of states that are reachable by following ε-transitions in a forward direction and a reverse direction among states included in a finite state automaton. The second set generating unit is configured to, when a plurality of the first sets are connected with one another by one transition that is not an ε-transition, generate a set of states included in each of the first sets connected by one transition that is not an ε-transition, and generate a second set representing the generated set and the first set that is not connected to another first set by one transition that is not an ε-transition. The combination generating unit configured to generate, for each of the second sets, a combination of removal patterns to be respectively applied to ε-transitions between states included in the second set among a plurality of predetermined removal patterns for removing an ε-transition, and obtain, among the generated combinations, a combination with which the number of transitions in the second set after removing ε-transitions is the smallest. The removing unit configured to remove ε-transitions in the second set by the removal patterns included in the obtained combination.
Various embodiments will be described below in detail with reference to the accompanying drawings.
An information processing device according to a first embodiment searches for a range of states that is affected by a result of selecting a pattern of ε-removal (an ε-removal pattern), and performs ε-removal for each searched range. A range affected by a result of selecting an ε-removal pattern is searched for without depending on the direction of ε-removal. Accordingly, ε-removal can be performed without depending on the direction of an ε-transition.
Details of an ε-removal pattern will be described here. A state that can be reached from a state qs only through ε-transitions is referred to as a state qd. In order to remove ε-transitions between these two states without changing an accepted language, another new transition needs to be generated. The accepted language is a set of input symbol sequences accepted by a finite state automaton. Generation of a transition has a pattern. In the following, this pattern is referred to as an ε-removal pattern. There are at least two ε-removal patterns.
One of the ε-removal patterns is a pattern of reproducing an incoming transition to a state qs as a transition where the next state is a state qd. Another of the ε-removal patterns is a pattern of reproducing an outgoing transition from a state qd as a transition where the previous state is a state qs. The final number of transitions varies depending of which ε-removal pattern is selected. In addition, a result of selecting an ε-removal pattern may be affected by a result of selecting an ε-removal pattern between other two states. Accordingly, in the first embodiment, ranges in which this selection is affected by one another are first searched for. Details of the first embodiment will be described below.
The first set generating unit 101 generates an undirected ε-closure representing a set (first set) of states that can be reached by following ε-transitions in a forward direction and in a reverse direction among states included in a finite state automaton to be processed.
The second set generating unit 102 generates a connected undirected ε-closure (CUEC) representing a set (second set) of undirected ε-closures connected directly or indirectly to other undirected ε-closures. The second set generating unit 102 also includes a set consisting of one undirected ε-closure that is not directly connected to any other undirected ε-closure in the connected undirected ε-closure. The meanings of direct connection and indirect connection will be described later. The connected undirected ε-closure corresponds to a range in which selections of ε-removal patterns are affected by one another, ε-removal is performed on such a connected undirected ε-closure to be processed and performed for each connected undirected ε-closure.
The combination generating unit 103 obtains, for each connected undirected ε-closure, a combination with the smallest number of transitions in the connected undirected ε-closure after removal of ε-transitions among combinations of removal patterns to be applied to each ε-transition between states included in the connected undirected ε-closure.
The removing unit 104 performs ε-removal of each ε-transition in the connected undirected ε-closure with the removal patterns included in the generated combination.
Next, an ε-removal process performed by the information processing device 100 thus configured according to the first embodiment will be described with reference to
First, the first set generating unit 101 searches for states and transitions in an input finite state automaton (FSA) and generates an undirected ε-closure (step S101). Next, the second set generating unit 102 generates a connected undirected ε-closure from generated undirected ε-closures (step S102). Next, the combination generating unit 103 searches for a combination of ε-removal patterns with the smallest number of transitions among combinations of ε-removal patterns that can be applied to ε-transitions in a connected undirected ε-closure (step S103).
When the total number of combinations is small, the combination generating unit 103 searches all the combinations. When the total number of combinations is so large that the combinations cannot be checked in a realistic time, the combination generating unit 103 searches only some combinations and selects a combination with the smallest number of transitions thereamong.
Next, the removing unit 104 performs ε-removal with the removal patterns included in the selected combination (step S104). Specifically, ε-transitions corresponding to the removal patterns included in the selected combination are removed, and transitions relating to states that become unreachable from an initial state are removed.
Next, the combination generating unit 103 determines whether or not processing of all connected undirected ε-closures is completed (step S105). If the processing is not completed (step S105: No), the combination generating unit 103 repeats processing on unprocessed connected undirected ε-closures (step S103). If the processing is completed (step S105: Yes), the ε-removal process is completed. As a result of the process above, a FSA in which no ε-transitions exits can be obtained.
Details of the steps in
Preliminaries
A FSA is composed of a 5-tuple sets (Q, E, E, I, F) including a set Q of states, a set E of transitions, a set Σ of input symbols, a set I of initial states and a set F of final states. A transition is composed of a 3-tuple (previous state, input symbol, next state). These five sets can be always referred as information constituting the FSA to be subjected to ε-removal. For example, this information is stored in a storage unit or the like (not illustrated) in a manner that this information can be always referred to from pseudo codes example of which are given below.
An empty set is represented by Φ. The number of elements in a set B is represented by |B|. A path consisting only of ε-transitions is defined as an ε-path.
A set of states that can be reached from a certain state by following one or more ε-transitions regardless of the directions of the transitions is referred to as an undirected ε-closure. States that are included in undirected ε-closures C1 and C2, respectively, are represented by q1 and q2. When q1 and q2 are connected by only one transition that is not an ε-transition, the undirected ε-closures C1 and C2 are referred to as being directly connected. In a case of undirected ε-closures C1, C2 and C3, when C1 and C2 are connected and C2 and C3 are also connected, C1 and C3 are referred to as being indirectly connected.
A set of undirected ε-closures that are directly or indirectly connected and a set of one undirected ε-closure that is not directly connected to any other undirected ε-closure are referred to as connected undirected ε-closures. In other words, a connected undirected ε-closure is composed of one or more undirected ε-closure, and when a connected undirected ε-closure includes two or more undirected ε-closures, these are directly or indirectly connected.
States included in a range in which selections of ε-removal patterns are affected by one another are the same as states included in a connected undirected ε-closure. In a case of two undirected ε-closures that are not connected, that is, two undirected ε-closures having two or more transitions that are not ε-transitions therebetween, an ε-removal pattern included in one undirected ε-closure never affects an ε-removal pattern included in the other undirected ε-closure.
Methods
First, a method for obtaining a range in which selections of ε-removal patterns are affected by one another will be described, and how an ε-removal pattern is selected will be described next. Finally, a method for removing ε-transitions on the basis of the selected ε-removal pattern will be described.
Method for Obtaining an Undirected ε-Closure: Step S101
Search is performed by a depth first search (DFS) regarding incoming ε-transitions to each state as also being outgoing ε-transitions therefrom. Transitions to be searched for here are only ε-transitions. When search is completed for all states that need to be searched, undirected ε-closures are obtained.
On line 1, all states included in a FSA to be processed are assigned to Qr. At this point, Q is equal to Qr. In addition, Θ is initialized as an empty set, and the stack S is emptied.
On line 2, whether Qr is an empty set or not is checked, and if Qr is an empty set, the process proceeds to line 17. If Qr is not an empty set, this means that there remains a state to be processed, and thus the process proceeds to line 3.
On line 3, Qε that will be used in subsequent processing is initialized to an empty set.
On line 4, any one state is selected from the set Qr and assigned to the state q. The selection may be performed in any manner, and examples of the method for the selection include random selection, selection from the smallest state number, and selection from the largest state number.
On line 5, the state q is added to the stack S.
On line 6, whether the stack S is an empty set or not is checked, and if the stack S is an empty set, the process proceeds to line 14. Otherwise, the process proceeds to line 7.
On line 7, one element is taken out from the stack S and assigned to qε. The assigned qε is removed from the stack S.
On line 8, qε is added to Qε.
Line 9 expresses that processing from line 10 to line 13 is executed for all transitions to which ε is assigned as an input symbol. Transitions to be processed in lines 10 to 13 are represented by e.
On line 10, it is determined whether q, is equal to the previous state of a transition e and the next state of the transition e is not included in Qε. If the determination is positive, the process proceeds to line 11. Otherwise, the process proceeds to line 12.
On line 11, the next state of the transition e is added to the stack S.
On line 12, it is determined whether the next state of the transition e is equal to qε and the previous state of the transition e is not included in Qε. If the determination is positive, the process proceeds to line 13. Otherwise, the process returns to line 9.
On line 13, the previous state of the transition e is added to the stack S. Then, the process returns to line 9.
On line 14, a state included in Qε is removed from Qr.
On line 15, it is determined whether or not the number of states included in Qε is two or larger. If the number is two or larger, the process proceeds to line 16. Otherwise, the process returns to line 2.
At the time when the process proceeds up to line 16, Qε has become one of undirected ε-closures included in the FSA to be processed. On line 16, Qε is added to the set Θ having undirected ε-closures as elements. Then, the process returns to line 2.
On line 17, the set Θ obtained by this processing is returned as a processing result.
Method for Obtaining a Connected Undirected ε-Closure: Step S102
On line 1, a set Ψ including connected undirected ε-closures as elements is initialized to an empty set.
Line 2 expresses that processing from line 3 to line 13 is executed for all elements of undirected ε-closures included in Θ that is a specified set of undirected ε-closures. An undirected ε-closure to be processed is represented by θ.
On line 3, a set ψ having undirected ε-closures as elements is initialized to a set having θ as elements.
Line 4 expresses that lines 5 to 8 are processed for all states included in θ. In lines 5 to 8, a state to be processed is represented by q.
Line 5 expresses that lines 6 to 8 are processed on elements other than θ that are included in Θ. An element to be processed is represented by θ.
Line 6 expresses that lines 7 and 8 are processed on all states included in θ′. A state to be processed is represented by q′.
On line 7, it is determined whether or not a transition with the previous state q and the next state q′ or a transition with the next state q and the previous state q′ is present among transitions that are not ε-transitions. If such a transition is present, the process proceeds to line 8.
On line 8, θ′ is added to ψ.
Lines 4 to 8 correspond to collecting undirected ε-closures that are directly connected to the undirected ε-closure θ to ψ.
When the series of processing on lines 4 to 8 is completed, the process proceeds to line 9. Line 9 expresses that processing from line 10 to line 12 is executed for all elements included in Ψ. An element to be processed in the processing from lines 10 to 12 is represented by ψ′.
On line 10, it is determined whether or not a product set of ψ and ψ′ is an empty set. If the product set is an empty set, the process returns to line 9. Otherwise, the process proceeds to line 11.
On line 11, undirected ε-closures that are elements included in ψ′ are added to ψ.
On line 12, ψ′ is removed from Ψ.
The processing from line 9 to line 12 corresponds to processing for finding, from undirected ε-closures that are directly connected, undirected ε-closures that are indirectly connected.
On line 13, ψ is added to Ψ.
On line 14, the set Ψ having, as elements, the connected undirected ε-closures obtained by the processing on lines 1 to 13 is returned as a processing result.
ε-Removal Pattern
Details of ε-removal patterns will be further described here with reference to
Two states q1 and q2 that are connected by an ε-path are considered. Sets of incoming transitions and outgoing transitions to/from q1 are represented by Ei1 and Eo1, respectively, and sets of incoming transitions and outgoing transitions to/from q2 are represented by Ei2 and Eo2, respectively (see
Two ε-removal patterns that are patterns for generating transitions required for transformation so as to accept the same language even when ε-transitions are removed can be considered. One is a pattern reproducing Ei1 as illustrated in
Hereinafter, the patterns in
In a case of an undirected ε-closure including three or more states, however, even if an ε-removal pattern with which the number of transitions is most reduced when one ε-path is removed is selected, the ε-removal pattern may not be a pattern with the smallest number of transitions as a whole including removal of other ε-paths. A combination with the smallest number of transitions can be found by checking all the combinations.
The total number of ε-removal patterns that are included in the connected undirected ε-closure and that need to be selected is represented by N, and a variable for recording which of the ε-removal pattern 0 or the ε-removal pattern 1 is selected in the selection of an i-th ε-removal pattern is represented by xi. An arrangement of N variables xi will be x1x2x3 . . . xN, which can be recorded as an arrangement. This is referred to as an ε-removal pattern arrangement x.
Listing of ε-removal patterns that need to be selected
In step S103, the combination generating unit 103 first lists all the ε-removal patterns that need to be selected. Details thereof will be described below.
A 2-tuple including a state included in a connected undirected ε-closure and a state that can be reached therefrom by following one or more ε-transitions in the forward direction will be referred to as an ε-tuple. Since one ε-removal pattern has to be selected for one ε-tuple, all the ε-removal patterns that need to be selected will be listed if all the ε-tuples can be listed.
On line 1, a set Pε and a stack S are initialized to empty sets.
Line 2 expresses that lines 3 to 10 are processed on all elements of a set ψ having undirected ε-closures as elements. An undirected ε-closure to be processed from line 3 to line 10 is represented by θ.
Line 3 expresses that lines 4 to 10 are processed on all states included in the undirected ε-closure θ. A state to be processed in the processing from line 4 to line 10 is represented by q.
On line 4, q is added to the stack S and Qs is initialized to an empty set.
On line 5, it is determined whether the stack S is an empty set. If the stack S is an empty set, the process returns to line 3. Otherwise, the process proceeds to line 6.
On line 6, a state is taken out from the stack S and assigned to qs.
On line 7, qs is added to Qs.
On line 8, processing on lines 9 and 10 is executed on transitions e with the next states not being included in Qs among outgoing ε-transitions from qs.
On line 9, a 2-tuple two states including q and the next state of a transitions e is added to Pε.
On line 10, the next state of the transition e is added to the stack S.
When all processing from line 1 to line 10 is completed, the ε-tuple is recorded in Pε, and Pε is thus returned as a processing result on line 11.
Calculation of the Number of Transitions after ε-Removal
Next, the combination generating unit 103 calculates the number of transitions after ε-removal. Details thereof will be described below.
A function fnum(x, Pε) for calculating the number of transitions after removing ε-transitions in a connected undirected ε-closure on the basis of an ε-removal pattern arrangement x is considered. Pε is a set consisting of a 2-tuple obtained in
When ε-removal in a certain unconnected undirected ε-closure is to be performed using the ε-removal pattern arrangement x, fnum(x, Pε) as in
On line 1, a set Ene of transitions after ε-removal is initialized to an empty set. In addition, all states included as a 2-tuple consisting of states in Pε are assigned to Qε.
Line 2 expresses that lines 3 to 7 are processed on all states q included in Qε.
On line 3, the function make-transition is called where a first argument is q, a second argument is x and a third argument is Pε, and results thereof are obtained as Ein, Eout, binitial, bfinal and berror. Ein is a set of incoming transitions to the state q after ε-removal, Eout is a set of outgoing transitions from the state q after ε-removal, binitial is a value representing whether or not the state q is the initial state after ε-removal, bfinal is a value representing whether the state q is the final state after ε-removal, and berror is a value representing whether the language to be accepted after ε-removal is changed.
On line 4, it is determined whether the accepted language is changed. If berror is false, the process proceeds to line 6. If berror is true, the process proceeds to line 5.
On line 5, an infinite value or a maximum value that fnum(x, Pε) can return is returned as an error and the process is completed.
On line 6, it is determined whether or not to proceed to line 7. If neither of Ein and Eout is an empty set or if binitial is true and Eout is not an empty set or if bfinal is true and Ein is not an empty set, the process proceeds to line 7. Otherwise, the process returns to line 2.
On line 7, Ein and Eout are added to Ene.
On line 8, the number of transitions included in Ene obtained by the processing from line 1 to line 7 is returned as a processing result.
Next, the function make-transition in
On line 1, binitial is initialized to true if q is the initial state or to false otherwise. Similarly, bfinal is initialized to true if q is the final state or to false otherwise.
On line 2, an incoming transition to the state q among transitions other than ε-transitions is assigned to Ein. Similarly, an outgoing transition from the state q among transitions other than ε-transitions is assigned to Eout.
Line 3 expresses that processing from line 4 to line 16 is repeated with the value of a variable i incremented by 1 from 1 to the number of elements of Pg.
On line 4, states included, in a 2-tuple that are the i-th elements among the elements included in Pε are assigned to qs and qd, respectively. qd is a state that is reachable from qs by following ε-transitions in the forward direction.
On line 5, it is determined whether or not qs is in the same state as q. If qs is not in the same state, the process proceeds to line 10. If qs is in the same state, the process proceeds to line 6.
On line 6, it is determined whether the i-th value of the ε-removal pattern arrangement x is 1. If the i-th value is not 1, the process proceeds to line 10. If the i-th value is 2, the process proceeds to line 7. When xi is 1, this means that the ε-removal pattern 1 is selected. In other words, this means that an outgoing transition from qd is copied as an outgoing transition from qs.
On line 7, transitions other than ε-transitions among outgoing transitions from qd are added to Eout as outgoing transitions from q.
On line 8, it is determined whether or not qd is the final state. If qd is not the final state, the process proceeds to line 10. Otherwise, the process proceeds to line 9.
On line 9, bfinal is assigned with true. Then, the process proceeds to line 10.
On line 10, it is determined wither or not qd and q are equal. If qd and q are equal, the process proceeds to line 11. Otherwise, the process returns to line 3.
On line 11, it is determined whether the i-th value of the ε-removal pattern arrangement x is 0. If the i-th value is not 0, the process returns to line 3. If the i-th value is 0, the process proceeds to line 12. When xi is 0, this means that the ε-removal pattern 0 is selected. In other words, this means that an incoming transition to qs is copied as an incoming transition to qd.
On line 12, it is determined whether or not qs is the final state. If qs is not the final state, the process proceeds to line 14, or otherwise to line 13.
When line 13 is processed, this means that a language different from the original FSA becomes acceptable, and ε-removal cannot be performed successfully. Accordingly, it has to be made sure that the ε-removal pattern arrangement x received as arguments are not used. Thus, a fifth value of a 5-tuple of a return value is set to true to inform the caller of the same. Since the other values in the 5-tuple are not used, the other values may be any values.
On line 14, transitions other than s-transitions among incoming transitions to qs are added to Ein as incoming transitions to q.
On line 15, it is determined whether or not qs is the initial state. If qs is the initial state, the process proceeds to line 16. Otherwise, the process returns to line 3.
On line 16, binitial is assigned with true.
When the repetition of the processing from line 3 to line 16 is completed, the process proceeds to line 17.
On line 17, a result of the processing from line 1 to line 16 is returned as a 5-tuple. The first of the 5-tuple is set to Ein, the second thereof is set to Eout, the third thereof is set to binitial, the fourth thereof is set to bfinal, and since no transformation that accepts a different language is caused, the fifth thereof is set to false.
out(q) represents a set of outgoing transitions from the state q, and in(q) represents a set of incoming transitions to the state q. xi is the i-th element of the ε-removal pattern arrangement x corresponding to the i-th ε-combination included in Pε.
The combination generating unit 103 obtains values of fnum(x, Pε) for various values of x and obtains a value of x with the smallest value of fnum(x, Pε). The removing unit 104 can remove ε-transitions without depending on the direction of ε-removal by generating and discarding transitions on the basis of thus obtained x. When the combination generating unit 103 calculates all possible values of the ε-removal pattern arrangement x, the number of transitions after removing ε-transitions can be made minimum. The number of all combination is, however, 2|x|. If the calculation cannot be performed for all possible values because |x| is too large, the combination generating unit 103 may calculate fnum(x, Pε) only for some combinations and select a value of x with the smallest value of fnum(x, Pg).
For example, a method of calculating only two patterns with all 1 and with all 0 and using the one with a smaller value of fnum(x, Pε) can be applied. Alternatively, a common technique used in combination optimization problem. such as a genetic algorithm may be applied since x is only an arrangement of 0 and 1.
Generation and Discarding of Transitions Resulting from ε-Removal: Step S104
When the value of the ε-removal pattern arrangement x is determined, the removing unit 104 performs ε-removal by which transitions are generated and discarded on the basis of the ε-removal pattern arrangement x.
On line 1, all of the states constituting a 2-tuple included in Pε are assigned to Qε. In addition, Q, E, I and F are assigned to Qnew, Enew, Inew and Fnew, respectively.
Line 2 expresses that a state included in Qε is represented by q, and processing from line 3 to line 12 is repeated for all the states included in Qε.
On line 3, the function make-transition is called where a first argument is q, a second argument is x and a third argument is Pε. The result thereof is returned as a 5-tuple, but the fifth value is not used. The first value is a set Ein of incoming transitions to q after ε-removal, the second value is a set Eout of outgoing transitions from q after ε-removal, the third value is a value binitial representing whether or not q is the initial state after ε-removal, and the fourth value is a value bfinal representing whether or not q is the final state after ε-removal. The part corresponding to the fifth value that is not used here is represented by “.”, and hereinafter, such part corresponding to a value that is not used included in a tuple, if any, will be represented by “.”.
Line 4 expresses that Ein and Eout are added to Enew on line 5 if any of the following four conditions (1) to (4) is satisfied:
If the conditions on line 4 are not satisfied, line 7 is executed to remove Ein and Eout from Enew. Furthermore, q is removed from Qnew constituting the FSA to be processed. If q is the initial state or the final state, q is also removed from Inew and Fnew.
If binitial is true on line 8, the state q is added to Inew that is a set of initial states on line 9.
If bfinal is true on line 10, the state q is added to Fnew that is a set of final states on line 11.
On line 12, outgoing ε-transitions from the state q are removed from Enew. On line 13, Qnew, Enew, Inew and Fnew that are changed as a result of repeating the processing from line 3 to line 12 are assigned to Q, E, I and F, respectively. As for Enew, note that only transitions with the previous states and the next states included in Qnew are assigned to E.
Method for Removing all ε-Transitions
A method (DI-ε-removal) for removing all ε-transitions included in a finite state automaton can be constituted by combining the methods described above.
On line 1, undirected ε-closures are calculated by all-undirected-ε-closure( ) (
On line 2, connected undirected ε-closures are calculated by all-CUEC(Θ) (
On line 4, ε-tuples included in y are obtained by all-ε-pair(ψ) (
On line 6, ε-transitions are removed from the FSA to be processed on the basis of x obtained on line 5 by CUEC-ε-removal(x, Pε) (FIG, 13).
When the processing from line 4 to line 6 is completed for all the connected undirected ε-closures, the ε-removal of the first embodiment is completed.
Example of Processes
Next, an example of processes according to a method of the related art and according to the first embodiment will be described.
Specific process procedures will be described below by using pseudo codes.
The process starts by a pseudo code on line 1 in
When a first tuple is (1, 3), a second tuple is (2, 4), a third tuple is (5, 6) and a fourth tuple is (5, 7), one of ε-removal pattern arrangements that minimize fnum will be x=0111. This means x1=0, x2=1, x3=1 and x4=1. ε-transitions are actually removed on line 5 on the basis of the ε-removal pattern arrangement, and necessary transitions are generated.
In ε-removal, lines 3 to 12 in
A case where q=1 will be described. In this case, the result of line 3 will be Ein=φ, Eout={(1, b, 2)}. binitial=true and bfinal=false. Since the second condition on line 4 is satisfied, line 5 is executed but Enew is not changed. This is because transitions and states to be added are already included in the original FSA. While the condition on line 8 is satisfied, Inew will not be changed even when line 9 is executed since the state 1 is originally included in Inew. On line 12, an ε-transition (1, ε, 3) is removed from Enew.
A case where q=2 will be described. In this case, the result of line 3 will be Ein={(1, b, 2)}, Eout={(2, a, 5) }, binitial=false and bfinal=false. Since the first condition on line 4 is satisfied, a transition (2, a, 5) is added to Enew as a result of line 5. (1, b, 2) is included in the original FSA. On line 12, an ε-transition (2, c, 4) is removed from Enew.
A case where q=3 will be described. In this case, the result of line 3 will be Ein={(5, c, 3)}, Eout={(3, a, 5)}, binitial=true and bfinal=false. Since the first and second conditions on line 4 are satisfied, (5, c, 3) and (3, a, 5) are added to Enew on line 5 but Enew is not changed because these are originally present. Since the condition on line 8 is also satisfied, a state 3 is added to the initial state as a result of executing line 9.
A case where q=4 will be described. In this case, the result of line 3 will be Ein=φ, Eout={(4, a, 5)}, binitial=false and bfinal=false. Since the conditions on line 4 are not satisfied, a transition (4, a, 5) is removed from Enew and a state 4 is removed from Qnew as a result of executing line 7.
A case where q=5 will be described. In this case, the result of line 3 will be Ein={(3, a, 5), (4, a, 5)}, Eout={(5, c, 3), (5, a, 7), (5, b, 6)}, binitial=false and bfinal=true. Since the condition on line 4 is satisfied, Ein and Eout are added to Enew. Although there are transitions that are already present, transitions newly added to Enew are (5, a, 7) and (5, b, 6). Since the condition on line 10 is also satisfied, a state 5 is added to Fnew, which becomes the final state. On line 12, transitions (5, ε, 6) and (5, ε, 7) are removed from Enew.
A case where q=6 will be described. In this case, the result of line 3 will be Ein={(7, b, 6)}, Eout={(6, a, 7)}, binitial=false and bfinal=true. Since the condition on line 4 is satisfied, Ein and Eout are added to Enew, but no transitions are newly added because there are already present in Enew.
A case where q=7 will be described. In this case, the result of line 3 will be Ein={(6, a, 7)}, Eout={(7, b, 6)}, binitial=false and bfinal=false. Since the condition on line 4 is satisfied, Ein and Eout are added to Enew, but no transitions are newly added because there are already present in Enew.
Finally, on line 13, a transition with the previous state and the next state included in Qnew among transitions included in Enew is assigned to E, and Qnew, Inew and Fnew are assigned to Q, I and F, respectively. As a result, the ε-removal according to the first embodiment is completed, and the result as in
Next, a hardware configuration of the information processing device 100 according to the first embodiment will be described.
As illustrated in
The CPU 1 performs various types of processing in cooperation with various control programs stored in advance in the ROM 4 or the storage unit 6 using a predetermined area of the RAM 5 as a work area, and performs overall control of the operations of the respective components (the first set generating unit, the second set generating unit, the combination generating unit, the removing unit, etc.) constituting the information processing device 100. The CPU 1 also implements functions of the respective components in cooperation with predetermined programs stored in advance in the ROM 4 or the storage unit 6.
The operation unit 2 is an input device such as a mouse and a keyboard that receives information input by operation of the user as an instruction signal and outputs the instruction signal to the CPU 1.
The display unit 3 is a display device such as a liquid crystal display (LCD) that displays a variety of information on the basis of a display signal from the CPU 1.
The ROM 4 stores therein programs, various setting information and the like for the control of the information processing device 100 in an unrewritable manner.
The RAM 5 is a volatile storage medium such as SDRAM that functions as a work area of the CPU 1. Specifically, the RAM 5 serves as a buffer or the like that temporarily stores therein various variables, parameters and the like generated in ε-removal processing.
The storage unit 6 includes a semiconductor storage medium such as a flash memory or a magnetically or optically recordable storage medium, and stores therein programs, a variety of setting information and the like for the control of the information processing device 100 in a rewritable manner. The storage unit 6 also stores therein a variety of information on FSAs in advance and records FSAs that are results of ε-removal processes.
Programs to be executed in the information processing device according to the first embodiment are recorded on a computer readable recording medium such as a compact disk read only memory (CD-ROM), a flexible disk (FD), a compact disk recordable (CD-R) and a digital versatile disk (DVD) in a form of a file that can be installed or executed, and provided as a computer program product.
Alternatively, the programs to be executed in the information processing device according to the first embodiment may be stored on a computer system connected to a network such as the Internet, and provided by being downloaded via the network. Still alternatively, the programs to be executed in the information processing device according to the first embodiment may be provided or distributed through a network such as the Internet.
The programs in the first embodiment may be embedded in a ROM or the like in advance and provided therefrom.
The hardware configurations of information processing devices in second and third embodiments described below are similar to that in
As described above, the information processing device according to the first embodiment obtains a range (connected undirected ε-closure) of states that is affected by a result of selection of an ε-removal pattern, and performs ε-removal for each obtained connected undirected ε-closure. A connected undirected ε-closure is searched without depending on the directions of ε-transitions. Accordingly, there is no dependency on the direction of ε-removal, and it is not necessary to select whether ε-removal is to be performed in the direction of original transitions or in the direction reverse to that of original transitions. Furthermore, a finite state automaton composed of the same number or a smaller number of transitions as/than the method of the related art can be obtained.
In the second embodiment, a method of removing ε-transitions appearing in a weighted finite state automaton (WFSA) will be described. An ε-transition used herein refers to a transition with the input symbol being ε. A WFSA has a function of determining whether or not to accept a certain symbol sequence when the symbol sequence is input, and outputting a weight thereof if the symbol sequence is accepted. The output weight is obtained by calculating weights on paths corresponding to the input symbol sequence according to a predetermined rule as described below.
An i-th path among the paths corresponding to an input of a symbol sequence x is represented by πi. A path π includes one or more transitions, which are represented by e1, e2, . . . , en in this order from the one that can be reached first from an initial state. The weight on the transition ei is represented by w(ei), and the weight on the path π is represented by w(π)=w(e1)(×)w(e2)(×) . . . (×)w(en). The weight corresponding to the symbol sequence x is represented by w(x)=w(π1)(+)w(π2)(+) . . . (+)w(πn). In other words, the weight corresponding to the symbol sequence x is a result of calculating the weights on all the paths with (+).
Note that operations such as min and max can be used for the operation (+). In addition, operations such as + (addition) and × (multiplication) can be used for the operation (×). 1# for a given weight c is defined as a value satisfying c(×)1#=1#(×)c=c. For example, 1# is 0 when (×) is +, and 1# is 1 when (×) is ×. In other words, 1# is a value (specific value) that does not affect the calculation result even when the value is not present in calculating a weight on a path connecting given states.
Such a technique of generalizing such operation of weights is described in detail in Mehryar Mohri, “Semiring Frameworks and Algorithms for Shortest-distance Problems” (Journal of Automata, Languages and Combinatorics, 2002, vol. 7, pp. 321-350).
If an ε-transition is removed when a value other than 1# is assigned to the ε-transition, the weight that is obtained when the symbol sequence corresponding to the path including the removed ε-transition changes. It is therefore necessary to transform the WFSA so that the weights on ε-transitions become 1# in advance in order to remove the ε-transitions by using the method described in the first embodiment.
The second embodiment is different from the first embodiment in that the changing unit 205 is added and in the functions of the combination generating unit 203 and the removing unit 204. Since the other configuration and functions are the same as in
The changing unit 205 changes a weight on an transition included in a path connecting given states included in a WFSA to a specific value 1#. The combination generating unit 203 is different from the combination generating unit 103 in the first embodiment in that the combination generating unit 203 evaluates the number of transitions taking the weights into account. The removing unit 204 is different from the removing unit 104 in the first embodiment in that the removing unit 204 performs ε-removal taking the weights into account.
Methods
Next, an ε-removal process performed by the information processing device 200 thus configured according to the second embodiment will be described. In the case of a WFSA, ε-transitions are removed by a method similar to that in the first embodiment after transforming the WFSA so that the weights on all the ε-transitions become 1# for the reason described above.
Moving of Weights
Weights are moved before or after ε-transitions so that as less weights as possible remain on the ε-transitions (so that as many weights as possible on the ε-transitions become 1#).
On line 1, first states out of 2-tuples consisting of states included in Pε are collected and assigned to Qs. Similarly, second states are collected and assigned to Qd. In addition, W is initialized to an empty set.
Line 2 expresses that a state included in Qs is represented by qs and lines 3 to 15 are processed for all the states included in Qs.
On line 3, second states with first states being qs out of 2-tuples consisting of states included in Pε are collected and assigned to Qn. This is equivalent to obtaining a set of states that can be reached by following ε-paths in the forward direction from q5.
On line 4, a weight on a best path among ε-paths from qs to respective states included in Qn is calculated by using a function ε-distance, and the calculation result is assigned to W′. Elements of W′ constitute a 3-tuple (an initial state of the ε-path, a final state of the ε-path and the weight on the ε-path). Herein, the first state of the 3-tuple is qs, and the second state is any of the states included in Qn. The third value is the weight on the best path among the ε-paths between the first state and the second state.
ε-distance can be calculated by the Dijkstra's Algorithm that is well known. Alternatively, ε-distance can also be calculated by a common method for solving a single-source shortest-distance problem from one state described in the document by Mohri mentioned above.
If an incoming ε-transition to the state qs is present or if the state qs is the final state on line 5, W′ is added to W on line 6. Otherwise, the process proceeds to line 8.
On line 8, all the weights that are the third values of the 3-tuples obtained on line 4 and all the weights on transitions other than ε-transitions among outgoing transitions from the state qs are calculated with (+), and the calculation result is assigned to w. Herein, weight(e) is a weight assigned to a transition e. When (+) is min, the smallest of the weights can be obtained.
On line 9, a 3-tuple having a value obtained by processing the weight recorded in the third of a 3-tuple included in W′ and wm−1 by (×) operation as a new third value is added to W. When (+) is max and (×) is + or when (+) is min and (×) is +, y−1 and −y are equal. For example, when wm is 2 and w is 3, wm−1 (×)w=−wm+w=−2+3=1 is obtained.
On lines 10 and 11, processing of replacing the weights w of transitions other than ε-transitions among outgoing transitions from qs with the result of operation of wm−1 and w by (x) is performed.
On lines 12 and 13, processing of replacing the weights w of transitions other than ε-transitions among incoming transitions to qs with the result of operation of w and wm by (×) is performed. For example, when the weight on an incoming transition e to qs is 10, wm is 2 and (×) is +, the weight on the transition e after this processing is completed will be 12.
On lines 14 and 15, when the state qs is the initial state, the initial weight λ(qs) of the state qs is replaced with λ(q)(×)wm.
As a result of the processing of lines 2 to 15, the weights assigned to ε-transitions will be pushed to the direction reverse to the direction of the transitions.
Line 16 expresses that a state included in Qd is represented by qd, and processing from line 17 to line 25 is executed for the respective states included in Qd.
On line 17, all the weights recorded as the third values of 3-tuples with the states recorded as the second values being qd among 3-tuples included in W and all the weights assigned to transitions other than ε-transitions among incoming transitions to the state qs are calculated with (+), and the calculation result is assigned to wm.
On lines 18 and 19, the weights w recorded as the third values of 3-tuples with the states recorded as the second values being qd among the 3-tuples included in W are replaced by values obtained by w(×)wm−1.
On lines 20 and 21, the weights w of incoming transitions to qd other than ε-transitions are replaced with values obtained by w(×)wm−1.
On lines 22 and 23, the weights w of outgoing transitions from qd other than ε-transitions are replaced with values obtained by wm(×)w.
On lines 24 and 25, when the state qd is the final state, final weights ρ(qd) of the state qd are replaced with wm(×)ρ(qd).
As a result of the processing of lines 16 to 25, the weights assigned to ε-transitions will be pushed to the direction of the transitions.
On line 26, 3-tuples with the weights recorded as the third values are 1# among the 3-tuples included in W are removed from W.
On line 27, W obtained as a result of the processing of lines 1 to 26 is returned as the result of this process.
All the weights on ε-paths do not always become 1# only by the push-weight illustrated in
Thus, the function fnum(x, Pε) that the combination generating unit 203 uses for the evaluation of the number of transitions is different from that in the first embodiment. Search of combinations, however, can be performed similarly to the first embodiment. In the following, a function that the combination generating unit 203 uses instead of the function fnum will be expressed as a function gnum(x, Pε, W). W is a set that the push-weight illustrated in
On line 1 in
Processing from line 2 to line 5 is that of obtaining the number of transitions after ε-removal from the WFSA to which the states and transitions generated on line 1 are added. More specifically, the processing is as follows.
On line 2, the states, the transitions, the initial states and the final states included in the WFSA to be processed are recorded in Qold, Eold, Iold and Fold, respectively.
On line 3, Qnew, Enew, Inew and Fnew are added to a set Q of the states, a set E of the transitions, a set I of the initial states and a set F of the final states, respectively, of the WFSA to be processed.
On line 4, the number of transitions after ε-removal by the function fnum used in the first embodiment is obtained and assigned to N.
On line 5, Qold, Eold, Iold and Fold saved on line 2 are used to return to the original WFSA.
On line 6, the number N of transitions obtained as a result of the processing from line 1 to line 5 is returned as the processing result.
Next, the function make-path in
Line 2 expresses that processing from line 3 to line 15 is repeated from i=1 to |x|−|Pε|.
On line 3, the first value of a 3-tuple recorded in wi that is the i-th element of W is assigned to qs, the second value thereof is assigned to qd and the third value thereof is assigned to w.
On line 4, a new state that is not included in Q is created and assigned to qnew.
On line 5, the new state gnew created on line 4 is added to Qnew.
On line 6, it is determined whether or not the i+|Pε|-th value of x is 0. If the value is 0, the process proceeds to line 7. If the value is other than 0, the process proceeds to line 12.
On lines 7 to 10, generation of transitions, changing of ε-tuples, etc. are performed on the basis of the push pattern 0.
On line 7, transitions other than ε-transitions among incoming transitions to the state qs are copied as incoming transitions to the new state qnew. The weights we are replaced with we(×)w at this point.
On line 8, ε-tuples (qs, qd) that have become unnecessary are removed from Pε and ε-tuples (qnew, qd) are newly added.
On line 9, it is determined whether qs is the initial state. If q3 is the initial state, qnew is added to Inew and the initial weight on qnew is set to a result of calculating the initial weight on qs and w with (×) on line 10.
On lines 12 to 15, generation of transitions, changing of ε-tuples, etc. are performed on the basis of the push pattern 1.
On line 12, transitions other than ε-transitions among outgoing transitions from the state qd are copied as outgoing transitions from the state qnew. The weights we are replaced with w(×)we at this point.
On line 13, ε-tuples (qs, qd) that have become unnecessary are removed from Pε and ε-tuples (qs, qnew) are newly added.
On line 14, it is determined whether or not qd is the final state. If qd is the final state, qnew is added to Fnew and the final weight on qnew is set to a result of calculating w and the final weight on qd with (×) on line 15.
On line 16, a 5-tuple (Qnew, Enew, Inew, Fnew, Pε) are returned as a result of processing of lines 1 to 15.
Method for removing all ε-transitions included in WFSA
All of ε-transitions included in a WFSA can be removed by combining the methods described above.
On line 1, undirected ε-closures are calculated by all-undirected-ε-closure( ) (
On line 2, connected undirected ε-closures are calculated by all-CUEC(Θ) (
Line 3 expresses that lines 4 to 9 are processed on each of the connected undirected ε-closures ψ included in Ψ.
On line 4, ε-tuples are obtained and assigned to Pε similarly to the first embodiment.
On line 5, the method of
On line 6, the patterns in an ε-removal pattern arrangement x′ having a length of |Pε|+|W| is variously changed to find x′ with which the function gnum is the smallest, and such x′ is assigned to x. Similarly to the first embodiment, all of the combinations of x may be searched or only some of the combinations may be searched. Similarly to the first embodiment, a common combination optimization method may be used for determining where to search. For example, a genetic algorithm can be applied. Only two patterns with all 0 and with all 1 may be checked.
On line 7, a set of new states and a set of new transitions obtained by the function make-path in
On line 8, Qnew, Enew, Inew and Fnew obtained on line 7 are added to Q, E, I and F, respectively.
On line 9, ε-transitions of the WFSA to which states and transitions are added on line 8 are removed on the basis of x and Pε, and necessary transformation is performed as a result. This is the same as in the first embodiment. However, the processing of initial weights and final weights are added (details thereof will be described later). As a result of the process described above, ε-transitions of a WFSA can be removed.
Next, details of a function WFSA-CUEC-ε-removal used on line 9 in
Items of the initial weights and the final weights are added to the returned values obtained on line 3, and setting of the initial weights using the values is added on line 9 and setting of the final weights using the values is added on line 11. Furthermore, processing on the initial weights and the final weights is also added to line 1 and line 13. On line 1, processing of assigning initial weights λ(q) associated with initial states q∈I to λnew(q) and assigning final weights ρ(q) associated with final states q∈F to ρnew(q) is added. On line 13, processing of assigning initial weights λnew(q) associated with initial states q∈Inew to λ(q) and assigning final weights ρnew(q) associated with final states q∈Fnew to ρ(q) is added. Since the other features are the same as CUEC-ε-removal in
On line 1, processing of initial weights and final weights are added. The initial weights on the states q are assigned to λq and the final weights on the states q are assigned to ρq. In a case where the state q is not the initial state, ∞ is assigned to λg when min is used for (+) and + is used for (×), and −∞ is assigned to λq when max is used for (+) and + is used for (×). A case where the state q is not the final state is similarly handled.
Processing of calculating the best final weight is added on line 9, and processing of calculating the best initial weight is added on line 16. Moreover, λq and ρq are added to the returned values on lines 13 and 17.
Example of Processes
Next, an example of processes according to a method of the related art and according to the second embodiment will be described.
In this example, processing of weights is performed using min as (+) and + as (×) both in the method according to the second embodiment and in the method of the related art.
A case where ε-removal is performed according to the second embodiment will be described below. On line 2 of
On line 4, ε-tuples can be obtained. Specifically, Pε={(2, 4), (2, 5), (3, 5), (3, 6)} is obtained. On line 5, as many weights as possible on ε-transitions are moved back or forth to eliminate weights on the ε-transitions. However, the weights assigned to the original ε-transitions need not be changed. Information resulting from the change is recorded in W that can be obtained by assigning a return value. Specifically, W={(3, 5, 1)} is obtained. This means that one weight remains on an ε-path between a state 3 and a state 5 but no weights remain on the other paths.
On line 6, x with which the number of transitions is the smallest can be obtained. It is assumed that a first tuple is (2, 4), a second tuple is (2, 5), a third tuple is (3, 5), a fourth tuple is (3, 6), and elements of W associated with a push pattern recorded in the fifth value is (3, 5, 1). In this case, one of ε-removal arrangement that minimizes the function gnum will be x=11111. This means x1=1, x2=1, x3=1, x4=1 and x5=1. On lines 6 and 7, necessary states and transitions are generated, and Pε is updated.
Although there is no incoming transition to a newly generated state 8, this will not be a problem in the next ε-removal process since the transition is included in Pε updated as an ε-tuple. Note that the updated Pε is {(2, 4), (2, 5), (3, 8), (3, 6)}. Finally, on line 8, ε-transitions are actually removed and necessary transitions are generated.
As described above, with the information processing device according to the second embodiment, removal of ε-transitions can also be performed without depending on the directions of the transitions even on a finite state automaton in which information other than the input symbols is assigned to transitions like a WFSA. Furthermore, a WFSA composed of the same number or a smaller number of transitions as/than the method of the related art can be obtained.
In the third embodiment, a method of removing ε-transitions in a finite state transducer (FST) will be described. In the case of FST, similarly to the case of the second embodiment, ε-removal is performed by the method of the first embodiment after transforming the FST so that ε becomes a value with which character strings on all of ε-transitions are empty character strings (empty symbols). 1# used in the second embodiment corresponds to ε.
The third embodiment is different from the second embodiment in the functions of the changing unit 305, the combination generating unit 303 and the removing unit 304. Since the other configuration and functions are the same as in
The changing unit 305 changes an output symbol of an ε-transition included in a path connecting given states included in an FST to an empty symbol ε. The combination generating unit 303 is different from the combination generating unit 203 in the second embodiment in that the combination generating unit 303 evaluates the number of transitions using the output symbols instead of weights. The removing unit 304 is different from the removing unit 204 in the second embodiment in that the removing unit 304 performs ε-removal using the output symbols instead of the weights.
Methods
Next, an ε-removal process performed by the information processing device 300 thus configured according to the third embodiment will be described.
Moving of Character Strings
In the third embodiment, first, character strings are moved so that as many character strings as possible on ε-transitions become empty character strings. This is basically the same as the process (push-weight in
On line 1, first states out of 2-tuples consisting of states included in Pε are collected and assigned to Qs. Similarly, second states are collected and assigned to Qd. In addition, O is initialized to an empty set.
Line 2 expresses that a state included in Qs is represented by qs, and lines 3 to 15 are processed for all the states included in Qs.
Line 3 is the same as in
On line 4, output symbols on ε-paths from qs to respective states included in Qn are calculated by using the function ε-output, and the calculation result is assigned to O′. Elements of O′ constitute a 3-tuple (an initial state of the ε-path, a final state of the ε-path and an output symbol on the ε-path). Herein, the first state of the 3-tuple is qs, and the second state is any of the states included in Qn. The third value is the output symbol on the ε-path between the first state and the second state. E-output will be described later.
On lines 5 and 6, if an incoming ε-transition to the state qs is present or if qs is the finial state, O′ is added to O. Otherwise, the process proceeds to line 8.
On line 8, the longest common prefix operation is performed using all the output symbols that are third values in the 3-tuples obtained on line 4 and all the output symbols of transitions that are not ε-transitions among outgoing transitions from the state qs, and the result thereof is assigned to om. Herein, output(e) is an output symbol assigned to a transition e.
On line 9, a 3-tuple having a value obtained by processing the output symbol recorded in the third of a 3-tuple included in O′ and om−1 by (×) operation as a new third value is added to O. om−1(×)o represents processing of removing om from ahead of an output symbol o. For example, when om=ab and o is abc, the result of this processing will be c.
On lines 10 and 11, processing of replacement with output symbols obtained by removing om from ahead of output symbols o of transitions other than ε-transitions among outgoing transitions from qs is performed. For example, when an output symbol of an outgoing transition e from qs is bc and wm is b, the output symbol of the transition e will be c after completing this processing.
On lines 12 and 13, processing of replacing of output symbols o of transitions other than ε-transitions among incoming transitions to qs with output symbols obtained by concatenating o and om is performed. For example, when an output symbol of an incoming transition e to qs is a and wm is b, the output symbol of the transition e will be ab after completing this processing.
On lines 14 and 15, when the state qs is the initial state, the initial output symbol λo(qs) of the state qs is replaced with an output symbol obtained by λo(qs) (×)om.
Line 16 expresses that a state included in Qd is represented by qd, and processing from line 17 to line 26 is executed for a case where there is no outgoing ε-transitions from qd among the respective states included in Qd and qd is not the initial state.
On line 17, all the output symbols recorded in the third values of 3-tuple with the states recorded in the second values being qd among the 3-tuples included in O and all the output symbols assigned to transitions that are not ε-transitions among incoming transitions to the state qd are reversed in the direction, and processed by the longest common prefix operation. For example, when there are abc and bbc as output symbols, cb is assigned to om. Note that rev in the pseudo codes is a function for reversing the direction of an output symbol.
On lines 18 to 20, the output symbol o recorded in the third value of a 3-tuple with the state recorded in the second value being qd among the 3-tuples included in O is replaced by the next output symbol. The output symbol is obtained by reversing the direction of o, removing om from ahead and reversing the direction of the resulting output symbol.
On lines 21 and 22, the direction of output symbols of incoming transitions e to qd that are not ε-transitions is reversed, om is removed from ahead thereof, the direction thereof is further reversed, and the result thereof is used as new output symbols of the transitions e.
On lines 23 and 24, output symbols of outgoing transitions e from qd that are not ε-transitions are replaced with output symbols in which the output symbols obtained by reversing the direction of om are connected to the front of the original output symbols.
On lines 25 and 26, when the state qd is the final state, the final output symbol ρo(qd) of the state qd is replaced by an output symbol obtained by concatenating an output symbol that is a reversed version of om with ρo(qd).
On line 27, a 3-tuple in which the output symbol recorded in the third value of the 3-tuple included in O is ε, that is, a 3-tuple in which the output symbol is empty is removed from O.
On line 28, O obtained by the processing of lines 1 to 27 is returned as a result of the processing.
Next, details of ε-output will be described. Unlike ε-distance, ε-output calculates all of combinations of output symbol sequences present on a path including only ε-transitions connecting two states.
On line 1, a function ε-DFS, which will be described later, is called and a result thereof is assigned to a set Qo of states and a set Eo of transitions. A set L of output symbols is also initialized to an empty set.
Line 2 expresses that processing of lines 3 to 7 is executed on the respective states q included in Qo. Note that the order of the processing is a topological order calculated by using only the set Eo of transitions. In this manner, it is ensured in processing a certain state that processing of lines 3 to 7 on states on a path through which the certain state is reached from qs is completed.
Line 3 expresses that processing of lines 4 to 7 is executed on incoming ε-transitions e to q among transitions included in E.
On lines 4 and 5, when the set L(p(e)) of output symbols associated with the previous states of the transitions e is an empty set, output symbols of the transitions e are added to a set L(q) of output symbols associated with the states q.
Line 6 expresses that line 7 is processed on output symbols o included in the set L(p(e)) recorded with the previous states of the transitions e.
On line 7, an output symbol obtained by connecting the output symbol o with an output symbol assigned to a transition E is added to a symbol L(q) assigned to the state q.
On lines 8 to 11, the result obtained up to line 7 is converted to a form to be returned as the processing result. As a result, the 3-tuples (qs, any of the states included in Qd, an output symbol) are recorded, as elements in a set R. In the third value of a 3-tuple, an output symbol on an ε-path from qs to a state recorded in the second value is to be recorded.
On line 12, the set R obtained by the processing up to line 11 is returned as the processing result.
Next, details of ε-DFS will be described. With this function, a set of states and a set of transitions on all of ε-paths with a state specified by a first argument being the initial state can be obtained.
On line 1, sets Qs and Qo of states are added to q. A empty set is assigned to Eo.
Line 2 expresses that processing from line 3 to line 7 is executed on outgoing ε-transitions e from the state q.
On line 3, it is determined whether the next state of a transition e is included in Qs. If the next state is not included, the process proceeds to line 4.
On line 4, a transition e is added to Eo.
On line 5, it is determined whether the next state of a transition e is included in Qo. If the next state is not included, the process proceeds to line 6.
On line 6, the function ε-DFS is called recursively. The arguments are the next state of the transition e, Qs and Qo. The obtained result is assigned to Qr and Er.
On line 7, Qr and Er obtained on line 6 are added to Qo and Eo, respectively.
On line 8, a 2-tuple composed of Qo and Eo is returned as a result obtained by the processing up to line 7.
Method for removing all ε-transitions included in FST
In order to remove all ε-transitions included in an FST, the processing relating to weights in
Example of Processes
Next, an example of processes according to the method of the related art and according to the third embodiment will be described.
Case of Weighted Finite State Transducer
In a case of a weighted finite state transducer, the ε-removal process described in the second embodiment may be performed after both moving weights and moving output symbols in this order and regarding a combination of a weight and an output symbol as a weight.
As described above, with the information processing device according to the third embodiment, removal of ε-transitions can also be performed without depending on the directions of the transitions even when information other than the input symbols is assigned to transitions as in an FST or a WFST. Furthermore, the number of transitions can be made equal to or smaller than that in the method of the related art.
While certain embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions. Indeed, the novel embodiments described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the embodiments described herein may be made without departing from the spirit of the inventions. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of the inventions.
Number | Date | Country | Kind |
---|---|---|---|
2010-064981 | Mar 2010 | JP | national |
This application is a continuation of PCT international application Ser. No. PCT/JP2011/055682 filed on Mar. 10, 2011 which designates the United States, and which claims the benefit of priority from Japanese Patent Application No. 2010-064981, filed on Mar. 19, 2010; the entire contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2011/055682 | Mar 2011 | US |
Child | 13617309 | US |