PHengLEI-NCCR/API/Geometry/include/OversetInformation.h

337 lines
13 KiB
C++

//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
// PPPPP H H EEEEE N N GGGGG L EEEEE III +
// P P H H E NN N G L E I +
// PPPPP HHHHH EEEEE N N N G GG L EEEEE I +
// P H H E N N N G G L E I +
// P H H EEEEE N N GGGGG LLLLL EEEEE III +
//------------------------------------------------------------------------+
// Platform for Hybrid Engineering Simulation of Flows +
// China Aerodynamics Research and Development Center +
// (C) Copyright, Since 2010 +
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//! @file OversetInformation.h
//! @brief It define overset information reconstruction(unstructured grid).
//! @author He Xin, Chang Xinghua .
#pragma once
#include "Geo_SimpleGrid.h"
namespace PHSPACE
{
class Grid;
class DataContainer;
class Geo_OversetGrid;
class OversetCell;
class OversetInterplateCell;
class OversetDonorCell;
class OversetInterplateCellManager;
class OversetDonorCellManager;
class Data_ParamFieldSuite;
class OversetSwapManager
{
public:
OversetSwapManager ();
~OversetSwapManager();
protected:
OversetInterplateCellManager *oversetInterplateCellManager;
OversetDonorCellManager *oversetDonorCellManager;
public:
OversetInterplateCellManager * GetOversetInterplateCellManager() { return oversetInterplateCellManager; }
OversetDonorCellManager * GetOversetDonorCellManager() { return oversetDonorCellManager; }
void AddOversetInterplateCell(OversetInterplateCell *oversetInterplateCell);
void AddOversetDonorCell(OversetDonorCell *oversetDonorCell);
public:
void PostProcessReceivingOversetInformation();
void PostProcessSendingOversetInformation();
void EncodeOversetInformation(DataContainer *dataContainer);
void DecodeOversetInformation(DataContainer *dataContainer);
protected:
void EncodeOversetInterplateCellInformation(DataContainer *dataContainer);
void EncodeOversetDonorCellInformation(DataContainer *dataContainer);
void DecodeOversetInterplateCellInformation(DataContainer *dataContainer);
void DecodeOversetDonorCellInformation(DataContainer *dataContainer);
};
class OversetDataProxy
{
public:
OversetDataProxy();
~OversetDataProxy();
protected:
int sendReceiveFlag; //! 0: send ; 1: receive;
OversetSwapManager *oversetSwapManager;
public:
void Initialize(OversetSwapManager *oversetSwapManager, int sendReceiveFlag);
int GetNumberOfNeighbors();
int GetNumberOfCells();
int GetNumberOfCells(int neighborIndex);
int * GetCellIndexContainer(int neighborIndex);
int * GetCellStorageIndexMapping(int neighborIndex);
RDouble * GetInterCellCenterX(int neighborIndex);
RDouble * GetInterCellCenterY(int neighborIndex);
RDouble * GetInterCellCenterZ(int neighborIndex);
Data_ParamFieldSuite * GetDataStorage();
public:
int FindNeighborIndex(int zoneIndex);
PHVectorInt1D GetNeighborZoneIndexArray();
protected:
int FindNeighborIndex(PHVectorInt1D &neighborZoneIndexArray, int neighborZoneIndexForSearching);
};
class OversetInformationProxy
{
public:
OversetInformationProxy ();
~OversetInformationProxy();
protected:
Grid *grid;
OversetSwapManager *oversetSwapManager;
PHVector1D < OversetCell * > *oversetCellContainer;
OversetDataProxy *oversetDataProxyForSend;
OversetDataProxy *oversetDataProxyForReceive;
public:
int GetZoneIndex();
OversetSwapManager * GetOversetSwapManager() { return oversetSwapManager; }
PHVector1D < OversetCell * > * GetOversetCellContainer() { return oversetCellContainer; }
void SetOversetCellContainer(PHVector1D < OversetCell * > *oversetCellContainer) { this->oversetCellContainer = oversetCellContainer; }
PHVectorInt1D GetNeighborZoneIndexArray();
public:
void GenerateNeighborZoneIndexSet(set < int > &neighborZoneIndexSet);
void GetNeighborZoneIndexContainer(PHVectorInt1D &neighborZoneIndexContainer);
void FreeOversetCellContainer(PHVector1D < OversetCell * > *oversetCellContainer);
public:
OversetDonorCellManager * GetOversetDonorCellManager() { return oversetSwapManager->GetOversetDonorCellManager(); }
OversetInterplateCellManager * GetOversetInterplateCellManager() { return oversetSwapManager->GetOversetInterplateCellManager(); }
OversetDataProxy * GetOversetDataProxyForSend() { return oversetDataProxyForSend; }
OversetDataProxy * GetOversetDataProxyForReceive() { return oversetDataProxyForReceive; }
public:
void PostProcessReceivingOversetInformation();
void PostProcessSendingOversetInformation();
public:
void SetGrid(Grid *grid) { this->grid = grid; }
Grid * GetGrid() { return grid; }
void PostProcessOversetInformation();
void InitializeReceivingInformation(PHVector1D < OversetCell * > *oversetCellContainer);
public:
void GetCellIndexContainer(int donorZoneIndexIn, PHVectorInt1D &cellIndexContainer);
void GetDonorCellIndexContainer(int donorZoneIndexIn, PHVectorInt1D &donorCellIndexContainer,
PHVectorRDouble1D &interCellCenterX,
PHVectorRDouble1D &interCellCenterY,
PHVectorRDouble1D &interCellCenterZ);
public:
void EncodeOversetInformation(DataContainer *dataContainer);
void DecodeOversetInformation(DataContainer *dataContainer);
};
class ActionKey;
class OversetInformationProxy;
OversetInformationProxy * GetOversetInformationProxy(int iZone, int gridLevelIndex = 0);
class OversetTopologyManager
{
public:
OversetTopologyManager();
~OversetTopologyManager();
protected:
PHVectorInt2D oversetTopology;
PHVectorInt2D oversetTopologyForSend;
PHVectorInt2D oversetTopologyForReceive;
public:
PHVectorInt2D & GetOversetTopology();
PHVectorInt2D & GetOversetTopologyForSend();
PHVectorInt2D & GetOversetTopologyForReceive();
uint_t GetNumberOfOversetNeighbors(int zoneIndex);
int GetNeighborOversetZoneIndex(int zoneIndex, int ithOversetNeighbor);
public:
void InitializeOversetInterfaceTopology();
void InitializeOversetInterfaceTopologyServerCollectAndBcast();
};
OversetTopologyManager * GetOversetTopologyManager();
void InitializeOversetInterfaceTopology();
class OversetCell
{
public:
OversetCell();
~OversetCell();
protected:
int zoneIndex;
int cellIndex;
int donorZoneIndex;
int donorCellIndex;
public:
void SetZoneIndex (int zoneIndex ) { this->zoneIndex = zoneIndex ; }
void SetCellIndex (int cellIndex ) { this->cellIndex = cellIndex ; }
void SetDonorZoneIndex(int donorZoneIndex) { this->donorZoneIndex = donorZoneIndex; }
void SetDonorCellIndex(int donorCellIndex) { this->donorCellIndex = donorCellIndex; }
int GetZoneIndex() { return zoneIndex; }
int GetCellIndex() { return cellIndex; }
int GetDonorZoneIndex() { return donorZoneIndex; }
int GetDonorCellIndex() { return donorCellIndex; }
};
class OversetInterplateCell
{
public:
OversetInterplateCell();
~OversetInterplateCell();
protected:
int zoneIndex;
int donorZoneIndex;
PHVectorInt1D cellIndexContainer;
PHVectorInt1D storageIndexContainer;
Data_ParamFieldSuite *dataStorage;
public:
Data_ParamFieldSuite * GetDataStorage() { return dataStorage; }
void SetZoneIndex (int zoneIndex ) { this->zoneIndex = zoneIndex; }
void SetDonorZoneIndex(int donorZoneIndex) { this->donorZoneIndex = donorZoneIndex; }
int GetZoneIndex () { return zoneIndex; }
int GetDonorZoneIndex() { return donorZoneIndex; }
PHVectorInt1D & GetCellIndexContainer() { return cellIndexContainer; }
int GetNumberOfOversetInterplateCells() { return static_cast<int>(cellIndexContainer.size()); }
PHVectorInt1D & GetStorageIndexContainer() { return storageIndexContainer; }
public:
void EncodeOversetInterplateCellInformation(DataContainer *dataContainer);
void DecodeOversetInterplateCellInformation(DataContainer *dataContainer);
};
class OversetDonorCell
{
public:
OversetDonorCell ();
~OversetDonorCell();
protected:
int zoneIndex;
int interplateZoneIndex;
PHVectorInt1D donorCellIndexContainer;
PHVectorInt1D storageIndexContainer;
Data_ParamFieldSuite *dataStorage;
PHVectorRDouble1D interCellCenterX;
PHVectorRDouble1D interCellCenterY;
PHVectorRDouble1D interCellCenterZ;
public:
Data_ParamFieldSuite * GetDataStorage() { return dataStorage; }
void SetZoneIndex(int zoneIndex) { this->zoneIndex = zoneIndex; }
int GetZoneIndex() { return zoneIndex; }
void SetInterplateZoneIndex(int interplateZoneIndex) { this->interplateZoneIndex = interplateZoneIndex; }
int GetInterplateZoneIndex() { return interplateZoneIndex; }
PHVectorInt1D & GetDonorCellIndexContainer() { return donorCellIndexContainer; }
PHVectorRDouble1D & GetInterCellCenterX() { return interCellCenterX; }
PHVectorRDouble1D & GetInterCellCenterY() { return interCellCenterY; }
PHVectorRDouble1D & GetInterCellCenterZ() { return interCellCenterZ; }
void SetDonorCellIndexContainer(PHVectorInt1D & donorCellIndexContainerIn) { this->donorCellIndexContainer = donorCellIndexContainerIn; }
void SetInterCellCenterX (PHVectorRDouble1D & interCellCenterXIn ) { this->interCellCenterX = interCellCenterXIn; }
void SetInterCellCenterY (PHVectorRDouble1D & interCellCenterYIn ) { this->interCellCenterY = interCellCenterYIn; }
void SetInterCellCenterZ (PHVectorRDouble1D & interCellCenterZIn ) { this->interCellCenterZ = interCellCenterZIn; }
int GetNumberOfOversetDonorCells() { return static_cast<int>(donorCellIndexContainer.size()); }
PHVectorInt1D & GetStorageIndexContainer() { return storageIndexContainer; }
public:
void EncodeOversetDonorCellInformation(DataContainer *dataContainer);
void DecodeOversetDonorCellInformation(DataContainer *dataContainer);
};
class OversetInterplateCellManager
{
public:
OversetInterplateCellManager ();
~OversetInterplateCellManager();
protected:
PHVector1D < OversetInterplateCell * > oversetInterplateCellContainer;
int totalNumberOfOversetInterplateCells;
Data_ParamFieldSuite *dataStorage;
public:
PHVector1D < OversetInterplateCell * > & GetOversetInterplateCellContainer() { return oversetInterplateCellContainer; }
int GetNumberOfNeighbors() { return static_cast<int>(oversetInterplateCellContainer.size()); }
int GetTotalNumberOfOversetInterplateCells() { return totalNumberOfOversetInterplateCells; }
void SetTotalNumberOfOversetInterplateCells(int totalNumberOfOversetInterplateCells) { this->totalNumberOfOversetInterplateCells = totalNumberOfOversetInterplateCells; }
int GetNumberOfOversetInterplateCells(int iNeighbor);
int * GetOversetInterplateCell(int iNeighbor);
int * GetInterplateCellStorageIndex(int iNeighbor);
Data_ParamFieldSuite * GetDataStorage() { return dataStorage; }
PHVectorInt1D GetNeighborDonorZoneIndexArray();
public:
void PostProcessReceivingOversetInformation();
void EncodeOversetInterplateCellInformation(DataContainer *dataContainer);
void DecodeOversetInterplateCellInformation(DataContainer *dataContainer);
public:
void AddOversetInterplateCell(OversetInterplateCell *oversetInterplateCell);
};
class OversetDonorCellManager
{
public:
OversetDonorCellManager();
~OversetDonorCellManager();
protected:
PHVector1D < OversetDonorCell * > oversetDonorCellContainer;
int totalNumberOfOversetDonorCells;
Data_ParamFieldSuite *dataStorage;
public:
PHVector1D < OversetDonorCell * > & GetOversetDonorCellContainer() { return oversetDonorCellContainer; }
int GetNumberOfNeighbors() { return static_cast<int>(oversetDonorCellContainer.size()); }
int GetTotalNumberOfOversetDonorCells() { return totalNumberOfOversetDonorCells; }
void SetTotalNumberOfOversetDonorCells(int totalNumberOfOversetDonorCells) { this->totalNumberOfOversetDonorCells = totalNumberOfOversetDonorCells; }
int GetNumberOfOversetDonorCells(int iNeighbor);
int * GetOversetDonorCell(int iNeighbor);
int * GetDonorCellStorageIndex(int iNeighbor);
RDouble * GetInterCellCenterX(int iNeighbor);
RDouble * GetInterCellCenterY(int iNeighbor);
RDouble * GetInterCellCenterZ(int iNeighbor);
Data_ParamFieldSuite * GetDataStorage() { return dataStorage; }
PHVectorInt1D GetNeighborInterplateZoneIndexArray();
public:
void PostProcessSendingOversetInformation();
void EncodeOversetDonorCellInformation(DataContainer *dataContainer);
void DecodeOversetDonorCellInformation(DataContainer *dataContainer);
public:
void AddOversetDonorCell(OversetDonorCell *oversetDonorCell);
};
uint_t GetNumberOfOversetNeighbors(int zoneIndex);
int GetNeighborOversetZoneIndex(int zoneIndex, int iNeighbor);
}