82 bool ExchangeHTGMetadata();
83 void CollectLocalTreeIds();
84 void BuildTargetPartMap();
85 void ExchangeHyperTreeMetaData(
vtkBitArray* descriptorSendBuffer,
86 std::vector<int>& descriptorSizesReceivedBuffer, std::vector<int>& treeSizesSendBuffer,
87 std::vector<int>& maskSizesSendBuffer, std::vector<int>& treeSizesReceivedBuffer,
88 std::vector<int>& maskSizesReceivedBuffer, std::vector<int>& descriptorsByteOffsets);
89 void BuildOutputTrees(
vtkBitArray* descriptorSendBuffer,
90 std::vector<int>& descriptorSizesReceivedBuffer, std::vector<int>& descriptorsByteOffsets);
92 std::vector<int>& maskSizesSendBuffer, std::vector<int>& maskSizesReceivedBuffer);
93 void CollectCellArraySizes(std::vector<int>& treeSizesSendBuffer,
94 std::vector<int>& treeSizesReceivedBuffer, std::vector<int>& cellsSentPerPartOffset,
95 std::vector<int>& cellsReceivedPerPartOffset, std::vector<int>& nbCellDataSentPerPart,
96 std::vector<int>& nbCellDataReceivedPerPart);
97 void ExchangeCellArray(
int arrayId, std::vector<int>& cellsSentPerPartOffset,
98 std::vector<int>& cellsReceivedPerPartOffset, std::vector<int>& nbCellDataSentPerPart,
99 std::vector<int>& nbCellDataReceivedPerPart);
104 bool HasMask =
false;
105 int NumPartitions = 0;
106 int CurrentPiece = 0;
108 std::vector<int> TreeTargetPartId;
109 std::vector<int> TreeIdsReceivedBuffer;
110 std::vector<int> NbTreesReceivedPerPart;
111 std::vector<int> NbTreesSentPerPart;
112 std::vector<int> NbDescriptorsBytesPerPart;
114 std::vector<vtkIdType> LocalTreeIds;
115 std::vector<std::vector<vtkIdType>> TreesToSend;
int RequestData(vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector) override
Override RequestData, to make sure every HTG piece can be processed, hence avoiding that one rank wai...