LCOV - code coverage report
Current view: top level - buildbot/coverage/build/src/proof - proof_letify.cpp (source / functions) Hit Total Coverage
Test: coverage.info Lines: 39 45 86.7 %
Date: 2024-10-10 10:22:32 Functions: 3 4 75.0 %
Branches: 29 46 63.0 %

           Branch data     Line data    Source code
       1                 :            : /******************************************************************************
       2                 :            :  * Top contributors (to current version):
       3                 :            :  *   Andrew Reynolds, Hans-Joerg Schurr
       4                 :            :  *
       5                 :            :  * This file is part of the cvc5 project.
       6                 :            :  *
       7                 :            :  * Copyright (c) 2009-2024 by the authors listed in the file AUTHORS
       8                 :            :  * in the top-level source directory and their institutional affiliations.
       9                 :            :  * All rights reserved.  See the file COPYING in the top-level source
      10                 :            :  * directory for licensing information.
      11                 :            :  * ****************************************************************************
      12                 :            :  *
      13                 :            :  * Utilities for computing letification of proofs.
      14                 :            :  */
      15                 :            : 
      16                 :            : #include "proof/proof_letify.h"
      17                 :            : 
      18                 :            : namespace cvc5::internal {
      19                 :            : namespace proof {
      20                 :            : 
      21                 :          0 : bool ProofLetifyTraverseCallback::shouldTraverse(const ProofNode* pn)
      22                 :            : {
      23                 :          0 :   return pn->getRule() != ProofRule::SCOPE;
      24                 :            : }
      25                 :            : 
      26                 :     361325 : void ProofLetify::computeProofLet(const ProofNode* pn,
      27                 :            :                                   std::vector<const ProofNode*>& pletList,
      28                 :            :                                   std::map<const ProofNode*, size_t>& pletMap,
      29                 :            :                                   size_t thresh,
      30                 :            :                                   ProofLetifyTraverseCallback* pltc)
      31                 :            : {
      32 [ +  - ][ +  - ]:     722650 :   Assert(pletList.empty() && pletMap.empty());
         [ -  + ][ -  - ]
      33         [ -  + ]:     361325 :   if (thresh == 0)
      34                 :            :   {
      35                 :            :     // value of 0 means do not introduce let
      36                 :          0 :     return;
      37                 :            :   }
      38                 :     722650 :   std::vector<const ProofNode*> visitList;
      39                 :     722650 :   std::map<const ProofNode*, size_t> pcount;
      40         [ -  + ]:     361325 :   if (pltc == nullptr)
      41                 :            :   {
      42                 :            :     // use default callback
      43                 :          0 :     ProofLetifyTraverseCallback defaultPltc;
      44                 :          0 :     computeProofCounts(pn, visitList, pcount, &defaultPltc);
      45                 :            :   }
      46                 :            :   else
      47                 :            :   {
      48                 :     361325 :     computeProofCounts(pn, visitList, pcount, pltc);
      49                 :            :   }
      50                 :            :   // Now populate the pletList and pletMap
      51                 :     361325 :   convertProofCountToLet(visitList, pcount, pletList, pletMap, thresh);
      52                 :            : }
      53                 :            : 
      54                 :     361325 : void ProofLetify::computeProofCounts(const ProofNode* pn,
      55                 :            :                                      std::vector<const ProofNode*>& visitList,
      56                 :            :                                      std::map<const ProofNode*, size_t>& pcount,
      57                 :            :                                      ProofLetifyTraverseCallback* pltc)
      58                 :            : {
      59                 :     361325 :   std::map<const ProofNode*, size_t>::iterator it;
      60                 :     722650 :   std::vector<const ProofNode*> visit;
      61                 :            :   const ProofNode* cur;
      62                 :     361325 :   visit.push_back(pn);
      63                 :   34215900 :   do
      64                 :            :   {
      65                 :   34577200 :     cur = visit.back();
      66                 :   34577200 :     it = pcount.find(cur);
      67         [ +  + ]:   34577200 :     if (it == pcount.end())
      68                 :            :     {
      69                 :   15379300 :       pcount[cur] = 0;
      70         [ +  + ]:   15379300 :       if (!pltc->shouldTraverse(cur))
      71                 :            :       {
      72                 :            :         // callback indicated we should not traverse
      73                 :     341934 :         continue;
      74                 :            :       }
      75                 :   15037400 :       const std::vector<std::shared_ptr<ProofNode>>& pc = cur->getChildren();
      76         [ +  + ]:   33874000 :       for (const std::shared_ptr<ProofNode>& cp : pc)
      77                 :            :       {
      78                 :   18836600 :         visit.push_back(cp.get());
      79                 :            :       }
      80                 :            :     }
      81                 :            :     else
      82                 :            :     {
      83         [ +  + ]:   19197900 :       if (it->second == 0)
      84                 :            :       {
      85                 :   15379300 :         visitList.push_back(cur);
      86                 :            :       }
      87                 :   19197900 :       pcount[cur]++;
      88                 :   19197900 :       visit.pop_back();
      89                 :            :     }
      90         [ +  + ]:   34577200 :   } while (!visit.empty());
      91                 :     361325 : }
      92                 :            : 
      93                 :     361325 : void ProofLetify::convertProofCountToLet(
      94                 :            :     const std::vector<const ProofNode*>& visitList,
      95                 :            :     const std::map<const ProofNode*, size_t>& pcount,
      96                 :            :     std::vector<const ProofNode*>& pletList,
      97                 :            :     std::map<const ProofNode*, size_t>& pletMap,
      98                 :            :     size_t thresh)
      99                 :            : {
     100 [ +  - ][ +  - ]:     722650 :   Assert(pletList.empty() && pletMap.empty());
         [ -  + ][ -  - ]
     101         [ -  + ]:     361325 :   if (thresh == 0)
     102                 :            :   {
     103                 :            :     // value of 0 means do not introduce let
     104                 :          0 :     return;
     105                 :            :   }
     106                 :            :   // Assign ids for those whose count is > 1, traverse in reverse order
     107                 :            :   // so that deeper proofs are assigned lower identifiers
     108                 :     361325 :   std::map<const ProofNode*, size_t>::const_iterator itc;
     109         [ +  + ]:   15740700 :   for (const ProofNode* pn : visitList)
     110                 :            :   {
     111                 :   15379300 :     itc = pcount.find(pn);
     112 [ -  + ][ -  + ]:   15379300 :     Assert(itc != pcount.end());
                 [ -  - ]
     113 [ +  + ][ +  + ]:   15379300 :     if (itc->second >= thresh && pn->getRule() != ProofRule::ASSUME)
                 [ +  + ]
     114                 :            :     {
     115                 :    1315900 :       pletList.push_back(pn);
     116                 :            :       // start with id 1
     117                 :    1315900 :       size_t id = pletMap.size() + 1;
     118                 :    1315900 :       pletMap[pn] = id;
     119                 :            :     }
     120                 :            :   }
     121                 :            : }
     122                 :            : 
     123                 :            : }  // namespace proof
     124                 :            : }  // namespace cvc5::internal

Generated by: LCOV version 1.14