summaryrefslogtreecommitdiff
path: root/src/prop/cryptominisat/Solver/BoundedQueue.h
blob: f7f40c158e44291a433938f896f03052005e455e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/*****************************************************************************************[Queue.h]
MiniSat -- Copyright (c) 2003-2006, Niklas Een, Niklas Sorensson
2008 - Gilles Audemard, Laurent Simon
CryptoMiniSat -- Copyright (c) 2009 Mate Soos

Original code by MiniSat and glucose authors are under an MIT licence.
Modifications for CryptoMiniSat are under GPLv3 licence.
**************************************************************************************************/

#ifndef BOUNDEDQUEUE_H
#define BOUNDEDQUEUE_H

#ifdef _MSC_VER
#include <msvc/stdint.h>
#else
#include <stdint.h>
#endif //_MSC_VER

#include "Vec.h"

namespace CMSat {

template <class T>
class bqueue {
    vec<T>  elems;
    uint32_t first;
    uint32_t last;
    int64_t  sumofqueue;
    int64_t  sumOfAllElems;
    uint64_t totalNumElems;
    uint32_t maxsize;
    uint32_t queuesize; // Number of current elements (must be < maxsize !)

public:
    bqueue(void) :
        first(0)
        , last(0)
        , sumofqueue(0)
        , sumOfAllElems(0)
        , totalNumElems(0)
        , maxsize(0)
        , queuesize(0)
    {}

    void initSize(const uint32_t size) {growTo(size);} // Init size of bounded size queue

    void push(const T x) {
        if (queuesize==maxsize) {
            assert(last==first); // The queue is full, next value to enter will replace oldest one
            sumofqueue -= elems[last];
            if ((++last) == maxsize) last = 0;
        } else
            queuesize++;
        sumofqueue += x;
        sumOfAllElems += x;
        totalNumElems++;
        elems[first] = x;
        if ((++first) == maxsize) first = 0;
    }

    const T peek() const { assert(queuesize>0); return elems[last]; }
    void pop() {sumofqueue-=elems[last]; queuesize--; if ((++last) == maxsize) last = 0;}

    int64_t getsum() const {return sumofqueue;}
    uint32_t getAvgUInt() const {return (uint64_t)sumofqueue/(uint64_t)queuesize;}
    double getAvgDouble() const {return (double)sumofqueue/(double)queuesize;}
    double getAvgAllDouble() const {return (double)sumOfAllElems/(double)totalNumElems;}
    uint64_t getTotalNumeElems() const {return totalNumElems;}
    int isvalid() const {return (queuesize==maxsize);}

    void growTo(const uint32_t size) {
        elems.growTo(size);
        first=0; maxsize=size; queuesize = 0;
        for(uint32_t i=0;i<size;i++) elems[i]=0;
    }

    void fastclear() {first = 0; last = 0; queuesize=0; sumofqueue=0;} // to be called after restarts... Discard the queue

    int  size(void)    { return queuesize; }

    void clear(bool dealloc = false)   {
        elems.clear(dealloc);
        first = 0;
        last = 0;
        maxsize=0;
        queuesize=0;
        sumofqueue=0;

        totalNumElems = 0;
        sumOfAllElems = 0;
    }
};

}

#endif //BOUNDEDQUEUE_H
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback