Proof of Theorem bitsinv1lem
| Step | Hyp | Ref
| Expression |
| 1 | | oveq2 5933 |
. . 3
       bits                              bits            |
| 2 | 1 | eqeq2d 2208 |
. 2
       bits                             
    
            bits             |
| 3 | | oveq2 5933 |
. . 3
   bits                          bits            |
| 4 | 3 | eqeq2d 2208 |
. 2
   bits                         
    
            bits             |
| 5 | | simpl 109 |
. . . . . . 7
 

  |
| 6 | | 2nn 9171 |
. . . . . . . . 9
 |
| 7 | 6 | a1i 9 |
. . . . . . . 8
 
   |
| 8 | | simpr 110 |
. . . . . . . 8
 

  |
| 9 | 7, 8 | nnexpcld 10806 |
. . . . . . 7
 
       |
| 10 | 5, 9 | zmodcld 10456 |
. . . . . 6
 
         |
| 11 | 10 | nn0cnd 9323 |
. . . . 5
 
         |
| 12 | 11 | adantr 276 |
. . . 4
   
bits           |
| 13 | | 1nn0 9284 |
. . . . . . . . . 10
 |
| 14 | 13 | a1i 9 |
. . . . . . . . 9
 
   |
| 15 | 8, 14 | nn0addcld 9325 |
. . . . . . . 8
 
     |
| 16 | 7, 15 | nnexpcld 10806 |
. . . . . . 7
 
    
    |
| 17 | 5, 16 | zmodcld 10456 |
. . . . . 6
 
           |
| 18 | 17 | nn0cnd 9323 |
. . . . 5
 
           |
| 19 | 18 | adantr 276 |
. . . 4
   
bits             |
| 20 | 12, 19 | pncan3d 8359 |
. . 3
   
bits                                     |
| 21 | 18, 11 | subcld 8356 |
. . . . . 6
 
      
            |
| 22 | 21 | adantr 276 |
. . . . 5
   
bits        
            |
| 23 | 6 | a1i 9 |
. . . . . . 7
   
bits     |
| 24 | | simplr 528 |
. . . . . . 7
   
bits  
  |
| 25 | 23, 24 | nnexpcld 10806 |
. . . . . 6
   
bits         |
| 26 | 25 | nncnd 9023 |
. . . . 5
   
bits         |
| 27 | | 2cnd 9082 |
. . . . . . 7
 
   |
| 28 | 7 | nnap0d 9055 |
. . . . . . 7
 
 #   |
| 29 | 8 | nn0zd 9465 |
. . . . . . 7
 

  |
| 30 | 27, 28, 29 | expap0d 10790 |
. . . . . 6
 
     #   |
| 31 | 30 | adantr 276 |
. . . . 5
   
bits       #   |
| 32 | | z0even 12095 |
. . . . . . . . . 10
 |
| 33 | | id 19 |
. . . . . . . . . 10
       
              
                        |
| 34 | 32, 33 | breqtrrid 4072 |
. . . . . . . . 9
       
              
          
             |
| 35 | | bitsval2 12128 |
. . . . . . . . . . . 12
 
  bits 
             |
| 36 | | zq 9719 |
. . . . . . . . . . . . . . . . 17
   |
| 37 | 36 | adantr 276 |
. . . . . . . . . . . . . . . 16
 

  |
| 38 | | 2z 9373 |
. . . . . . . . . . . . . . . . . 18
 |
| 39 | | zq 9719 |
. . . . . . . . . . . . . . . . . 18
   |
| 40 | 38, 39 | ax-mp 5 |
. . . . . . . . . . . . . . . . 17
 |
| 41 | | qexpcl 10666 |
. . . . . . . . . . . . . . . . 17
 
       |
| 42 | 40, 8, 41 | sylancr 414 |
. . . . . . . . . . . . . . . 16
 
       |
| 43 | 9 | nngt0d 9053 |
. . . . . . . . . . . . . . . 16
 

      |
| 44 | | modqdiffl 10446 |
. . . . . . . . . . . . . . . 16
             
              
        |
