Added extra functionality to Point class( an iterator ) and PersistenceDiagram( dimension property and __len__ func ).
persistence-diagram.h:
Added a new read-only dimension member and member function to access it.
With a new constructor that that takes in an int type to initialize dimension.
persistence-diagram.cpp:
Added new bp::init constructor. Takes in an integer type to initialize the dimension. Exposed the dimension property. Exposed the size property via a __len__ method.
__init__.py:
Added an iterator for Point objects. This iterates over the coords and then the data( if present ).
#ifndef __DIAGRAM_H__
#define __DIAGRAM_H__
#include <QtGui>
#include <QObject>
#include <QColor>
#include <map>
#include <utilities/types.h>
#include <topology/persistence-diagram.h>
typedef         PersistenceDiagram<>                PDiagram;
typedef         std::map<Dimension, PDiagram>       Diagrams;
class DgmPoint;
class DgmViewer: public QGraphicsView
{
    Q_OBJECT
    public:
        typedef             std::vector<DgmPoint*>          PointsVector;
                            DgmViewer(const PDiagram& dgm);
                            ~DgmViewer();
        void                addDgmPoints();
    private:
        PointsVector        points;
        QGraphicsScene      scene;
        RealType            min_x, min_y, max_x, max_y;
};
class DgmPoint: public PDPoint<>, public QGraphicsItem
{
    public:
        typedef             PDPoint<>                                       Parent;
                            DgmPoint(QGraphicsItem* parent = 0);
                            DgmPoint(const Parent& pt, qreal size, QGraphicsItem *parent = 0); 
                            DgmPoint(RealType b, RealType d, qreal size, QGraphicsItem *parent = 0); 
        
        void                paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = 0);
        QRectF                 boundingRect() const;
        
        qreal               getX() const                    { return Parent::x(); }
        qreal               getY() const                    { return Parent::y(); }
        int                 type() const                                    { return QGraphicsItem::UserType + 1; }
    private:
        // size of rectangle containing ellipses
        qreal                 ellipse_size;
};
#endif // __DIAGRAM_H__