Misplaced Pages

LowerUnits

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
This article relies largely or entirely on a single source. Relevant discussion may be found on the talk page. Please help improve this article by introducing citations to additional sources.
Find sources: "LowerUnits" – news · newspapers · books · scholar · JSTOR (April 2014)
This article may be too technical for most readers to understand. Please help improve it to make it understandable to non-experts, without removing the technical details. (April 2014) (Learn how and when to remove this message)

In proof compression LowerUnits (LU) is an algorithm used to compress propositional logic resolution proofs. The main idea of LowerUnits is to exploit the following fact:

Theorem: Let 
  
    
      
        φ

      
    
    {\displaystyle \varphi }
  
 be a potentially redundant proof, and 
  
    
      
        η

      
    
    {\displaystyle \eta }
  
 be the redundant proof | redundant node. If 
  
    
      
        η

      
    
    {\displaystyle \eta }
  
’s clause is a unit clause, 
then 
  
    
      
        φ

      
    
    {\displaystyle \varphi }
  
 is redundant.

The algorithm targets exactly the class of global redundancy stemming from multiple resolutions with unit clauses. The algorithm takes its name from the fact that, when this rewriting is done and the resulting proof is displayed as a DAG (directed acyclic graph), the unit node η {\displaystyle \eta } appears lower (i.e., closer to the root) than it used to appear in the original proof.

A naive implementation exploiting theorem would require the proof to be traversed and fixed after each unit node is lowered. It is possible, however, to do better by first collecting and removing all the unit nodes in a single traversal, and afterwards fixing the whole proof in a single second traversal. Finally, the collected and fixed unit nodes have to be reinserted at the bottom of the proof.

Care must be taken with cases when a unit node η {\displaystyle \eta ^{\prime }} occurs above in the subproof that derives another unit node η {\displaystyle \eta } . In such cases, η {\displaystyle \eta } depends on η {\displaystyle \eta ^{\prime }} . Let {\displaystyle \ell } be the single literal of the unit clause of η {\displaystyle \eta ^{\prime }} . Then any occurrence of ¯ {\displaystyle {\overline {\ell }}} in the subproof above η {\displaystyle \eta } will not be cancelled by resolution inferences with η {\displaystyle \eta ^{\prime }} anymore. Consequently, ¯ {\displaystyle {\overline {\ell }}} will be propagated downwards when the proof is fixed and will appear in the clause of η {\displaystyle \eta } . Difficulties with such dependencies can be easily avoided if we reinsert the upper unit node η {\displaystyle \eta ^{\prime }} after reinserting the unit node η {\displaystyle \eta } (i.e. after reinsertion, η {\displaystyle \eta ^{\prime }} must appear below η {\displaystyle \eta } , to cancel the extra literal ¯ {\displaystyle {\overline {\ell }}} from η {\displaystyle \eta } ’s clause). This can be ensured by collecting the unit nodes in a queue during a bottom-up traversal of the proof and reinserting them in the order they were queued.

The algorithm for fixing a proof containing many roots performs a top-down traversal of the proof, recomputing the resolvents and replacing broken nodes (e.g. nodes having deletedNodeMarker as one of their parents) by their surviving parents (e.g. the other parent, in case one parent was deletedNodeMarker).

When unit nodes are collected and removed from a proof of a clause κ {\displaystyle \kappa } and the proof is fixed, the clause κ {\displaystyle \kappa ^{\prime }} in the root node of the new proof is not equal to κ {\displaystyle \kappa } anymore, but contains (some of) the duals of the literals of the unit clauses that have been removed from the proof. The reinsertion of unit nodes at the bottom of the proof resolves κ {\displaystyle \kappa ^{\prime }} with the clauses of (some of) the collected unit nodes, in order to obtain a proof of κ {\displaystyle \kappa } again.

Algorithm

General structure of the algorithm

Algorithm LowerUnits
  Input: A proof 
  
    
      
        ψ

      
    
    {\displaystyle \psi }
  

  Output: A proof 
  
    
      
        
          ψ

          
            
          
        
      
    
    {\displaystyle \psi ^{\prime }}
  
 with no global redundancy with unit redundant node
  (unitsQueue, 
  
    
      
        
          ψ

          
            b
          
        
      
    
    {\displaystyle \psi _{b}}
  
) ← collectUnits(
  
    
      
        ψ

      
    
    {\displaystyle \psi }
  
); 
  
  
    
      
        
          ψ

          
            f
          
        
      
    
    {\displaystyle \psi _{f}}
  
 ← fix(
  
    
      
        
          ψ

          
            b
          
        
      
    
    {\displaystyle \psi _{b}}
  
); 
  fixedUnitsQueue ← fix(unitsQueue); 
  
  
    
      
        
          ψ

          
            
          
        
      
    
    {\displaystyle \psi ^{\prime }}
  
 ← reinsertUnits(
  
    
      
        
          ψ

          
            f
          
        
      
    
    {\displaystyle \psi _{f}}
  
, fixedUnitsQueue);
  return 
  
    
      
        
          ψ

          
            
          
        
      
    
    {\displaystyle \psi ^{\prime }}
  