| 45 | 37, 42, 43, 44 | syl3anc 1249 |
. . . . . . . . . . . . . . 15
 
   
              
        |
| 46 | 45 | breq2d 4046 |
. . . . . . . . . . . . . 14
 
               
             |
| 47 | 38 | a1i 9 |
. . . . . . . . . . . . . . 15
 
   |
| 48 | | modqdifz 10447 |
. . . . . . . . . . . . . . . 16
             
             |
| 49 | 37, 42, 43, 48 | syl3anc 1249 |
. . . . . . . . . . . . . . 15
 
   
             |
| 50 | 5 | zcnd 9468 |
. . . . . . . . . . . . . . . . . . 19
 

  |
| 51 | 50, 11, 18 | nnncan1d 8390 |
. . . . . . . . . . . . . . . . . 18
 
   
           
              
        |
| 52 | 51 | oveq1d 5940 |
. . . . . . . . . . . . . . . . 17
 
           
                                       |
| 53 | 50, 11 | subcld 8356 |
. . . . . . . . . . . . . . . . . 18
 
           |
| 54 | 50, 18 | subcld 8356 |
. . . . . . . . . . . . . . . . . 18
 
             |
| 55 | 9 | nncnd 9023 |
. . . . . . . . . . . . . . . . . 18
 
       |
| 56 | 53, 54, 55, 30 | divsubdirapd 8876 |
. . . . . . . . . . . . . . . . 17
 
           
                                
                |
| 57 | 52, 56 | eqtr3d 2231 |
. . . . . . . . . . . . . . . 16
 
           
                            
                |
| 58 | 27, 54 | mulcomd 8067 |
. . . . . . . . . . . . . . . . . . . 20
 
  
    
           
       |
| 59 | 27, 55 | mulcomd 8067 |
. . . . . . . . . . . . . . . . . . . . 21
 
               |
| 60 | 27, 8 | expp1d 10785 |
. . . . . . . . . . . . . . . . . . . . 21
 
    
          |
| 61 | 59, 60 | eqtr4d 2232 |
. . . . . . . . . . . . . . . . . . . 20
 
               |
| 62 | 58, 61 | oveq12d 5943 |
. . . . . . . . . . . . . . . . . . 19
 
                                     
     |
| 63 | | 2ap0 9102 |
. . . . . . . . . . . . . . . . . . . . 21
#  |
| 64 | 63 | a1i 9 |
. . . . . . . . . . . . . . . . . . . 20
 
 #   |
| 65 | 54, 55, 27, 30, 64 | divcanap5d 8863 |
. . . . . . . . . . . . . . . . . . 19
 
                           
           |
| 66 | 16 | nncnd 9023 |
. . . . . . . . . . . . . . . . . . . 20
 
    
    |
| 67 | 29 | peano2zd 9470 |
. . . . . . . . . . . . . . . . . . . . 21
 
     |
| 68 | 27, 28, 67 | expap0d 10790 |
. . . . . . . . . . . . . . . . . . . 20
 
    
  #   |
| 69 | 54, 27, 66, 68 | div23apd 8874 |
. . . . . . . . . . . . . . . . . . 19
 
        
                                  |
| 70 | 62, 65, 69 | 3eqtr3d 2237 |
. . . . . . . . . . . . . . . . . 18
 
   
                                   |
| 71 | | qexpcl 10666 |
. . . . . . . . . . . . . . . . . . . . 21
  
     
    |
| 72 | 40, 15, 71 | sylancr 414 |
. . . . . . . . . . . . . . . . . . . 20
 
    
    |
| 73 | 16 | nngt0d 9053 |
. . . . . . . . . . . . . . . . . . . 20
 

        |
| 74 | | modqdifz 10447 |
. . . . . . . . . . . . . . . . . . . 20
     
           
                 |
| 75 | 37, 72, 73, 74 | syl3anc 1249 |
. . . . . . . . . . . . . . . . . . 19
 
   
                 |
