All Downloads are FREE. Search and download functionalities are using the official Maven repository.

z3-z3-4.13.0.src.smt.spanning_tree.h Maven / Gradle / Ivy

The newest version!
/*++
Copyright (c) 2013 Microsoft Corporation

Module Name:

    spanning_tree.h

Abstract:

    Represent spanning trees with needed operations for Network Simplex

Author:

    Anh-Dung Phan (t-anphan) 2013-11-06

Notes:
   
--*/
#pragma once

#include "smt/diff_logic.h"
#include "smt/spanning_tree_base.h"

namespace smt {

    template
    class thread_spanning_tree : public spanning_tree_base, protected Ext {
    protected:        
        typedef dl_edge edge;
        typedef dl_graph graph;     
        typedef typename Ext::numeral numeral;
        typedef typename Ext::fin_numeral fin_numeral;

        // Store the parent of a node i in the spanning tree
        svector m_pred;
        // Store the number of edge on the path from node i to the root
        svector m_depth;
        svector m_thread;           // Store the pointer from node i to the next node in depth-first search order

        svector m_tree;          // i |-> edge between (i, m_pred[i])

        node_id m_root_t2;

        graph & m_graph;

        void swap_order(node_id q, node_id v);
        node_id find_rev_thread(node_id n) const;
        void fix_depth(node_id start, node_id after_end);
        node_id get_final(int start);
        bool is_preorder_traversal(node_id start, node_id end);   
        node_id get_common_ancestor(node_id u, node_id v);
        bool is_forward_edge(edge_id e_id) const;
        bool is_ancestor_of(node_id ancestor, node_id child);

    public:      
        thread_spanning_tree(graph & g);

        virtual void initialize(svector const & tree);
        void get_descendants(node_id start, svector & descendants);
        
        virtual void update(edge_id enter_id, edge_id leave_id);                
        void get_path(node_id start, node_id end, svector & path, bool_vector & against);              
        bool in_subtree_t2(node_id child);

        bool check_well_formed();        
    };

    template
    class basic_spanning_tree : public thread_spanning_tree {
    private:
        graph * m_tree_graph;

    public:
        basic_spanning_tree(graph & g);
        void initialize(svector const & tree);
        void update(edge_id enter_id, edge_id leave_id);
    };

}





© 2015 - 2024 Weber Informatics LLC | Privacy Policy