| Step | Hyp | Ref | Expression | 
|---|
        
          | 1 |  | eqidd | _1 = n -> z = z | 
        
          | 2 |  | eqsidd | _1 = n -> S == S | 
        
          | 3 |  | id | _1 = n -> _1 = n | 
        
          | 4 | 1, 2, 3 | recnauxeqd | _1 = n -> recnaux z S _1 = recnaux z S n | 
        
          | 5 | 4 | fsteqd | _1 = n -> fst (recnaux z S _1) = fst (recnaux z S n) | 
        
          | 6 | 5, 3 | eqeqd | _1 = n -> (fst (recnaux z S _1) = _1 <-> fst (recnaux z S n) = n) | 
        
          | 7 |  | eqidd | _1 = 0 -> z = z | 
        
          | 8 |  | eqsidd | _1 = 0 -> S == S | 
        
          | 9 |  | id | _1 = 0 -> _1 = 0 | 
        
          | 10 | 7, 8, 9 | recnauxeqd | _1 = 0 -> recnaux z S _1 = recnaux z S 0 | 
        
          | 11 | 10 | fsteqd | _1 = 0 -> fst (recnaux z S _1) = fst (recnaux z S 0) | 
        
          | 12 | 11, 9 | eqeqd | _1 = 0 -> (fst (recnaux z S _1) = _1 <-> fst (recnaux z S 0) = 0) | 
        
          | 13 |  | eqidd | _1 = a1 -> z = z | 
        
          | 14 |  | eqsidd | _1 = a1 -> S == S | 
        
          | 15 |  | id | _1 = a1 -> _1 = a1 | 
        
          | 16 | 13, 14, 15 | recnauxeqd | _1 = a1 -> recnaux z S _1 = recnaux z S a1 | 
        
          | 17 | 16 | fsteqd | _1 = a1 -> fst (recnaux z S _1) = fst (recnaux z S a1) | 
        
          | 18 | 17, 15 | eqeqd | _1 = a1 -> (fst (recnaux z S _1) = _1 <-> fst (recnaux z S a1) = a1) | 
        
          | 19 |  | eqidd | _1 = suc a1 -> z = z | 
        
          | 20 |  | eqsidd | _1 = suc a1 -> S == S | 
        
          | 21 |  | id | _1 = suc a1 -> _1 = suc a1 | 
        
          | 22 | 19, 20, 21 | recnauxeqd | _1 = suc a1 -> recnaux z S _1 = recnaux z S (suc a1) | 
        
          | 23 | 22 | fsteqd | _1 = suc a1 -> fst (recnaux z S _1) = fst (recnaux z S (suc a1)) | 
        
          | 24 | 23, 21 | eqeqd | _1 = suc a1 -> (fst (recnaux z S _1) = _1 <-> fst (recnaux z S (suc a1)) = suc a1) | 
        
          | 25 |  | eqtr | fst (recnaux z S 0) = fst (0, z) -> fst (0, z) = 0 -> fst (recnaux z S 0) = 0 | 
        
          | 26 |  | fsteq | recnaux z S 0 = 0, z -> fst (recnaux z S 0) = fst (0, z) | 
        
          | 27 |  | recnaux0 | recnaux z S 0 = 0, z | 
        
          | 28 | 26, 27 | ax_mp | fst (recnaux z S 0) = fst (0, z) | 
        
          | 29 | 25, 28 | ax_mp | fst (0, z) = 0 -> fst (recnaux z S 0) = 0 | 
        
          | 30 |  | fstpr | fst (0, z) = 0 | 
        
          | 31 | 29, 30 | ax_mp | fst (recnaux z S 0) = 0 | 
        
          | 32 |  | eqtr | fst (recnaux z S (suc a1)) = fst (suc (fst (recnaux z S a1)), S @ recnaux z S a1) ->
  fst (suc (fst (recnaux z S a1)), S @ recnaux z S a1) = suc (fst (recnaux z S a1)) ->
  fst (recnaux z S (suc a1)) = suc (fst (recnaux z S a1)) | 
        
          | 33 |  | fsteq | recnaux z S (suc a1) = suc (fst (recnaux z S a1)), S @ recnaux z S a1 -> fst (recnaux z S (suc a1)) = fst (suc (fst (recnaux z S a1)), S @ recnaux z S a1) | 
        
          | 34 |  | recnauxS2 | recnaux z S (suc a1) = suc (fst (recnaux z S a1)), S @ recnaux z S a1 | 
        
          | 35 | 33, 34 | ax_mp | fst (recnaux z S (suc a1)) = fst (suc (fst (recnaux z S a1)), S @ recnaux z S a1) | 
        
          | 36 | 32, 35 | ax_mp | fst (suc (fst (recnaux z S a1)), S @ recnaux z S a1) = suc (fst (recnaux z S a1)) -> fst (recnaux z S (suc a1)) = suc (fst (recnaux z S a1)) | 
        
          | 37 |  | fstpr | fst (suc (fst (recnaux z S a1)), S @ recnaux z S a1) = suc (fst (recnaux z S a1)) | 
        
          | 38 | 36, 37 | ax_mp | fst (recnaux z S (suc a1)) = suc (fst (recnaux z S a1)) | 
        
          | 39 |  | suceq | fst (recnaux z S a1) = a1 -> suc (fst (recnaux z S a1)) = suc a1 | 
        
          | 40 | 38, 39 | syl5eq | fst (recnaux z S a1) = a1 -> fst (recnaux z S (suc a1)) = suc a1 | 
        
          | 41 | 6, 12, 18, 24, 31, 40 | ind | fst (recnaux z S n) = n |