| 76 | 75, 47 | zmulcld 9473 |
. . . . . . . . . . . . . . . . . 18
 
        
       
      |
| 77 | 70, 76 | eqeltrd 2273 |
. . . . . . . . . . . . . . . . 17
 
   
               |
| 78 | 49, 77 | zsubcld 9472 |
. . . . . . . . . . . . . . . 16
 
                                   |
| 79 | 57, 78 | eqeltrd 2273 |
. . . . . . . . . . . . . . 15
 
           
             |
| 80 | | dvdsmul2 11998 |
. . . . . . . . . . . . . . . . 17
    
                       
       
      |
| 81 | 75, 47, 80 | syl2anc 411 |
. . . . . . . . . . . . . . . 16
 

                      |
| 82 | 50, 18, 11 | nnncan2d 8391 |
. . . . . . . . . . . . . . . . . 18
 
   
                        
          |
| 83 | 82 | oveq1d 5940 |
. . . . . . . . . . . . . . . . 17
 
                
                      
           |
| 84 | 53, 21, 55, 30 | divsubdirapd 8876 |
. . . . . . . . . . . . . . . . 17
 
                
                                         
              |
| 85 | 83, 84, 70 | 3eqtr3d 2237 |
. . . . . . . . . . . . . . . 16
 
                      
                                      |
| 86 | 81, 85 | breqtrrd 4062 |
. . . . . . . . . . . . . . 15
 

                         
              |
| 87 | | dvdssub2 12019 |
. . . . . . . . . . . . . . 15
     
                 
                                     
                
              
          
              |
| 88 | 47, 49, 79, 86, 87 | syl31anc 1252 |
. . . . . . . . . . . . . 14
 
               
          
              |
| 89 | 46, 88 | bitr3d 190 |
. . . . . . . . . . . . 13
 
           
          
              |
| 90 | 89 | notbid 668 |
. . . . . . . . . . . 12
 
           
                         |
| 91 | 35, 90 | bitrd 188 |
. . . . . . . . . . 11
 
  bits 
          
              |
| 92 | 91 | biimpd 144 |
. . . . . . . . . 10
 
  bits                           |
| 93 | 92 | con2d 625 |
. . . . . . . . 9
 
        
              
bits     |
| 94 | 34, 93 | syl5 32 |
. . . . . . . 8
 
                       
bits     |
| 95 | 94 | con2d 625 |
. . . . . . 7
 
  bits            
              |
| 96 | | df-neg 8219 |
. . . . . . . . . . . . . . 15
    |
| 97 | 55 | mulm1d 8455 |
. . . . . . . . . . . . . . . . 17
 
               |
| 98 | 9 | nnred 9022 |
. . . . . . . . . . . . . . . . . . 19
 
       |
| 99 | 98 | renegcld 8425 |
. . . . . . . . . . . . . . . . . 18
 
        |
| 100 | 37, 42, 43 | modqcld 10439 |
. . . . . . . . . . . . . . . . . . . 20
 
         |
| 101 | | qre 9718 |
. . . . . . . . . . . . . . . . . . . 20
               |
| 102 | 100, 101 | syl 14 |
. . . . . . . . . . . . . . . . . . 19
 
         |
| 103 | 102 | renegcld 8425 |
. . . . . . . . . . . . . . . . . 18
 
          |
| 104 | 37, 72, 73 | modqcld 10439 |
. . . . . . . . . . . . . . . . . . . 20
 
           |
| 105 | | qre 9718 |
. . . . . . . . . . . . . . . . . . . 20
                   |
| 106 | 104, 105 | syl 14 |
. . . . . . . . . . . . . . . . . . 19
 
           |
| 107 | 106, 102 | resubcld 8426 |
. . . . . . . . . . . . . . . . . 18
 
      
            |
| 108 | | modqlt 10444 |
. . . . . . . . . . . . . . . . . . . 20
                       |
| 109 | 37, 42, 43, 108 | syl3anc 1249 |
. . . . . . . . . . . . . . . . . . 19
 
             |
