Minimalist Machine Derivations

Files: grammar.pl / m12.pl / Back to homepage

Examples:

  • Tough-Constructions. A Case-theoretic approach. collapse
    Example Instruction stream (clickable) Notes
    (1) John is easy to please [john, d, please, 'v_unerg', ['PRO', d0], 'Tinf', c, easy, v_be, 'T', c] John (with unvalued uCase) is stacked after merge with please.
    vunerg doesn't assign Case to John.
    Tinf assigns null Case to PRO.
    At the Local Extent (LE) boundary, the embedded CP, John (with unvalued uCase) is re-stacked.
    T picks up TOS John.
    (2) The violin is easy to play the sonata on [violin, the, on_nc, [sonata, the], play, 'v*', ['PRO', d0], 'Tinf', c, easy, v_be, 'T', c] onnc (no case) selects for the violin but does not assign it Case.
    At the Local Extent (LE) boundary, the embedded CP, the violin (with unvalued uCase) is re-stacked.
    Matrix T picks up TOS the violin.
    (3) *What sonata is the violin easy to play on? [violin, the, on_nc, [sonata, what:d], play, 'v*', ['PRO', d0], 'Tinf', c, easy, v_be, 'T', c_Q] Does not converge.
    onnc (no case) selects for the violin but does not assign it Case.
    what sonata is stacked (uScope).
    At the LE boundary, the embedded CP, what sonata (unvalued uScope) and the violin (unvalued uCase) are re-stacked.
    Matrix T fails to agree with TOS what sonata: nom Case clashes with acc Case assigned by embedded v*.
    (4) The sonata is easy to play on this violin [violin, this, on, [sonata, the], play, 'v_unerg', ['PRO', d0], 'Tinf', c, easy, v_be, 'T', c] on assigns Case to this violin.
    vunerg doesn't assign Case to the sonata.
    At the LE boundary, the embedded CP, the sonata (unvalued uCase) is restacked.
    Matrix T picks up TOS the sonata.
    (5) What violin is the sonata easy to play on? [violin, what:d, on, [sonata, the], play, v_unerg, ['PRO', d0], 'Tinf', c, easy, v_be, 'T', c_Q] on assigns Case to this violin.
    vunerg doesn't assign Case to the sonata.
    At the LE boundary, the embedded CP, the sonata (unvalued uCase) and what violin (unvalued uScope) are restacked.
    Matrix T picks up TOS the sonata.
    cQ finds iWh what violin.
    (6) Linguists are tough to please [linguists, d, please, v_unerg, ['PRO', d0], 'Tinf', c, tough, v_be, 'T', c] (Same as (1).)
    Linguists (with unvalued uCase) is stacked after merge with please.
    vunerg doesn't assign Case to linguists.
    Tinf assigns null Case to PRO.
    At the LE boundary, the embedded CP, linguists (with unvalued uCase) is re-stacked.
    T picks up TOS linguists.
    (7) It is tough to please linguists [linguists, d, please,'v*', ['PRO', d0], 'Tinf', c, tough, v_be, it, 'T', c] v* assigns Case to linguists.
    (No restacking is done at the LE boundary, the embedded CP.)
    Expletive it merge to the edge of vbe.
    Agree(matrix T,it) obtains.
    (8) The book is easy to put on the table [table, the, on, [book, the], put, v_unerg, ['PRO', d0], 'Tinf', c, easy, 'v_be', 'T', c] (Same as (4).)
    on assigns Case to the table.
    vunerg doesn't assign Case to the book.
    At the LE boundary, the embedded CP, the book (unvalued uCase) is restacked.
    Matrix T picks up TOS the book.
    (9) What table is the book easy to put on? [table, what:d, on, [book, the], put, v_unerg, ['PRO', d0], 'Tinf', c, easy, 'v_be', 'T', c_Q] (Same as (5).)
    on assigns Case to what table.
    vunerg doesn't assign Case to the book.
    At the LE boundary, the embedded CP, the book (unvalued uCase) and what table (unvalued uScope) are restacked.
    Matrix T picks up TOS the book.
    cQ finds iWh what table.
  • Machine Parameters: expand

    Animation:
    (5) What violin is the sonata easy to play on?

    Derivation:
    (5) What violin is the sonata easy to play on?

    Stream:[[violin!D],[what!case!N!scope],[on],[[sonata!D],[the!case!N]],[play],[vunerg],[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):
    SO:[]

    Step 1.

    Head of stream [violin!D] is the initial SO
    Stream:[[what!case!N!scope],[on],[[sonata!D],[the!case!N]],[play],[vunerg],[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):
    SO:[violin!D]

    Step 2.

    Merge [what!case!N!scope] and [violin!D]
    Label from [what!case!N!scope] (head with an unvalued uF)
    Inherit interpretable feature(s) [f(phi,[3,sg,n])] from [violin!D]
    [what!case!N!scope] values D on [violin!D]
    [violin] values N on [what!case!N!scope]
    Stream:[[on],[[sonata!D],[the!case!N]],[play],[vunerg],[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):
    SO:[what!case!scope[what!scope][violin]]

    Step 3.

    Merge [on] and [what!case!scope[what!scope][violin]]
    Label from [on] (head merging with a non-head)
    Theta-mark [what!case!scope[what!scope][violin]]
    [on] values obq case on [what!case!scope[what!scope][violin]]
    Push [what!scope[what!scope][violin]] (unvalued uF) onto stack
    Stream:[[[sonata!D],[the!case!N]],[play],[vunerg],[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[what!scope[what!scope][violin]]
    SO:[on[on][what!scope[what!scope][violin]]]

    Step 4.

    Begin substream
    Stream:[[sonata!D],[the!case!N]]
    Stack (⥥):
    SO:[]

    Step 5.

    Head of stream [sonata!D] is the initial SO
    Stream:[[the!case!N]]
    Stack (⥥):
    SO:[sonata!D]

    Step 6.

    Merge [the!case!N] and [sonata!D]
    Label from [the!case!N] (head with an unvalued uF)
    Inherit interpretable feature(s) [f(phi,[3,sg,n])] from [sonata!D]
    [the!case!N] values D on [sonata!D]
    [sonata] values N on [the!case!N]
    Stream:[]
    Stack (⥥):
    SO:[the!case[the][sonata]]
    End substream, SO [the!case[the][sonata]] re-inserted into main stream

    Step 7.

    Stream:[[the!case[the][sonata]],[play],[vunerg],[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[what!scope[what!scope][violin]]
    SO:[on[on][what!scope[what!scope][violin]]]

    Step 8.

    Merge [on[on][what!scope[what..][violin..]]] and [the!case[the][sonata]]
    Label from [on[on][what!scope[what..][violin..]]] (edge feature)
    Theta-mark [the!case[the][sonata]]
    Push [the!case[the][sonata]] (unvalued uF) onto stack
    Stream:[[play],[vunerg],[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [what!scope[what!scope][violin]]
    SO:[on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]

    Step 9.

    Merge [play] and [on[the!case[the..][sonata..]][on[on..][what..]]]
    Label from [play] (head merging with a non-head)
    Stream:[[vunerg],[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [what!scope[what!scope][violin]]
    SO:[play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]

    Step 10.

    Merge [vunerg] and [play[play][on[the..][on..]]]
    Label from [vunerg] (head merging with a non-head)
    Stream:[[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [what!scope[what!scope][violin]]
    SO:[vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]

    Step 11.

    Begin substream
    Stream:[[PRO!D],[d0!case!N]]
    Stack (⥥):
    SO:[]

    Step 12.

    Head of stream [PRO!D] is the initial SO
    Stream:[[d0!case!N]]
    Stack (⥥):
    SO:[PRO!D]

    Step 13.

    Merge [d0!case!N] and [PRO!D]
    Label from [d0!case!N] (head with an unvalued uF)
    Inherit interpretable feature(s) [f(phi,[3,sg,n])] from [PRO!D]
    [d0!case!N] values D on [PRO!D]
    [PRO] values N on [d0!case!N]
    Stream:[]
    Stack (⥥):
    SO:[d0!case[d0][PRO]]
    End substream, SO [d0!case[d0][PRO]] re-inserted into main stream

    Step 14.

    Stream:[[d0!case[d0][PRO]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [what!scope[what!scope][violin]]
    SO:[vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]

    Step 15.

    Merge [vunerg[vunerg][play[play..][on..]]] and [d0!case[d0][PRO]]
    Label from [vunerg[vunerg][play[play..][on..]]] (edge feature)
    Theta-mark [d0!case[d0][PRO]]
    Push [d0!case[d0][PRO]] (unvalued uF) onto stack
    Stream:[[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[d0!case[d0][PRO]]
    [the!case[the][sonata]]
    [what!scope[what!scope][violin]]
    SO:[vunerg[d0!case[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]

    Step 16.

    Merge [Tinf!phi] and [vunerg[d0!case[d0..][PRO..]][vunerg[vunerg..][play..]]]
    Label from [Tinf!phi] (head merging with a non-head)
    [d0!case[d0][PRO]] values uPhi on [Tinf!phi]
    [Tinf] values nullCase case on [d0[d0][PRO]]
    Stream:[[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[d0[d0][PRO]]
    [the!case[the][sonata]]
    [what!scope[what!scope][violin]]
    SO:[Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]

    Step 17.

    Internal merge selected
    Merge [Tinf[Tinf][vunerg[d0..][vunerg..]]] and [d0[d0][PRO]]
    Label from [Tinf[Tinf][vunerg[d0..][vunerg..]]] (edge feature)
    Stream:[[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[d0[d0][PRO]]
    [the!case[the][sonata]]
    [what!scope[what!scope][violin]]
    SO:[Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]

    Step 18.

    Merge [c] and [Tinf[d0[d0..][PRO..]][Tinf[Tinf..][vunerg..]]]
    Label from [c] (head merging with a non-head)
    Stream:[[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[d0[d0][PRO]]
    [the!case[the][sonata]]
    [what!scope[what!scope][violin]]
    SO:[c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]

    Step 19.

    Local Extent boundary at [c[c][Tinf[d0..][Tinf..]]]
    Stack element [the!case[the][sonata]] with unvalued uF found
    Stack element [what!scope[what!scope][violin]] with unvalued uF found
    New boundary (b) marker stacked
    Restack [what!scope[what!scope][violin]] onto stack
    Restack [the!case[the][sonata]] onto stack
    Stream:[[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [what!scope[what!scope][violin]]
    b
    [d0[d0][PRO]]
    SO:[c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]

    Step 20.

    Merge [easy] and [c[c][Tinf[d0..][Tinf..]]]
    Label from [easy] (head merging with a non-head)
    Stream:[[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [what!scope[what!scope][violin]]
    b
    [d0[d0][PRO]]
    SO:[easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]]

    Step 21.

    Merge [vbe] and [easy[easy][c[c..][Tinf..]]]
    Label from [vbe] (head merging with a non-head)
    Stream:[[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [what!scope[what!scope][violin]]
    b
    [d0[d0][PRO]]
    SO:[vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]]]

    Step 22.

    Internal merge selected
    Merge [vbe[vbe][easy[easy..][c..]]] and [the!case[the][sonata]]
    Label from [vbe[vbe][easy[easy..][c..]]] (edge feature)
    Preference: [vbe] edge merge from the stack (not stream)
    Stream:[[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [what!scope[what!scope][violin]]
    b
    [d0[d0][PRO]]
    SO:[vbe[the!case[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]]]]

    Step 23.

    Merge [T!phi!v] and [vbe[the!case[the..][sonata..]][vbe[vbe..][easy..]]]
    Label from [T!phi!v] (head merging with a non-head)
    [the!case[the][sonata]] values uPhi on [T!phi!v]
    [T!v] values nom case on [the!case[the][sonata]]
    Relativized TOS search for iF(v) skipping [the[the][sonata]]
    Relativized TOS search for iF(v) skipping [what!scope[what!scope][violin]]
    [T!v] attracts [vbe[the[the..][sonata..]][vbe[vbe..][easy..]]]
    Merge [T[T][vbe[the..][vbe..]]] and [vbe]
    Label from [T[T][vbe[the..][vbe..]]] (edge feature)
    Stream:[[cQ!wh!T]]
    Stack (⥥):[the[the][sonata]]
    [what!scope[what!scope][violin]]
    b
    [d0[d0][PRO]]
    SO:[T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]]]]]]

    Step 24.

    Internal merge selected
    Merge [T[vbe][T[T..][vbe..]]] and [the[the][sonata]]
    Label from [T[vbe][T[T..][vbe..]]] (edge feature)
    Stream:[[cQ!wh!T]]
    Stack (⥥):[the[the][sonata]]
    [what!scope[what!scope][violin]]
    b
    [d0[d0][PRO]]
    SO:[T[the[the][sonata]][T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]]]]]]]

    Step 25.

    Merge [cQ!wh!T] and [T[the[the..][sonata..]][T[vbe..][T..]]]
    Label from [cQ!wh!T] (head merging with a non-head)
    Relativized TOS search for iF(wh) skipping [the[the][sonata]]
    [what!scope[what!scope][violin]] values wh on [cQ!wh!T]
    [the[the][sonata]] values T on [cQ!T]
    Internal merge selected
    Merge [cQ[cQ][T[the..][T..]]] and [the[the][sonata]]
    Label from [cQ[cQ][T[the..][T..]]] (edge feature)
    [cQ] values uscope on [what!scope[what!scope][violin]]
    Merge [cQ[the[the..][sonata..]][cQ[cQ..][T..]]] and [what[what][violin]]
    Label from [cQ[the[the..][sonata..]][cQ[cQ..][T..]]] (edge feature)
    Stream:[]
    Stack (⥥):[the[the][sonata]]
    [what[what][violin]]
    b
    [d0[d0][PRO]]
    SO:[cQ[what[what][violin]][cQ[the[the][sonata]][cQ[cQ][T[the[the][sonata]][T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what[what][violin]]]]]]]]]]]]]]]]]]]

    Step 26.

    Local Extent boundary at [cQ[what[what..][violin..]][cQ[the..][cQ..]]]
    New boundary (b) marker stacked
    Stream:[]
    Stack (⥥):b
    [the[the][sonata]]
    [what[what][violin]]
    b
    [d0[d0][PRO]]
    SO:[cQ[what[what][violin]][cQ[the[the][sonata]][cQ[cQ][T[the[the][sonata]][T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what[what][violin]]]]]]]]]]]]]]]]]]]
    Conceptual-Intensional (CI) Interface: [cQ] + edge [[what[what][violin]],[the[the][sonata]]] constitutes an ill-formed interrogative!

    Backtrack

    Stream:[[cQ!wh!T]]
    Stack (⥥):[the[the][sonata]]
    [what!scope[what!scope][violin]]
    b
    [d0[d0][PRO]]
    SO:[T[the[the][sonata]][T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]]]]]]]
    re-doing step 25

    Step 27.

    [cQ!T] attracts [T[the[the..][sonata..]][T[vbe..][T..]]]
    Internal merge selected
    Merge [cQ[cQ][T[the..][T..]]] and [vbe]
    Label from [cQ[cQ][T[the..][T..]]] (edge feature)
    Merge [cQ[vbe][cQ[cQ..][T..]]] and [T]
    Label from [cQ[vbe][cQ[cQ..][T..]]] (edge feature)
    [cQ] values uscope on [what!scope[what!scope][violin]]
    Merge [cQ[T][cQ[vbe..][cQ..]]] and [what[what][violin]]
    Label from [cQ[T][cQ[vbe..][cQ..]]] (edge feature)
    Stream:[]
    Stack (⥥):[the[the][sonata]]
    [what[what][violin]]
    b
    [d0[d0][PRO]]
    SO:[cQ[what[what][violin]][cQ[T][cQ[vbe][cQ[cQ][T[the[the][sonata]][T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what[what][violin]]]]]]]]]]]]]]]]]]]]

    Step 28.

    Local Extent boundary at [cQ[what[what..][violin..]][cQ[T..][cQ..]]]
    New boundary (b) marker stacked
    Stream:[]
    Stack (⥥):b
    [the[the][sonata]]
    [what[what][violin]]
    b
    [d0[d0][PRO]]
    SO:[cQ[what[what][violin]][cQ[T][cQ[vbe][cQ[cQ][T[the[the][sonata]][T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what[what][violin]]]]]]]]]]]]]]]]]]]]
    CI: wh-question

    Parse:
    Spell-out:
    what violin -s be the sonata easy to play on (after morpheme realization)
    what violin be -s the sonata easy to play on (after affix-hop)
    what violin be -s the sonata easy to play on (after morpheme realization, stage 2)
    what violin is the sonata easy to play on  

    Backtrack

    Stream:[[on],[[sonata!D],[the!case!N]],[play],[vunerg],[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):
    SO:[what!case!scope[what!scope][violin]]
    re-doing step 3

    Step 29.

    Push [on[on][what!scope[what..][violin..]]] (unvalued uF) onto stack
    Stream:[[[sonata!D],[the!case!N]],[play],[vunerg],[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[on[on][what!scope[what!scope][violin]]]
    SO:[on[on][what!scope[what!scope][violin]]]

    Step 30.

    Begin substream
    Stream:[[sonata!D],[the!case!N]]
    Stack (⥥):
    SO:[]

    Step 31.

    Head of stream [sonata!D] is the initial SO
    Stream:[[the!case!N]]
    Stack (⥥):
    SO:[sonata!D]

    Step 32.

    Merge [the!case!N] and [sonata!D]
    Label from [the!case!N] (head with an unvalued uF)
    Inherit interpretable feature(s) [f(phi,[3,sg,n])] from [sonata!D]
    [the!case!N] values D on [sonata!D]
    [sonata] values N on [the!case!N]
    Stream:[]
    Stack (⥥):
    SO:[the!case[the][sonata]]
    End substream, SO [the!case[the][sonata]] re-inserted into main stream

    Step 33.

    Stream:[[the!case[the][sonata]],[play],[vunerg],[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[on[on][what!scope[what!scope][violin]]]
    SO:[on[on][what!scope[what!scope][violin]]]

    Step 34.

    Merge [on[on][what!scope[what..][violin..]]] and [the!case[the][sonata]]
    Label from [on[on][what!scope[what..][violin..]]] (edge feature)
    Theta-mark [the!case[the][sonata]]
    Push [the!case[the][sonata]] (unvalued uF) onto stack
    Stream:[[play],[vunerg],[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    SO:[on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]

    Step 35.

    Merge [play] and [on[the!case[the..][sonata..]][on[on..][what..]]]
    Label from [play] (head merging with a non-head)
    Stream:[[vunerg],[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    SO:[play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]

    Step 36.

    Merge [vunerg] and [play[play][on[the..][on..]]]
    Label from [vunerg] (head merging with a non-head)
    Stream:[[[PRO!D],[d0!case!N]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    SO:[vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]

    Step 37.

    Begin substream
    Stream:[[PRO!D],[d0!case!N]]
    Stack (⥥):
    SO:[]

    Step 38.

    Head of stream [PRO!D] is the initial SO
    Stream:[[d0!case!N]]
    Stack (⥥):
    SO:[PRO!D]

    Step 39.

    Merge [d0!case!N] and [PRO!D]
    Label from [d0!case!N] (head with an unvalued uF)
    Inherit interpretable feature(s) [f(phi,[3,sg,n])] from [PRO!D]
    [d0!case!N] values D on [PRO!D]
    [PRO] values N on [d0!case!N]
    Stream:[]
    Stack (⥥):
    SO:[d0!case[d0][PRO]]
    End substream, SO [d0!case[d0][PRO]] re-inserted into main stream

    Step 40.

    Stream:[[d0!case[d0][PRO]],[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    SO:[vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]

    Step 41.

    Merge [vunerg[vunerg][play[play..][on..]]] and [d0!case[d0][PRO]]
    Label from [vunerg[vunerg][play[play..][on..]]] (edge feature)
    Theta-mark [d0!case[d0][PRO]]
    Push [d0!case[d0][PRO]] (unvalued uF) onto stack
    Stream:[[Tinf!phi],[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[d0!case[d0][PRO]]
    [the!case[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    SO:[vunerg[d0!case[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]

    Step 42.

    Merge [Tinf!phi] and [vunerg[d0!case[d0..][PRO..]][vunerg[vunerg..][play..]]]
    Label from [Tinf!phi] (head merging with a non-head)
    [d0!case[d0][PRO]] values uPhi on [Tinf!phi]
    [Tinf] values nullCase case on [d0[d0][PRO]]
    Stream:[[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[d0[d0][PRO]]
    [the!case[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    SO:[Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]

    Step 43.

    Internal merge selected
    Merge [Tinf[Tinf][vunerg[d0..][vunerg..]]] and [d0[d0][PRO]]
    Label from [Tinf[Tinf][vunerg[d0..][vunerg..]]] (edge feature)
    Stream:[[c],[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[d0[d0][PRO]]
    [the!case[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    SO:[Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]

    Step 44.

    Merge [c] and [Tinf[d0[d0..][PRO..]][Tinf[Tinf..][vunerg..]]]
    Label from [c] (head merging with a non-head)
    Stream:[[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[d0[d0][PRO]]
    [the!case[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    SO:[c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]

    Step 45.

    Local Extent boundary at [c[c][Tinf[d0..][Tinf..]]]
    Stack element [the!case[the][sonata]] with unvalued uF found
    Stack element [on[on][what!scope[what..][violin..]]] with unvalued uF found
    New boundary (b) marker stacked
    Restack [on[on][what!scope[what..][violin..]]] onto stack
    Restack [the!case[the][sonata]] onto stack
    Stream:[[easy],[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    b
    [d0[d0][PRO]]
    SO:[c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]

    Step 46.

    Merge [easy] and [c[c][Tinf[d0..][Tinf..]]]
    Label from [easy] (head merging with a non-head)
    Stream:[[vbe],[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    b
    [d0[d0][PRO]]
    SO:[easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]]

    Step 47.

    Merge [vbe] and [easy[easy][c[c..][Tinf..]]]
    Label from [vbe] (head merging with a non-head)
    Stream:[[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    b
    [d0[d0][PRO]]
    SO:[vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the!case[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]]]

    Step 48.

    Internal merge selected
    Merge [vbe[vbe][easy[easy..][c..]]] and [the!case[the][sonata]]
    Label from [vbe[vbe][easy[easy..][c..]]] (edge feature)
    Preference: [vbe] edge merge from the stack (not stream)
    Stream:[[T!phi!v],[cQ!wh!T]]
    Stack (⥥):[the!case[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    b
    [d0[d0][PRO]]
    SO:[vbe[the!case[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]]]]

    Step 49.

    Merge [T!phi!v] and [vbe[the!case[the..][sonata..]][vbe[vbe..][easy..]]]
    Label from [T!phi!v] (head merging with a non-head)
    [the!case[the][sonata]] values uPhi on [T!phi!v]
    [T!v] values nom case on [the!case[the][sonata]]
    Relativized TOS search for iF(v) skipping [the[the][sonata]]
    Relativized TOS search for iF(v) skipping [on[on][what!scope[what..][violin..]]]
    [T!v] attracts [vbe[the[the..][sonata..]][vbe[vbe..][easy..]]]
    Merge [T[T][vbe[the..][vbe..]]] and [vbe]
    Label from [T[T][vbe[the..][vbe..]]] (edge feature)
    Stream:[[cQ!wh!T]]
    Stack (⥥):[the[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    b
    [d0[d0][PRO]]
    SO:[T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]]]]]]

    Step 50.

    Internal merge selected
    Merge [T[vbe][T[T..][vbe..]]] and [the[the][sonata]]
    Label from [T[vbe][T[T..][vbe..]]] (edge feature)
    Stream:[[cQ!wh!T]]
    Stack (⥥):[the[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    b
    [d0[d0][PRO]]
    SO:[T[the[the][sonata]][T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]]]]]]]

    Step 51.

    Merge [cQ!wh!T] and [T[the[the..][sonata..]][T[vbe..][T..]]]
    Label from [cQ!wh!T] (head merging with a non-head)
    Relativized TOS search for iF(wh) skipping [the[the][sonata]]
    [on[on][what!scope[what..][violin..]]] values wh on [cQ!wh!T]
    [the[the][sonata]] values T on [cQ!T]
    Internal merge selected
    Merge [cQ[cQ][T[the..][T..]]] and [the[the][sonata]]
    Label from [cQ[cQ][T[the..][T..]]] (edge feature)
    [cQ] values uscope on [what!scope[what!scope][violin]]
    Merge [cQ[the[the..][sonata..]][cQ[cQ..][T..]]] and [on[on][what[what..][violin..]]]
    Label from [cQ[the[the..][sonata..]][cQ[cQ..][T..]]] (edge feature)
    Stream:[]
    Stack (⥥):[the[the][sonata]]
    [on[on][what[what][violin]]]
    b
    [d0[d0][PRO]]
    SO:[cQ[on[on][what[what][violin]]][cQ[the[the][sonata]][cQ[cQ][T[the[the][sonata]][T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what[what][violin]]]]]]]]]]]]]]]]]]]

    Step 52.

    Local Extent boundary at [cQ[on[on..][what..]][cQ[the..][cQ..]]]
    New boundary (b) marker stacked
    Stream:[]
    Stack (⥥):b
    [the[the][sonata]]
    [on[on][what[what][violin]]]
    b
    [d0[d0][PRO]]
    SO:[cQ[on[on][what[what][violin]]][cQ[the[the][sonata]][cQ[cQ][T[the[the][sonata]][T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what[what][violin]]]]]]]]]]]]]]]]]]]
    Conceptual-Intensional (CI) Interface: [cQ] + edge [[on[on][what[what][violin]]],[the[the][sonata]]] constitutes an ill-formed interrogative!

    Backtrack

    Stream:[[cQ!wh!T]]
    Stack (⥥):[the[the][sonata]]
    [on[on][what!scope[what!scope][violin]]]
    b
    [d0[d0][PRO]]
    SO:[T[the[the][sonata]][T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what!scope[what!scope][violin]]]]]]]]]]]]]]]]
    re-doing step 51

    Step 53.

    [cQ!T] attracts [T[the[the..][sonata..]][T[vbe..][T..]]]
    Internal merge selected
    Merge [cQ[cQ][T[the..][T..]]] and [vbe]
    Label from [cQ[cQ][T[the..][T..]]] (edge feature)
    Merge [cQ[vbe][cQ[cQ..][T..]]] and [T]
    Label from [cQ[vbe][cQ[cQ..][T..]]] (edge feature)
    [cQ] values uscope on [what!scope[what!scope][violin]]
    Merge [cQ[T][cQ[vbe..][cQ..]]] and [on[on][what[what..][violin..]]]
    Label from [cQ[T][cQ[vbe..][cQ..]]] (edge feature)
    Stream:[]
    Stack (⥥):[the[the][sonata]]
    [on[on][what[what][violin]]]
    b
    [d0[d0][PRO]]
    SO:[cQ[on[on][what[what][violin]]][cQ[T][cQ[vbe][cQ[cQ][T[the[the][sonata]][T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what[what][violin]]]]]]]]]]]]]]]]]]]]

    Step 54.

    Local Extent boundary at [cQ[on[on..][what..]][cQ[T..][cQ..]]]
    New boundary (b) marker stacked
    Stream:[]
    Stack (⥥):b
    [the[the][sonata]]
    [on[on][what[what][violin]]]
    b
    [d0[d0][PRO]]
    SO:[cQ[on[on][what[what][violin]]][cQ[T][cQ[vbe][cQ[cQ][T[the[the][sonata]][T[vbe][T[T][vbe[the[the][sonata]][vbe[vbe][easy[easy][c[c][Tinf[d0[d0][PRO]][Tinf[Tinf][vunerg[d0[d0][PRO]][vunerg[vunerg][play[play][on[the[the][sonata]][on[on][what[what][violin]]]]]]]]]]]]]]]]]]]]
    CI: wh-question

    Parse:
    Spell-out:
    on what violin -s be the sonata easy to play (after morpheme realization)
    on what violin be -s the sonata easy to play (after affix-hop)
    on what violin be -s the sonata easy to play (after morpheme realization, stage 2)
    on what violin is the sonata easy to play  

    2 derivations found.
    Computational Cost:
    Merge: 44, Agree: 27, Unify: 0, Push: 6, Boundaries: 6, Inject: 4
    Non-TOS access: 6, Pop: 0, Depth cost: 88
    Step:0123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
    Stack depth:0001000122200023333444444454510001222000233334444444545

    Back to top