47 lines
1.2 KiB
C++
47 lines
1.2 KiB
C++
#ifndef TOPOLOGYRECORDER_H
|
|
#define TOPOLOGYRECORDER_H
|
|
#include <QObject>
|
|
#include <QVector>
|
|
#include <QHash>
|
|
#include <QString>
|
|
#include <QPair>
|
|
#include "BasicElementInfo.h"
|
|
#include "breaker.h"
|
|
#include "aclinesegment.h"
|
|
#include "nodetoterminal.h"
|
|
#include "terminal.h"
|
|
#include "powertransformer.h"
|
|
#include "substation.h"
|
|
#include "busbarsection.h"
|
|
#include "disconnector.h"
|
|
#include "cimexporter.h"
|
|
#include "element/branch.h"
|
|
#include "element/line.h"
|
|
#include "element/switch.h"
|
|
#include "element/transformer.h"
|
|
class TopologyRecorder:public QObject
|
|
{
|
|
Q_OBJECT
|
|
class Type
|
|
{
|
|
public:
|
|
enum EleType{AC=0,BREAKER,DISCONNECTOR,BS,TF};
|
|
};
|
|
|
|
public:
|
|
TopologyRecorder(const QHash<QString,BasicElementInfo *>& elementHT,const QVector<QString> &FDSet,QObject *parent=0);
|
|
~TopologyRecorder();
|
|
bool startWithNode(const QString& node);
|
|
void exportTo(const QString& path);
|
|
private:
|
|
NodeToTerminal nodeToTerminal;
|
|
const QHash<QString,BasicElementInfo *>& eleHT;
|
|
QHash<QString,char> reachedTerminal;
|
|
QVector<QString> tfs;
|
|
CIMExporter cimExporter;
|
|
QVector<QString> FDSet;
|
|
bool isEquipmentNeeded(const QString& substatinID);
|
|
};
|
|
|
|
#endif // TOPOLOGYRECORDER_H
|