| 110 | 102, 98 | ltnegd 8569 |
. . . . . . . . . . . . . . . . . . 19
 
                
          |
| 111 | 109, 110 | mpbid 147 |
. . . . . . . . . . . . . . . . . 18
 
     
         |
| 112 | | df-neg 8219 |
. . . . . . . . . . . . . . . . . . 19
                |
| 113 | | 0red 8046 |
. . . . . . . . . . . . . . . . . . . 20
 
   |
| 114 | | modqge0 10443 |
. . . . . . . . . . . . . . . . . . . . 21
     
        
    
     |
| 115 | 37, 72, 73, 114 | syl3anc 1249 |
. . . . . . . . . . . . . . . . . . . 20
 

    
     |
| 116 | 113, 106,
102, 115 | lesub1dd 8607 |
. . . . . . . . . . . . . . . . . . 19
 
                  
        |
| 117 | 112, 116 | eqbrtrid 4069 |
. . . . . . . . . . . . . . . . . 18
 
       
         
        |
| 118 | 99, 103, 107, 111, 117 | ltletrd 8469 |
. . . . . . . . . . . . . . . . 17
 
     
         
        |
| 119 | 97, 118 | eqbrtrd 4056 |
. . . . . . . . . . . . . . . 16
 
                          |
| 120 | | 1red 8060 |
. . . . . . . . . . . . . . . . . 18
 
   |
| 121 | 120 | renegcld 8425 |
. . . . . . . . . . . . . . . . 17
 
    |
| 122 | 9 | nnrpd 9788 |
. . . . . . . . . . . . . . . . 17
 
       |
| 123 | 121, 107,
122 | ltmuldivd 9838 |
. . . . . . . . . . . . . . . 16
 
                         
                         |
| 124 | 119, 123 | mpbid 147 |
. . . . . . . . . . . . . . 15
 
                          |
| 125 | 96, 124 | eqbrtrrid 4070 |
. . . . . . . . . . . . . 14
 
                           |
| 126 | | 0zd 9357 |
. . . . . . . . . . . . . . 15
 
   |
| 127 | | zlem1lt 9401 |
. . . . . . . . . . . . . . 15
            
                   
              
            
              |
| 128 | 126, 79, 127 | syl2anc 411 |
. . . . . . . . . . . . . 14
 
        
              
            
              |
| 129 | 125, 128 | mpbird 167 |
. . . . . . . . . . . . 13
 

                        |
| 130 | | elnn0z 9358 |
. . . . . . . . . . . . 13
       
                                     
                         |
| 131 | 79, 129, 130 | sylanbrc 417 |
. . . . . . . . . . . 12
 
           
             |
| 132 | | nn0uz 9655 |
. . . . . . . . . . . 12
     |
| 133 | 131, 132 | eleqtrdi 2289 |
. . . . . . . . . . 11
 
           
                 |
| 134 | 16 | nnred 9022 |
. . . . . . . . . . . . . 14
 
    
    |
| 135 | | modqge0 10443 |
. . . . . . . . . . . . . . . 16
          
        |
| 136 | 37, 42, 43, 135 | syl3anc 1249 |
. . . . . . . . . . . . . . 15
 

        |
| 137 | 106, 102 | subge02d 8583 |
. . . . . . . . . . . . . . 15
 
       
         
     
    
      |
| 138 | 136, 137 | mpbid 147 |
. . . . . . . . . . . . . 14
 
      
              
     |
| 139 | | modqlt 10444 |
. . . . . . . . . . . . . . 15
     
                         |
| 140 | 37, 72, 73, 139 | syl3anc 1249 |
. . . . . . . . . . . . . 14
 
                 |
| 141 | 107, 106,
134, 138, 140 | lelttrd 8170 |
. . . . . . . . . . . . 13
 
      
                  |
| 142 | 141, 60 | breqtrd 4060 |
. . . . . . . . . . . 12
 
      
                  |
| 143 | 7 | nnred 9022 |
. . . . . . . . . . . . 13
 
   |
