File: AbstractHitIterator.hpp

package info (click to toggle)
plast 2.3.2%2Bdfsg-10
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, trixie
  • size: 16,312 kB
  • sloc: cpp: 28,979; ansic: 2,075; sh: 478; makefile: 73
file content (116 lines) | stat: -rwxr-xr-x 4,436 bytes parent folder | download | duplicates (6)
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/*****************************************************************************
 *                                                                           *
 *   PLAST : Parallel Local Alignment Search Tool                            *
 *   Version 2.3, released November 2015                                     *
 *   Copyright (c) 2009-2015 Inria-Cnrs-Ens                                  *
 *                                                                           *
 *   PLAST is free software; you can redistribute it and/or modify it under  *
 *   the Affero GPL ver 3 License, that is compatible with the GNU General   *
 *   Public License                                                          *
 *                                                                           *
 *   This program is distributed in the hope that it will be useful,         *
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of          *
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the            *
 *   Affero GPL ver 3 License for more details.                              *
 *****************************************************************************/

/** \file AbstractHitIterator.hpp
 *  \brief Abstract implementation of IHitIterator interface
 *  \date 07/11/2011
 *  \author edrezen
 */

#ifndef _ABSTRACT_HITITERATOR_HPP_
#define _ABSTRACT_HITITERATOR_HPP_

/********************************************************************************/

#include <algo/hits/api/IHitIterator.hpp>

#include <stdio.h>

/********************************************************************************/
namespace algo   {
namespace hits   {
/** \brief Abstract implementations for IHitIterator interface. */
namespace common {
/********************************************************************************/

/** \brief Abstract implementation of IHitIterator interface
 *
 * This class implements a few methods of the IHitIterator interface and is used
 * as a base class for complete implementations.
 *
 * In particular, AbstractHitIterator manages:
 *      - a list of IHitIterator instance for splitting process
 *      - informative methods (getInputHitsNumber(), getOutputHitsNumber()) according to the split scheme
 *      - default implementation of the update() method
 *
 * The class is still abstract; complete implementations have to tell how to effectively
 * iterate hits (ie. have to implement the iterate() method).
 */
class AbstractHitIterator : public IHitIterator
{
public:

    /** Constructor.
     */
    AbstractHitIterator ()
        : _inputHitsNumber(0), _outputHitsNumber(0),
          _maxHitsPerIteration (1000*1000),
          _totalTime(0) {}

    /** Destructor. */
    virtual ~AbstractHitIterator ()
    {
        for (size_t i=0; i<_splitIterators.size(); i++)  {  _splitIterators[i]->forget(); }
    }

    /** \copydoc IHitIterator::getInputHitsNumber */
    u_int64_t getInputHitsNumber  ();

    /** \copydoc IHitIterator::getOutputHitsNumber */
    u_int64_t getOutputHitsNumber ();

    /** \copydoc IHitIterator::update
     * This implementation just forwards the notification.
     */
    void update (dp::EventInfo* evt, dp::ISubject* subject)
    {
        /** We forward the event to potential clients. */
        if (this != subject)  {   notify (evt);  }
    }

    /** \copydoc IHitIterator::getProperties */
    dp::IProperties* getProperties ();

protected:

    /** Number of incoming hits. */
    u_int64_t _inputHitsNumber;

    /** Number of outcoming hits. */
    u_int64_t _outputHitsNumber;

    /** Set referenced split instances (ensure use/forget and observer managements).
     * Should be used to link split instances to the instance from which they have
     * been split.
     * \param[in] split : the split instances to be linked to the current instance.
     */
    void setSplitIterators (const std::vector<IHitIterator*>& split);

    /** Set of split IHitIterator instances linked to the current instance. */
    std::vector<IHitIterator*> _splitIterators;

    /** Threshold for controlling memory usage. */
    u_int32_t _maxHitsPerIteration;

    /** Statistics. */
    u_int32_t _totalTime;
};

/********************************************************************************/
}}} /* end of namespaces. */
/********************************************************************************/

#endif /* _ABSTRACT_HITITERATOR_HPP_ */