Embodiments described herein relate generally to a finite state transducer determinizing device and a finite state transducer determinizing method.
A finite state transducer (FST) which is a kind of finite state automation (FSA) is used in various fields, such as natural language processing or speech recognition. Formally, the FST is expressed by a six-tuple (Q, Σ, Δ, E, I, F). Q denotes a set of states, Σ denotes a set of input symbols, E denotes a set of transitions, I denotes a set of initial states, F denotes a set of final states, and Δ denotes a set of output symbols. In the FST, the transition E is EQ×Σ×Δ*×Q. Δ* is the Kleene closure of Δ, and refers to a set of all symbol sequences which can be created by combinations of null symbol sequences ε and Δ. If the output symbols are excluded from the FST, the FSA is implemented. The FST is also called a generalized sequential machine.
When the FST is nondeterministic, this means that the same input symbol sequence is assigned to a plurality of paths. Formally, this means that, when the size of a set X (the number of components) is expressed by |X|, and a set of paths which can be transited from a state qεQ by an input symbol sequence wεΣ* is Π(q,w)E*, there is q such that the condition |Π(q,w)|>1 is satisfied. This FST is referred to as a nondeterministic finite state transducer (NFST). Meanwhile, when the FST is deterministic, this means that there is only one path to the maximum when a certain input symbol sequence is applied. Formally, this means that the condition |Π(q,w)|≦1 is satisfied for all of qεQ and wεΣ*. This FST is referred to as a deterministic finite state transducer (DFST). Conversion of NFST to DFST is referred to as determinizing. The determinizing is carried out, for example, by a method described in U.S. Pat. No. 6,456,971 or M. Mohri, “On Some Applications of Finite-State Automata Theory to Natural Language Processing,” Natural Language Engineering, 1996, vol. 2, issue 1, Pages 61-80.
However, in determinizing a non-single-valued NFST by the method of the related art, it is necessary to perform preprocessing, which includes a step of finding a portion responsible for a non-single value and a step of converting the found portion to a single value to form a single-valued NFST (“single value” will be described below).
In general, according to one embodiment, a finite state transducer determinizing device includes a symbol determination unit, a state merging unit, and a single-value processing unit. The symbol determination unit generates an identification symbol different from an input symbol assigned to each transition of a finite state transducer. The state merging unit extracts one or more states at a transition destination by the same input symbol from among the states of the finite state transducer and generates states having the extracted states as sub-states. The single-value processing unit applies the input symbol assigned to each transition of the finite state transducer or the identification symbol as an input symbol of a transition between the states generated by the state merging unit to perform determinizing.
Hereinafter, embodiments will be described with reference to the drawings.
An NFST is single-valued or non-single-valued. When the NEST is single-valued, this means that there is one output to the maximum even when any input symbol sequence is input to the NFST. Formally, this means that, when an output symbol sequence of a path πεΠ(q,w) is out(π), the condition |{out(π)|πεΠ(q,w),qεQ,wεΣ*}|≦1 is satisfied. Similarly, when the NFST is non-single-valued, this means that the condition |{out(π)|πεΠ(q,w),qεQ,wεΣ*}|>1 is satisfied.
If the determinizing of the non-single-valued NFST is performed by the method described in U.S. Pat. No. 6,456,971, an output symbol which has been present before the determinizing may be erased. According to the method described in “On Some Applications of Finite-State Automata Theory to Natural Language Processing”, the determinizing may not end. This situation occurs when the FST does not have a twins property described below (Jean Berstel, “Transductions and Context-Free Languages,” 1979, Chapter IV, Section 6 and C. Allauzen, M. Mohri, “An Optimal Pre-determinization Algorithm for Weighted Transducers,” Theoretical Computer Science, 2004, Volume 328, Issue 1-2, Implementation and application of automata, Pages 3-18).
It is assumed that a set of paths which reaches a state q′ from a state q by an input symbol w is Π(q,w,q′), and the state of a transition destination of a path π is n(π). When (×) is a conjunction operation of a symbol sequence, and a symbol sequence is x, it is assumed that x−1 is a symbol sequence which satisfies x−1(×)x=ε. For example, A(×)B=AB and A−1(×)AB=B are established.
(Condition)
out(π1)−1(×)out(π2)=out(π1π′1)−1(×)out(π2π′2)
When this condition is satisfied, this means that the states q1=n(π1) and q2=n(π2) are twins. Paths from initial states i1, i2εI by an input symbol sequence xεΣ* are π1εΠ(i1,x) and n2εΠ(i2,x). For an input symbol sequence yεΣ*, paths are π′1εΠ(q1,y,q1) and π′2εΠ(q2,y,q2). A path in which a path π′1 is connected behind a path π1 is expressed by π1π′1. When all combinations of q1 and q2 are twins, this means that the FST has a twins property. In the case of an FST with no cyclic path, since ∪(q1,y,q1) or ∪(q2,y,q2) is an empty set, there is no non-twins state. Thus, this FST also has a twins property.
A method which finds a non-twins state and introduces an auxiliary input symbol into the corresponding location, thereby enabling determinizing, that is, a method which carries out conversion to a single-valued FST is heretofore known (“An Optimal Pre-determinization Algorithm for Weighted Transducers”). An auxiliary input symbol is an input symbol which is not included in an original FST and is newly introduced to form a single-valued FST. With this method, a non-single-valued FST is converted to a single-valued FST in advance, thereby determinizing a non-single-valued FST.
When a twins property is provided, an output symbol may be erased. There is a case illustrated in
In this case, if it is defined such that n outgoing transitions are recognized from the final state, and an output symbol is assigned to each transition (
An FST in which each transition is weighted is called a weighted finite state transducer (WFST). Similarly to an FST, determinizing can be performed on a WFST. For example, determinizing can be performed by the method described in U.S. Pat. No. 6,456,971. In the case of a WFST as well, there is a non-single-valued WFST. The determinizing of a non-single-valued WFST requires conversion to a single-valued WFST, and the conversion method is described in “An Optimal Pre-determinization Algorithm for Weighted Transducers.” A method is carried out in which a non-single-valued WFST is first converted to a single-valued WFST by the conversion method, and then determinizing is performed, thereby determinizing a non-single-valued WFST.
That is, it is necessary to perform preprocessing, which includes a step of finding a portion responsible for a non-single value and a step of converting the found portion to a single value to construct a single-valued NFST. In the following embodiments, a case will be described where a non-single-valued NFST is determinized without preprocessing.
Next, necessary symbols, terms, and the like in this embodiment or subsequent embodiments will be described.
An empty set is expressed by φ or { }. An empty symbol sequence is expressed by ε. An empty symbol sequence is also called an empty sequence or an empty string. The transition source state of a transition eεE is p(e), the transition destination state of the transition eεE is n(e), an input symbol is in(e), and an output symbol sequence is out(e). Similarly, the starting state of a path πεE* is p(π), the ending state of the path πεE* is n(π), an input symbol sequence is in(π), and an output symbol sequence is out(π). The total number of transitions on a path π is |π|. The state of a j-th transition destination on π is (π)j. p(π)=(π)0 and n(π)=(π)|π|. It is assumed that an auxiliary input symbol is expressed by #n (where n is an integer). It is desirable that a plurality of auxiliary input symbols can be distinguished from each other, thus it is assumed that n of #n is an integer.
When a set is expressed by a program or the like, a set may be expressed in any way insofar as elements of a set can be stored, and overlapping elements are not generated in the set. For example, an array, a linked list, a binary tree, a hash table, or the like may be used.
According to the method in this embodiment, it is not possible to determinize all FST having no twins property. Only an NFST which satisfies the following condition can be determinized by the method in this embodiment.
It is assumed that paths from an initial state to states q1 and q2 are respectively π1 and π2, a path from the state q1 to q1 is π′1, a path from the state q2 to q2 is π′2, and in(π1π′1)=in(π2π′2). When all the states q1 and q2 are twins or satisfy the following condition, determinizing can be performed with conversion to a single value by the method in this embodiment.
This condition is that, if there is j such that (π1)j=(π2)j, and all output symbol sequences of transitions on π1 and π2 to states (π1)j and (π2) are assumed as ε, the states q1 and q2 become twins.
Since an NFST which does not satisfy the above condition cannot be converted to a single value, there is no case where determinizing processing by the method in this embodiment is completed.
The details of the method in this embodiment are as pseudo codes of
From the viewpoint of generalization, an operation of an output symbol is expressed by (+) and (×). In the drawings, (+) is a symbol with + enclosed in a circle, and (×) is a symbol with × enclosed in a circle. In this embodiment, (+) represents a longest common prefix operation, and (×) represents a conjunction operation. For example, abc(+)adc=a and a(×)b=ab. 1# is further introduced. In this embodiment, 1# is handled as an empty symbol sequence ε. In other words, in this embodiment, even when 1# of
When a state which is an element of a set Q2 of states of T2 is q2, q2 is expressed by a set of two-tuples (state of T1 and input symbol or output symbol sequence). Formally, q2{(q1,w)|q1εQ1,wε(Σ1∪Δ*)}. At the time of actual operation on a computer, as the pseudo code of
γ(q2,α) and ξ(q2,α,qn) which are used in
γ(q2,α)={n(e)|eεE1,(q,•)εq2,p(e)=q,in(e)=α}
ξ(q2,α,qn)={(w,e)|(q,w)εq2,eεE1,p(e)=q,n(e)=qn,in(e)=α}
γ(q2,α) represents a set of states of a transition destination by an input symbol α from each state before determinizing as an element of the state q2 after determinizing. ξ(q2,α,qn) represents a set of transitions in which the state before determinizing as an element of the state q2 after determinizing is a transition source state, and a state qnεQ1 before determinizing is a transition destination, and to which the input symbol α is assigned.
The pseudo code of
In the 2nd row, the result of a longest common prefix operation on all output symbol sequences assigned to the initial states of FST T1 is substituted in an initial output symbol sequence λ2 of FST T2.
In the 3rd row, an initial state i2 of T2 is created. An initial state is expressed as a set which has two-tuples of the initial state of T1 and the output symbol sequence as elements. If an element included in i2 is (i,w), w is obtained by removing the same output symbol sequence as λ2 in order from the front of an initial output symbol sequence λ1(i) corresponding to the initial state i of T1. For example, λ1(i) is abc, and λ2 becomes w=(ab)−1(×)abc=c from ab.
In the 4th row, the initial state of T2 is set in the stack S. At this time, an element included in S is i2 only. With regard to the stack S, any structure may be used insofar as values can be added or extracted one by one. Thus, for example, a queue may be mounted, instead of a stack. And, i2 is added to Q2.
In the 5th row, it is determined whether or not the stack S is empty. If the stack S is empty, this means that determinizing is completed, thus the processing ends. When the stack S is not empty, the processing of the 6th or subsequent row is performed.
In the 6th row, one element is extracted from the stack S and substituted in q2. The extracted element is removed from the stack S.
In the 7th row, if at least one symbol sequence from among two-tuples (states and symbol sequences) as elements included in q2 is included in Σ1, the processing progresses to the 8th row. Otherwise, the processing progresses to the 14th row.
In the 8th row, let a two-tuple as the element included in q2 be (q,w). Further, since surely |q2|=1, q,w is determined uniquely.
In the 9th row, a transition destination state qn2 of a transition which will be created in the 10th row is created. The state qn2 becomes a set of two-tuples of a state q and an output symbol sequence 1# as elements.
In the 10th row, a transition in which a transition source state is q2, an input symbol is w, an output symbol is 1#, and a transition destination state is qn2 is added to E2.
In the 11th row, it is determined whether or not qn2 is already included in Q2, and if qn2 is not yet included in Q2, the processing progresses to the 12th row. In the 12th row, qn2 is added to the stack S. qn2 is also added to Q2.
In the 14th row to the 23rd row, a final state and a final output of T2 are created.
In the 14th row, it is determined whether or not at least one of states qεQ1 included in the two-tuples as the elements of q2 is included in a final state F1. If at least one is included, the processing progresses to the 15th row.
In the 15th row, w(×)ρ1(q) is calculated for all the two-tuples (q,w) satisfying qεF1 from among the two tuples (q,w) included in q2. Let a set including all output symbol sequences obtained by the calculation be W.
In the 16th row, an operation by (+) is carried out on all the output symbol sequences included in a set W of output symbol sequences, and the result is substituted in w2. For example, if W={x1,x2,x3}, calculation x1(+)x2(+)x3 is carried out.
In the 17th row, if at least one output symbol sequence which is the same as w2 calculated in the 16th row is included, the processing progresses to the 18th row. Otherwise, the processing progresses to the 19th row.
In the 18th row, w2 is substituted in ρ2(q2) as a final output of q2, and q2 is also added to F2 as a final state.
The 19th row shows that the processing from the 20th row to the 23rd row is performed on an output symbol sequence different from w2 from among the output symbol sequences w included in W.
In the 20th row, the state qn2 becomes an empty set.
In the 21st row, a transition in which a transition source state is q2, an input symbol is (qn2,w), an output symbol sequence is w, and a transition destination state is qn2 is added to E2. An input symbol of the added transition is added to Σ2.
In the 22nd row, it is determined whether or not qn2 is included in the set Q2 of states of T2. If qn2 is included, the processing progresses to the 23rd row.
In the 23rd row, a final output ρ2(qn2) of qn2 is 1#, and qn2 is added to the set Q2 of states of T2 and the set F2 of final states.
The 24th row shows that the processing from the 25th row to the 37th row is performed on the input symbol α included in Σ1. It should suffice that the processing from the 25th row to the 37th row is performed on all the input symbols assigned to the transitions in which the state of T1 included in q2 as the two-tuple (state of T1 and output symbol sequence) is a transition source state. Thus, it is not necessary to perform the processing from the 25th row to the 37th row on other input symbols. However, even when the processing is performed, since none satisfies the condition of the 26th row or the 32nd row, the result is the same as when the processing is not performed.
In the 25th row, the following processing is performed on the elements qn of γ(q2,α) to create a two-tuple (qn and a set of output symbol sequences) on the basis of qn and the obtained result, and a set of two-tuples (qn and a set of output symbol sequences) corresponding to all qn is substituted in θ. This processing refers to processing for creating a set having the calculation results of w(×)out(e) on the elements (w,e) of τ(q2,α,qn) as elements when w is an output symbol sequence and e is a transition.
In the 26th row, the processing from the 27th row to the 31st row is performed on elements having the size of W equal to or greater than 2 from among the two-tuples (qn,W) as the elements of θ created in the 25th row.
In the 27th row, a two-tuple (qn,α) is substituted in qn2.
The 28th row shows that the processing of the 29th row is performed on the elements w included in W.
In the 29th row, a transition in which a transition source state is q2, an input symbol is aux(qn2,w), an output symbol sequence is w, and a transition destination state is qn2 is added to E2. An input symbol of the added transition is added to Σ2.
In the 30th row, it is determined whether or not qn2 is included in Q2, and if qn2 is not included in Q2, the processing progresses to the 31st row.
In the 31st row, qn2 is added to the stack S. And, qn2 is also added to Q2.
In the 32nd row, if there is at least one having the size of W equal to 1 from among the two-tuples (qn,W) as the elements of θ, the processing from the 33rd row to the 37th row is performed.
In the 33rd row, an output symbol sequence wεW is calculated by (+) for all having the size of W equal to 1 from among the two-tuples (qn,W) as the elements of θ, and the obtained result is substituted in w2. For example, when θ={(r1,{ab}),(r2,{ac}),(r3,{b,cd})} as r1,r2,r3εQ1, the two-tuples having the size of W equal to 1 are (r1,{ab}) and (r2,{ac}), and if the output symbol sequences are calculated by (+), ab(+)ac=a, such that w2=a.
In the 34th row, similarly to the 33rd row, for the two-tuples (qn,W) having the size of W equal to 1 of θ, two-tuples which are constituted by qn and output symbol sequences with portions corresponding to w2 removed from the front of the elements w of W are created, and the set of two-tuples is substituted in qn2. Description will be provided using the example of the 33rd row. Similarly to the 33rd row, since the two-tuples having the size of W equal to 1 are (r1,{ab}) and (r2,{ac}), a−1(×)ab=b for r1, and a−1(×)ac=c for r2. As a result, in this example, qn2={(r1,b),(r2,c)}.
In the 35th row, a transition in which a transition source state is q2, an input symbol is α, an output symbol is w2, and a transition destination state is qn2 is added to E2.
In the 36th row, it is determined whether or not qn2 is included in Q2, and if qn2 is not included in Q2, the processing of the 37th row is performed.
In the 37th row, qn2 is added to the stack S. And, qn2 is also added to Q2.
If determinizing is completed, it is not necessary to store a set of two-tuples (state and symbol sequence) associated with respective states. Thus, processing may be performed for reassigning different numbers to the states. A number may be assigned as needed during determinizing, and a set of two-tuples (state and symbol sequence) may be associated with the number.
It is desirable that an algorithm aux which uses the state qεQ2 after determinizing and the output symbol sequence vεΔ* as arguments and returns an auxiliary input symbol as a return value can assign different auxiliary input symbols to two-tuples constituted by q and v.
It is assumed that an auxiliary input symbol is y, and a set having three-tuples (q,v,y) as elements is Y and initialized as an empty set before determinizing. Then, the algorithm aux can be realized by a procedure of
If a number n is delivered as an argument, make_aux performs processing for returning an auxiliary input symbol #n.
An operation example of the pseudo code of
If aux(1,B) is called again, since Y={(1,B,#1)}, the condition of the 1st row is satisfied. Thus, in the 2nd row, #1 which is the 3rd element y1 of the elements of Y satisfying the condition is returned as a result.
Next, if aux(2,B) is called, the condition of the 1st row is not satisfied. This is because elements q1=2 and v1=B are not included in Y. Thus, in the 3rd row, a new auxiliary input symbol is created. Now, since |Y|=1, make_aux(2) is executed, and #2 is obtained and substituted in y. With the use of this, if (2,B,#2) is added to Y, Y={(1,B,#1),(2,B,#2)}. Then, #2 is returned as a result.
In the above-described manner, it is possible to assign different auxiliary input symbols to the combinations of the states q and the output symbol sequences v. It is also possible to create only a necessary number of auxiliary input symbols.
Each time an outgoing transition from the state after determinizing is created for each state, Y may be initialized to an empty set. Specifically, each time the processing from the 6th row to the 37th row of
How the determinizing method of this embodiment operates will be described assuming that an FST of
In the 1st row of
Next, in the 2nd row, an initial output is calculated. In this example, the FST has no initial output. In other words, λ1(0)=1#=ε, that is, an empty symbol sequence is output. Thus, λ2=ε.
In the 3rd row, the initial state of the FST after determinizing is created. i2={(0,ε)} (
In the 4th row, the state i2 created in the 3rd row is added to the stack S and Q2, and as a result, S={{(0,ε)}} and Q2={(0,ε)}}.
Since |S|=1, the condition of the 5th row is satisfied, and the processing progresses to the 6th row.
In the 6th row, if a value is extracted from the stack S and substituted in q2, S=φ and q2={(0,ε)}.
In the 7th row, w should be determined only when w=ε. Since w is not included in Σ1, the condition of the 7th row is not satisfied. Thus, the processing progresses to the 14th row.
In the 14th row, it is determined whether or not a state from among the two-tuples (state and symbol sequence) included in q2 is included in F1. Now, the state included in q2 is the state 0, and the state 0 is not included in F1. Thus, the processing progresses to the 24th row.
Although Σ1={a,b,c}, since an input symbol of an outgoing transition from the state 0 is only a, it is desirable to process only α=a. Thus, in the 24th row, α=a, and the processing of the 25th or subsequent row is performed.
In the 25th row, θ={(1,{ε(×)A}),(2,{ε(×)B}),(3,{ε(×)C})}={(1,{A}),(2,{B}),(3,{C})}.
Since there is no element of θ which satisfies the condition |W|>1 of the 26th row, the processing progresses to the 32nd row.
Since there is an element of θ which satisfies |W|=1, the condition of the 32nd row is satisfied, and the processing progresses to the 33rd row.
In the processing of the 33rd row, w2=A(+)B(+)C=ε=1#.
In the processing of the 34th row, qn2={(1,A),(2,B),(3,C)} is obtained. Since x−1(×)x=ε, ε−1=ε. If X=ε, E−1(×)ε=ε. Thus, if ε is connected to both sides from the right side by the (×) operation, ε−1(×)ε(×)ε=ε(×)ε, such that ε−1(×)ε=ε(×)ε. If ε on the right side is extracted from both sides, modification to ε−1=ε can be made. Thus, for example, (1,A) which is the first element of q,n2 is obtained by calculating w2(×)A=ε−1(×)A=ε(×)A=A.
In the 35th row, a transition in which a transition source state is {(0,ε)}, an input symbol is a, an output symbol is ε, and a transition destination state is {(1,A),(2,B),(3,C)} is created and added to E2. As a result, an FST is constituted by the initial state and the state S101 of
Now, since qn2 is not included in Q2, the 36th row is satisfied, and the processing of the 37th row is performed.
In the 37th row, since qn2 is added to S and Q2, S={{(1,A),(2,B),(3,C)}} and q2={{(0,ε)},{(1,A),(2,B),(3,C)}}.
The processing returns to the 5th row, and since the stack S is not an empty set, the processing progresses to the 6th row.
In the 6th row, q2={(1,A),(2,B),(3,C)}, and S=φ.
Since all of A, B, and C are not included in Σ1, the condition of the 7th row is not satisfied, and the processing progresses to the 14th row.
Since the states 1, 2, and 3 are not included in F1, that is, not a final state, the condition of the 14th row is not satisfied. Thus, the processing progresses to the 24th row.
An input symbol of an outgoing transition from the states 1, 2, and 3 is b only. Thus, it is desirable to perform the processing from the 25th row to the 37th row only when a=b.
In the 25th row, θ={(4,{A(×)ε,B(×)ε}),(5,{C(×)ε})}={(4,{A,B}),(5,{C})}.
In the 26th row, from among the elements of θ, (4,{A,B}) satisfies the condition |W|>1, and the processing from the 27th row to the 31st row is performed on (4,{A,B}).
In the 27th row, qn2={(qn,α)}={(4,b)}, and the processing progresses to the 28th row.
Now, since W={A,B}, first, the processing of the 29th row is performed on w=A. Here, let aux(qn2,w)=aux({(4,b)},A)=#1. Then, in the 29th row, a transition in which a transition source state is {(1,A),(2,B),(3,C)}, an input symbol is #1, an output symbol sequence is A, and a transition destination state is {(4,b)} is added to 82, and #1 is also added to Σ2. Similarly, the processing is performed on w=B. At this time, if aux({(4,b)},B)=#2, a transition in which a transition source state is {(1,A),(2,B),(3,C)}, an input symbol is #2, an output symbol sequence is B, and a transition destination state is {(4,b)} is added to E2, and #2 is also added to Σ2. As a result, an FST is constituted by the initial state, the state S101, and the state S102 of
In the 30th row, it is determined that {(4,b)} is not included in Q2, and in the 31st row, {(4,b)} is added to S and Q2. As a result, S={{(4,b)}} and Q2={{(0,ε)},{(1,A),(2,B),(3,C)},{(4,b)}}.
Although the processing progresses to the 32nd row, since an element which satisfies |W|=1 is included in θ, the condition of the 32nd row is satisfied, and the processing of the 33rd or subsequent row is performed. Here, the element which satisfies the condition is (5,{C}).
In the 33rd row, w2=C.
In the 34th row, qn2={(5,C−(×)C)}={(5,ε)}.
In the 35th row, a transition in which a transition source state is {(1,A),(2,B),(3,C)}, an input symbol is b, an output symbol sequence is C, and a transition destination state is {(5,ε)} is added. As a result, an FST is constituted by the initial state, the state S101, the state S102, and the state S103 of
Since qn2={(5,ε)}, the condition of the 36th row is satisfied, and the processing progresses to the 37th row.
In the 37th row, {(5,ε)} is added to S and Q2. As a result, S={{(4,b)},{(5,ε)}} and Q2={{(0,ε)},{(1,A),(2,B),(3,C)},{(4,b)},{(5,ε)}}.
Although the processing returns to the 5th row, since S is not an empty set, the processing progresses to the 6th row.
In this example, S is a stack, such that, in the 6th row, q2={(5,ε)}. And, S={{(4,b)}}.
Since a symbol sequence included in q2 is ε only, the condition of the 7th row is not satisfied. For this reason, the processing progresses to the 14th row.
Since the state 5 is not a final state, the condition of the 14th row is not satisfied, and the processing progresses to the 24th row.
Since α which should be processed in the 25th or subsequent row is c only, let α=c.
In the 25th row, θ={(6,{ε(×)ε})}={(6,{ε})}.
Since there is no element of θ which satisfies the 26th row, the processing progresses to the 32nd row.
The number of elements of θ is 1, and with regard to the corresponding element, W={ε}. For this reason, |W|=1, and the condition of the 32nd row is satisfied. Thus, the processing progresses to the 33rd or subsequent row.
In the 33rd row, w2=ε.
In the 34th row, qn2={(6,ε)}.
In the 35th row, a transition in which a transition source state is {(5,ε)}, an input symbol is c, an output symbol is ε, and a transition destination state is {(6,ε)} is added to E2. As a result, an FST illustrated in
Since qn2={(6,ε)}, the condition of the 36th row is satisfied, and the processing progresses to the 37th row. In the 37th row, {(6,ε)} is added to S and Q2. As a result, S={{(4,b)},{(6,ε)}} and Q2={{(0,ε)},{(1,A),(2,B),(3,C)},{(4,b)},{(5,ε)},{(6,ε)}}.
Although the processing returns to the 5th row, since S is not an empty set, the processing progresses to the 6th row.
In the 6th row, q2={(6,ε)}. And, S={{(4,b)}}.
Since a symbol sequence included in q2 is ε only, the condition of the 7th row is not satisfied. For this reason, the processing progresses to the 14th row.
Since the state 6 is a final state, the condition of the 14th row is satisfied, and the processing progresses to the 15th row.
Since ρ1(6)=ε, in the 15th row, W={ε(×)ε}={ε}.
In the 16th row, w2=ε.
The number of elements of W is 1, and the element is ε. For this reason, the condition of the 17th row is satisfied, and the processing progresses to the 18th row.
In the 18th row, ρ2({(6,ε)})=ε and F2={{(6,ε)}}. As a result, it becomes as illustrated in
Since there is no element of W which satisfies the 19th row, the processing from the 20th row to the 23rd row is not performed, and the processing progresses to the 24th row.
Since α which should be processed in the 25th or subsequent row is d only, let α=d.
In the 25th row, θ={(0,{ε(×)ε})}={(0,{ε})}.
Since there is no element of θ which satisfies the 26th row, the processing progresses to the 32nd row.
The number of elements of θ is 1, and with regard to the corresponding element, W={ε}. For this reason, |W|=1, and the condition of the 32nd row is satisfied. Thus, the processing progresses to the 33rd or subsequent row.
In the 33rd row, w2=ε.
In the 34th row, qn2={(0,ε)}.
In the 35th row, a transition in which a transition source state is {(6,ε)}, an input symbol is d, an output symbol is ε, and a transition destination state is {(0,ε)} is added to E2. As a result, an FST is constituted by the state S105 of
Since qn2={(0,ε)}, the condition of the 36th row is not satisfied, such that the processing of the 37th row is not performed.
Although the processing returns to the 5th row, since S is not empty, the processing progresses to the 6th row.
In the 6th row, q2={(4,b)}. And, S=φ.
Since a symbol sequence included in q2 is b, the condition of the 7th row is satisfied, and the processing progresses to the 8th row.
In the 8th row, q=4 and w=b.
In the 9th row, qn2={(4,1#)}={(4,ε)}.
In the 10th row, a transition in which a transition source state is {(4,b)}, an input symbol is b, an output symbol is ε, and a transition destination state is {(4,ε)} is added to E2. As a result, an FST is constituted by the portions excluding the outgoing transition from the state S105 of
Since qn2={(4,ε)}, the condition of the 11th row is satisfied, and the processing progresses to the 12th row.
In the 12th row, {(4,ε)} is added to S and Q2. As a result, S={{(4,ε)}} and Q2={{(0,ε)},{(1,A),(2,B),(3,C)},{(4,b)},{(5,ε)}},{(6,ε)},{(4,ε)}}.
Although the processing returns to the 5th row, since S is not empty, the processing progresses to the 6th row.
In the 6th row, q2={(4,ε)}. And, S=φ.
Since a symbol sequence included in q2 is ε only, the condition of the 7th row is not satisfied. For this reason, the processing progresses to the 14th row.
Since the state 4 is not a final state, the condition of the 14th row is not satisfied, and the processing progresses to the 24th row.
Since α which should be processed in the 25th or subsequent row is c only, let α=c.
In the 25th row, θ={(6,{ε(×)ε})}={(6,{ε})}.
Since there is no element of θ which satisfies the 26th row, the processing progresses to the 32nd row.
The number of elements of θ is 1, and with regard to the corresponding element, W={ε}. For this reason, |W|=1, and the condition of the 32nd row is satisfied. Thus, the processing progresses to the 33rd or subsequent row.
In the 33rd row, w2=ε.
In the 34th row, qn2={(6,ε)}.
In the 35th row, a transition in which a transition source state is {(4,ε)}, an input symbol is c, an output symbol is ε, and a transition destination state is {(6,ε)} is added to E2. As a result, it becomes as illustrated in
Since qn2={(6,ε)}, the condition of the 36th row is not satisfied, and the processing of the 37th row is not performed.
Although the processing returns to the 5th row, now, since S is an empty set, the condition of the 5th row is not satisfied. Thus, the determinizing processing is completed.
A set of two-tuples associated with the states may be substituted with numbers and may be as illustrated in
How the determinizing method of this embodiment operates when there are a plurality of initial states or final states will be described assuming that the FST of
Similarly to
In the 1st row of
Next, in the 2nd row, an initial output is calculated. λ2=λ1(0)(+)λ1(1)=A(+)AB=A.
In the 3rd row, an initial state of the FST after determinizing is created. i2={(0,A−1(×)A),(1,A−1(×)AB)}={(0,ε),(1,B)} (
In the 4th row, the state i2 created in the 3rd row is added to the stack S and Q2, and as a result, S={{(0,ε),(1,B)}} and Q2={{(0,ε),(1,B)}}.
Since |S|=1, the condition of the 5th row is satisfied, and the processing progresses to the 6th row.
In the 6th row, if a value is extracted from the stack S and substituted in q2, S=φ and q2={(0,ε),(1,B)}.
In the 7th row, symbol sequences corresponding to w which should be determined are ε and B. Since all of them are not included in Σ1, the condition of the 7th row is not satisfied. Thus, the processing progresses to the 14th row.
In the 14th row, it is determined whether or not a state from among the two-tuples (state and symbol sequence) included in q2 is included in the F1. Now, although the states included in the q2 are the state 0 and the state 1, these states are not included in F1. Thus, the processing progresses to the 24th row.
Although Σ1={a,b}, since an input symbol of an outgoing transition from the state 0 and the state 1 is a only, it is desirable to perform processing only α=a. Thus, in the 24th row, α=a, and the processing of the 25th or subsequent row is performed.
In the 25th row, θ={(2,{ε(×)ε,B(×)C})}={(2,{ε,BC})}.
In the 26th row, since (2,{ε,BC}) from among the elements of θ satisfies the condition |W|>1, the processing from the 27th row to the 31st row is performed on (2,1ε,BC}).
In the 27th row, qn2={(qn,α)}={(2,α)}, and the processing progresses to the 28th row.
Now, since W={ε,BC}, first, with regard to w=ε, the processing of the 29th row is performed. Here, it is assumed that aux(qn2,w)=aux({(2,a)},ε)=#1. Then, in the 29th row, a transition in which a transition source state is {(0,ε),(1,B)}, an input symbol is #1, an output symbol sequence is ε, and a transition destination state is {(2,a)} is added to E2, and #1 is also added to Σ2. Similarly, with regard to w=BC, the processing is performed. At this time, if aux({(2,a)},BC)=#2, a transition in which a transition source state is {(0,ε),(1,B)}, an input symbol is #2, an output symbol sequence is BC, and a transition destination state is {(2,a)} is added to E2, and #2 is also added to Σ2. As a result, an FST is constituted by the initial state and the state S201 of
In the 30th row, it is determined that {(2,a)} is not included in Q2, and in the 31st row, {(2,a)} is added to S and Q2. As a result, S={{(2,a)}} and Q2={{(0,ε),(1,B)},{(2,a)}}.
Although the processing progresses to the 32nd row, since no element which satisfies |W|=1 is not included in θ, the condition of the 32nd row is not satisfied. Thus, the processing of the 33rd or subsequent row is not performed, and the processing returns to the 5th row.
Since S is not an empty set, the processing progresses to the 6th row.
In the 6th row, q2={(2,a)}. And, S=φ.
Since a symbol sequence included in q2 is a, the condition of the 7th row is satisfied, and the processing progresses to the 8th row.
In the 8th row, q=2 and w=a.
In the 9th row, qn2={(2,1#)}={(2,ε)}.
In the 10th row, a transition in which a transition source state is {(2,a)}, an input symbol is a, an output symbol sequence is ε, and a transition destination state is {(2,ε)} is added to E2. As a result, an FST is constituted by the initial state, the state S201, and the state S202 of
Since qn2={(2,ε)}, the condition of the 11th row is satisfied, and the processing progresses to the 12th row.
In the 12th row, {(2,ε)} is added to S and Q2. As a result, S={{(2,ε)}} and Q2={{(0,ε),(1,B)},{(2,a)},{(2,ε)}}.
Although the processing returns to the 5th row, since S is not empty, the processing progresses to the 6th row.
In the 6th row, q2={(2,ε)}. And, S=φ.
Since a symbol sequence included in q2 is ε only, the condition of the 7th row is not satisfied. For this reason, the processing progresses to the 14th row.
Since the state 2 is not a final state, the condition of the 14th row is not satisfied, and the processing progresses to the 24th row.
Since α which should be processed in the 25th or subsequent row is b only, let α=b.
In the 25th row, θ={(3,{ε(×)ε}),(4,{ε(×)D}),(5,{ε(×)DB})}={(3,{ε}),(4,{D}),(5,{DB})}.
Since there is no element of θ which satisfies the 26th row, the processing progresses to the 32nd row.
The number of elements of θ is 3, and with regard to these elements, W is {ε}, {D}, and {DB}, and for all of these elements, |W|=1. Thus, the condition of the 32nd row is satisfied, and the processing progresses to the 33rd row.
In the 33rd row, w2=ε.
In the 34th row, qn2={(3,ε),(4,D),(5,DB)}.
In the 35th row, a transition in which a transition source state is {(2,ε)}, an input symbol is b, an output symbol is ε, and a transition destination state is {(3,ε),(4,D),(5,DB)} is added to E2. As a result, an FST of
Since qn2={(3,ε),(4,D),(5,DB)}, the condition of the 36th row is satisfied, and the processing progresses to the 37th row. In the 37th row, {(3,ε),(4,D),(5,DB)} is added to S and Q2. As a result, S={{(3,ε),(4,D),(5,DB)}} and Q2={{(0,ε),(1,B)},{(2,a)},(2,ε),{(3,ε),(4,D),(5,DB)}}.
Although the processing returns to the 5th row, since S is not an empty set, the processing progresses to the 6th row.
In the 6th row, q2={(3,ε),(4,D),(5,DB)). And, S=φ.
Since symbol sequences included in q2 are ε, D, and DB, the condition of the 7th row is not satisfied. For this reason, the processing progresses to the 14th row.
Since the states 3, 4, and 5 are final states, the condition of the 14th row is satisfied, and the processing progresses to the 15th row.
Since ρ1(3)=D, ρ1(4)=A, and ρ1(5)=ε, in the 15th row, W={ε(×)D,D(×)A,DB(×)ε}={D,DA,DB}.
In the 16th row, w2=D(+)DA(+)DB=D.
Since D is not included in the elements of W, the condition of the 17th row is satisfied, and the processing progresses to the 18th row.
In the 18th row, ρ2({(3,ε),(4,D),(5,DB)})=D and F2={{(3,ε),(4,D),(5,DB)}}. As a result, it becomes as illustrated in
Since there is an element of W which satisfies the 19th row, first, with regard to w=DA, the processing from the 20th row to the 23rd row is performed.
In the 20th row, let qn2=φ.
If aux(qn2,w)=aux(φ,DA)=#3, in the 21st row, a transition in which a transition source state is {(3,ε),(4,D),(5,DB)}, an input symbol is #3, an output symbol is DA, and a transition destination state is φ is added to E2.
Since φ is not included in Q2, the 22nd row is satisfied, and the processing progresses to the 23rd row.
In the 23rd row, ρ2(qn2)=ρ2(φ)=1#=ε, Q2={{(0,ε),(1,B)},{(2,a)},{(2,ε)},{(3,ε),(4,D),(5,DB)},φ}, and F2={{(3,ε),(4,D),(5,DB)},φ}. As a result, the state S204 and the transition t204a of
Next, with regard to w=DB, the processing from the 20th row to the 23rd row is performed.
In the 20th row, let qn2=φ.
If aux(qn2,w)=aux(φ,DB)=#4, in the 21st row, a transition in which a transition source state is {(3,ε),(4,D),(5,DB)}, an input symbol is #4, an output symbol is DB, and a transition destination state is φ is added to E2. Referring to
Now, since φ is included in Q2, the 22nd row is not satisfied.
Since the processing ends on all the elements of W, not w2, the processing progresses to the 24th row.
Since there is no outgoing transition from the states 3, 4, and 5, even when the processing of the 24th or subsequent row is performed, nothing occurs.
Although the processing returns to the 5th row, now, since S is an empty set, the condition of the 5th row is not satisfied. Thus, the determinizing processing is completed.
As described above, the number (n of #n) of an auxiliary input symbol can be assigned to each state starting from 1. In this case, an FST after determinizing is as illustrated in
(Processing of FST with No Initial Output)
When an FST with no initial output is used, it is considered that an initial output of an NFST to be determinized is ε. Thus, in the 2nd row of
(Processing of FST with No Final Output)
When determinizing regarding an FST with no final output, that is, an FST with p undefined is performed, the 15th row to the 23rd row in the method of
Since there is no final output of an FST before determinizing, W is constituted by symbol sequences, which form a tuple along with the states included in F1, from among the two-tuples (state and symbol sequence) included in the q2. However, a symbol sequence 1# is not included (the 1st row of
If W is an empty set (the 2nd row of
Although the processing from the 5th row to the 8th row of
In summary, when a final output is not necessary, q2 is simply set as a final state. Otherwise, a final state is newly created, a transition in which the corresponding state is a transition destination state, and q2 is a transition source state is created, and w is assigned to the output symbol sequence of the corresponding transition.
(Processing of FST which may have N Final Outputs)
In the case of an FST in which N (N≧0) final outputs can be assigned to each final state to the maximum, final outputs ρ(q) which is assigned to a state q becomes a set of output symbol sequences. However, it is assumed that |ρ(q)|≦N is satisfied. When ρ(q)=φ, there is no final output of the state q. When determinizing regarding this FST is performed, the 15th row to the 23rd row in the method of
In the 1st row of
In the 2nd row, a list of final outputs is created. For all the two-tuples, in which the state q is the final state of the FST before determinizing, from among the two-tuples (state q and symbol sequence w) included in q2, x=w(×)y is calculated from the final output y assigned to the symbol sequence w and the state q. Of these, let a set of symbol sequences which are constituted by x not equal to 1# be W.
In the 3rd row, it is determined whether or not the size of W is greater than N. When the size of W is greater than N, the processing progresses to the 4th row. Otherwise, the processing progresses to the 11th row. This is because, when the size of W is greater than N, all the final outputs included in W cannot be assigned to the final outputs of q2.
In the 4th row, similarly to the 20th row of
In the 5th row, it is determined whether or not the created qn2 is included in Q2. If qn2 is not included in Q2, the processing of the 6th row is performed.
In the 6th row, the final output ρ2(qn2) of qn2 is set as an empty set, and qn2 is added to Q2 and F2.
In the 7th row, it is determined whether or not the size of W is greater than N. When the size of W is greater than N, the processing from the 8th row to the 10th row is repeatedly performed.
In the 8th row, one output symbol is extracted from W and is set as w. With regard to a way to extract, for example, an output symbol may be extracted from a long output symbol sequence from among the output symbol sequences included in W. An output symbol may be extracted from a short output symbol sequence.
In the 9th row, a transition in which a transition source state is q2, an input symbol is aux(qn2,w), an output symbol sequence is w, and a transition destination state is qn2 is added to E2. The input symbol of the added transition is added to Σ2.
In the 10th row, w is removed from W.
In the 11th row, the output symbols which remain in W are assigned to the final output ρ2(q2) of q2.
(Hardware Configuration)
The CPU 1 performs various kinds of processing in cooperation with various control programs stored in advance in the ROM 4 or the storage unit 6 with a predetermined area of the RAM 5 as a work area, and performs overall control of the operations of the respective units which constitute the determinizing device 2700. The CPU 1 realizes the functions of respective functional units described below in cooperation with a predetermined program stored in the ROM 4 or the storage unit 6.
The operating unit 2 is an input device, such as a mouse or a keyboard, receives information input from a user as an instruction signal, and outputs the instruction signal to the CPU 1. The display unit 3 is constituted by a display device, such as an LCD (Liquid Crystal Display), and displays various kinds of information on the basis of a display signal from the CPU 1.
The ROM 4 unrewritably stores a program relating to the control of the determinizing device 2700, various kinds of setting information, or the like. The RAM 5 is a storage medium, such as an SDRAM, and functions as a work area of the CPU 1. Specifically, the RAM 5 functions as a buffer or the like which temporarily stores various variables or parameter values generated at the time of the determinizing processing.
The storage unit 6 has a semiconductor storage medium, such as a flash memory, or a magnetically or optically recordable storage medium, and rewritably stores a program relating to the control of the determinizing device 2700, various kinds of setting information, or the like. The storage unit 6 stores various kinds of information relating to an FST in advance or records an FST as the processing result of the determinizing processing.
(Processing Unit Configuration)
The determinizing device 100 has a set generation unit 10, a single-valued state processing unit 20, a final state processing unit 30, a single-value processing unit 40, and a transition selection unit 50.
The set generation unit 10 generates a set including states, input symbols and output symbols assigned to transitions corresponding to the states, and states of a transition destination from the FST input from the FST reading unit 101. With regard to a set corresponding to an FST after determinizing, a set including an empty set is generated. Other sets which are used as a work area, or the like are generated. The generated sets are processed by the single-valued state processing unit 20, the final state processing unit 30, the single-value processing unit 40, and the transition selection unit 50, and FST determinizing is performed. The set generation unit 10 also performs the processing from the 1st row to the 4th row of
The single-valued state processing unit 20 has a state acquisition unit 21 and a transition generation control unit 22. The state acquisition unit 21 acquires a state, in which processing is not yet performed for generating an outgoing transition from the corresponding state, from among the states after determinizing from the sets generated by the set generation unit 10. This state is called a state during the determinizing processing, and corresponds to q2 of
The single-valued state processing unit 20 performs the processing from the 6th row to the 12th row of
The final state processing unit 30 generates a final state of an FST. The final state processing unit 30 has a state merging unit 31, a symbol determination unit 32, and a transition generation control unit 33. The state merging unit 31 acquires one or a plurality of final outputs corresponding to the state during the determinizing processing.
When a plurality of final outputs are acquired by the state merging unit 31, if necessary, the symbol determination unit 32 determines an identification symbol corresponding to a transition generated by the transition generation control unit 33. The determined identification symbol is different from any input symbol included in an FST read by the FST reading unit 101. The transition generation control unit 33 performs overall control of the processing for generating a transition or a final state.
The final state processing unit 30 performs the processing from the 13th row to the 23rd row of
The single-value processing unit 40 merges a plurality of transitions assigned to the same input symbol to a single value and performs determinizing. The single-value processing unit 40 has a state merging unit 41, a symbol determination unit 42, a sub-state generation unit 43, and a transition generation control unit 44.
The state merging unit 41 acquires a plurality of states at a transition destination by the same input symbol from among the sets generated by the set generation unit 10, and generates states having the states as sub-states. Even when there is one state of a transition destination by the same input symbol, similarly to a case where there are a plurality of states of a transition destination, if the corresponding state has sub-states, processing relating to the sub-states is facilitated.
The symbol determination unit 42 generates one or a plurality of identification symbols, which are handed as input symbols, for one state generated by the state merging unit 41. The generated identification symbols correspond to the output symbols assigned to one or a plurality of outgoing transitions from one state. Here, similarly to the symbol determination unit 32, the determined identification symbols are different from any input symbols included in the FST read by the FST reading unit 101. The sub-state generation unit 43 generates sub-states which are included in the states generated by the state merging unit 41. The identification symbols generated by the symbol determination unit 42 correspond to the states generated by the state merging unit 41.
The transition generation control unit 44 performs overall control of the processing performed by the single-value processing unit 40.
The state merging unit 41 performs the processing of the 25th row of
When an input FST is a weighted FST, the transition selection unit 50 selects a transition as an optimum path on the basis of a weight.
(Specific Example of FST in Speech Recognition)
An FST is used in the fields of speech recognition or natural language processing. As an example, a method is used which realizes a function of converting a phoneme string to a word as an NFST. In general, in this NFST, determinizing processing is performed. This is because, if an input symbol is applied, the state of a transition destination from each state is uniquely determined and easily handled. At this time, if there are homophonous, different words are assigned to the same phonetic string. That is, a non-single-valued NFST is created. Specifically, it becomes as illustrated in
(Specific Example of FST in Translation)
Since an FST which converts an utterance to words can be realized, similarly, it is assumed that letters of any language are assigned to input symbols, and letter strings of another language are assigned to output symbols. For example, since a Japanese letter string “KAIGI” can be translated to meeting, conference, council, or the like in English, with the use of an FST, this is expressed as illustrated in
(Specific Example of FST in Retrieval)
If a target sentence to be retrieved is expressed by an FST, it becomes possible to facilitate retrieval in a document.
For example, a sentence “Good morning” is given. Let the head “G” of the sentence be the first letter, and next “o” be the second letter. An FST illustrated in
If an FST is determinized, a letter string to be retrieved, that is, the path in the FST with respect to the input symbol sequence is uniquely determined, making it possible to reduce the amount of calculation at the time of retrieval compared to a case where an FST is not determinized. Meanwhile, since the FST is non-single-valued, it is not possible to perform determinizing by the determinizing method of the related art. Thus, with the use of determinizing of this embodiment, determinizing is performed while a non-single-valued FST is modified to a single-valued FST. At the time of retrieval using a determinized FST, all the transitions having an auxiliary input symbol may be regarded as e transitions. A c transition is a transition when the transition to the next state is possible without consuming input symbols.
An FST which is obtained by determinizing the FST of
(Effects)
As described above, according to this embodiment, it is possible to perform determinizing while modifying a non-single-valued FST to a non-single-valued FST without processing for modification to a single value in advance.
(Preparation)
In this embodiment, in a determinizing method of a weighted finite state transducer (WFST) in which a weight is applied, in addition to the input symbols and the output symbol sequences assigned to the transitions of the FST, a method which performs determinizing while converting a non-single-valued WFST to a single value will be described. The term “weight” used herein is any probability value, a score, a penalty, or the like, and is calculated by any rule (addition, multiplication, minimum value, maximum value, or the like) along a path in which an input symbol is received.
Let a set of values of the weight be Rw. Rw is, for example, an integer or a real number. Let a set of output symbols which is represented by Δ in the case of an FST be Ro. Then, a WFST can be expressed by a nine-tuple (Q, Σ, Ro, Rw, E, I, F, λ, ρ). Q, Σ, I, F, λ, and ρ are the same as an FST. A set E of transitions is EQ×Σ×Δ×Q. Here, Δ is an output, and Δ=Ro*×Rw. Let out(e)εΔ such that an output symbol sequence and a weight assigned to a transition eεE are the same as an FST. That is, out(e) represents a two-tuple (output symbol sequence and weight) assigned to a transition e. When an initial state is iεI, an initial output function λ is λ(i)εΔ. Similarly, when a final state is qεF, a final output function is ρ(q)εΔ.
(Method)
If the calculation method of the output Δ is defined as follows, the determinizing method of first embodiment can be used in determinizing a non-single-valued WFST as it is.
The operations (+)o and (×)o of an output symbol sequence Ro and a special value 1#o are defined to be the same as in first embodiment. That is, (+)o is defined as a longest common prefix operation, (×)o is defined as a conjunction operation, and 1#o is defined as an empty symbol sequence ε.
The operations (+)w and (×)w of a weight Rw and a special value 1#w are defined, for example, as follows. For the values x,yεRw, x(+)wy=min(x,y) and x(×)wy=x+y are defined, and 1#w=0 is defined. This is a calculation method which is called tropical semiring in C. Allauzen, M. Mohri, Generalized Optimization Algorithm for Speech Recognition Transducers, 2003, In Proceedings of the International Conference on Acoustics, Speech, and Signal Processing (ICASSP'03). Besides, x(+)wy=x+y and x(×)wy=x×y may be defined, and 1#w=1 may be defined. A calculation method may be used which is called log semiring in C. Allauzen, M. Mohri, “Generalized Optimization Algorithm for Speech Recognition Transducers,” 2003, In Proceedings of the International Conference on Acoustics, Speech, and Signal Processing (ICASSP'03).
If the calculation method of an output symbol sequence and a weight is defined as described above, the operations (+) and (×) of an output Δ having two-tuples of an output symbol sequence and a weight and the special value 1# can be respectively defined as (x1,y1)(+)(x2,y2)=(x1(+)ox2,y1(+)wy2), (x1,y1)(×)(x2,y2)=(x1(×)ox2,y1(×)wy2) and 1#=(1#o,1#w) with x1,x2εRo and y1,y2εRw. An operation ∪ of a sum of sets relating to the output Δ is defined by the following expression.
With a state qεQ2 after determinizing and an output vεΔ as arguments, an algorithm aux which returns an auxiliary input symbol as a return value is as illustrated in
Here, aux0 corresponds to the algorithm aux used in first embodiment, and is, for example, the method illustrated in
If (+), (×), 1#, ∪, and aux which are used in
How the determinizing method of a WFST in this embodiment operates will be described assuming that a WFST of
From
In the 1st row of
In the 3rd row, an initial state of a WFST after determinizing is created. i2={(0,(ε,0))γ (
In the 4th row, the state i2 created in the 3rd row is added to the stack S and Q2. As a result, S={{(0,(ε,0))}} and Q2={{(0,(ε,0))}}.
Since |S|=1, the condition of the 5th row is satisfied, and the processing progresses to the 6th row.
In the 6th row, if a value is extracted from the stack S and substituted in q2, S=φ and Q2={(0,(ε0))}.
In the 7th row, w should be determined only when w=(ε,0). Since w is not included in Σ1, the condition of the 7th row is not satisfied. Thus, the processing progresses to the 14th row.
In the 14th row, it is determined whether or not a state from among the two-tuples (state and output) included in q2 is included in F1. Now, a state included in q2 is the state 0 only, and the state 0 is not included in F1. Thus, the processing progresses to the 24th row.
Although Σ1={a,b}, an input symbol of an outgoing transition from the state 0 is a only, such that the processing may be performed only when a=a. Thus, in the 24th row, a=a, and the processing of the 25th or subsequent row is performed.
In the 25th row, θ={(1,{(ε,0)(×)(A,1)}),(2,{(ε,0)(×)(A,3)})}={(1,{(ε(×)oA,0(×)w1)}),(2,{(ε(×)oA,0(×)w3)})}={(1,{(A,0+1)}),(2,{(A,0+3)})}={(1,{(A,1)}),(2,{(A,3)})}.
Since there is no element of 8 which satisfies the condition |W|>1 of the 26th row, the processing progresses to the 32nd row.
Since there is an element of θ which satisfies the condition |W|=1, the condition of the 32nd row is satisfied, and the processing progresses to the 33rd row.
In the 33rd row, w2=(A,1)(+)(A,3)=(A(+)oA,1(+)w3)=(A,min(1,3))=(A,1).
In the processing of the 34th row, qn2={(1,(A,1)−1(×)(A,1)),(2,(A,1)−1(×)(A,3))}={(1,(A−1(×)oA,1−1(×)w1)),(2,(A−1(×)oA,1−1(×)w3))}={(1,(ε,−1+1)),(2,(ε,−1+3))}={(1,(ε,0)),(2,(ε,2))} is obtained.
In the 35th row, a transition in which a transition source state is {(0,(ε,0))}, an input symbol is a, an output symbol is A, a weight is 1, and a transition destination state is {(1,(ε,0)),(2,(ε,2))} is created and added to E2. As a result, an FST is constituted by the initial state and the state S301 of
Now, since qn2 is not included in Q2, the 36th row is satisfied, and the processing of the 37th row is performed.
In the 37th row, qn2 is added to S and Q2, such that S={{(1,(ε,0)),(2,(ε,2))}} and Q2={{(0,(ε,0))},{(1,(ε,0)),(2,(ε,2))}}.
The processing returns to the 5th row, and since the stack S is not an empty set, the processing progresses to the 6th row.
In the 6th row, q2={(1,(ε,0)),(2,(ε,2))}, and S=φ.
Since (ε,0) and (ε,2) are not included in Σ1, the condition of the 7th row is not satisfied, and the processing progresses to the 14th row.
Since the states 1 and 2 are not included in F1, that is, not a final state, the condition of the 14th row is not satisfied. Thus, the processing progresses to the 24th row.
Since an input symbol of an outgoing transition from the states 1 and 2 is b only, the processing from the 25th row to the 37th row may be performed only when α=b.
In the 25th row, θ={(3,{(ε,0)(×)(A,2)}∪{(ε,0)(×)(B,1)}∪{(ε,2)(×)(A,5)}∪{(ε,2)(×)(A,2)})}={(3,{(A,2)}∪{(B,1)}∪{(A,7)}∪{(A,4)})}={(3,{(A,2(+)w7)}∪{(B,1(+)w4)})}={(3,{(A,min(2,7))}∪{(B,min(1,4))})}={(3,{(A,2)}∪{(B,1)})}={(3,{(A,2),(B,1)})}.
In the 26th row, since the (3,{(A,2),(B,1)}) from the elements of θ satisfies the condition |W|>1, with regard to the corresponding element, the processing from the 27th row to the 31st row is performed.
In the 27th row, qn2={(qn,α)}={(3,b)}, and the processing progresses to the 28th row.
Now, since W={(A,2),(B,1)}, first, with regard to w=(A,2), the processing of the 29th row is performed. Here, it is assumed that aux(qn2,w)=aux({(3,b)} and (A,2))=#1. If so, in the 29th row, a transition in which a transition source state is {(1,(ε,0)),(2,(ε,2))}, an input symbol is #1, an output is (A,2), and a transition destination state is {(3,b) } is added to E2, and #1 is added to Σ2. Similarly, with regard to w=(B,1), the processing is performed. At this time, if aux({(3,b)},(B,1))=#2, a transition in which a transition source state is {(1,(ε,0)),(2,(ε,2))}, an input symbol is #2, an output is (B,1), and a transition destination state is {(3,b)} is added to E2, and #2 is added to Σ2. As a result, an FST is constituted by the initial state, the state S301, and the state S302 of
In the 30th row, it is determined that {(3,b)} is not included in Q2, and in the 31st row, {(3,b)} is added to S and Q2. As a result, S={{(3,b)}} and Q2={{(0,(ε,0))},{(1,(ε,0)),(2,(ε,2))},{(3,b)}}.
Although the processing progresses to the 32nd row, since no element which satisfies |W|=1 is included in θ, the condition of the 32nd row is not satisfied. Thus, the processing of the 33rd or subsequent row is not performed, and the processing returns to the 5th row.
Since S is not an empty set, the processing progresses to the 6th row.
In the 6th row, q2={(3,b)}. And, S=φ.
Since a symbol sequence included in q2 is b, the condition of the 7th row is satisfied, and the processing progresses to the 8th row.
In the 8th row, q=3 and w=b.
In the 9th row, qn2={(3,1#)}={(3,(ε,0))}.
In the 10th row, a transition in which a transition source state is {(3,b)}, an input symbol is b, an output symbol sequence is ε, a weight is 0, and a transition destination state is {(3,(ε,0))} is added to E2. As a result, an FST is constituted by all the states including the state S303 of
Since qn2={(3,ε)}, the condition of the 11th row is satisfied, and the processing progresses to the 12th row.
In the 12th row, {{3,(ε,0)}} is added to S and Q2. As a result, S={{(3,(ε,0))}} and Q2={{(0,(ε,0))},{(1,(ε,0)),(2,(ε,2))},{(3,b)},{(3,(ε,0))}}.
Although the processing returns to the 5th row, since S is not empty, the processing progresses to the 6th row.
In the 6th row, q2={(3,(ε,0))}. And, S=φ. Since a symbol sequence included in q2 is (ε,0) only, the condition of the 7th row is not satisfied. For this reason, the processing progresses to the 14th row.
Since the state 3 is a final state, the condition of the 14th row is satisfied, and the processing progresses to the 15th row.
Since ρ1(3)=(ε,0), in the 15th row, W={(ε,0)(×)(ε,0)}={(ε,0)}.
In the 16th row, w2={(ε,0)}. Since the number of elements of W is one, (ε,0), the condition of the 17th row is satisfied, and the processing progresses to the 18th row.
In the 18th row, ρ2({(3,(ε,0))})=(ε,0),F2={{(3,(ε,0))}}. As a result, it becomes as illustrated in
Since no element of W satisfies the 19th row, the processing of the 20th row to the 23rd row is not performed, and the processing progresses to the 24th row.
Since there is no outgoing transition from the state 3, even when the processing of the 24th or subsequent row is performed, nothing occurs.
Although the processing returns to the 5th row, since S is now an empty set, the condition of the 5th row is not satisfied. Thus, the determinizing processing is completed.
Similarly to the FST, a set of two-tuples associated with the states may be substituted with numbers and may be as illustrated in
(Specific Example in Speech Recognition)
As a specific example using a WFST, a WFST in which an insertion penalty is set as a weight for each word in a word dictionary of speech recognition is shown in
As described above, according to the method of second embodiment, determinizing can be performed while a non-single-valued WFST is modified to a single-valued WFST.
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 |
---|---|---|---|
2009-082866 | Mar 2009 | JP | national |
This application is a continuation of PCT international application Ser. No. PCT/JP2009/068016 filed on Oct. 19, 2009 which designates the United States, and which claims the benefit of priority from Japanese Patent Application No. 2009-082866, filed on Mar. 30, 2009; the entire contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2009/068016 | Oct 2009 | US |
Child | 13231065 | US |