| 144 | 107, 143,
122 | ltdivmuld 9842 |
. . . . . . . . . . . 12
 
                                                 |
| 145 | 142, 144 | mpbird 167 |
. . . . . . . . . . 11
 
           
             |
| 146 | | elfzo2 10244 |
. . . . . . . . . . 11
       
                ..^                           
      
                  |
| 147 | 133, 47, 145, 146 | syl3anbrc 1183 |
. . . . . . . . . 10
 
           
            ..^   |
| 148 | | fzo0to2pr 10313 |
. . . . . . . . . 10
 ..^     |
| 149 | 147, 148 | eleqtrdi 2289 |
. . . . . . . . 9
 
           
                |
| 150 | | elpri 3646 |
. . . . . . . . 9
       
                 
       
                                        |
| 151 | 149, 150 | syl 14 |
. . . . . . . 8
 
                                                 |
| 152 | 151 | ord 725 |
. . . . . . 7
 
                       
                         |
| 153 | 95, 152 | syld 45 |
. . . . . 6
 
  bits        
                  |
| 154 | 153 | imp 124 |
. . . . 5
   
bits             
             |
| 155 | 22, 26, 31, 154 | diveqap1d 8844 |
. . . 4
   
bits        
                |
| 156 | 155 | oveq2d 5941 |
. . 3
   
bits                                         |
| 157 | 20, 156 | eqtr3d 2231 |
. 2
   
bits                         |
| 158 | 18 | adantr 276 |
. . . 4
    bits             |
| 159 | 11 | adantr 276 |
. . . 4
    bits           |
| 160 | 21 | adantr 276 |
. . . . 5
    bits        
            |
| 161 | 55 | adantr 276 |
. . . . 5
    bits         |
| 162 | 30 | adantr 276 |
. . . . 5
    bits       #   |
| 163 | 17 | nn0zd 9465 |
. . . . . . . . . 10
 
           |
| 164 | 10 | nn0zd 9465 |
. . . . . . . . . 10
 
         |
| 165 | 163, 164 | zsubcld 9472 |
. . . . . . . . 9
 
      
            |
| 166 | | znq 9717 |
. . . . . . . . 9
       
                         
             |
| 167 | 165, 9, 166 | syl2anc 411 |
. . . . . . . 8
 
           
             |
| 168 | | 0z 9356 |
. . . . . . . . 9
 |
| 169 | | zq 9719 |
. . . . . . . . 9
   |
| 170 | 168, 169 | mp1i 10 |
. . . . . . . 8
 
   |
| 171 | | qdceq 10353 |
. . . . . . . 8
            
           
DECID           
             |
| 172 | 167, 170,
171 | syl2anc 411 |
. . . . . . 7
 
 DECID       
                 |
| 173 | | n2dvds1 12096 |
. . . . . . . . . 10
 |
| 174 | | breq2 4038 |
. . . . . . . . . 10
       
              
                      
   |
| 175 | 173, 174 | mtbiri 676 |
. . . . . . . . 9
       
              
          
             |
| 176 | 152, 175 | syl6 33 |
. . . . . . . 8
 
                       
          
              |
| 177 | 176, 91 | sylibrd 169 |
. . . . . . 7
 
                       
bits     |
| 178 | | con1dc 857 |
. . . . . . 7
DECID                      
            
           bits  

bits 
                          |
| 179 | 172, 177,
178 | sylc 62 |
. . . . . 6
 
  bits            
              |
| 180 | 179 | imp 124 |
. . . . 5
    bits             
             |
| 181 | 160, 161,
162, 180 | diveqap0d 8843 |
. . . 4
    bits        
            |
| 182 | 158, 159,
181 | subeq0d 8364 |
. . 3
    bits                   |
| 183 | 159 | addridd 8194 |
. . 3
    bits                   |
| 184 | 182, 183 | eqtr4d 2232 |
. 2
    bits                     |
| 185 | | bitsdc 12131 |
. 2
 
 DECID bits    |
| 186 | 2, 4, 157, 184, 185 | ifbothdadc 3594 |
1
 
                  bits            |