;
  • "←" denotes assignment. For instance, "largestitem" means that the value of largest changes to the value of item.
  • "return" terminates the algorithm and outputs the following value.

We collect the unit clauses as follow

Algorithm CollectUnits
  Input: A proof 
  
    
      
        ψ

      
    
    {\displaystyle \psi }
  

  Output: A pair containing a queue of all unit nodes (unitsQueue) that are used more than once in 
  
    
      
        ψ

      
    
    {\displaystyle \psi }
  
 and a broken proof 
  
    
      
        
          ψ

          
            b
          
        
      
    
    {\displaystyle \psi _{b}}
  


  
    
      
        
          ψ

          
            b
          
        
      
    
    {\displaystyle \psi _{b}}
  

  
    
      
        ψ

      
    
    {\displaystyle \psi }
  
; 
traverse 
  
    
      
        
          ψ

          
            b
          
        
      
    
    {\displaystyle \psi _{b}}
  
 bottom-up and foreach node 
  
    
      
        η

      
    
    {\displaystyle \eta }
  
 in 
  
    
      
        
          ψ

          
            b
          
        
      
    
    {\displaystyle \psi _{b}}
  
 do
  if 
  
    
      
        η

      
    
    {\displaystyle \eta }
  
 is unit and 
  
    
      
        η

      
    
    {\displaystyle \eta }
  
 has more than one child then
      add 
  
    
      
        η

      
    
    {\displaystyle \eta }
  
 to unitsQueue; 
      remove 
  
    
      
        η

      
    
    {\displaystyle \eta }
  
 from 
  
    
      
        
          ψ

          
            b
          
        
      
    
    {\displaystyle \psi _{b}}
  
; 
  end
end
return (unitsQueue, 
  
    
      
        
          ψ

          
            b
          
        
      
    
    {\displaystyle \psi _{b}}
  
); 
  • "←" denotes assignment. For instance, "largestitem" means that the value of largest changes to the value of item.
  • "return" terminates the algorithm and outputs the following value.

Then we reinsert the units

Algorithm ReinsertUnits
  Input: A proof 
  
    
      
        
          ψ

          
            f
          
        
      
    
    {\displaystyle \psi _{f}}
  
 (with a single root) and a queue 
  
    
      
        q
      
    
    {\displaystyle q}
  
 of root nodes 
  Output: A proof 
  
    
      
        
          ψ

          
            
          
        
      
    
    {\displaystyle \psi ^{\prime }}
  


  
    
      
        
          ψ

          
            
          
        
      
    
    {\displaystyle \psi ^{\prime }}
  

  
    
      
        
          ψ

          
            f
          
        
      
    
    {\displaystyle \psi _{f}}
  
; 
while 
  
    
      
        q
        
        
      
    
    {\displaystyle q\neq \emptyset }
  
 do
    
  
    
      
        η

      
    
    {\displaystyle \eta }
  
 ← first element of 
  
    
      
        q
      
    
    {\displaystyle q}
  
;
    
  
    
      
        q
      
    
    {\displaystyle q}
  
 ← tail of 
  
    
      
        q
      
    
    {\displaystyle q}
  
;
    if 
  
    
      
        η

      
    
    {\displaystyle \eta }
  
 is resolvable with root of 
  
    
      
        
          ψ

          
            
          
        
      
    
    {\displaystyle \psi ^{\prime }}
  
 then
        
  
    
      
        
          ψ

          
            
          
        
      
    
    {\displaystyle \psi ^{\prime }}
  
 ← resolvent of 
  
    
      
        η

      
    
    {\displaystyle \eta }
  
 with the root of 
  
    
      
        
          ψ

          
            
          
        
      
    
    {\displaystyle \psi ^{\prime }}
  
; 
    end 
end
return 
  
    
      
        
          ψ

          
            
          
        
      
    
    {\displaystyle \psi ^{\prime }}
  
;
  • "←" denotes assignment. For instance, "largestitem" means that the value of largest changes to the value of item.
  • "return" terminates the algorithm and outputs the following value.

Notes

  1. Fontaine, Pascal; Merz, Stephan; Woltzenlogel Paleo, Bruno. Compression of Propositional Resolution Proofs via Partial Regularization. 23rd International Conference on Automated Deduction, 2011.
Categories: