diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/CMakeLists.txt b/packages/seacas/libraries/ioss/src/visualization/catalyst/CMakeLists.txt index a5c1c68784..98566e2012 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/CMakeLists.txt +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/CMakeLists.txt @@ -24,7 +24,6 @@ SET(PARAVIEW_PYTHON_LIBRARY_RPATH_DIRECTORY CACHE FILEPATH "Path to the directory containing the Python library used by ParaView.") IF(PARAVIEW_PYTHON_LIBRARY_RPATH_DIRECTORY) - CMAKE_POLICY(SET CMP0015 OLD) LINK_DIRECTORIES(${PARAVIEW_PYTHON_LIBRARY_RPATH_DIRECTORY}) ENDIF() @@ -37,9 +36,9 @@ IF("${isSystemDir}" STREQUAL "-1") SET(CMAKE_INSTALL_RPATH "${CMAKE_INSTALL_PREFIX}/lib") ENDIF() -TRIBITS_INCLUDE_DIRECTORIES("manager") -TRIBITS_INCLUDE_DIRECTORIES("parser") -TRIBITS_INCLUDE_DIRECTORIES("../../") +INCLUDE_DIRECTORIES("manager") +INCLUDE_DIRECTORIES("parser") +INCLUDE_DIRECTORIES("../../") ADD_SUBDIRECTORY(manager) ADD_SUBDIRECTORY(parser) @@ -47,6 +46,7 @@ ADD_LIBRARY(${PVCSA_LIBRARY_NAME} SHARED manager/CatalystManager.cxx manager/CatalystMeshWriter.cxx exodus/CatalystExodusMesh.cxx cgns/CatalystCGNSMesh.cxx) +TARGET_COMPILE_DEFINITIONS(${PVCSA_LIBRARY_NAME} PRIVATE __CATALYST_PLUGIN_BUILD) TARGET_INCLUDE_DIRECTORIES(${PVCSA_LIBRARY_NAME} PUBLIC @@ -69,16 +69,11 @@ IF(BUILD_IOSS_2_CATALYST_APPLICATION) SET(CMAKE_PREFIX_PATH ${SEACAS_INSTALL_DIR} ${CMAKE_PREFIX_PATH}) FIND_PACKAGE(SEACAS REQUIRED) - FIND_PACKAGE(HDF5 REQUIRED) IF(SEACAS_FOUND) - IF("CGNS" IN_LIST SEACAS_TPL_LIST) - ADD_SUBDIRECTORY(ioss2catalyst) - ENABLE_TESTING() - ADD_SUBDIRECTORY(test) - ELSE() - MESSAGE(FATAL_ERROR "Must build SEACAS with CGNS TPL enabled.") - ENDIF() + ADD_SUBDIRECTORY(ioss2catalyst) + ENABLE_TESTING() + ADD_SUBDIRECTORY(test) ENDIF() ENDIF() diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/ParaViewCatalystCGNSAdapter.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/ParaViewCatalystCGNSAdapter.cxx deleted file mode 100644 index 70fde9f0c1..0000000000 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/ParaViewCatalystCGNSAdapter.cxx +++ /dev/null @@ -1,329 +0,0 @@ -// Copyright(C) 1999-2021 National Technology & Engineering Solutions -// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with -// NTESS, the U.S. Government retains certain rights in this software. -// -// See packages/seacas/LICENSE for details - -#include "include/ParaViewCatalystCGNSAdapter.h" -#include "vtkCPDataDescription.h" -#include "vtkCPInputDataDescription.h" -#include "vtkCPProcessor.h" -#include "vtkCPPythonScriptPipeline.h" -#include "include/vtkCGNSMultiBlockDataSet.h" - -#include -#include -#include -#include -#include - -class ParaViewCatalystCGNSAdapterImplementation -{ -public: - static ParaViewCatalystCGNSAdapterImplementation &getInstance() - { - static ParaViewCatalystCGNSAdapterImplementation instance; - return instance; - } - - void CleanupCatalyst() - { - if (this->dd) { - this->dd->Delete(); - this->dd = 0; - } - - if (this->pl) { - this->pl->Delete(); - this->pl = 0; - } - - if (this->coProcessor) { - this->coProcessor->Finalize(); - this->coProcessor->Delete(); - this->coProcessor = 0; - } - } - - void CreateNewPipeline(const char *catalyst_python_filename, - const char *catalyst_sierra_block_json) - { - this->dd = vtkCPDataDescription::New(); - this->pl = vtkCPPythonScriptPipeline::New(); - - vtkCGNSMultiBlockDataSet *cgnsmbds = vtkCGNSMultiBlockDataSet::New(); - dd->AddInput("input"); - dd->GetInputDescriptionByName("input")->SetGrid(cgnsmbds); - cgnsmbds->Delete(); - - if (this->pl->Initialize(catalyst_python_filename) == 0) { - std::cerr << "Unable to initialize ParaView Catalyst with python script " - << catalyst_python_filename << std::endl; - std::cerr << "ParaView Catalyst CoProcessing will not be available." << std::endl; - this->pl->Delete(); - this->pl = 0; - this->dd->Delete(); - this->dd = 0; - this->coProcessor->Delete(); - this->coProcessor = 0; - } - } - - void SetTimeData(double currentTime, - int timeStep) - { - if(this->dd) { - this->dd->SetTimeData(currentTime, timeStep); - - vtkMultiProcessController* controller = vtkMultiProcessController::GetGlobalController(); - int myrank = controller->GetLocalProcessId(); - - vtkCGNSMultiBlockDataSet *cgnsmbds = - vtkCGNSMultiBlockDataSet::SafeDownCast(dd->GetInputDescriptionByName("input")->GetGrid()); - - vtkMultiBlockDataSet *bases = vtkMultiBlockDataSet::SafeDownCast(cgnsmbds->GetBlock(0)); - - if(!bases) - std::cout << "bases is NULL\n"; - - std::cout << "number of bases = " << bases->GetNumberOfBlocks() << "\n"; - - vtkMultiBlockDataSet *base = vtkMultiBlockDataSet::SafeDownCast(bases->GetBlock(0)); - - if(!base) - std::cout << "base is NULL\n"; - - std::cout << "number of base = " << base->GetNumberOfBlocks() << "\n"; - - vtkMultiBlockDataSet *zones = vtkMultiBlockDataSet::SafeDownCast(base->GetBlock(0)); - - if(!zones) - std::cout << "zones is NULL\n"; - - std::cout << "number of zones = " << zones->GetNumberOfBlocks() << "\n"; - - vtkStructuredGrid *sg = vtkStructuredGrid::SafeDownCast(zones->GetBlock(0)); - - if(!sg) - std::cout << "sg is NULL\n"; - //it's okay for sg to be NULL. It means there was no data on - //this process on this block - -/* - //pts is not used anywhere below, not sure why there was code getting it - //(which caused core dump when sg was NULL) - //vtkPoints* pts = sg->GetPoints(); - - vtkXMLStructuredGridWriter* writer = vtkXMLStructuredGridWriter::New(); - writer->SetInputData(sg); - std::ostringstream convert; - convert << timeStep; - std::ostringstream convert_rank; - convert_rank << myrank; - writer->SetFileName(std::string("test_" + convert.str() - + "_" + convert_rank.str() +".vts").c_str()); - writer->Write(); - writer->Delete(); -*/ - - // vtkCGNSMultiBlockDataSet *cgnsmbds = - // vtkCGNSMultiBlockDataSet::SafeDownCast(dd->GetInputDescriptionByName("input")->GetGrid()); -/* vtkXMLPMultiBlockDataWriter* writer = vtkXMLPMultiBlockDataWriter::New(); - writer->SetInputData(cgnsmbds->GetBlock(0)); - std::ostringstream oss; - oss << "." << writer->GetDefaultFileExtension(); - std::ostringstream convert; - convert << timeStep; - writer->SetFileName(std::string("test_" + convert.str() + oss.str()).c_str()); - if(myrank == 0) { - writer->SetWriteMetaFile(1); - } - writer->Update(); - writer->Delete(); -*/ - } - } - - void PerformCoProcessing() - { - vtkCGNSMultiBlockDataSet *cgnsmbds = - vtkCGNSMultiBlockDataSet::SafeDownCast(dd->GetInputDescriptionByName("input")->GetGrid()); - - vtkMultiProcessController* controller = vtkMultiProcessController::GetGlobalController(); - int myrank = controller->GetLocalProcessId(); - vtkXMLPMultiBlockDataWriter* writer = vtkXMLPMultiBlockDataWriter::New(); - writer->SetInputData(cgnsmbds->GetBlock(0)); - std::ostringstream oss; - oss << "." << writer->GetDefaultFileExtension(); - std::ostringstream convert; - convert << 0; - writer->SetFileName(std::string("test_" + convert.str() + oss.str()).c_str()); - if(myrank == 0) { - writer->SetWriteMetaFile(1); - } - writer->Update(); - writer->Delete(); - - } - - void CreateBase(int base_id, - const std::string& base_name) - { - if(this->dd) { - vtkCGNSMultiBlockDataSet *cgnsmbds = - vtkCGNSMultiBlockDataSet::SafeDownCast(dd->GetInputDescriptionByName("input")->GetGrid()); - cgnsmbds->CreateBase(base_id, base_name); - } - } - - void AddStructuredZoneData(int base_id, - int zone_id, - const std::string& zone_name, - const std::string& data_name, - int ni, - int nj, - int nk, - int comp_count, - bool is_cell_field, - char field_suffix_separator, - double* data, - int size) - { - if(this->dd) { - vtkCGNSMultiBlockDataSet *cgnsmbds = - vtkCGNSMultiBlockDataSet::SafeDownCast(dd->GetInputDescriptionByName("input")->GetGrid()); - cgnsmbds->AddStructuredZoneData(base_id, - zone_id, - zone_name, - data_name, - ni, - nj, - nk, - comp_count, - is_cell_field, - field_suffix_separator, - data, - size); - } - } - - int parseFile(const std::string &filepath, - CatalystParserInterface::parse_info &pinfo) - { - } - - int parseString(const std::string &s, CatalystParserInterface::parse_info &pinfo) - { - } - -private: - ParaViewCatalystCGNSAdapterImplementation() - { - this->coProcessor = vtkCPProcessor::New(); - this->coProcessor->Initialize(); - } - - ~ParaViewCatalystCGNSAdapterImplementation() - { - } - - ParaViewCatalystCGNSAdapterImplementation(ParaViewCatalystCGNSAdapterImplementation const &); - void operator=(ParaViewCatalystCGNSAdapterImplementation const &); - - vtkCPProcessor *coProcessor; - vtkCPPythonScriptPipeline *pl; - vtkCPDataDescription *dd; -}; - -void ParaViewCatalystCGNSAdapter::CleanupCatalyst() -{ - ParaViewCatalystCGNSAdapterImplementation &pcsai = - ParaViewCatalystCGNSAdapterImplementation::getInstance(); - - pcsai.CleanupCatalyst(); -} - -void ParaViewCatalystCGNSAdapter::CreateNewPipeline(const char *catalyst_python_filename, - const char *catalyst_sierra_block_json) -{ - ParaViewCatalystCGNSAdapterImplementation &pcsai = - ParaViewCatalystCGNSAdapterImplementation::getInstance(); - - pcsai.CreateNewPipeline(catalyst_python_filename, catalyst_sierra_block_json); -} - -void ParaViewCatalystCGNSAdapter::PerformCoProcessing() -{ - ParaViewCatalystCGNSAdapterImplementation &pcsai = - ParaViewCatalystCGNSAdapterImplementation::getInstance(); - - pcsai.PerformCoProcessing(); -} - -void ParaViewCatalystCGNSAdapter::CreateBase(int base_id, - const std::string& base_name) -{ - ParaViewCatalystCGNSAdapterImplementation &pcsai = - ParaViewCatalystCGNSAdapterImplementation::getInstance(); - - pcsai.CreateBase(base_id, - base_name); -} - -void ParaViewCatalystCGNSAdapter::AddStructuredZoneData(int base_id, - int zone_id, - const std::string& zone_name, - const std::string& data_name, - int ni, - int nj, - int nk, - int comp_count, - bool is_cell_field, - char field_suffix_separator, - double* data, - int size) -{ - ParaViewCatalystCGNSAdapterImplementation &pcsai = - ParaViewCatalystCGNSAdapterImplementation::getInstance(); - - pcsai.AddStructuredZoneData(base_id, - zone_id, - zone_name, - data_name, - ni, - nj, - nk, - comp_count, - is_cell_field, - field_suffix_separator, - data, - size); -} - -void ParaViewCatalystCGNSAdapter::SetTimeData(double currentTime, int timeStep) -{ - ParaViewCatalystCGNSAdapterImplementation &pcsai = - ParaViewCatalystCGNSAdapterImplementation::getInstance(); - - pcsai.SetTimeData(currentTime, timeStep); -} - -int ParaViewCatalystCGNSAdapter::parseFile(const std::string &filepath, - CatalystParserInterface::parse_info &pinfo) -{ - return CatalystParserInterface::parseFile(filepath, pinfo); -} - -int ParaViewCatalystCGNSAdapter::parseString(const std::string &s, - CatalystParserInterface::parse_info &pinfo) -{ - return CatalystParserInterface::parseString(s, pinfo); -} - -extern "C" { -ParaViewCatalystCGNSAdapterBase *ParaViewCatalystCGNSAdapterCreateInstance() -{ - ParaViewCatalystCGNSAdapterBase *t(new ParaViewCatalystCGNSAdapter()); - return t; -} -} diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/ParaViewCatalystIossAdapter.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/ParaViewCatalystIossAdapter.cxx deleted file mode 100644 index 4604cdc6b7..0000000000 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/ParaViewCatalystIossAdapter.cxx +++ /dev/null @@ -1,691 +0,0 @@ -// Copyright(C) 1999-2021 National Technology & Engineering Solutions -// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with -// NTESS, the U.S. Government retains certain rights in this software. -// -// See packages/seacas/LICENSE for details - -#include "include/ParaViewCatalystIossAdapter.h" -#include "vtkCPDataDescription.h" -#include "vtkCPInputDataDescription.h" -#include "vtkCPProcessor.h" -#include "vtkCPPythonScriptPipeline.h" -#include "include/vtkExodusIIMultiBlockDataSet.h" - -#include "vtkDoubleArray.h" -#include "vtkFieldData.h" -#include "vtkIntArray.h" -#include "vtkMPIController.h" -#include "vtkProcessModule.h" -#include "vtkStringArray.h" -#include "vtkVariant.h" -#include -#include -#include -#include - -typedef std::pair PipelineDataDescPair; -typedef std::pair TimerPair; -typedef std::pair LoggingPair; - -class ParaViewCatalystIossAdapterImplementation -{ -public: - static ParaViewCatalystIossAdapterImplementation &getInstance() - { - static ParaViewCatalystIossAdapterImplementation instance; - return instance; - } - - void CleanupCatalyst() - { - if (this->coProcessor) { - this->coProcessor->Finalize(); - this->coProcessor->Delete(); - this->coProcessor = 0; - } - } - - void DeletePipeline(const char *results_output_filename) - { - if (this->pipelines.find(results_output_filename) != this->pipelines.end()) { - this->pipelines[results_output_filename].first->Delete(); - this->pipelines[results_output_filename].second->Delete(); - this->pipelines.erase(results_output_filename); - } - - if (this->logging.find(results_output_filename) != this->logging.end()) { - this->logging[results_output_filename].second->Delete(); - this->logging.erase(results_output_filename); - } - } - - void CreateNewPipeline(const char *catalyst_python_filename, - const char *catalyst_sierra_block_json, - const char *catalyst_sierra_separator_character, - const char *catalyst_sierra_input_deck_name, int UnderscoreVectors, - int ApplyDisplacements, const char *restart_tag, int enable_logging, - int debug_level, const char *results_output_filename, - const char * catalyst_output_directory, - std::vector &catalyst_sierra_data) - { - if (enable_logging) { - TimerPair tp = std::make_pair(clock(), clock()); - vtkDoubleArray *da = vtkDoubleArray::New(); - da->SetNumberOfComponents(3); - LoggingPair lp = std::make_pair(tp, da); - this->logging[results_output_filename] = lp; - - vtkProcessModule *pm = vtkProcessModule::GetProcessModule(); - vtkMPIController *mpic = vtkMPIController::SafeDownCast(pm->GetGlobalController()); - std::string s(results_output_filename); - if (mpic && mpic->GetNumberOfProcesses() > 1) { - if (mpic->GetLocalProcessId() == 0) { - ofstream logfile; - logfile.open((s + ".catalyst.log").c_str(), ios::out | ios::trunc); - logfile << "# ELAPSED TIME (S)" - << ",PROC MEM USED - MIN (KiB)" - << ",PROC MEM USED - MAX (KiB)" - << ",PROC MEM USED - AVG (KiB)" - << ",HOST MEM USED - MIN (KiB)" - << ",HOST MEM USED - MAX (KiB)" - << ",HOST MEM USED - AVG (KiB)" - << ",TIME SINCE LAST LOG - MIN (S)" - << ",TIME SINCE LAST LOG - MAX (S)" - << ",TIME SINCE LAST LOG - AVG (S)" - << "\n"; - logfile.close(); - } - } - else { - ofstream logfile; - logfile.open((s + ".catalyst.log").c_str(), ios::out | ios::trunc); - logfile << "# ELAPSED TIME (S)" - << ",PROC MEM USED (KiB)" - << ",HOST MEM USED (KiB)" - << ",TIME SINCE LAST LOG (S)" - << "\n"; - logfile.close(); - } - } - - if (this->pipelines.find(results_output_filename) == this->pipelines.end()) { - vtkCPDataDescription * dd = vtkCPDataDescription::New(); - vtkCPPythonScriptPipeline *pl = vtkCPPythonScriptPipeline::New(); - - vtkExodusIIMultiBlockDataSet *mbds = vtkExodusIIMultiBlockDataSet::New(); - mbds->SetUnderscoreVectors(UnderscoreVectors); - mbds->SetApplyDisplacements(ApplyDisplacements); - dd->AddInput("input"); - dd->GetInputDescriptionByName("input")->SetGrid(mbds); - mbds->Delete(); - PipelineDataDescPair pddp = std::make_pair(pl, dd); - this->pipelines[results_output_filename] = pddp; - } - - if (catalyst_sierra_block_json) { - vtkFieldData * fd = vtkFieldData::New(); - vtkStringArray *sa = vtkStringArray::New(); - sa->SetName("catalyst_sierra_data"); - vtkIntArray *ec = vtkIntArray::New(); - ec->SetName("catalyst_sierra_error_codes"); - vtkStringArray *em = vtkStringArray::New(); - em->SetName("catalyst_sierra_error_messages"); - sa->InsertNextValue(catalyst_sierra_block_json); - sa->InsertNextValue(catalyst_sierra_separator_character); - sa->InsertNextValue(catalyst_sierra_input_deck_name); - sa->InsertNextValue(restart_tag); - if (enable_logging) { - sa->InsertNextValue("True"); - } - else { - sa->InsertNextValue(""); - } - std::stringstream ss; - ss << debug_level; - sa->InsertNextValue(ss.str().c_str()); - ss.clear(); - sa->InsertNextValue(results_output_filename); - sa->InsertNextValue(catalyst_output_directory); - - for (int i = 0; i < catalyst_sierra_data.size(); i++) - sa->InsertNextValue(catalyst_sierra_data[i]); - - fd->AddArray(sa); - fd->AddArray(ec); - fd->AddArray(em); - this->pipelines[results_output_filename].second->SetUserData(fd); - fd->Delete(); - sa->Delete(); - ec->Delete(); - em->Delete(); - } - - if (this->pipelines[results_output_filename].first->Initialize(catalyst_python_filename) == 0) { - std::cerr << "Unable to initialize ParaView Catalyst with python script " - << catalyst_python_filename << std::endl; - std::cerr << "ParaView Catalyst CoProcessing will not be available." << std::endl; - this->coProcessor->Delete(); - this->coProcessor = 0; - } - } - - void SetTimeData(double currentTime, int timeStep, const char *results_output_filename) - { - if (!this->coProcessor) - return; - - if (this->pipelines.find(results_output_filename) != this->pipelines.end()) { - this->pipelines[results_output_filename].second->SetTimeData(currentTime, timeStep); - } - } - - void CoProcess(const char *results_output_filename, std::vector &error_and_warning_codes, - std::vector &error_and_warning_messages) - { - if (!this->coProcessor) - return; - - if (this->pipelines.find(results_output_filename) != this->pipelines.end()) { - error_and_warning_codes.clear(); - error_and_warning_messages.clear(); - - vtkCPPythonScriptPipeline *pl = this->pipelines[results_output_filename].first; - - vtkCPDataDescription * dd = this->pipelines[results_output_filename].second; - vtkExodusIIMultiBlockDataSet *mbds = vtkExodusIIMultiBlockDataSet::SafeDownCast( - dd->GetInputDescriptionByName("input")->GetGrid()); - mbds->Register(0); - pl->Register(0); - vtkMultiBlockDataSet *mb = vtkMultiBlockDataSet::New(); - mb->ShallowCopy(mbds); - dd->GetInputDescriptionByName("input")->SetGrid(mb); - this->coProcessor->AddPipeline(pl); - - this->coProcessor->CoProcess(dd); - - vtkFieldData *fd = this->pipelines[results_output_filename].second->GetUserData(); - vtkIntArray * ec = - vtkIntArray::SafeDownCast(fd->GetAbstractArray("catalyst_sierra_error_codes")); - vtkStringArray *em = - vtkStringArray::SafeDownCast(fd->GetAbstractArray("catalyst_sierra_error_messages")); - - if (ec && em && ec->GetNumberOfTuples() > 0 && em->GetNumberOfTuples() > 0 && - ec->GetNumberOfTuples() == em->GetNumberOfTuples()) { - for (int i = 0; i < ec->GetNumberOfTuples(); i++) { - error_and_warning_codes.push_back(ec->GetValue(i)); - error_and_warning_messages.push_back(em->GetValue(i)); - } - fd->RemoveArray("catalyst_sierra_error_codes"); - fd->RemoveArray("catalyst_sierra_error_messages"); - vtkIntArray *ec = vtkIntArray::New(); - ec->SetName("catalyst_sierra_error_codes"); - vtkStringArray *em = vtkStringArray::New(); - em->SetName("catalyst_sierra_error_messages"); - fd->AddArray(ec); - fd->AddArray(em); - ec->Delete(); - em->Delete(); - } - - this->coProcessor->RemoveAllPipelines(); - dd->GetInputDescriptionByName("input")->SetGrid(mbds); - mbds->Delete(); - pl->Delete(); - mb->Delete(); - } - } - - vtkExodusIIMultiBlockDataSet *GetMultiBlockDataSet(const char *results_output_filename) - { - if (this->pipelines.find(results_output_filename) != this->pipelines.end()) { - vtkCPDataDescription *dd = this->pipelines[results_output_filename].second; - return (vtkExodusIIMultiBlockDataSet::SafeDownCast( - dd->GetInputDescriptionByName("input")->GetGrid())); - } - else - return 0; - } - - void logMemoryUsageAndTakeTimerReading(const char *results_output_filename) - { - if (this->logging.find(results_output_filename) != this->logging.end()) { - vtksys::SystemInformation sysInfo; - vtkProcessModule * pm = vtkProcessModule::GetProcessModule(); - vtkMPIController * mpic = vtkMPIController::SafeDownCast(pm->GetGlobalController()); - double measurements[3]; - measurements[0] = sysInfo.GetProcMemoryUsed() * (1.0 / 1024.0); // Store in MB - measurements[1] = sysInfo.GetHostMemoryUsed() * (1.0 / 1024.0); - clock_t last_time = this->logging[results_output_filename].first.second; - measurements[2] = double(clock() - last_time) / (double)CLOCKS_PER_SEC; - this->logging[results_output_filename].first.second = clock(); - this->logging[results_output_filename].second->InsertNextTuple(measurements); - } - } - - void WriteToLogFile(const char *results_output_filename) - { - if (this->logging.find(results_output_filename) != this->logging.end()) { - vtkProcessModule *pm = vtkProcessModule::GetProcessModule(); - vtkMPIController *mpic = vtkMPIController::SafeDownCast(pm->GetGlobalController()); - vtkDoubleArray * logData = this->logging[results_output_filename].second; - std::string s(results_output_filename); - clock_t begin_time = this->logging[results_output_filename].first.first; - if (mpic && mpic->GetNumberOfProcesses() > 1) { - vtkDoubleArray *recvBufferMin = vtkDoubleArray::New(); - vtkDoubleArray *recvBufferMax = vtkDoubleArray::New(); - vtkDoubleArray *recvBufferSum = vtkDoubleArray::New(); - if (mpic->GetLocalProcessId() == 0) { - recvBufferMin->SetNumberOfComponents(3); - recvBufferMin->SetNumberOfTuples(logData->GetNumberOfTuples()); - - recvBufferMax->SetNumberOfComponents(3); - recvBufferMax->SetNumberOfTuples(logData->GetNumberOfTuples()); - - recvBufferSum->SetNumberOfComponents(3); - recvBufferSum->SetNumberOfTuples(logData->GetNumberOfTuples()); - } - - mpic->Reduce(logData, recvBufferMin, vtkCommunicator::MIN_OP, 0); - mpic->Reduce(logData, recvBufferMax, vtkCommunicator::MAX_OP, 0); - mpic->Reduce(logData, recvBufferSum, vtkCommunicator::SUM_OP, 0); - - if (mpic->GetLocalProcessId() == 0) { - ofstream logfile; - logfile.open((s + ".catalyst.log").c_str(), ios::out | ios::app); - for (int i = 0; i < logData->GetNumberOfTuples(); i++) { - double min[3]; - double max[3]; - double sum[3]; - recvBufferMin->GetTuple(i, min); - recvBufferMax->GetTuple(i, max); - recvBufferSum->GetTuple(i, sum); - logfile << double(clock() - begin_time) / (double)CLOCKS_PER_SEC << "," << min[0] << "," - << max[0] << "," << sum[0] / (double)mpic->GetNumberOfProcesses() << "," - << min[1] << "," << max[1] << "," - << sum[1] / (double)mpic->GetNumberOfProcesses() << "," << min[2] << "," - << max[2] << "," << sum[2] / (double)mpic->GetNumberOfProcesses() << "\n"; - } - logfile.close(); - } - recvBufferMin->Delete(); - recvBufferMax->Delete(); - recvBufferSum->Delete(); - } - else { - ofstream logfile; - logfile.open((s + ".catalyst.log").c_str(), ios::out | ios::app); - for (int i = 0; i < logData->GetNumberOfTuples(); i++) { - double data[3]; - logData->GetTuple(i, data); - logfile << double(clock() - begin_time) / CLOCKS_PER_SEC << "," << data[0] << "," - << data[1] << "," << data[2] << "\n"; - } - logfile.close(); - } - logData->SetNumberOfTuples(0); - } - } - -private: - ParaViewCatalystIossAdapterImplementation() - { - this->coProcessor = vtkCPProcessor::New(); - this->coProcessor->Initialize(); - } - - ~ParaViewCatalystIossAdapterImplementation() - { - for (std::map::iterator it = this->pipelines.begin(); - it != this->pipelines.end(); it++) { - this->DeletePipeline(it->first.c_str()); - } - } - - ParaViewCatalystIossAdapterImplementation(ParaViewCatalystIossAdapterImplementation const &); - void operator=(ParaViewCatalystIossAdapterImplementation const &); - - vtkCPProcessor * coProcessor; - std::map pipelines; - std::map logging; -}; - -void ParaViewCatalystIossAdapter::DeletePipeline(const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - - pcsai.DeletePipeline(results_output_filename); -} - -void ParaViewCatalystIossAdapter::CleanupCatalyst() -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - - pcsai.CleanupCatalyst(); -} - -void ParaViewCatalystIossAdapter::CreateNewPipeline( - const char *catalyst_python_filename, const char *catalyst_sierra_block_json, - const char *catalyst_sierra_separator_character, const char *catalyst_sierra_input_deck_name, - int UnderscoreVectors, int ApplyDisplacements, const char *restart_tag, int enable_logging, - int debug_level, const char *results_output_filename, const char *catalyst_output_directory, - std::vector &catalyst_sierra_data) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - - pcsai.CreateNewPipeline(catalyst_python_filename, catalyst_sierra_block_json, - catalyst_sierra_separator_character, catalyst_sierra_input_deck_name, - UnderscoreVectors, ApplyDisplacements, restart_tag, enable_logging, - debug_level, results_output_filename, catalyst_output_directory, - catalyst_sierra_data); -} - -void ParaViewCatalystIossAdapter::PerformCoProcessing( - const char *results_output_filename, std::vector &error_and_warning_codes, - std::vector &error_and_warning_messages) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - - pcsai.CoProcess(results_output_filename, error_and_warning_codes, error_and_warning_messages); -} - -void ParaViewCatalystIossAdapter::SetTimeData(double currentTime, int timeStep, - const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - - pcsai.SetTimeData(currentTime, timeStep, results_output_filename); -} - -void ParaViewCatalystIossAdapter::CreateGlobalVariable(std::vector &component_names, - const int * data, - const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((int)0); - mbds->CreateGlobalVariable(component_names, v, data); - } -} - -void ParaViewCatalystIossAdapter::CreateGlobalVariable(std::vector &component_names, - const double * data, - const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((double)0.0); - mbds->CreateGlobalVariable(component_names, v, data); - } -} - -void ParaViewCatalystIossAdapter::InitializeGlobalPoints(int num_points, int dimension, - const double *data, - const char * results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - mbds->InitializeGlobalPoints(num_points, dimension, data); - } -} - -void ParaViewCatalystIossAdapter::InitializeElementBlocks( - const std::vector &element_block_id_list, const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - mbds->InitializeElementBlocks(element_block_id_list); - } -} - -void ParaViewCatalystIossAdapter::ReleaseMemory(const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - mbds->ReleaseMemory(); - } - pcsai.WriteToLogFile(results_output_filename); -} - -void ParaViewCatalystIossAdapter::CreateElementBlock(const char *elem_block_name, int elem_block_id, - const std::string &elem_type, - int nodes_per_elem, int num_elem, - const int64_t *global_elem_ids, - int * connectivity, - const char * results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((int)0); - mbds->CreateElementBlock(elem_block_name, elem_block_id, elem_type, nodes_per_elem, num_elem, v, - global_elem_ids, connectivity); - } -} - -void ParaViewCatalystIossAdapter::CreateElementBlock(const char *elem_block_name, int elem_block_id, - const std::string &elem_type, - int nodes_per_elem, int num_elem, - const int64_t *global_elem_ids, - int64_t * connectivity, - const char * results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((int64_t)0); - mbds->CreateElementBlock(elem_block_name, elem_block_id, elem_type, nodes_per_elem, num_elem, v, - global_elem_ids, connectivity); - } -} - -void ParaViewCatalystIossAdapter::CreateNodeSet(const char *node_set_name, int node_set_id, - int num_ids, const int *data, - const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((int)0); - mbds->CreateNodeSet(node_set_name, node_set_id, num_ids, v, data); - } -} - -void ParaViewCatalystIossAdapter::CreateNodeSet(const char *node_set_name, int node_set_id, - int num_ids, const int64_t *data, - const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((int64_t)0); - mbds->CreateNodeSet(node_set_name, node_set_id, num_ids, v, data); - } -} - -void ParaViewCatalystIossAdapter::CreateSideSet(/*const char* side_set_name,*/ - const char *ss_owner_name, int side_set_id, - int num_ids, const int *element_ids, - const int * face_ids, - const char *results_output_filename) -{ - /*NOTE: Jeff Mauldin JAM 2015Oct8 - CreateSideSet is called once for each block which the sideset - spans, and the side_set_name for the side set is the ss_owner_name - with additional characters to indicate which block we are doing. - The current implementation of the sierra sideset construction - creates a single independent sideset and collects all the - nodes and elements from the side set from each block spanned by - the sideset into that single sideset. It needs to have the - ss_owner_name, not the side_set_name, because that is the name - in the input deck for the sideset for reference for things like - extractblock. It may become necessary at a later date to - pass in both, but for now we - are just passing in ss_owner_name to give us correct - functionality while not changing the function interface*/ - - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((int)0); - mbds->CreateSideSet(/*side_set_name,*/ - ss_owner_name, side_set_id, num_ids, v, element_ids, face_ids); - } -} - -void ParaViewCatalystIossAdapter::CreateSideSet(/*const char* side_set_name,*/ - const char *ss_owner_name, int side_set_id, - int num_ids, const int64_t *element_ids, - const int64_t *face_ids, - const char * results_output_filename) -{ - /*NOTE: Jeff Mauldin JAM 2015Oct8 - CreateSideSet is called once for each block which the sideset - spans, and the side_set_name for the side set is the ss_owner_name - with additional characters to indicate which block we are doing. - The current implementation of the sierra sideset construction - creates a single independent sideset and collects all the - nodes and elements from the side set from each block spanned by - the sideset into that single sideset. It needs to have the - ss_owner_name, not the side_set_name, because that is the name - in the input deck for the sideset for reference for things like - extractblock. It may become necessary at a later date to - pass in both, but for now we - are just passing in ss_owner_name to give us correct - functionality while not changing the function interface*/ - - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((int64_t)0); - mbds->CreateSideSet(/*side_set_name,*/ - ss_owner_name, side_set_id, num_ids, v, element_ids, face_ids); - } -} - -void ParaViewCatalystIossAdapter::CreateElementVariable(std::vector &component_names, - int elem_block_id, const double *data, - const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((double)0.0); - mbds->CreateElementVariable(component_names, elem_block_id, v, data); - } -} - -void ParaViewCatalystIossAdapter::CreateElementVariable(std::vector &component_names, - int elem_block_id, const int *data, - const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((int)0); - mbds->CreateElementVariable(component_names, elem_block_id, v, data); - } -} - -void ParaViewCatalystIossAdapter::CreateElementVariable(std::vector &component_names, - int elem_block_id, const int64_t *data, - const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((int64_t)0); - mbds->CreateElementVariable(component_names, elem_block_id, v, data); - } -} - -void ParaViewCatalystIossAdapter::CreateNodalVariable(std::vector &component_names, - const double * data, - const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((double)0.0); - mbds->CreateNodalVariable(component_names, v, data); - } -} - -void ParaViewCatalystIossAdapter::CreateNodalVariable(std::vector &component_names, - const int * data, - const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((int)0); - mbds->CreateNodalVariable(component_names, v, data); - } -} - -void ParaViewCatalystIossAdapter::CreateNodalVariable(std::vector &component_names, - const int64_t * data, - const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - vtkExodusIIMultiBlockDataSet *mbds = pcsai.GetMultiBlockDataSet(results_output_filename); - if (mbds) { - vtkVariant v((int64_t)0); - mbds->CreateNodalVariable(component_names, v, data); - } -} - -void ParaViewCatalystIossAdapter::logMemoryUsageAndTakeTimerReading( - const char *results_output_filename) -{ - ParaViewCatalystIossAdapterImplementation &pcsai = - ParaViewCatalystIossAdapterImplementation::getInstance(); - - pcsai.logMemoryUsageAndTakeTimerReading(results_output_filename); -} - -int ParaViewCatalystIossAdapter::parseFile(const std::string & filepath, - CatalystParserInterface::parse_info &pinfo) -{ - return CatalystParserInterface::parseFile(filepath, pinfo); -} - -int ParaViewCatalystIossAdapter::parseString(const std::string & s, - CatalystParserInterface::parse_info &pinfo) -{ - return CatalystParserInterface::parseString(s, pinfo); -} - -extern "C" { -ParaViewCatalystIossAdapterBase *ParaViewCatalystIossAdapterCreateInstance() -{ - ParaViewCatalystIossAdapterBase *t(new ParaViewCatalystIossAdapter()); - return t; -} -} diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/cgns/CatalystCGNSMesh.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/cgns/CatalystCGNSMesh.cxx index c070d77bfb..6a081b505c 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/cgns/CatalystCGNSMesh.cxx +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/cgns/CatalystCGNSMesh.cxx @@ -6,212 +6,181 @@ #include "CatalystCGNSMesh.h" #include "CatalystManager.h" -#include "vtkMultiBlockDataSet.h" -#include "vtkObjectFactory.h" +#include "vtkCellData.h" +#include "vtkDataAssembly.h" +#include "vtkAOSDataArrayTemplate.h" #include "vtkInformation.h" -#include "vtkStructuredGrid.h" -#include "vtkPoints.h" -#include "vtkDoubleArray.h" +#include "vtkObjectFactory.h" +#include "vtkPartitionedDataSet.h" #include "vtkPointData.h" -#include "vtkCellData.h" +#include "vtkPoints.h" +#include "vtkStructuredGrid.h" #include namespace Iovs_cgns { -CatalystCGNSMesh::CatalystCGNSMesh(Iovs::CatalystManager *cm, - CatalystPipelineInfo& catalystPipelineInfo) { + namespace detail { + + template + void addStructuredZoneArray(T *data, const CatalystCGNSMeshBase::ZoneData &zoneData, int index, + vtkStructuredGrid *sg) + { + if (index >= 0) { + vtkPoints *pts = sg->GetPoints(); + for (int i = 0; i < zoneData.size; i++) { + double p[3]; + pts->GetPoint(i, p); + p[index] = data[i]; + pts->InsertPoint(i, p); + } + } + else { + vtkAOSDataArrayTemplate *da = vtkAOSDataArrayTemplate::New(); + da->SetName(zoneData.data_name.c_str()); + da->SetNumberOfComponents(zoneData.comp_count); + da->SetNumberOfTuples(zoneData.size); + for (int j = 0; j < zoneData.size; j++) { + double d[zoneData.comp_count]; + for (int i = 0; i < zoneData.comp_count; i++) { + d[i] = data[(zoneData.comp_count * j) + i]; + } + da->InsertTuple(j, d); + } - this->multiBlock = vtkMultiBlockDataSet::New(); - this->catManager = cm; - this->catalystPipelineInfo = catalystPipelineInfo; - vtkMultiBlockDataSet* b = vtkMultiBlockDataSet::New(); - this->multiBlock->SetBlock(BASES_BLOCK_ID, b); - this->multiBlock->GetMetaData(BASES_BLOCK_ID)->Set( - vtkCompositeDataSet::NAME(), BASES_BLOCK_NAME); - b->Delete(); -} - -CatalystCGNSMesh::~CatalystCGNSMesh() { - this->multiBlock->Delete(); - this->multiBlock = nullptr; -} - -vtkMultiBlockDataSet* CatalystCGNSMesh::getMultiBlockDataSet() { - return this->multiBlock; -} - -void CatalystCGNSMesh::PerformCoProcessing( - std::vector &error_and_warning_codes, - std::vector &error_and_warning_messages) { - - this->catManager->PerformCoProcessing(error_and_warning_codes, - error_and_warning_messages, catalystPipelineInfo); -} - -void CatalystCGNSMesh::SetTimeData(double currentTime, int timeStep) { - this->catManager->SetTimeData(currentTime, timeStep, - catalystPipelineInfo); -} - -void CatalystCGNSMesh::ReleaseMemory() { -} - -void CatalystCGNSMesh::logMemoryUsageAndTakeTimerReading() { - this->catManager->logMemoryUsageAndTakeTimerReading( - catalystPipelineInfo); -} - -void CatalystCGNSMesh::Delete() { - this->catManager->DeletePipeline(catalystPipelineInfo); -} - -void CatalystCGNSMesh::CreateBase(int base_id, const std::string& base_name) { - - if(base_id_to_base_map.find(base_id) != - base_id_to_base_map.end()) { - return; + if (zoneData.is_cell_field) { + sg->GetCellData()->AddArray(da); + } + else { + sg->GetPointData()->AddArray(da); + } + da->Delete(); + } } - vtkMultiBlockDataSet *b = vtkMultiBlockDataSet::SafeDownCast( - this->multiBlock->GetBlock(BASES_BLOCK_ID)); - vtkMultiBlockDataSet *nb = vtkMultiBlockDataSet::New(); - vtkMultiBlockDataSet *zb = vtkMultiBlockDataSet::New(); - nb->SetBlock(ZONES_BLOCK_ID, zb); - nb->GetMetaData(ZONES_BLOCK_ID)->Set( - vtkCompositeDataSet::NAME(), ZONES_BLOCK_NAME); - int location = b->GetNumberOfBlocks(); - b->SetBlock(location, nb); - b->GetMetaData(location)->Set(vtkCompositeDataSet::NAME(), base_name); - nb->Delete(); - zb->Delete(); - - base bs; - bs.base_location = location; - base_id_to_base_map[base_id] = bs; -} - -void CatalystCGNSMesh::AddStructuredZoneData(int base_id, - int zone_id, - const std::string& zone_name, - const std::string& data_name, - int ni, - int nj, - int nk, - int comp_count, - bool is_cell_field, - char field_suffix_separator, - double* data, - int size) { - - if(base_id_to_base_map.find(base_id) == - base_id_to_base_map.end()) { - return; - } + } // namespace detail - base& bs = base_id_to_base_map[base_id]; - int dims[3] = {ni+1,nj+1,nk+1}; - vtkMultiBlockDataSet *bases = vtkMultiBlockDataSet::SafeDownCast( - this->multiBlock->GetBlock(BASES_BLOCK_ID)); - vtkMultiBlockDataSet *base = vtkMultiBlockDataSet::SafeDownCast( - bases->GetBlock(bs.base_location)); - vtkMultiBlockDataSet *zones = vtkMultiBlockDataSet::SafeDownCast( - base->GetBlock(ZONES_BLOCK_ID)); - - //if this is an empty block, we just need to make a NULL grid with the - //proper name, and we don't need to add any data variables - //alternative is to make block with dims of (I think) -1,-1,-1 - //or extents of [0,-1,0,-1,0,-1] (I think) - if((ni == 0) or (nj == 0) or (nk == 0)) { - if(bs.zone_id_to_zone_location_map.find(zone_id) == - bs.zone_id_to_zone_location_map.end()) { - int location = zones->GetNumberOfBlocks(); - vtkStructuredGrid* sg = nullptr; - zones->SetBlock(location, sg); - zones->GetMetaData(location)->Set( - vtkCompositeDataSet::NAME(), zone_name); - bs.zone_id_to_zone_location_map[zone_id] = location; - } - return; + CatalystCGNSMesh::CatalystCGNSMesh(Iovs::CatalystManager *cm, + CatalystPipelineInfo &catalystPipelineInfo) + { + + vtkNew assembly; + assembly->SetRootNodeName(ASSEMBLY_ROOT_NAME.c_str()); + auto id = assembly->AddNode(ASSEMBLY_STRUCTURED_BLOCKS.c_str()); + this->vpdc->SetDataAssembly(assembly); + + this->catManager = cm; + this->catalystPipelineInfo = catalystPipelineInfo; + } + + CatalystCGNSMesh::~CatalystCGNSMesh() {} + + vtkPartitionedDataSetCollection *CatalystCGNSMesh::getPartitionedDataSetCollection() + { + return this->vpdc.GetPointer(); + } + + void CatalystCGNSMesh::PerformCoProcessing(std::vector &error_and_warning_codes, + std::vector &error_and_warning_messages) + { + + this->catManager->PerformCoProcessing(error_and_warning_codes, error_and_warning_messages, + catalystPipelineInfo); + } + + void CatalystCGNSMesh::SetTimeData(double currentTime, int timeStep) + { + this->catManager->SetTimeData(currentTime, timeStep, catalystPipelineInfo); + } + + void CatalystCGNSMesh::ReleaseMemory() {} + + void CatalystCGNSMesh::logMemoryUsageAndTakeTimerReading() + { + this->catManager->logMemoryUsageAndTakeTimerReading(catalystPipelineInfo); + } + + void CatalystCGNSMesh::Delete() { this->catManager->DeletePipeline(catalystPipelineInfo); } + + void CatalystCGNSMesh::AddStructuredZoneData(const ZoneData &zoneData) + { + int dims[3] = {zoneData.ni + 1, zoneData.nj + 1, zoneData.nk + 1}; + + // if this is an empty block, we just need to make a NULL grid with the + // proper name, and we don't need to add any data variables + // alternative is to make block with dims of (I think) -1,-1,-1 + // or extents of [0,-1,0,-1,0,-1] (I think) + if ((zoneData.ni == 0) or (zoneData.nj == 0) or (zoneData.nk == 0)) { + if (zone_id_to_zone_location_map.find(zoneData.zone_id) == + zone_id_to_zone_location_map.end()) { + createPartitionedDataSet(zoneData, nullptr); + } + return; } - if(bs.zone_id_to_zone_location_map.find(zone_id) == - bs.zone_id_to_zone_location_map.end()) { - - int location = zones->GetNumberOfBlocks(); - vtkStructuredGrid* sg = vtkStructuredGrid::New(); - vtkPoints* pts = vtkPoints::New(); - sg->SetDimensions(dims); - pts->Allocate(dims[0]*dims[1]*dims[2]); - sg->SetPoints(pts); - zones->SetBlock(location, sg); - zones->GetMetaData(location)->Set( - vtkCompositeDataSet::NAME(), zone_name); - sg->Delete(); - pts->Delete(); - bs.zone_id_to_zone_location_map[zone_id] = location; + if (zone_id_to_zone_location_map.find(zoneData.zone_id) == zone_id_to_zone_location_map.end()) { + vtkStructuredGrid *sg = vtkStructuredGrid::New(); + vtkPoints *pts = vtkPoints::New(); + sg->SetDimensions(dims); + pts->Allocate(dims[0] * dims[1] * dims[2]); + sg->SetPoints(pts); + pts->Delete(); + createPartitionedDataSet(zoneData, sg); + sg->Delete(); } - int zone_location = bs.zone_id_to_zone_location_map[zone_id]; - vtkStructuredGrid *sg = vtkStructuredGrid::SafeDownCast( - zones->GetBlock(zone_location)); + vtkStructuredGrid *sg = getStucturedGrid(zoneData); int index = -1; - if(data_name == "mesh_model_coordinates_x") { - index = 0; + if (zoneData.data_name == "mesh_model_coordinates_x") { + index = 0; } - else if(data_name == "mesh_model_coordinates_y") { - index = 1; + else if (zoneData.data_name == "mesh_model_coordinates_y") { + index = 1; } - else if(data_name == "mesh_model_coordinates_z") { - index = 2; + else if (zoneData.data_name == "mesh_model_coordinates_z") { + index = 2; } - if(index >= 0) { - vtkPoints* pts = sg->GetPoints(); - for(int i=0; iGetPoint(i, p); - p[index] = data[i]; - pts->InsertPoint(i, p); - } - } - else { - for(int i=0; icreateFieldVariableName(data_name, - field_suffix_separator, i, comp_count); - da->SetName(fn.c_str()); - da->SetNumberOfComponents(1); - da->SetNumberOfTuples(size); - for(int j=0; jInsertValue(j, data[comp_count * j + i]); - } - - if(is_cell_field) { - sg->GetCellData()->AddArray(da); - } - else { - sg->GetPointData()->AddArray(da); - } - da->Delete(); - } + if (zoneData.data_type == zoneData.T_INT) { + detail::addStructuredZoneArray(zoneData.data.p_int, zoneData, index, sg); } -} - -std::string CatalystCGNSMesh::createFieldVariableName( - std::string fieldNamePrefix, char fieldSuffixSeparator, - int componentIndex, int componentCount) { - std::string name; - if(componentCount == 1) { - name = fieldNamePrefix; + else if (zoneData.data_type == zoneData.T_INT64) { + detail::addStructuredZoneArray(zoneData.data.p_int64, zoneData, index, sg); } else { - std::ostringstream oss; - oss << componentIndex + 1; - name = fieldNamePrefix + fieldSuffixSeparator + oss.str(); + detail::addStructuredZoneArray(zoneData.data.p_double, zoneData, index, sg); } - - return name; -} + } + + int CatalystCGNSMesh::getStructuredBlocksAssemblyNode() + { + auto assembly = vpdc->GetDataAssembly(); + return assembly->GetFirstNodeByPath( + ("/" + ASSEMBLY_ROOT_NAME + "/" + ASSEMBLY_STRUCTURED_BLOCKS).c_str()); + } + + void CatalystCGNSMesh::createPartitionedDataSet(const ZoneData &zoneData, vtkStructuredGrid *sg) + { + const auto pdsIdx = vpdc->GetNumberOfPartitionedDataSets(); + zone_id_to_zone_location_map[zoneData.zone_id] = pdsIdx; + vtkNew pds; + if (sg != nullptr) { + pds->SetPartition(PDS_STRUCTURED_GRID_INDEX, sg); + } + vpdc->SetPartitionedDataSet(pdsIdx, pds); + vpdc->GetMetaData(pdsIdx)->Set(vtkCompositeDataSet::NAME(), zoneData.zone_name); + auto assembly = vpdc->GetDataAssembly(); + auto node = assembly->AddNode(zoneData.zone_name.c_str(), getStructuredBlocksAssemblyNode()); + assembly->SetAttribute(node, ASSEMBLY_LABEL.c_str(), zoneData.zone_name.c_str()); + assembly->AddDataSetIndex(node, pdsIdx); + } + + vtkStructuredGrid *CatalystCGNSMesh::getStucturedGrid(const ZoneData &zoneData) + { + int zone_location = zone_id_to_zone_location_map[zoneData.zone_id]; + vtkStructuredGrid *sg = vtkStructuredGrid::SafeDownCast( + vpdc->GetPartitionedDataSet(zone_location)->GetPartition(PDS_STRUCTURED_GRID_INDEX)); + return sg; + } } // namespace Iovs_cgns diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/cgns/CatalystCGNSMesh.h b/packages/seacas/libraries/ioss/src/visualization/catalyst/cgns/CatalystCGNSMesh.h index 68109658c7..0358a120c2 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/cgns/CatalystCGNSMesh.h +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/cgns/CatalystCGNSMesh.h @@ -11,8 +11,10 @@ #include #include #include +#include "vtkPartitionedDataSetCollection.h" +#include "vtkNew.h" -class vtkMultiBlockDataSet; +class vtkStructuredGrid; namespace Iovs_cgns { @@ -37,42 +39,30 @@ namespace Iovs_cgns { void Delete(); - void CreateBase(int base_id, const std::string &base_name); + void AddStructuredZoneData(const ZoneData& zoneData); - void AddStructuredZoneData(int base_id, int zone_id, const std::string &zone_name, - const std::string &data_name, int ni, int nj, int nk, int comp_count, - bool is_cell_field, char field_suffix_separator, double *data, - int size); - - vtkMultiBlockDataSet *getMultiBlockDataSet(); + vtkPartitionedDataSetCollection *getPartitionedDataSetCollection(); private: - const unsigned int BASES_BLOCK_ID = 0; - const char * BASES_BLOCK_NAME = "Bases"; - - const unsigned int ZONES_BLOCK_ID = 0; - const char * ZONES_BLOCK_NAME = "Zones"; CatalystCGNSMesh(); CatalystCGNSMesh(const CatalystCGNSMesh &) = delete; CatalystCGNSMesh &operator=(const CatalystCGNSMesh &) = delete; - std::string createFieldVariableName(std::string fieldNamePrefix, char fieldSuffixSeparator, - int componentIndex, int componentCount); - - struct base - { - int base_location; - std::map zone_id_to_zone_location_map; - }; - - std::map base_id_to_base_map; + std::map zone_id_to_zone_location_map; - vtkMultiBlockDataSet * multiBlock = nullptr; + vtkNew vpdc; Iovs::CatalystManager *catManager = nullptr; bool writeCatalystMesh; std::string catalystMeshFilePrefix; CatalystPipelineInfo catalystPipelineInfo; + const std::string ASSEMBLY_LABEL = "label"; + const std::string ASSEMBLY_ROOT_NAME = "IOSS"; + const std::string ASSEMBLY_STRUCTURED_BLOCKS = "structured_blocks"; + const int PDS_STRUCTURED_GRID_INDEX = 0; + int getStructuredBlocksAssemblyNode(); + void createPartitionedDataSet(const ZoneData& zoneData, vtkStructuredGrid* sg); + vtkStructuredGrid* getStucturedGrid(const ZoneData& zoneData); }; } // namespace Iovs_cgns diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/exodus/CatalystExodusMesh.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/exodus/CatalystExodusMesh.cxx index e8e69e56e5..49dc6b6ca2 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/exodus/CatalystExodusMesh.cxx +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/exodus/CatalystExodusMesh.cxx @@ -6,15 +6,16 @@ #include "CatalystExodusMesh.h" #include "CatalystManager.h" -#include "vtkMultiBlockDataSet.h" #include "vtkCell.h" #include "vtkCellData.h" #include "vtkCellType.h" #include "vtkCompositeDataIterator.h" +#include "vtkDataAssembly.h" #include "vtkDoubleArray.h" #include "vtkFieldData.h" #include "vtkInformation.h" #include "vtkObjectFactory.h" +#include "vtkPartitionedDataSet.h" #include "vtkPointData.h" #include "vtkUnstructuredGrid.h" #include "vtksys/SystemTools.hxx" @@ -22,175 +23,129 @@ namespace Iovs_exodus { -CatalystExodusMesh::CatalystExodusMesh(Iovs::CatalystManager *cm, - CatalystPipelineInfo& catalystPipelineInfo) { + CatalystExodusMesh::CatalystExodusMesh(Iovs::CatalystManager *cm, + CatalystPipelineInfo &catalystPipelineInfo) + { this->catalystPipelineInfo = catalystPipelineInfo; - this->multiBlock = vtkMultiBlockDataSet::New(); - this->catManager = cm; - this->global_points = nullptr; - this->num_global_points = 0; - this->UnderscoreVectors = true; - this->ApplyDisplacements = true; - this->writeCatalystMesh = false; -} - -CatalystExodusMesh::~CatalystExodusMesh() { + this->catManager = cm; + this->global_points = nullptr; + this->num_global_points = 0; + this->UnderscoreVectors = true; + this->ApplyDisplacements = true; + this->writeCatalystMesh = false; + + vtkNew assembly; + assembly->SetRootNodeName(ASSEMBLY_ROOT_NAME.c_str()); + assembly->AddNode(ASSEMBLY_ELEMENT_BLOCKS.c_str()); + this->vpdc->SetDataAssembly(assembly); + } + + CatalystExodusMesh::~CatalystExodusMesh() + { this->ReleaseGlobalPoints(); this->ebmap.clear(); this->ebmap_reverse.clear(); this->global_elem_id_map.clear(); this->global_point_id_to_global_elem_id.clear(); this->ebidmap.clear(); - this->nsmap.clear(); - this->nsidmap.clear(); - this->ssmap.clear(); - this->ssidmap.clear(); - std::map::iterator ssinfomapiter; - for (ssinfomapiter = this->ssinfomap.begin(); ssinfomapiter != this->ssinfomap.end(); - ssinfomapiter++) { - if (ssinfomapiter->second != NULL) { - delete ssinfomapiter->second; - } - } - this->ssinfomap.clear(); - this->multiBlock->Delete(); - this->multiBlock = nullptr; -} + } -void CatalystExodusMesh::ReleaseGlobalPoints() { + void CatalystExodusMesh::ReleaseGlobalPoints() + { if (this->global_points) { - this->global_points->Delete(); - this->global_points = nullptr; + this->global_points->Delete(); + this->global_points = nullptr; } -} + } -vtkMultiBlockDataSet* CatalystExodusMesh::getMultiBlockDataSet() { - return this->multiBlock; -} + vtkPartitionedDataSetCollection *CatalystExodusMesh::getPartitionedDataSetCollection() + { + return this->vpdc.GetPointer(); + } -bool CatalystExodusMesh::UnderscoreVectorsON() { - return this->UnderscoreVectors; -} + bool CatalystExodusMesh::UnderscoreVectorsON() { return this->UnderscoreVectors; } -void CatalystExodusMesh::SetUnderscoreVectors(bool status) { - this->UnderscoreVectors = status; -} + void CatalystExodusMesh::SetUnderscoreVectors(bool status) { this->UnderscoreVectors = status; } -bool CatalystExodusMesh::ApplyDisplacementsON() { - return this->ApplyDisplacements; -} + bool CatalystExodusMesh::ApplyDisplacementsON() { return this->ApplyDisplacements; } -void CatalystExodusMesh::SetApplyDisplacements(bool status) { - this->ApplyDisplacements = status; -} + void CatalystExodusMesh::SetApplyDisplacements(bool status) { this->ApplyDisplacements = status; } -void CatalystExodusMesh::PerformCoProcessing( - std::vector &error_and_warning_codes, - std::vector &error_and_warning_messages) { + void CatalystExodusMesh::PerformCoProcessing(std::vector &error_and_warning_codes, + std::vector &error_and_warning_messages) + { - this->catManager->PerformCoProcessing(error_and_warning_codes, - error_and_warning_messages, catalystPipelineInfo); -} + this->catManager->PerformCoProcessing(error_and_warning_codes, error_and_warning_messages, + catalystPipelineInfo); + } -void CatalystExodusMesh::SetTimeData(double currentTime, int timeStep) { - this->catManager->SetTimeData(currentTime, timeStep, - catalystPipelineInfo); -} + void CatalystExodusMesh::SetTimeData(double currentTime, int timeStep) + { + this->catManager->SetTimeData(currentTime, timeStep, catalystPipelineInfo); + } -void CatalystExodusMesh::CreateGlobalVariable( - std::vector &component_names, const double *data) { + void CatalystExodusMesh::CreateGlobalVariable(const std::string &variable_name, int num_comps, + const double *data) + { vtkVariant v((double)0.0); - this->CreateGlobalVariableVariant(component_names, v, data); -} + this->CreateGlobalVariableVariant(variable_name, num_comps, v, data); + } -void CatalystExodusMesh::CreateGlobalVariable( - std::vector &component_names, const int *data) { + void CatalystExodusMesh::CreateGlobalVariable(const std::string &variable_name, int num_comps, + const int *data) + { vtkVariant v((int)0); - this->CreateGlobalVariableVariant(component_names, v, data); -} + this->CreateGlobalVariableVariant(variable_name, num_comps, v, data); + } -void CatalystExodusMesh::CreateGlobalVariableVariant( - std::vector &component_names, vtkVariant &v, - const void *data) { + void CatalystExodusMesh::CreateGlobalVariable(const std::string &variable_name, int num_comps, + const int64_t *data) + { - vtkMultiBlockDataSet *eb = - vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(ELEMENT_BLOCK_MBDS_ID)); + vtkVariant v((int64_t)0); + this->CreateGlobalVariableVariant(variable_name, num_comps, v, data); + } + void CatalystExodusMesh::CreateGlobalVariableVariant(const std::string &variable_name, + int num_comps, vtkVariant &v, + const void *data) + { for (std::map::iterator iter = this->ebidmap.begin(); iter != this->ebidmap.end(); ++iter) { - this->CreateGlobalVariableInternal(component_names, eb, - iter->second, v, data); - } - -/* - eb = vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(NODE_SETS_MBDS_ID)); - - for (std::map::iterator iter = this->nsidmap.begin(); - iter != this->nsidmap.end(); ++iter) { - this->CreateGlobalVariableInternal(component_names, eb, - iter->second, v, data); - } - - eb = vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(SIDE_SETS_MBDS_ID)); - - for (std::map::iterator iter = this->ssidmap.begin(); - iter != this->ssidmap.end(); ++iter) { - this->CreateGlobalVariableInternal(component_names, eb, - iter->second, v, data); + vtkUnstructuredGrid *ug = getUnstructuredGrid(iter->second); + this->CreateGlobalVariableInternal(variable_name, num_comps, ug, v, data); } -*/ -} - -void CatalystExodusMesh::CreateGlobalVariableInternal( - std::vector &component_names, vtkMultiBlockDataSet *eb, - unsigned int bid, vtkVariant &v, const void *data) { + } - int number_data_components = 1; - std::vector prefix_name; - this->ContainsVector(component_names, prefix_name); - std::vector component_names_buffer = component_names; - if (prefix_name.size() == 1) { - number_data_components = component_names.size(); - component_names_buffer = prefix_name; + void CatalystExodusMesh::CreateGlobalVariableInternal(const std::string &variable_name, + int num_comps, vtkUnstructuredGrid *ug, + vtkVariant &v, const void *data) + { + if (ug == nullptr) { + return; } - - vtkUnstructuredGrid *ug = vtkUnstructuredGrid::SafeDownCast(eb->GetBlock(bid)); - vtkFieldData *field_data = ug->GetFieldData(); - std::vector data_arrays; - for (std::vector::iterator it = component_names_buffer.begin(); - it != component_names_buffer.end(); ++it) { - - vtkDataArray *da = field_data->GetArray((*it).c_str()); - if (da) { - field_data->RemoveArray((*it).c_str()); - } - vtkDataArray *arr = vtkDataArray::CreateDataArray(v.GetType()); - arr->SetName((*it).c_str()); - arr->SetNumberOfComponents(number_data_components); - arr->SetNumberOfTuples(1); - field_data->AddArray(arr); - data_arrays.push_back(arr); - arr->Delete(); + vtkFieldData *fieldData = ug->GetFieldData(); + vtkDataArray *da = fieldData->GetArray(variable_name.c_str()); + if (da) { + fieldData->RemoveArray(variable_name.c_str()); } + vtkDataArray *arr = vtkDataArray::CreateDataArray(v.GetType()); + arr->SetName(variable_name.c_str()); + arr->SetNumberOfComponents(num_comps); + arr->SetNumberOfTuples(1); + fieldData->AddArray(arr); + arr->Delete(); - int index = 0; - for (std::vector::iterator it = data_arrays.begin(); - it != data_arrays.end(); ++it) { - - for (int c = 0; c < number_data_components; c++) { - (*it)->SetComponent(0, c, this->GetArrayValue(v, data, index++)); - } + for (int cc = 0; cc < num_comps; cc++) { + arr->SetComponent(0, cc, this->GetArrayValue(v, data, cc)); } -} + } -void CatalystExodusMesh::InitializeGlobalPoints(int num_points, int dimension, - const double *data) { + void CatalystExodusMesh::InitializeGlobalPoints(int num_points, int dimension, const double *data) + { this->global_point_id_to_global_elem_id.resize(num_points); this->num_global_points = num_points; @@ -201,83 +156,70 @@ void CatalystExodusMesh::InitializeGlobalPoints(int num_points, int dimension, coords->SetNumberOfTuples(num_points); int index = 0; for (int i = 0; i < num_points; i++) { - coords->SetComponent(i, 0, data[index++]); - coords->SetComponent(i, 1, data[index++]); - if (dimension != 2) - coords->SetComponent(i, 2, data[index++]); - else - coords->SetComponent(i, 2, 0.0); + coords->SetComponent(i, 0, data[index++]); + coords->SetComponent(i, 1, data[index++]); + if (dimension != 2) + coords->SetComponent(i, 2, data[index++]); + else + coords->SetComponent(i, 2, 0.0); } this->global_points->SetData(coords); coords->Delete(); -} - -void CatalystExodusMesh::InitializeElementBlocks( - const std::vector &element_block_id_list) { + } - this->multiBlock->Initialize(); + void + CatalystExodusMesh::InitializeElementBlocks(const ElementBlockIdNameList &elemBlockNameIdList) + { this->ReleaseGlobalPoints(); this->ebmap.clear(); this->ebmap_reverse.clear(); this->global_elem_id_map.clear(); this->global_point_id_to_global_elem_id.clear(); this->ebidmap.clear(); - this->nsmap.clear(); - this->nsidmap.clear(); - this->ssmap.clear(); - this->ssidmap.clear(); - - vtkMultiBlockDataSet *eb = vtkMultiBlockDataSet::New(); - this->multiBlock->SetBlock(ELEMENT_BLOCK_MBDS_ID, eb); - this->multiBlock->GetMetaData(ELEMENT_BLOCK_MBDS_ID)->\ - Set(vtkCompositeDataSet::NAME(), ELEMENT_BLOCK_MBDS_NAME); - - for (unsigned int i = 0; i < element_block_id_list.size(); i++) { - this->ebidmap[element_block_id_list[i]] = i; - vtkUnstructuredGrid *ug = vtkUnstructuredGrid::New(); - eb->SetBlock(i, ug); - ug->Delete(); - } - eb->Delete(); - -/* - eb = vtkMultiBlockDataSet::New(); - this->multiBlock->SetBlock(SIDE_SETS_MBDS_ID, eb); - this->multiBlock->GetMetaData(SIDE_SETS_MBDS_ID)->\ - Set(vtkCompositeDataSet::NAME(), SIDE_SETS_MBDS_NAME); - eb->Delete(); - - eb = vtkMultiBlockDataSet::New(); - this->multiBlock->SetBlock(NODE_SETS_MBDS_ID, eb); - this->multiBlock->GetMetaData(NODE_SETS_MBDS_ID)->\ - Set(vtkCompositeDataSet::NAME(), NODE_SETS_MBDS_NAME); - eb->Delete(); -*/ -} - -void CatalystExodusMesh::CreateElementBlock(const char *elem_block_name, - int elem_block_id, const std::string &elem_type, int nodes_per_elem, - int num_elem, const int64_t *global_elem_ids, int *connectivity) { + + for (unsigned int i = 0; i < elemBlockNameIdList.size(); i++) { + this->ebidmap[elemBlockNameIdList[i].first] = i; + unsigned int pdsIdx = vpdc->GetNumberOfPartitionedDataSets(); + vtkNew pds; + vpdc->SetPartitionedDataSet(pdsIdx, pds); + vpdc->GetMetaData(pdsIdx)->Set(vtkCompositeDataSet::NAME(), elemBlockNameIdList[i].second); + auto assembly = vpdc->GetDataAssembly(); + auto node = + assembly->AddNode(elemBlockNameIdList[i].second.c_str(), getElementBlocksAssemblyNode()); + assembly->SetAttribute(node, ASSEMBLY_LABEL.c_str(), elemBlockNameIdList[i].second.c_str()); + assembly->AddDataSetIndex(node, pdsIdx); + } + } + + void CatalystExodusMesh::CreateElementBlock(const char *elem_block_name, int elem_block_id, + const std::string &elem_type, int nodes_per_elem, + int num_elem, const int64_t *global_elem_ids, + int *connectivity) + { vtkVariant v((int)0); - this->CreateElementBlockInternal(elem_block_name, elem_block_id, - elem_type, nodes_per_elem, num_elem, v, global_elem_ids, connectivity); -} + this->CreateElementBlockInternal(elem_block_name, elem_block_id, elem_type, nodes_per_elem, + num_elem, v, global_elem_ids, connectivity); + } -void CatalystExodusMesh::CreateElementBlock(const char *elem_block_name, - int elem_block_id, const std::string &elem_type, int nodes_per_elem, - int num_elem, const int64_t *global_elem_ids, int64_t *connectivity) { + void CatalystExodusMesh::CreateElementBlock(const char *elem_block_name, int elem_block_id, + const std::string &elem_type, int nodes_per_elem, + int num_elem, const int64_t *global_elem_ids, + int64_t *connectivity) + { vtkVariant v((int64_t)0); - this->CreateElementBlockInternal(elem_block_name, elem_block_id, - elem_type, nodes_per_elem, num_elem, v, global_elem_ids, connectivity); -} + this->CreateElementBlockInternal(elem_block_name, elem_block_id, elem_type, nodes_per_elem, + num_elem, v, global_elem_ids, connectivity); + } -void CatalystExodusMesh::CreateElementBlockInternal( - const char * elem_block_name, int elem_block_id, - const std::string &elem_type, int nodes_per_elem, int num_elem, - vtkVariant &v, const int64_t *global_elem_ids, - void *connectivity) { + void CatalystExodusMesh::CreateElementBlockInternal(const char *elem_block_name, + int elem_block_id, + const std::string &elem_type, + int nodes_per_elem, int num_elem, + vtkVariant &v, const int64_t *global_elem_ids, + void *connectivity) + { std::string elemType(vtksys::SystemTools::UpperCase(elem_type)); @@ -286,851 +228,519 @@ void CatalystExodusMesh::CreateElementBlockInternal( // Check for quadratic elements if ((elemType.substr(0, 3) == "TRI") && (nodes_per_elem == 6)) { - vtk_type = VTK_QUADRATIC_TRIANGLE; - point_count = 6; + vtk_type = VTK_QUADRATIC_TRIANGLE; + point_count = 6; } else if ((elemType.substr(0, 3) == "SHE") && (nodes_per_elem == 8)) { - vtk_type = VTK_QUADRATIC_QUAD; - point_count = 8; + vtk_type = VTK_QUADRATIC_QUAD; + point_count = 8; } else if ((elemType.substr(0, 3) == "SHE") && (nodes_per_elem == 9)) { - vtk_type = VTK_QUADRATIC_QUAD; - point_count = 8; + vtk_type = VTK_QUADRATIC_QUAD; + point_count = 8; } else if ((elemType.substr(0, 3) == "TET") && (nodes_per_elem == 10)) { - vtk_type = VTK_QUADRATIC_TETRA; - point_count = 10; + vtk_type = VTK_QUADRATIC_TETRA; + point_count = 10; } else if ((elemType.substr(0, 3) == "TET") && (nodes_per_elem == 11)) { - vtk_type = VTK_QUADRATIC_TETRA; - point_count = 10; + vtk_type = VTK_QUADRATIC_TETRA; + point_count = 10; } else if ((elemType.substr(0, 3) == "WED") && (nodes_per_elem == 15)) { - vtk_type = VTK_QUADRATIC_WEDGE; - point_count = 15; + vtk_type = VTK_QUADRATIC_WEDGE; + point_count = 15; } else if (((elemType.substr(0, 3) == "HEX") && (nodes_per_elem == 20)) || - ((elemType.substr(0, 3) == "HEX") && (nodes_per_elem == 21))) { - vtk_type = VTK_QUADRATIC_HEXAHEDRON; - point_count = 20; + ((elemType.substr(0, 3) == "HEX") && (nodes_per_elem == 21))) { + vtk_type = VTK_QUADRATIC_HEXAHEDRON; + point_count = 20; } else if ((elemType.substr(0, 3) == "HEX") && (nodes_per_elem == 27)) { - vtk_type = VTK_TRIQUADRATIC_HEXAHEDRON; - point_count = 27; + vtk_type = VTK_TRIQUADRATIC_HEXAHEDRON; + point_count = 27; } else if ((elemType.substr(0, 3) == "QUA") && (nodes_per_elem == 8)) { - vtk_type = VTK_QUADRATIC_QUAD; - point_count = 8; + vtk_type = VTK_QUADRATIC_QUAD; + point_count = 8; } else if ((elemType.substr(0, 3) == "QUA") && (nodes_per_elem == 9)) { - vtk_type = VTK_BIQUADRATIC_QUAD; - point_count = 9; + vtk_type = VTK_BIQUADRATIC_QUAD; + point_count = 9; } else if ((elemType.substr(0, 3) == "TRU") && (nodes_per_elem == 3)) { - vtk_type = VTK_QUADRATIC_EDGE; - point_count = 3; + vtk_type = VTK_QUADRATIC_EDGE; + point_count = 3; } else if ((elemType.substr(0, 3) == "BEA") && (nodes_per_elem == 3)) { - vtk_type = VTK_QUADRATIC_EDGE; - point_count = 3; + vtk_type = VTK_QUADRATIC_EDGE; + point_count = 3; } else if ((elemType.substr(0, 3) == "BAR") && (nodes_per_elem == 3)) { - vtk_type = VTK_QUADRATIC_EDGE; - point_count = 3; + vtk_type = VTK_QUADRATIC_EDGE; + point_count = 3; } else if ((elemType.substr(0, 3) == "EDG") && (nodes_per_elem == 3)) { - vtk_type = VTK_QUADRATIC_EDGE; - point_count = 3; + vtk_type = VTK_QUADRATIC_EDGE; + point_count = 3; } // Check for linear elements else if (elemType.substr(0, 3) == "CIR") { - vtk_type = VTK_VERTEX; - point_count = 1; + vtk_type = VTK_VERTEX; + point_count = 1; } else if (elemType.substr(0, 3) == "SPH") { - vtk_type = VTK_VERTEX; - point_count = 1; + vtk_type = VTK_VERTEX; + point_count = 1; } else if (elemType.substr(0, 3) == "BAR") { - vtk_type = VTK_LINE; - point_count = 2; + vtk_type = VTK_LINE; + point_count = 2; } else if (elemType.substr(0, 3) == "TRU") { - vtk_type = VTK_LINE; - point_count = 2; + vtk_type = VTK_LINE; + point_count = 2; } else if (elemType.substr(0, 3) == "BEA") { - vtk_type = VTK_LINE; - point_count = 2; + vtk_type = VTK_LINE; + point_count = 2; } else if (elemType.substr(0, 3) == "EDG") { - vtk_type = VTK_LINE; - point_count = 2; + vtk_type = VTK_LINE; + point_count = 2; } else if (elemType.substr(0, 3) == "TRI") { - vtk_type = VTK_TRIANGLE; - point_count = 3; + vtk_type = VTK_TRIANGLE; + point_count = 3; } else if (elemType.substr(0, 3) == "QUA") { - vtk_type = VTK_QUAD; - point_count = 4; + vtk_type = VTK_QUAD; + point_count = 4; } else if (elemType.substr(0, 3) == "TET") { - vtk_type = VTK_TETRA; - point_count = 4; + vtk_type = VTK_TETRA; + point_count = 4; } else if (elemType.substr(0, 3) == "PYR") { - vtk_type = VTK_PYRAMID; - point_count = 5; + vtk_type = VTK_PYRAMID; + point_count = 5; } else if (elemType.substr(0, 3) == "WED") { - vtk_type = VTK_WEDGE; - point_count = 6; + vtk_type = VTK_WEDGE; + point_count = 6; } else if (elemType.substr(0, 3) == "HEX") { - vtk_type = VTK_HEXAHEDRON; - point_count = 8; + vtk_type = VTK_HEXAHEDRON; + point_count = 8; } else if (elemType.substr(0, 3) == "NSI") { - vtk_type = VTK_POLYGON; - point_count = 0; + vtk_type = VTK_POLYGON; + point_count = 0; } else if (elemType.substr(0, 3) == "NFA") { - vtk_type = VTK_POLYHEDRON; - point_count = 0; + vtk_type = VTK_POLYHEDRON; + point_count = 0; } else if ((elemType.substr(0, 3) == "SHE") && (nodes_per_elem == 3)) { - vtk_type = VTK_TRIANGLE; - point_count = 3; + vtk_type = VTK_TRIANGLE; + point_count = 3; } else if ((elemType.substr(0, 3) == "SHE") && (nodes_per_elem == 4)) { - vtk_type = VTK_QUAD; - point_count = 4; + vtk_type = VTK_QUAD; + point_count = 4; } else if ((elemType.substr(0, 8) == "STRAIGHT") && (nodes_per_elem == 2)) { - vtk_type = VTK_LINE; - point_count = 2; + vtk_type = VTK_LINE; + point_count = 2; } else if (elemType.substr(0, 3) == "SUP") { - vtk_type = VTK_POLY_VERTEX; - point_count = nodes_per_elem; + vtk_type = VTK_POLY_VERTEX; + point_count = nodes_per_elem; } else if ((elemType.substr(0, 4) == "NULL") && (num_elem == 0)) { - std::cout << "NULL element block found"; - std::cout << "Unable to create element block " << elem_block_name; - this->multiBlock->RemoveBlock(ELEMENT_BLOCK_MBDS_ID); - return; // silently ignore empty element blocks + std::cout << "NULL element block found"; + std::cout << "Unable to create element block " << elem_block_name; + return; // silently ignore empty element blocks } else { - std::cout << "Unsupported element type: " << elemType.c_str(); - std::cout << "Unable to create element block " << elem_block_name; - this->multiBlock->RemoveBlock(ELEMENT_BLOCK_MBDS_ID); - return; - // cell types not currently handled - // quadratic wedge - 15,16 nodes - // quadratic pyramid - 13 nodes + std::cout << "Unsupported element type: " << elemType.c_str(); + std::cout << "Unable to create element block " << elem_block_name; + return; + // cell types not currently handled + // quadratic wedge - 15,16 nodes + // quadratic pyramid - 13 nodes } vtkIdType cell_vertex_order[point_count]; for (int p = 0; p < point_count; p++) { - cell_vertex_order[p] = p; + cell_vertex_order[p] = p; } if (vtk_type == VTK_QUADRATIC_WEDGE) { - cell_vertex_order[12] = 9; - cell_vertex_order[13] = 10; - cell_vertex_order[14] = 11; + cell_vertex_order[12] = 9; + cell_vertex_order[13] = 10; + cell_vertex_order[14] = 11; - cell_vertex_order[9] = 12; - cell_vertex_order[10] = 13; - cell_vertex_order[11] = 14; + cell_vertex_order[9] = 12; + cell_vertex_order[10] = 13; + cell_vertex_order[11] = 14; } else if (vtk_type == VTK_QUADRATIC_HEXAHEDRON) { - cell_vertex_order[16] = 12; - cell_vertex_order[17] = 13; - cell_vertex_order[18] = 14; - cell_vertex_order[19] = 15; + cell_vertex_order[16] = 12; + cell_vertex_order[17] = 13; + cell_vertex_order[18] = 14; + cell_vertex_order[19] = 15; - cell_vertex_order[12] = 16; - cell_vertex_order[13] = 17; - cell_vertex_order[14] = 18; - cell_vertex_order[15] = 19; + cell_vertex_order[12] = 16; + cell_vertex_order[13] = 17; + cell_vertex_order[14] = 18; + cell_vertex_order[15] = 19; } else if (vtk_type == VTK_TRIQUADRATIC_HEXAHEDRON) { - cell_vertex_order[16] = 12; - cell_vertex_order[17] = 13; - cell_vertex_order[18] = 14; - cell_vertex_order[19] = 15; + cell_vertex_order[16] = 12; + cell_vertex_order[17] = 13; + cell_vertex_order[18] = 14; + cell_vertex_order[19] = 15; - cell_vertex_order[12] = 16; - cell_vertex_order[13] = 17; - cell_vertex_order[14] = 18; - cell_vertex_order[15] = 19; + cell_vertex_order[12] = 16; + cell_vertex_order[13] = 17; + cell_vertex_order[14] = 18; + cell_vertex_order[15] = 19; - cell_vertex_order[23] = 20; - cell_vertex_order[24] = 21; - cell_vertex_order[25] = 22; - cell_vertex_order[26] = 23; + cell_vertex_order[23] = 20; + cell_vertex_order[24] = 21; + cell_vertex_order[25] = 22; + cell_vertex_order[26] = 23; - cell_vertex_order[21] = 24; - cell_vertex_order[22] = 25; - cell_vertex_order[20] = 26; + cell_vertex_order[21] = 24; + cell_vertex_order[22] = 25; + cell_vertex_order[20] = 26; } vtkIdType pts[point_count]; int index = 0; while (index < num_elem * point_count) { - for (int p = 0; p < point_count; p++) { - int index_orig = index; - - int64_t conn_ind = this->GetArrayValue(v, connectivity, index_orig) - 1; - this->ebmap[elem_block_id][conn_ind] = -1; - index++; - } - if (point_count < nodes_per_elem) { - for (int p = 0; p < (nodes_per_elem - point_count); p++) { - index++; - } + for (int p = 0; p < point_count; p++) { + int index_orig = index; + + int64_t conn_ind = this->GetArrayValue(v, connectivity, index_orig) - 1; + this->ebmap[elem_block_id][conn_ind] = -1; + index++; + } + if (point_count < nodes_per_elem) { + for (int p = 0; p < (nodes_per_elem - point_count); p++) { + index++; } + } } - vtkMultiBlockDataSet *eb = - vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(ELEMENT_BLOCK_MBDS_ID)); - vtkUnstructuredGrid *ug = - vtkUnstructuredGrid::SafeDownCast(eb->GetBlock(\ - this->ebidmap[elem_block_id])); - vtkPoints *points = vtkPoints::New(); - double x[3]; - vtkIdType i = 0; + vtkUnstructuredGrid *ug = vtkUnstructuredGrid::New(); + vtkPoints *points = vtkPoints::New(); + double x[3]; + vtkIdType i = 0; for (std::map::iterator ii = this->ebmap[elem_block_id].begin(); - ii != this->ebmap[elem_block_id].end(); ++ii) { + ii != this->ebmap[elem_block_id].end(); ++ii) { - this->global_points->GetPoint((*ii).first, x); - (*ii).second = i; - this->ebmap_reverse[elem_block_id][i] = (*ii).first; - points->InsertNextPoint(x); - i++; + this->global_points->GetPoint((*ii).first, x); + (*ii).second = i; + this->ebmap_reverse[elem_block_id][i] = (*ii).first; + points->InsertNextPoint(x); + i++; } index = 0; std::vector object_ids; while (index < num_elem * point_count) { - for (int p = 0; p < point_count; p++) { - int64_t conn_ind = this->GetArrayValue(v, connectivity, index) - 1; - this->global_point_id_to_global_elem_id[conn_ind] = global_elem_ids[ug->GetNumberOfCells()]; - - conn_ind = this->GetArrayValue(v, connectivity, index++) - 1; - pts[cell_vertex_order[p]] = this->ebmap[elem_block_id][conn_ind]; - } - if (point_count < nodes_per_elem) { - for (int p = 0; p < (nodes_per_elem - point_count); p++) { - int64_t conn_ind = this->GetArrayValue(v, connectivity, index) - 1; - this->global_point_id_to_global_elem_id[conn_ind] = global_elem_ids[ug->GetNumberOfCells()]; - index++; - } + for (int p = 0; p < point_count; p++) { + int64_t conn_ind = this->GetArrayValue(v, connectivity, index) - 1; + this->global_point_id_to_global_elem_id[conn_ind] = global_elem_ids[ug->GetNumberOfCells()]; + + conn_ind = this->GetArrayValue(v, connectivity, index++) - 1; + pts[cell_vertex_order[p]] = this->ebmap[elem_block_id][conn_ind]; + } + if (point_count < nodes_per_elem) { + for (int p = 0; p < (nodes_per_elem - point_count); p++) { + int64_t conn_ind = this->GetArrayValue(v, connectivity, index) - 1; + this->global_point_id_to_global_elem_id[conn_ind] = + global_elem_ids[ug->GetNumberOfCells()]; + index++; } + } - this->global_elem_id_map[elem_block_id][global_elem_ids[ug->GetNumberOfCells()]] = - ug->GetNumberOfCells(); + this->global_elem_id_map[elem_block_id][global_elem_ids[ug->GetNumberOfCells()]] = + ug->GetNumberOfCells(); - ug->InsertNextCell(vtk_type, point_count, pts); - object_ids.push_back(this->ebidmap[elem_block_id]); + ug->InsertNextCell(vtk_type, point_count, pts); + object_ids.push_back(this->ebidmap[elem_block_id]); } ug->SetPoints(points); - eb->GetMetaData(this->ebidmap[elem_block_id])->\ - Set(vtkCompositeDataSet::NAME(), elem_block_name); - points->Delete(); - - std::vector element_block_name; - element_block_name.push_back("ElementBlockIds"); - vtkVariant vb((int)this->ebidmap[elem_block_id]); - int bid = this->ebidmap[elem_block_id]; - this->CreateGlobalVariableInternal(element_block_name, eb, - this->ebidmap[elem_block_id], vb, &bid); - - std::vector component_names; - component_names.push_back("ObjectId"); - this->CreateElementVariableInternal(component_names, eb, bid, - vb, &object_ids[0]); -} - -void CatalystExodusMesh::CreateNodeSet(const char *node_set_name, - int node_set_id, int num_ids, const int *data) { - - vtkVariant v((int)0); - this->CreateNodeSetVariant(node_set_name, node_set_id, num_ids, v, data); -} - -void CatalystExodusMesh::CreateNodeSet(const char *node_set_name, - int node_set_id, int num_ids, const int64_t *data) { - - vtkVariant v((int64_t)0); - this->CreateNodeSetVariant(node_set_name, node_set_id, num_ids, v, data); -} - -void CatalystExodusMesh::CreateNodeSetVariant(const char *node_set_name, - int node_set_id, int num_ids, vtkVariant &v, const void *ids) { - - vtkMultiBlockDataSet *eb = vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(NODE_SETS_MBDS_ID)); - unsigned int bid = eb->GetNumberOfBlocks(); - vtkUnstructuredGrid *ug = vtkUnstructuredGrid::New(); - vtkPoints *points = vtkPoints::New(); - points->SetNumberOfPoints(num_ids); - this->nsidmap[node_set_id] = bid; - std::vector object_ids; - std::vector global_element_id; - - for (int i = 0; i < num_ids; i++) { - double x[3]; - vtkIdType ptids[1]; - int id = (int)this->GetArrayValue(v, ids, i) - 1; - this->global_points->GetPoint(id, x); - ptids[0] = (vtkIdType)i; - points->SetPoint(i, x); - ug->InsertNextCell(VTK_VERTEX, 1, ptids); - this->nsmap[node_set_id][id] = i; - object_ids.push_back(node_set_id); - global_element_id.push_back(this->global_point_id_to_global_elem_id[id]); - } + vpdc->GetPartitionedDataSet(this->ebidmap[elem_block_id]) + ->SetPartition(PDS_UNSTRUCTURED_GRID_INDEX, ug); - ug->SetPoints(points); - eb->SetBlock(bid, ug); - eb->GetMetaData(bid)->Set(vtkCompositeDataSet::NAME(), node_set_name); ug->Delete(); points->Delete(); + } - if (num_ids > 0) { - std::vector component_names; - component_names.push_back("ObjectId"); - vtkVariant val((int)0); - this->CreateElementVariableInternal(component_names, eb, bid, - val, &object_ids[0]); - - component_names.clear(); - component_names.push_back("GlobalElementId"); - this->CreateElementVariableInternal(component_names, eb, bid, - val, &global_element_id[0]); - } -} - -void CatalystExodusMesh::CreateSideSet(const char *ss_owner_name, - int side_set_id, int num_ids, const int *element_ids, - const int *face_ids) { - /*NOTE: Jeff Mauldin JAM 2015Oct8 - CreateSideSet is called once for each block which the sideset - spans, and the side_set_name for the side set is the ss_owner_name - with additional characters to indicate which block we are doing. - The current implementation of the sierra sideset construction - creates a single independent sideset and collects all the - nodes and elements from the side set from each block spanned by - the sideset into that single sideset. It needs to have the - ss_owner_name, not the side_set_name, because that is the name - in the input deck for the sideset for reference for things like - extractblock. It may become necessary at a later date to - pass in both, but for now we - are just passing in ss_owner_name to give us correct - functionality while not changing the function interface*/ - - vtkVariant v((int)0); - this->CreateSideSetVariant(ss_owner_name, side_set_id, num_ids, - v, element_ids, face_ids); -} - -void CatalystExodusMesh::CreateSideSet(const char *ss_owner_name, - int side_set_id, int num_ids, const int64_t *element_ids, - const int64_t *face_ids) { - - vtkVariant v((int64_t)0); - this->CreateSideSetVariant(ss_owner_name, side_set_id, num_ids, - v, element_ids, face_ids); -} - -void CatalystExodusMesh::CreateSideSetVariant(const char *ss_owner_name, - int side_set_id, int num_ids, vtkVariant &v, const void *element_ids, - const void *face_ids) { - - vtkMultiBlockDataSet *ssb = vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(SIDE_SETS_MBDS_ID)); - vtkMultiBlockDataSet *eb = vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(ELEMENT_BLOCK_MBDS_ID)); - - // side set can span multiple blocks; we appear to get callback for same - // side set once per block in which the side set exists - // we need to track this situation and only construct one unstructured grid - // per sideset, but put info from every block the sideset spans into the - // unstructured grid (and the map of the point ids) - int newSideSetFlag; - vtkPoints * points = nullptr; - vtkUnstructuredGrid *ug = nullptr; - unsigned int bid = -1; - - Ve2mSideSetInfo * ssinfo = nullptr; - std::map::iterator ssinfomapiter; - ssinfomapiter = this->ssinfomap.find(side_set_id); - if (ssinfomapiter != ssinfomap.end()) { - // we have already seen this side_set_id, so we add this side set rather - // than constructing a new one - newSideSetFlag = 0; - ssinfo = ssinfomapiter->second; - bid = ssinfo->bid; - ug = vtkUnstructuredGrid::SafeDownCast(ssb->GetBlock(bid)); - points = ug->GetPoints(); - } - else { - // we have not seen this side_set_id, so we need to create it and add - // it to the map of information about existing side sets - newSideSetFlag = 1; - bid = ssb->GetNumberOfBlocks(); - ug = vtkUnstructuredGrid::New(); - points = vtkPoints::New(); - ssinfo = new Ve2mSideSetInfo(); - ssinfomap[side_set_id] = ssinfo; - ssinfo->bid = bid; - this->ssidmap[side_set_id] = bid; - } - - vtkIdType point_index = ssinfo->unique_points.size(); - - for (int i = 0; i < num_ids; i++) { - int e_id; - int e_bid; - int face_id; - vtkUnstructuredGrid *eb_ug = 0; - vtkCell *cell = 0; - - for (std::map::iterator iter = this->ebidmap.begin(); - iter != this->ebidmap.end(); ++iter) { - - eb_ug = vtkUnstructuredGrid::SafeDownCast(\ - eb->GetBlock(this->ebidmap[iter->first])); - e_id = this->GetArrayValue(v, element_ids, i); - if (this->global_elem_id_map[iter->first].find(e_id) != - this->global_elem_id_map[iter->first].end()) { - - face_id = this->GetArrayValue(v, face_ids, i) - 1; - e_id = this->global_elem_id_map[iter->first][e_id]; - e_bid = iter->first; - cell = eb_ug->GetCell(e_id); - break; - } - } - - if (cell != 0 && cell->GetCellType() != VTK_EMPTY_CELL) { - if (cell->GetCellType() == VTK_HEXAHEDRON || - cell->GetCellType() == VTK_QUADRATIC_HEXAHEDRON || - cell->GetCellType() == VTK_TRIQUADRATIC_HEXAHEDRON) { - - face_id = HEXAHEDRON_FACE_MAP[face_id]; - } - else if (cell->GetCellType() == VTK_WEDGE || - cell->GetCellType() == VTK_QUADRATIC_WEDGE) { - face_id = WEDGE_FACE_MAP[face_id]; - } - else { - } - - vtkCell *face = eb_ug->GetCell(e_id)->GetFace(face_id); - if (!face) { - face = eb_ug->GetCell(e_id)->GetEdge(face_id); - } - vtkPoints *face_points = face->GetPoints(); - double x[3]; - vtkIdType pts[face_points->GetNumberOfPoints()]; - - for (int j = 0; j < face_points->GetNumberOfPoints(); j++) { - int global_point_id = this->\ - ebmap_reverse[e_bid][face->GetPointId(j)]; - if (ssinfo->unique_points.find(global_point_id) != - ssinfo->unique_points.end()) { - - pts[j] = ssinfo->unique_points[global_point_id]; - if (pts[j] >= points->GetNumberOfPoints()) { - std::cerr << "ERROR!!! BAD INDEX\n"; - } - } - else { - if (point_index > points->GetNumberOfPoints()) { - std::cerr << "ERROR!!! BAD INDEX\n"; - } - ssinfo->unique_points[global_point_id] = point_index; - this->ssmap[side_set_id][global_point_id] = point_index; - pts[j] = point_index++; - face_points->GetPoint(j, x); - points->InsertNextPoint(x); - } - } - ug->InsertNextCell(face->GetCellType(), - face->GetNumberOfPoints(), pts); - ssinfo->object_ids.push_back(side_set_id); - } - } - - if (newSideSetFlag) { - ug->SetPoints(points); - ssb->SetBlock(bid, ug); - ssb->GetMetaData(bid)->Set(vtkCompositeDataSet::NAME(), ss_owner_name); - ug->Delete(); - points->Delete(); - } - - if (num_ids > 0) { - std::vector component_names; - component_names.push_back("ObjectId"); - vtkVariant val((int)0); - this->CreateElementVariableInternal(component_names, ssb, bid, val, - &(ssinfo->object_ids)[0]); - } -} - -void CatalystExodusMesh::CreateElementVariable( - std::vector &component_names, int elem_block_id, - const double *data) { + void CatalystExodusMesh::CreateElementVariable(const std::string &variable_name, int num_comps, + int elem_block_id, const double *data) + { vtkVariant v((double)0.0); - this->CreateElementVariableVariant(component_names, - elem_block_id, v, data); -} + this->CreateElementVariableVariant(variable_name, num_comps, elem_block_id, v, data); + } -void CatalystExodusMesh::CreateElementVariable( - std::vector &component_names, int elem_block_id, - const int *data) { + void CatalystExodusMesh::CreateElementVariable(const std::string &variable_name, int num_comps, + int elem_block_id, const int *data) + { vtkVariant v((int)0); - this->CreateElementVariableVariant(component_names, - elem_block_id, v, data); -} + this->CreateElementVariableVariant(variable_name, num_comps, elem_block_id, v, data); + } -void CatalystExodusMesh::CreateElementVariable( - std::vector &component_names, int elem_block_id, - const int64_t *data) { + void CatalystExodusMesh::CreateElementVariable(const std::string &variable_name, int num_comps, + int elem_block_id, const int64_t *data) + { vtkVariant v((int64_t)0); - this->CreateElementVariableVariant(component_names, - elem_block_id, v, data); -} - -void CatalystExodusMesh::CreateElementVariableVariant( - std::vector &component_names, int elem_block_id, vtkVariant &v, - const void *data) { - - vtkMultiBlockDataSet *eb = - vtkMultiBlockDataSet::SafeDownCast(this->multiBlock->\ - GetBlock(ELEMENT_BLOCK_MBDS_ID)); - this->CreateElementVariableInternal(component_names, eb, - this->ebidmap[elem_block_id], v, data); -} - -void CatalystExodusMesh::CreateElementVariableInternal( - std::vector &component_names, vtkMultiBlockDataSet *eb, - unsigned int bid, vtkVariant &v, const void *data) { - - vtkUnstructuredGrid *ug = vtkUnstructuredGrid::SafeDownCast(\ - eb->GetBlock(bid)); - - int number_data_components = 1; - std::vector prefix_name; - this->ContainsVector(component_names, prefix_name); - std::vector component_names_buffer = component_names; - if (prefix_name.size() == 1) { - number_data_components = component_names.size(); - component_names_buffer = prefix_name; - } - - vtkFieldData* cell_data = ug->GetCellData(); - std::vector data_arrays; - for (std::vector::iterator it = component_names_buffer.begin(); - it != component_names_buffer.end(); ++it) { - vtkDataArray *da = cell_data->GetArray((*it).c_str()); - if (da) { - cell_data->RemoveArray((*it).c_str()); - } - vtkDataArray *arr = vtkDataArray::CreateDataArray(v.GetType()); - arr->SetName((*it).c_str()); - arr->SetNumberOfComponents(number_data_components); - arr->SetNumberOfTuples(ug->GetNumberOfCells()); - cell_data->AddArray(arr); - data_arrays.push_back(arr); - arr->Delete(); - } + this->CreateElementVariableVariant(variable_name, num_comps, elem_block_id, v, data); + } - const double *dp = static_cast(data); - int index = 0; - for (int i = 0; i < ug->GetNumberOfCells(); i++) { - for (std::vector::iterator it = data_arrays.begin(); - it != data_arrays.end(); ++it) { - for (int c = 0; c < number_data_components; c++) { - (*it)->SetComponent(i, c, - this->GetArrayValue(v, data, index++)); - } - } + void CatalystExodusMesh::CreateElementVariableVariant(const std::string &variable_name, + int num_comps, int elem_block_id, + vtkVariant &v, const void *data) + { + vtkUnstructuredGrid *ug = getUnstructuredGrid(this->ebidmap[elem_block_id]); + this->CreateElementVariableInternal(variable_name, num_comps, ug, v, data); + } + + void CatalystExodusMesh::CreateElementVariableInternal(const std::string &variable_name, + int num_comps, vtkUnstructuredGrid *ug, + vtkVariant &v, const void *data) + { + if (ug == nullptr) { + return; + } + vtkFieldData *cell_data = ug->GetCellData(); + vtkDataArray *da = cell_data->GetArray(variable_name.c_str()); + if (da) { + cell_data->RemoveArray(variable_name.c_str()); + } + vtkDataArray *arr = vtkDataArray::CreateDataArray(v.GetType()); + arr->SetName(variable_name.c_str()); + arr->SetNumberOfComponents(num_comps); + arr->SetNumberOfTuples(ug->GetNumberOfCells()); + cell_data->AddArray(arr); + arr->Delete(); + + for (int ii = 0; ii < ug->GetNumberOfCells(); ii++) { + for (int cc = 0; cc < num_comps; cc++) { + arr->SetComponent(ii, cc, this->GetArrayValue(v, data, num_comps * ii + cc)); + } } -} + } -void CatalystExodusMesh::CreateNodalVariable( - std::vector &component_names, const double *data) { + void CatalystExodusMesh::CreateNodalVariable(const std::string &variable_name, int num_comps, + const double *data) + { vtkVariant v((double)0.0); - this->CreateNodalVariableVariant(component_names, v, data); -} + this->CreateNodalVariableVariant(variable_name, num_comps, v, data); + } -void CatalystExodusMesh::CreateNodalVariable( - std::vector &component_names, const int *data) { + void CatalystExodusMesh::CreateNodalVariable(const std::string &variable_name, int num_comps, + const int *data) + { vtkVariant v((int)0); - this->CreateNodalVariableVariant(component_names, v, data); -} + this->CreateNodalVariableVariant(variable_name, num_comps, v, data); + } -void CatalystExodusMesh::CreateNodalVariable( - std::vector &component_names, const int64_t *data) { + void CatalystExodusMesh::CreateNodalVariable(const std::string &variable_name, int num_comps, + const int64_t *data) + { vtkVariant v((int64_t)0); - this->CreateNodalVariableVariant(component_names, v, data); -} - -void CatalystExodusMesh::CreateNodalVariableVariant( - std::vector &component_names, vtkVariant &v, - const void *data) { - - vtkMultiBlockDataSet *eb = - vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(ELEMENT_BLOCK_MBDS_ID)); - - this->CreateNodalVariableInternal(component_names, eb, this->ebidmap, - this->ebmap, v, data); - -/* - eb = vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(NODE_SETS_MBDS_ID)); - - this->CreateNodalVariableInternal(component_names, eb, this->nsidmap, - this->nsmap, v, data); - - eb = vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(SIDE_SETS_MBDS_ID)); + this->CreateNodalVariableVariant(variable_name, num_comps, v, data); + } - this->CreateNodalVariableInternal(component_names, eb, this->ssidmap, - this->ssmap, v, data); -*/ -} + void CatalystExodusMesh::CreateNodalVariableVariant(const std::string &variable_name, + int num_comps, vtkVariant &v, + const void *data) + { + for (std::map::iterator iter = this->ebidmap.begin(); + iter != this->ebidmap.end(); ++iter) { + vtkUnstructuredGrid *ug = getUnstructuredGrid(iter->second); + this->CreateNodalVariableInternal(variable_name, num_comps, ug, iter->first, this->ebmap, v, + data); + } + } -void CatalystExodusMesh::CreateNodalVariableInternal( - std::vector &component_names, vtkMultiBlockDataSet *eb, - std::map &id_map, std::map> &point_map, vtkVariant &v, const void *data) { + void CatalystExodusMesh::CreateNodalVariableInternal(const std::string &variable_name, + int num_comps, vtkUnstructuredGrid *ug, + int element_block_id, + std::map> &point_map, + vtkVariant &v, const void *data) + { + if (ug == nullptr) { + return; + } - int number_data_components = 1; - std::vector prefix_name; bool displace_nodes = false; - this->ContainsVector(component_names, prefix_name); - std::vector component_names_buffer = component_names; - if (prefix_name.size() == 1) { - number_data_components = component_names.size(); - component_names_buffer = prefix_name; - if (this->ApplyDisplacementsON() && (number_data_components <= 3) && - (prefix_name[0].length() >= 3)) { - if ((prefix_name[0].substr(0, 3) == "DIS") ||\ - (prefix_name[0].substr(0, 3) == "dis")) { - displace_nodes = true; - } - } + if ((variable_name.substr(0, 3) == "DIS") || (variable_name.substr(0, 3) == "dis")) { + displace_nodes = true; } - for (std::map::iterator iter = id_map.begin(); - iter != id_map.end(); ++iter) { - - vtkUnstructuredGrid *ug = vtkUnstructuredGrid::SafeDownCast(eb->GetBlock(iter->second)); - if (!ug) { - continue; - } - if (ug->GetNumberOfCells() == 0) { - continue; - } - vtkFieldData* point_data = ug->GetPointData(); - std::vector data_arrays; - - for (std::vector::iterator it = component_names_buffer.begin(); - it != component_names_buffer.end(); ++it) { - - vtkDataArray *da = point_data->GetArray((*it).c_str()); - if (da) { - point_data->RemoveArray((*it).c_str()); - } - vtkDataArray *arr = vtkDataArray::CreateDataArray(v.GetType()); - arr->SetName((*it).c_str()); - arr->SetNumberOfComponents(number_data_components); - arr->SetNumberOfTuples(ug->GetPoints()->GetNumberOfPoints()); - point_data->AddArray(arr); - data_arrays.push_back(arr); - arr->Delete(); - } + if (ug->GetNumberOfCells() == 0) { + return; + } + vtkFieldData *point_data = ug->GetPointData(); + vtkDataArray *da = point_data->GetArray(variable_name.c_str()); + if (da) { + point_data->RemoveArray(variable_name.c_str()); + } + vtkDataArray *arr = vtkDataArray::CreateDataArray(v.GetType()); + arr->SetName(variable_name.c_str()); + arr->SetNumberOfComponents(num_comps); + arr->SetNumberOfTuples(ug->GetPoints()->GetNumberOfPoints()); + point_data->AddArray(arr); + arr->Delete(); - int index = 0; - for (int i = 0; i < this->num_global_points; i++) { - std::map::iterator mit = point_map[iter->first].find(i); - for (std::vector::iterator it = data_arrays.begin(); - it != data_arrays.end(); ++it) { + int index = 0; + for (int i = 0; i < this->num_global_points; i++) { + std::map::iterator mit = point_map[element_block_id].find(i); - for (int c = 0; c < number_data_components; c++) { - if (mit != point_map[iter->first].end()) { - (*it)->SetComponent(point_map[iter->first][i], c, + for (int c = 0; c < num_comps; c++) { + if (mit != point_map[element_block_id].end()) { + arr->SetComponent(point_map[element_block_id][i], c, this->GetArrayValue(v, data, index++)); - } - else { - index++; - } - } - - if (displace_nodes) { - if (mit != point_map[iter->first].end()) { - vtkPoints *points = ug->GetPoints(); - double x[3]; - this->global_points->GetPoint(i, x); - for (int c = 0; c < number_data_components; c++) { - x[c] += (*it)->GetComponent(\ - point_map[iter->first][i], c); - } - points->SetPoint(point_map[iter->first][i], x); - } - } - } } + else { + index++; + } + } + + if (displace_nodes) { + if (mit != point_map[element_block_id].end()) { + vtkPoints *points = ug->GetPoints(); + double x[3]; + this->global_points->GetPoint(i, x); + for (int c = 0; c < num_comps; c++) { + x[c] += arr->GetComponent(point_map[element_block_id][i], c); + } + points->SetPoint(point_map[element_block_id][i], x); + } + } } -} - -void CatalystExodusMesh::ReleaseMemory() { - - vtkMultiBlockDataSet *eb = - vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(ELEMENT_BLOCK_MBDS_ID)); - this->ReleaseMemoryInternal(eb); - -/* - eb = vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(NODE_SETS_MBDS_ID)); - this->ReleaseMemoryInternal(eb); + } - eb = vtkMultiBlockDataSet::SafeDownCast(\ - this->multiBlock->GetBlock(SIDE_SETS_MBDS_ID)); - this->ReleaseMemoryInternal(eb); -*/ + void CatalystExodusMesh::ReleaseMemory() + { + for (std::map::iterator iter = this->ebidmap.begin(); + iter != this->ebidmap.end(); ++iter) { + vtkUnstructuredGrid *ug = getUnstructuredGrid(iter->second); + this->ReleaseMemoryInternal(ug); + } this->ebmap_reverse.clear(); this->global_elem_id_map.clear(); this->global_point_id_to_global_elem_id.clear(); this->catManager->WriteToLogFile(catalystPipelineInfo); -} - -void CatalystExodusMesh::ReleaseMemoryInternal(vtkMultiBlockDataSet *eb) { - - vtkCompositeDataIterator *iter = eb->NewIterator(); - for (iter->InitTraversal(); !iter->IsDoneWithTraversal(); - iter->GoToNextItem()) { - - vtkUnstructuredGrid *ug = vtkUnstructuredGrid::SafeDownCast(\ - iter->GetCurrentDataObject()); - vtkFieldData * data = ug->GetCellData(); - vtkDataArray * global_element_ids = nullptr; - vtkDataArray * object_id = nullptr; - while (data->GetNumberOfArrays() > 0) { - if (std::string(data->GetArray(0)->GetName()) == - "GlobalElementId") { - - global_element_ids = data->GetArray(0); - global_element_ids->Register(0); - } - if (std::string(data->GetArray(0)->GetName()) == "ObjectId") { - object_id = data->GetArray(0); - object_id->Register(0); - } - data->RemoveArray(data->GetArray(0)->GetName()); - } + } - if (global_element_ids) { - data->AddArray(global_element_ids); - global_element_ids->Delete(); - } + void CatalystExodusMesh::ReleaseMemoryInternal(vtkUnstructuredGrid *ug) + { + if (ug == nullptr) { + return; + } + vtkFieldData *data = ug->GetCellData(); + vtkDataArray *global_element_ids = nullptr; + vtkDataArray *object_id = nullptr; + while (data->GetNumberOfArrays() > 0) { + if (std::string(data->GetArray(0)->GetName()) == "ids") { + global_element_ids = data->GetArray(0); + global_element_ids->Register(0); + } + if (std::string(data->GetArray(0)->GetName()) == "object_id") { + object_id = data->GetArray(0); + object_id->Register(0); + } + data->RemoveArray(data->GetArray(0)->GetName()); + } - if (object_id) { - data->AddArray(object_id); - object_id->Delete(); - } + if (global_element_ids) { + data->AddArray(global_element_ids); + ug->GetCellData()->SetActiveGlobalIds("ids"); + global_element_ids->Delete(); + } - data = ug->GetPointData(); - vtkDataArray *global_node_ids = 0; - while (data->GetNumberOfArrays() > 0) { - if (std::string(data->GetArray(0)->GetName()) == "GlobalNodeId") { - global_node_ids = data->GetArray(0); - global_node_ids->Register(0); - } - data->RemoveArray(data->GetArray(0)->GetName()); - } + if (object_id) { + data->AddArray(object_id); + object_id->Delete(); + } - if (global_node_ids) { - data->AddArray(global_node_ids); - global_node_ids->Delete(); - } + data = ug->GetPointData(); + vtkDataArray *global_node_ids = 0; + while (data->GetNumberOfArrays() > 0) { + if (std::string(data->GetArray(0)->GetName()) == "ids") { + global_node_ids = data->GetArray(0); + global_node_ids->Register(0); + } + data->RemoveArray(data->GetArray(0)->GetName()); } - iter->Delete(); -} -void CatalystExodusMesh::logMemoryUsageAndTakeTimerReading() { - this->catManager->logMemoryUsageAndTakeTimerReading( - catalystPipelineInfo); -} + if (global_node_ids) { + data->AddArray(global_node_ids); + ug->GetPointData()->SetActiveGlobalIds("ids"); + global_node_ids->Delete(); + } + } -void CatalystExodusMesh::Delete() { - this->catManager->DeletePipeline(catalystPipelineInfo); -} + void CatalystExodusMesh::logMemoryUsageAndTakeTimerReading() + { + this->catManager->logMemoryUsageAndTakeTimerReading(catalystPipelineInfo); + } -void CatalystExodusMesh::ContainsVector(std::vector &component_names, - std::vector &prefix_name) { + void CatalystExodusMesh::Delete() { this->catManager->DeletePipeline(catalystPipelineInfo); } - if (component_names.size() == 3) { - if ((*component_names[0].rbegin() == 'X' || *component_names[0].rbegin() == 'x') && - (*component_names[1].rbegin() == 'Y' || *component_names[1].rbegin() == 'y') && - (*component_names[2].rbegin() == 'Z' || *component_names[2].rbegin() == 'z')) { - prefix_name.push_back(component_names[0].substr(0, component_names[0].size() - 1)); + double CatalystExodusMesh::GetArrayValue(vtkVariant &v, const void *data, int index) + { + if (v.IsDouble()) { + return ((double)static_cast(data)[index]); } - } - else if (component_names.size() == 2) { - if ((*component_names[0].rbegin() == 'X' || *component_names[0].rbegin() == 'x') && - (*component_names[1].rbegin() == 'Y' || *component_names[1].rbegin() == 'y')) { - prefix_name.push_back(component_names[0].substr(0, component_names[0].size() - 1)); + else if (v.IsFloat()) { + return ((double)static_cast(data)[index]); } - } - if (!this->UnderscoreVectorsON() && prefix_name.size() == 1) { - if (*prefix_name[0].rbegin() == '_') { - prefix_name[0] = prefix_name[0].substr(0, prefix_name[0].size() - 1); + else if (v.IsInt()) { + return ((double)static_cast(data)[index]); + } + else if (v.IsLongLong()) { + return ((double)static_cast(data)[index]); + } + else if (v.IsLong()) { + return ((double)static_cast(data)[index]); + } + else { + std::cout << "Unhandled type found in GetArrayValue: " << v.GetTypeAsString(); + return 0.0; } } -} -double CatalystExodusMesh::GetArrayValue(vtkVariant &v, const void *data, int index) { - if (v.IsDouble()) { - return ((double)static_cast(data)[index]); - } - else if (v.IsFloat()) { - return ((double)static_cast(data)[index]); + int CatalystExodusMesh::getElementBlocksAssemblyNode() + { + auto assembly = vpdc->GetDataAssembly(); + return assembly->GetFirstNodeByPath( + ("/" + ASSEMBLY_ROOT_NAME + "/" + ASSEMBLY_ELEMENT_BLOCKS).c_str()); } - else if (v.IsInt()) { - return ((double)static_cast(data)[index]); - } - else if (v.IsLongLong()) { - return ((double)static_cast(data)[index]); - } - else if (v.IsLong()) { - return ((double)static_cast(data)[index]); - } - else { - std::cout << "Unhandled type found in GetArrayValue: " << v.GetTypeAsString(); - return 0.0; + + vtkUnstructuredGrid *CatalystExodusMesh::getUnstructuredGrid(int blockId) + { + vtkDataSet *ds = + vpdc->GetPartitionedDataSet(blockId)->GetPartition(PDS_UNSTRUCTURED_GRID_INDEX); + return vtkUnstructuredGrid::SafeDownCast(ds); } -} } // namespace Iovs_exodus diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/exodus/CatalystExodusMesh.h b/packages/seacas/libraries/ioss/src/visualization/catalyst/exodus/CatalystExodusMesh.h index 9935cfdfe3..337846b11e 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/exodus/CatalystExodusMesh.h +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/exodus/CatalystExodusMesh.h @@ -7,12 +7,14 @@ #ifndef __CATALYST_EXODUS_MESH_H #define __CATALYST_EXODUS_MESH_H +#include "vtkNew.h" +#include "vtkPartitionedDataSetCollection.h" #include #include #include #include -class vtkMultiBlockDataSet; +class vtkUnstructuredGrid; class vtkVariant; class vtkPoints; @@ -28,24 +30,26 @@ namespace Iovs_exodus { ~CatalystExodusMesh(); - void PerformCoProcessing(std::vector & error_and_warning_codes, + void PerformCoProcessing(std::vector &error_and_warning_codes, std::vector &error_and_warning_messages); void SetTimeData(double currentTime, int timeStep); - void ReleaseMemory(); - void logMemoryUsageAndTakeTimerReading(); + void ReleaseMemory(); + void Delete(); - void CreateGlobalVariable(std::vector &component_names, const double *data); + void CreateGlobalVariable(const std::string &variable_name, int num_comps, const double *data); + + void CreateGlobalVariable(const std::string &variable_name, int num_comps, const int *data); - void CreateGlobalVariable(std::vector &component_names, const int *data); + void CreateGlobalVariable(const std::string &variable_name, int num_comps, const int64_t *data); void InitializeGlobalPoints(int num_points, int dimension, const double *data); - void InitializeElementBlocks(const std::vector &element_block_id_list); + void InitializeElementBlocks(const ElementBlockIdNameList &elemBlockNameIdList); void CreateElementBlock(const char *elem_block_name, int elem_block_id, const std::string &elem_type, int nodes_per_elem, int num_elem, @@ -55,31 +59,20 @@ namespace Iovs_exodus { const std::string &elem_type, int nodes_per_elem, int num_elem, const int64_t *global_elem_ids, int64_t *connectivity); - void CreateNodeSet(const char *node_set_name, int node_set_id, int num_ids, const int *data); - - void CreateNodeSet(const char *node_set_name, int node_set_id, int num_ids, - const int64_t *data); - - void CreateSideSet(const char *ss_owner_name, int side_set_id, int num_ids, - const int *element_ids, const int *face_ids); - - void CreateSideSet(const char *ss_owner_name, int side_set_id, int num_ids, - const int64_t *element_ids, const int64_t *face_ids); - - void CreateElementVariable(std::vector &component_names, int elem_block_id, + void CreateElementVariable(const std::string &variable_name, int num_comps, int elem_block_id, const double *data); - void CreateElementVariable(std::vector &component_names, int elem_block_id, + void CreateElementVariable(const std::string &variable_name, int num_comps, int elem_block_id, const int *data); - void CreateElementVariable(std::vector &component_names, int elem_block_id, + void CreateElementVariable(const std::string &variable_name, int num_comps, int elem_block_id, const int64_t *data); - void CreateNodalVariable(std::vector &component_names, const double *data); + void CreateNodalVariable(const std::string &variable_name, int num_comps, const double *data); - void CreateNodalVariable(std::vector &component_names, const int *data); + void CreateNodalVariable(const std::string &variable_name, int num_comps, const int *data); - void CreateNodalVariable(std::vector &component_names, const int64_t *data); + void CreateNodalVariable(const std::string &variable_name, int num_comps, const int64_t *data); // Description: // If true (the default), vector variables will contain a @@ -97,59 +90,17 @@ namespace Iovs_exodus { bool ApplyDisplacementsON(); void SetApplyDisplacements(bool status); - vtkMultiBlockDataSet *getMultiBlockDataSet(); + vtkPartitionedDataSetCollection *getPartitionedDataSetCollection(); private: - const unsigned int ELEMENT_BLOCK_MBDS_ID = 0; - const char * ELEMENT_BLOCK_MBDS_NAME = "Element Blocks"; - - const unsigned int SIDE_SETS_MBDS_ID = 1; - const char * SIDE_SETS_MBDS_NAME = "Side Sets"; - - const unsigned int NODE_SETS_MBDS_ID = 2; - const char * NODE_SETS_MBDS_NAME = "Node Sets"; - - const int HEXAHEDRON_FACE_MAP[6] = {2, 1, 3, 0, 4, 5}; - const int WEDGE_FACE_MAP[5] = {2, 3, 4, 0, 1}; - - // see ssinfomap below, lets us combine sidesets which span multiple - // blocks int a single sideset entity - class Ve2mSideSetInfo - { - public: - Ve2mSideSetInfo() { this->bid = -1; } - ~Ve2mSideSetInfo() - { - this->unique_points.clear(); - this->object_ids.clear(); - } - int bid; - std::map unique_points; - std::vector object_ids; - }; - std::map> ebmap; std::map> ebmap_reverse; std::map> global_elem_id_map; std::vector global_point_id_to_global_elem_id; std::map ebidmap; - std::map nsidmap; - std::map> nsmap; - std::map ssidmap; - - // ssinfomap is used to help track when we see a new sideset. CreateSideSet - // is called once for each sideset for each block which the sideset spans, - // and we combine those into a single sideset entity in the vtk - // representation; also lets us do the necessary bookkeeping to combine - // the data from the different blocks into the same sideset - std::map ssinfomap; - - std::map> ssmap; - void ContainsVector(std::vector &component_names, - std::vector &prefix_name); double GetArrayValue(vtkVariant &v, const void *data, int index); void ReleaseGlobalPoints(); - vtkPoints * global_points; + vtkPoints *global_points; int num_global_points; bool writeCatalystMesh; std::string catalystMeshFilePrefix; @@ -159,42 +110,40 @@ namespace Iovs_exodus { vtkVariant &v, const int64_t *global_elem_ids, void *connectivity); - void CreateGlobalVariableVariant(std::vector &component_names, vtkVariant &v, + void CreateGlobalVariableVariant(const std::string &variable_name, int num_comps, vtkVariant &v, const void *data); - void CreateGlobalVariableInternal(std::vector &component_names, - vtkMultiBlockDataSet *eb, unsigned int bid, vtkVariant &v, - const void *data); + void CreateGlobalVariableInternal(const std::string &variable_name, int num_comps, + vtkUnstructuredGrid *ug, vtkVariant &v, const void *data); - void CreateNodalVariableVariant(std::vector &component_names, vtkVariant &v, + void CreateNodalVariableVariant(const std::string &variable_name, int num_comps, vtkVariant &v, const void *data); - void CreateNodalVariableInternal(std::vector &component_names, - vtkMultiBlockDataSet *eb, std::map &id_map, + void CreateNodalVariableInternal(const std::string &variable_name, int num_comps, + vtkUnstructuredGrid *ug, int element_block_id, std::map> &point_map, vtkVariant &v, const void *data); - void CreateElementVariableVariant(std::vector &component_names, int elem_block_id, - vtkVariant &v, const void *data); - void CreateElementVariableInternal(std::vector &component_names, - vtkMultiBlockDataSet *eb, unsigned int bid, vtkVariant &v, - const void *data); - - void CreateNodeSetVariant(const char *node_set_name, int node_set_id, int num_ids, - vtkVariant &v, const void *ids); - - void CreateSideSetVariant(const char *ss_owner_name, int side_set_id, int num_ids, - vtkVariant &v, const void *element_ids, const void *face_ids); + void CreateElementVariableVariant(const std::string &variable_name, int num_comps, + int elem_block_id, vtkVariant &v, const void *data); + void CreateElementVariableInternal(const std::string &variable_name, int num_comps, + vtkUnstructuredGrid *ug, vtkVariant &v, const void *data); - void ReleaseMemoryInternal(vtkMultiBlockDataSet *eb); + void ReleaseMemoryInternal(vtkUnstructuredGrid *ug); CatalystExodusMesh(); - CatalystExodusMesh(const CatalystExodusMesh &) = delete; + CatalystExodusMesh(const CatalystExodusMesh &) = delete; CatalystExodusMesh &operator=(const CatalystExodusMesh &) = delete; - vtkMultiBlockDataSet * multiBlock = nullptr; - Iovs::CatalystManager *catManager = nullptr; - bool UnderscoreVectors; - bool ApplyDisplacements; - CatalystPipelineInfo catalystPipelineInfo; + vtkNew vpdc; + Iovs::CatalystManager *catManager = nullptr; + bool UnderscoreVectors; + bool ApplyDisplacements; + CatalystPipelineInfo catalystPipelineInfo; + const std::string ASSEMBLY_LABEL = "label"; + const std::string ASSEMBLY_ROOT_NAME = "IOSS"; + const std::string ASSEMBLY_ELEMENT_BLOCKS = "element_blocks"; + const int PDS_UNSTRUCTURED_GRID_INDEX = 0; + int getElementBlocksAssemblyNode(); + vtkUnstructuredGrid* getUnstructuredGrid(int blockId); }; } // namespace Iovs_exodus diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/include/ParaViewCatalystCGNSAdapter.h b/packages/seacas/libraries/ioss/src/visualization/catalyst/include/ParaViewCatalystCGNSAdapter.h deleted file mode 100644 index bb59bc6e44..0000000000 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/include/ParaViewCatalystCGNSAdapter.h +++ /dev/null @@ -1,81 +0,0 @@ -// Copyright(C) 1999-2021 National Technology & Engineering Solutions -// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with -// NTESS, the U.S. Government retains certain rights in this software. -// -// See packages/seacas/LICENSE for details - -#ifndef __PARAVIEW_CATALYST_CGNS_ADAPTER_H -#define __PARAVIEW_CATALYST_CGNS_ADAPTER_H - -#include "CatalystParserInterface.h" -#include -#include -#include - -class ParaViewCatalystCGNSAdapterBase -{ -public: - ParaViewCatalystCGNSAdapterBase(){}; - virtual ~ParaViewCatalystCGNSAdapterBase(){}; - virtual void CreateNewPipeline(const char *catalyst_python_filename, - const char *catalyst_sierra_block_json) = 0; - virtual void CleanupCatalyst() = 0; - virtual void PerformCoProcessing() = 0; - virtual void SetTimeData(double currentTime, int timeStep) = 0; - virtual void CreateBase(int base_id, - const std::string& base_name) = 0; - virtual void AddStructuredZoneData(int base_id, - int zone_id, - const std::string& zone_name, - const std::string& data_name, - int ni, - int nj, - int nk, - int comp_count, - bool is_cell_field, - char field_suffix_separator, - double* data, - int size) = 0; - virtual int parseFile(const std::string &filepath, - CatalystParserInterface::parse_info &pinfo) = 0; - virtual int parseString(const std::string &s, CatalystParserInterface::parse_info &pinfo) = 0; -}; - -typedef ParaViewCatalystCGNSAdapterBase *(*ParaViewCatalystCGNSAdapterBaseSignature)(); - -extern "C" { -ParaViewCatalystCGNSAdapterBase *ParaViewCatalystCGNSAdapterCreateInstance(); -} - -class ParaViewCatalystCGNSAdapterImplementation; - -class ParaViewCatalystCGNSAdapter : public ParaViewCatalystCGNSAdapterBase -{ -public: - ParaViewCatalystCGNSAdapter() {} - virtual ~ParaViewCatalystCGNSAdapter() {} - virtual void CreateNewPipeline(const char *catalyst_python_filename, - const char *catalyst_sierra_block_json); - virtual void CleanupCatalyst(); - virtual void PerformCoProcessing(); - virtual void SetTimeData(double currentTime, int timeStep); - virtual void CreateBase(int base_id, - const std::string& base_name); - virtual void AddStructuredZoneData(int base_id, - int zone_id, - const std::string& zone_name, - const std::string& data_name, - int ni, - int nj, - int nk, - int comp_count, - bool is_cell_field, - char field_suffix_separator, - double* data, - int size); - virtual int parseFile(const std::string &filepath, - CatalystParserInterface::parse_info &pinfo); - virtual int parseString(const std::string &s, CatalystParserInterface::parse_info &pinfo); -}; - -#endif /* __PARAVIEW_CATALYST_CGNS_ADAPTER_H */ diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/include/ParaViewCatalystIossAdapter.h b/packages/seacas/libraries/ioss/src/visualization/catalyst/include/ParaViewCatalystIossAdapter.h deleted file mode 100644 index 28155b614f..0000000000 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/include/ParaViewCatalystIossAdapter.h +++ /dev/null @@ -1,230 +0,0 @@ -// Copyright(C) 1999-2021 National Technology & Engineering Solutions -// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with -// NTESS, the U.S. Government retains certain rights in this software. -// -// See packages/seacas/LICENSE for details - -#ifndef __PARAVIEW_CATALYST_IOSS_ADAPTER_H -#define __PARAVIEW_CATALYST_IOSS_ADAPTER_H - -#include "CatalystParserInterface.h" -#include -#include -#include - -// Base class needed for Ioss's dynamic library -// registration. - -class ParaViewCatalystIossAdapterBase -{ -public: - ParaViewCatalystIossAdapterBase(){}; - virtual ~ParaViewCatalystIossAdapterBase(){}; - virtual std::string getName() const { return "ParaViewCatalystIossAdapterBase"; } - virtual void DeletePipeline(const char *results_output_filename) = 0; - virtual void CleanupCatalyst() = 0; - virtual void CreateNewPipeline( - const char *catalyst_python_filename, const char *catalyst_sierra_block_json, - const char *catalyst_sierra_separator_character, const char *catalyst_sierra_input_deck_name, - int UnderscoreVectors, int ApplyDisplacements, const char *restart_tag, int enable_logging, - int debug_level, const char *results_output_filename, const char *catalyst_output_directory, - std::vector &catalyst_sierra_data) = 0; - virtual void PerformCoProcessing(const char * results_output_filename, - std::vector & error_and_warning_codes, - std::vector &error_and_warning_messages) = 0; - virtual void SetTimeData(double currentTime, int timeStep, - const char *results_output_filename) = 0; - virtual void CreateGlobalVariable(std::vector &component_names, const double *data, - const char *results_output_filename) = 0; - virtual void CreateGlobalVariable(std::vector &component_names, const int *data, - const char *results_output_filename) = 0; - virtual void InitializeGlobalPoints(int num_points, int dimension, const double *data, - const char *results_output_filename) = 0; - virtual void InitializeElementBlocks(const std::vector &element_block_id_list, - const char * results_output_filename) = 0; - virtual void CreateElementBlock(const char *elem_block_name, int elem_block_id, - const std::string &elem_type, int nodes_per_elem, int num_elem, - const int64_t *global_elem_ids, int *connectivity, - const char *results_output_filename) = 0; - virtual void CreateElementBlock(const char *elem_block_name, int elem_block_id, - const std::string &elem_type, int nodes_per_elem, int num_elem, - const int64_t *global_elem_ids, int64_t *connectivity, - const char *results_output_filename) = 0; - virtual void CreateNodeSet(const char *node_set_name, int node_set_id, int num_ids, - const int *data, const char *results_output_filename) = 0; - virtual void CreateNodeSet(const char *node_set_name, int node_set_id, int num_ids, - const int64_t *data, const char *results_output_filename) = 0; - virtual void CreateSideSet(/*const char* side_set_name,*/ - const char *ss_owner_name, int side_set_id, int num_ids, - const int *element_ids, const int *face_ids, - const char *results_output_filename) = 0; - virtual void CreateSideSet(/*const char* side_set_name,*/ - const char *ss_owner_name, int side_set_id, int num_ids, - const int64_t *element_ids, const int64_t *face_ids, - const char *results_output_filename) = 0; - virtual void CreateElementVariable(std::vector &component_names, int elem_block_id, - const double *data, const char *results_output_filename) = 0; - virtual void CreateElementVariable(std::vector &component_names, int elem_block_id, - const int *data, const char *results_output_filename) = 0; - virtual void CreateElementVariable(std::vector &component_names, int elem_block_id, - const int64_t *data, const char *results_output_filename) = 0; - virtual void CreateNodalVariable(std::vector &component_names, const double *data, - const char *results_output_filename) = 0; - virtual void CreateNodalVariable(std::vector &component_names, const int *data, - const char *results_output_filename) = 0; - virtual void CreateNodalVariable(std::vector &component_names, const int64_t *data, - const char *results_output_filename) = 0; - virtual void ReleaseMemory(const char *results_output_filename) = 0; - virtual void logMemoryUsageAndTakeTimerReading(const char *results_output_filename) = 0; - virtual int parseFile(const std::string & filepath, - CatalystParserInterface::parse_info &pinfo) = 0; - - virtual int parseString(const std::string &s, CatalystParserInterface::parse_info &pinfo) = 0; -}; - -typedef ParaViewCatalystIossAdapterBase *(*ParaViewCatalystIossAdapterBaseSignature)(); - -extern "C" { -ParaViewCatalystIossAdapterBase *ParaViewCatalystIossAdapterCreateInstance(); -} - -// ParaViewCatalystIossAdapter is a link between Ioss's mesh -// data structure and a ParaView vtkMultiBlockDataSet data structure. - -class ParaViewCatalystIossAdapterImplementation; - -class ParaViewCatalystIossAdapter : public ParaViewCatalystIossAdapterBase -{ -public: - ParaViewCatalystIossAdapter() {} - virtual ~ParaViewCatalystIossAdapter() {} - - // Description: - // Deletes pipeline with name results_output_filename and any associated - // logging data. - virtual void DeletePipeline(const char *results_output_filename); - - // Description: - // Cleanup ParaView Catalyst and free resources. - virtual void CleanupCatalyst(); - - // Description: - // Initializes ParaView Catalyst to perform in-situ co-processing - // with the Python file catalyst_python_filename. This method can - // be called multiple times with different co-processing Python scripts. - // If initialization fails, co-processing will not occur in any other - // methods on this class. - // Additional arguments: - // UnderscoreVectors - joined vector variable names end in an underscore. - // ApplyDisplacements - a nodal variable named DISPL or displ is applied to - // the mesh node coordinates each time-step. - // restart_tag - if not empty, contains the current restart iteration string, ie s0001 - // enable_logging - turn on logging in the adapter. Default is off. - // debug_level - enable catalyst debug output 0, 1, 2. Default is 0. - // results_output_filename - filename associated with the Ioss results output block. - // catalyst_output_directory - name of the output directory for storing Catalyst output. - // Default is CatalystOutput. - // catalyst_sierra_data - string data vector for development and debugging. - virtual void CreateNewPipeline( - const char *catalyst_python_filename, const char *catalyst_sierra_block_json, - const char *catalyst_sierra_separator_character, const char *catalyst_sierra_input_deck_name, - int UnderscoreVectors, int ApplyDisplacements, const char *restart_tag, int enable_logging, - int debug_level, const char *results_output_filename, const char *catalyst_output_directory, - std::vector &catalyst_sierra_data); - - // Description: - // Calls the ParaView Catalyst pipeline to run co-processing for this time iteration. - virtual void PerformCoProcessing(const char * results_output_filename, - std::vector & error_and_warning_codes, - std::vector &error_and_warning_messages); - - // Description: - // Sets time data for this ParaView Catalyst co-processing iteration. - // currentTime is the current Ioss simulation time and timeStep is - // the current time iteration count. - virtual void SetTimeData(double currentTime, int timeStep, const char *results_output_filename); - - // Description: - // Creates global vtkPoints array. - virtual void InitializeGlobalPoints(int num_points, int dimension, const double *data, - const char *results_output_filename); - - // Description: - // Creates empty element blocks for the ids contained in element_block_id_list - virtual void InitializeElementBlocks(const std::vector &element_block_id_list, - const char * results_output_filename); - - // Description: - // Clears all nodal and element variables from the vtkMultiBlockDataSet. - // Clears the global vtkPoints. - virtual void ReleaseMemory(const char *results_output_filename); - - // Description: - // Creates a global variable on the vtkMultiBlockDataSet. - virtual void CreateGlobalVariable(std::vector &component_names, const double *data, - const char *results_output_filename); - virtual void CreateGlobalVariable(std::vector &component_names, const int *data, - const char *results_output_filename); - - // Description: - // Creates an element block on the vtkMultiBlockDataSet. - virtual void CreateElementBlock(const char *elem_block_name, int elem_block_id, - const std::string &elem_type, int nodes_per_elem, int num_elem, - const int64_t *global_elem_ids, int *connectivity, - const char *results_output_filename); - virtual void CreateElementBlock(const char *elem_block_name, int elem_block_id, - const std::string &elem_type, int nodes_per_elem, int num_elem, - const int64_t *global_elem_ids, int64_t *connectivity, - const char *results_output_filename); - - // Description: - // Creates a node set on the vtkMultiBlockDataSet. - virtual void CreateNodeSet(const char *node_set_name, int node_set_id, int num_ids, - const int *data, const char *results_output_filename); - virtual void CreateNodeSet(const char *node_set_name, int node_set_id, int num_ids, - const int64_t *data, const char *results_output_filename); - - // Description: - // Creates a side set (side block) on the vtkMultiBlockDataSet. - void CreateSideSet(/*const char* side_set_name,*/ - const char *ss_owner_name, int side_set_id, int num_ids, - const int *element_ids, const int *face_ids, - const char *results_output_filename); - void CreateSideSet(/*const char* side_set_name,*/ - const char *ss_owner_name, int side_set_id, int num_ids, - const int64_t *element_ids, const int64_t *face_ids, - const char *results_output_filename); - - // Description: - // Creates an element variable on the vtkMultiBlockDataSet. - virtual void CreateElementVariable(std::vector &component_names, int elem_block_id, - const double *data, const char *results_output_filename); - virtual void CreateElementVariable(std::vector &component_names, int elem_block_id, - const int *data, const char *results_output_filename); - virtual void CreateElementVariable(std::vector &component_names, int elem_block_id, - const int64_t *data, const char *results_output_filename); - - // Description: - // Creates a nodal variable on the vtkMultiBlockDataSet. - virtual void CreateNodalVariable(std::vector &component_names, const double *data, - const char *results_output_filename); - virtual void CreateNodalVariable(std::vector &component_names, const int *data, - const char *results_output_filename); - virtual void CreateNodalVariable(std::vector &component_names, const int64_t *data, - const char *results_output_filename); - - // Description: - // Collects memory usage information from all processors and - // writes the min, max, and mean to the log file. Also writes the - // min, max, and mean of the elapsed time since this method was - // last called. - virtual void logMemoryUsageAndTakeTimerReading(const char *results_output_filename); - - int parseFile(const std::string &filepath, CatalystParserInterface::parse_info &pinfo); - - int parseString(const std::string &s, CatalystParserInterface::parse_info &pinfo); - - virtual std::string getName() const { return "ParaViewCatalystIossAdapter"; } -}; - -#endif /* __PARAVIEW_CATALYST_IOSS_ADAPTER_H */ diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/include/vtkCGNSMultiBlockDataSet.h b/packages/seacas/libraries/ioss/src/visualization/catalyst/include/vtkCGNSMultiBlockDataSet.h deleted file mode 100644 index 47723400bb..0000000000 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/include/vtkCGNSMultiBlockDataSet.h +++ /dev/null @@ -1,45 +0,0 @@ -// Copyright(C) 1999-2021 National Technology & Engineering Solutions -// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with -// NTESS, the U.S. Government retains certain rights in this software. -// -// See packages/seacas/LICENSE for details - -#ifndef __VTK_CGNS_MULTI_BLOCK_DATA_SET_H -#define __VTK_CGNS_MULTI_BLOCK_DATA_SET_H - -#include "vtkMultiBlockDataSet.h" -#include - -class vtkCGNSMultiBlockDataSet : public vtkMultiBlockDataSet -{ -public: - vtkTypeMacro(vtkCGNSMultiBlockDataSet, vtkMultiBlockDataSet); - void PrintSelf(ostream &os, vtkIndent indent); - - static vtkCGNSMultiBlockDataSet *New(); - - void CreateBase(int base_id, const std::string &base_name); - - void AddStructuredZoneData(int base_id, int zone_id, const std::string &zone_name, - const std::string &data_name, int ni, int nj, int nk, int comp_count, - bool is_cell_field, char field_suffix_separator, double *data, - int size); - -protected: - vtkCGNSMultiBlockDataSet(); - ~vtkCGNSMultiBlockDataSet(); - -private: - vtkCGNSMultiBlockDataSet(const vtkCGNSMultiBlockDataSet &); // Not implemented. - void operator=(const vtkCGNSMultiBlockDataSet &); // Not implemented. - - struct base - { - int base_location; - std::map zone_id_to_zone_location_map; - }; - - std::map base_id_to_base_map; -}; - -#endif /* __VTK_CGNS_MULTI_BLOCK_DATA_SET_H */ diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/include/vtkExodusIIMultiBlockDataSet.h b/packages/seacas/libraries/ioss/src/visualization/catalyst/include/vtkExodusIIMultiBlockDataSet.h deleted file mode 100644 index 96d218221a..0000000000 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/include/vtkExodusIIMultiBlockDataSet.h +++ /dev/null @@ -1,157 +0,0 @@ -// Copyright(C) 1999-2021 National Technology & Engineering Solutions -// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with -// NTESS, the U.S. Government retains certain rights in this software. -// -// See packages/seacas/LICENSE for details - -#ifndef __VTK_EXODUS_II_MULTI_BLOCK_DATA_SET_H -#define __VTK_EXODUS_II_MULTI_BLOCK_DATA_SET_H - -#include "vtkMultiBlockDataSet.h" -#include -#include -#include - -class vtkVariant; -class vtkPoints; -class Ve2mSideSetInfo; - -class vtkExodusIIMultiBlockDataSet : public vtkMultiBlockDataSet -{ -public: - vtkTypeMacro(vtkExodusIIMultiBlockDataSet, vtkMultiBlockDataSet); - void PrintSelf(ostream &os, vtkIndent indent); - - static vtkExodusIIMultiBlockDataSet *New(); - - // Description: - // Initializes the element blocks to NULL data sets with ids in element_block_id_list. - // This method must be called first. - void InitializeElementBlocks(const std::vector &element_block_id_list); - - // Description: - // Initializes the vtkMultiBlockDataSet with a global array of points - // defined by num_points, dimension (2,3), and data. Clears any existing data. - void InitializeGlobalPoints(int num_points, int dimension, const double *data); - - // Description: - // Clears all nodal and element variables from the vtkMultiBlockDataSet. - // Clears the global vtkPoints. - void ReleaseMemory(); - - // Description: - // Creates a global variable on the vtkExodusIIMultiBlockDataSet. - // Input argument v must have the same type as the data - // contained in input the argument array data. Creates - // the global variable on all element blocks. - void CreateGlobalVariable(std::vector &component_names, vtkVariant &v, - const void *data); - - // Description: - // Creates a vtkUnstructuredGrid on the vtkExodusIIMultiBlockDataSet - // that represents and element block in the Exodus II data. The global_points - // array contains all of the points in the Exodus II file. - void CreateElementBlock(const char *elem_block_name, int elem_block_id, - const std::string &elem_type, int nodes_per_elem, int num_elem, - vtkVariant &v, const int64_t *global_elem_ids, void *connectivity); - - // Description: - // Creates an element variable the vtkExodusIIMultiBlockDataSet. - void CreateElementVariable(std::vector &component_names, int elem_block_id, - vtkVariant &v, const void *data); - - // Description: - // Creates a nodal variable the vtkExodusIIMultiBlockDataSet. - void CreateNodalVariable(std::vector &component_names, vtkVariant &v, - const void *data); - - // Description: - // Creates a vtkUnstructuredGrid representing the node set in the Exodus II - // data. Node sets are arbitrary lists of mesh point ids. - void CreateNodeSet(const char *node_set_name, int node_set_id, int num_ids, vtkVariant &v, - const void *ids); - - // Description: - // Creates a vtkUnstructuredGrid representing the side set (also Side Block) in - // the Exodus II data. Side sets are collections of element faces and edges. - void CreateSideSet(/*const char* side_set_name,*/ - const char *ss_owner_name, int side_set_id, int num_ids, vtkVariant &v, - const void *element_ids, const void *face_ids); - - // Description: - // If true (the default), vector variables will contain a - // trailing underscore in their name. The default behavior - // is consistent with the ParaView Exodus II file reader. - vtkSetMacro(UnderscoreVectors, int); - vtkGetMacro(UnderscoreVectors, int); - vtkBooleanMacro(UnderscoreVectors, int); - - // Description: - // If true (the default), displacements will be applied to the - // mesh nodes before being sent to the in-situ pipeline. The node - // displacement variable is called either DISPL or displ. The - // default behavior is consistent with the ParaView Exodus II - // file reader. - vtkSetMacro(ApplyDisplacements, int); - vtkGetMacro(ApplyDisplacements, int); - vtkBooleanMacro(ApplyDisplacements, int); - -protected: - vtkExodusIIMultiBlockDataSet(); - ~vtkExodusIIMultiBlockDataSet(); - -private: - vtkExodusIIMultiBlockDataSet(const vtkExodusIIMultiBlockDataSet &); // Not implemented. - void operator=(const vtkExodusIIMultiBlockDataSet &); // Not implemented. - std::map> ebmap; - std::map> ebmap_reverse; - std::map> global_elem_id_map; - std::vector global_point_id_to_global_elem_id; - std::map ebidmap; - std::map nsidmap; - std::map> nsmap; - std::map ssidmap; - - // ssinfomap is used to help track when we see a new sideset. CreateSideSet - // is called once for each sideset for each block which the sideset spans, - // and we combine those into a single sideset entity in the vtk - // representation; also lets us do the necessary bookkeeping to combine - // the data from the different blocks into the same sideset - std::map ssinfomap; - - std::map> ssmap; - void ContainsVector(std::vector &component_names, - std::vector &prefix_name); - double GetArrayValue(vtkVariant &v, const void *data, int index); - void ReleaseGlobalPoints(); - vtkPoints * global_points; - int num_global_points; - int UnderscoreVectors; - int ApplyDisplacements; - void CreateGlobalVariableInternal(std::vector &component_names, - vtkMultiBlockDataSet *eb, unsigned int bid, vtkVariant &v, - const void *data); - void CreateNodalVariableInternal(std::vector &component_names, - vtkMultiBlockDataSet *eb, std::map &id_map, - std::map> &point_map, vtkVariant &v, - const void *data); - void CreateElementVariableInternal(std::vector &component_names, - vtkMultiBlockDataSet *eb, unsigned int bid, vtkVariant &v, - const void *data); - void ReleaseMemoryInternal(vtkMultiBlockDataSet *eb); -}; - -// see ssinfomap above, lets us combine sidesets which span multiple -// blocks int a single sideset entity -class Ve2mSideSetInfo -{ -public: - Ve2mSideSetInfo(); - ~Ve2mSideSetInfo(); - - int bid; - std::map unique_points; - std::vector object_ids; -}; - -#endif /* __VTK_EXODUS_II_MULTI_BLOCK_DATA_SET_H */ diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/ioss2catalyst/CMakeLists.txt b/packages/seacas/libraries/ioss/src/visualization/catalyst/ioss2catalyst/CMakeLists.txt index c7e0fb8c70..cd52bf08fb 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/ioss2catalyst/CMakeLists.txt +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/ioss2catalyst/CMakeLists.txt @@ -15,8 +15,7 @@ TARGET_INCLUDE_DIRECTORIES(catalystiossapp TARGET_LINK_LIBRARIES(catalystiossapp PUBLIC -L${SEACAS_INSTALL_DIR}/lib - Ionit - Ioss + SEACASIoss::all_libs MPI::MPI_C PRIVATE ${Python3_LIBRARY}) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/ioss2catalyst/IossApplication.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/ioss2catalyst/IossApplication.cxx index 4361aca1cf..e2d8bc3a80 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/ioss2catalyst/IossApplication.cxx +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/ioss2catalyst/IossApplication.cxx @@ -45,28 +45,29 @@ IossApplication::IossApplication(int argc, char **argv) void IossApplication::initialize() { - myRank = 0; - numRanks = 1; - printIOSSReport = false; - copyDatabase = false; - writeCatalystMeshOneFile = false; - writeCatalystMeshFilePerProc = false; - usePhactoriInputScript = false; - usePhactoriInputJSON = false; - useParaViewExportedScript = false; - phactoriInputScriptFilePath = ""; - phactoriInputJSONFilePath = ""; - paraViewExportedScriptFilePath = ""; - catalystStartTimeStep = 0; - useCatalystStartTimeStep = false; - catalystStopTimeStep = 0; - useCatalystStopTimeStep = false; - forceCGNSOutput = false; - forceExodusOutput = false; - useIOSSInputDBType = false; - hasCommandLineArguments = false; - applicationExitCode = EXIT_SUCCESS; - additionalProperties = nullptr; + myRank = 0; + numRanks = 1; + printIOSSReport = false; + copyDatabase = false; + writeCatalystMeshOneFile = false; + writeCatalystMeshFilePerProc = false; + usePhactoriInputScript = false; + usePhactoriInputJSON = false; + useParaViewExportedScript = false; + phactoriInputScriptFilePath = ""; + phactoriInputJSONFilePath = ""; + paraViewExportedScriptFilePath = ""; + catalystStartTimeStep = 0; + useCatalystStartTimeStep = false; + catalystStopTimeStep = 0; + useCatalystStopTimeStep = false; + forceCGNSOutput = false; + forceExodusOutput = false; + useIOSSInputDBType = false; + hasCommandLineArguments = false; + applicationExitCode = EXIT_SUCCESS; + additionalProperties = nullptr; + sendMultipleGridsToTheSamePipeline = true; initMPIRankAndSize(); } @@ -98,6 +99,7 @@ void IossApplication::runApplication() } callCatalystIOSSDatabaseOnRank(); + sync(); exitApplicationSuccess(); } @@ -157,7 +159,7 @@ void IossApplication::processCommandLine(int argc, char **argv) break; case 'i': cvalue = optarg; - setPhactoriInputJSON(cvalue); + addPhactoriInputJSON(cvalue); break; case 'm': setOutputCatalystMeshOneFile(true); break; case 'n': setOutputCatalystMeshFilePerProc(true); break; @@ -320,12 +322,22 @@ void IossApplication::setPhactoriInputScript(const std::string &scriptFilePath) bool IossApplication::usePhactoriInputJSONON() { return usePhactoriInputJSON; } -std::string IossApplication::getPhactoriInputJSON() { return phactoriInputJSONFilePath; } +int IossApplication::getNumberOfPhactoriInputJSONs() { return phctriInptJSONFilePathList.size(); } -void IossApplication::setPhactoriInputJSON(const std::string &jsonFilePath) +std::string IossApplication::getPhactoriInputJSON(int ndx) { - phactoriInputJSONFilePath = jsonFilePath; - usePhactoriInputJSON = true; + if (ndx >= phctriInptJSONFilePathList.size()) { + printErrorMessage("phctriInptJSONFilePathList called with ndx too large."); + printUsageMessage(); + exitApplicationFailure(); + } + return phctriInptJSONFilePathList[ndx]; +} + +void IossApplication::addPhactoriInputJSON(const std::string &jsonFilePath) +{ + phctriInptJSONFilePathList.push_back(jsonFilePath); + usePhactoriInputJSON = true; } bool IossApplication::useParaViewExportedScriptON() { return useParaViewExportedScript; } @@ -370,6 +382,16 @@ bool IossApplication::useIOSSInputDBTypeON() { return useIOSSInputDBType; } std::string IossApplication::getIOSSInputDBType() { return iossInputDBType; } +bool IossApplication::sendMultipleGridsToTheSamePipelineON() +{ + return sendMultipleGridsToTheSamePipeline; +} + +void IossApplication::setSendMultipleGridsToTheSamePipeline(bool onOffFlag) +{ + sendMultipleGridsToTheSamePipeline = onOffFlag; +} + void IossApplication::setIOSSInputDBType(const std::string &dbType) { iossInputDBType = dbType; @@ -648,13 +670,18 @@ void IossApplication::callCatalystIOSSDatabaseOnRank() callCatalystIOSSDatabaseOnRankOneGrid(); } else { - callCatalystIOSSDatabaseOnRankMultiGrid(); + if (this->sendMultipleGridsToTheSamePipelineON()) { + callCatalystIOSSDatabaseOnRankMultiGrid(true); + } + else { + callCatalystIOSSDatabaseOnRankMultiGrid(false); + } } } const char *gGridInputNames[5] = {"input", "inputB", "inputC", "inputD", "inputE"}; -void IossApplication::callCatalystIOSSDatabaseOnRankMultiGrid() +void IossApplication::callCatalystIOSSDatabaseOnRankMultiGrid(bool sendAllGridsToOnePipeline) { // create all the ioss database instances // create the output region for each grid (one on each database) @@ -668,6 +695,8 @@ void IossApplication::callCatalystIOSSDatabaseOnRankMultiGrid() std::vector outputRegions; int ii; + printMessage("IossApplication::callCatalystIOSSDatabaseOnRankMultiGrid entered\n"); + std::cerr << "IossApplication::callCatalystIOSSDatabaseOnRankMultiGrid entered2\n"; // create a Ioss::DatabaseIO instance for each grid char mytmpnm[256]; int imyRandomInt = myuni9(rng); @@ -676,8 +705,15 @@ void IossApplication::callCatalystIOSSDatabaseOnRankMultiGrid() for (ii = 0; ii < numInputRegions; ii++) { Ioss::PropertyManager *newProps = new (Ioss::PropertyManager); SetUpDefaultProperties(newProps); - newProps->add(Ioss::Property("CATALYST_MULTI_INPUT_PIPELINE_NAME", "multipipe1")); + if (sendAllGridsToOnePipeline) { + newProps->add(Ioss::Property("CATALYST_MULTI_INPUT_PIPELINE_NAME", "multipipe1")); + } newProps->add(Ioss::Property("CATALYST_INPUT_NAME", gGridInputNames[ii % 5])); + if (getNumberOfPhactoriInputJSONs() > 1) { + printMessage("getNumberOfPhactoriInputJSONs() > 1\n"); + printMessage(getPhactoriInputJSON(ii) + "\n"); + newProps->add(Ioss::Property("PHACTORI_JSON_SCRIPT", getPhactoriInputJSON(ii))); + } outputProps.push_back(newProps); Ioss::DatabaseIO *newDbo = Ioss::IOFactory::create(getCatalystDatabaseType(ii), mytmpnm, Ioss::WRITE_RESULTS, @@ -754,7 +790,11 @@ void IossApplication::SetUpDefaultProperties(Ioss::PropertyManager *outputProper outputProperties->add(Ioss::Property("PHACTORI_INPUT_SYNTAX_SCRIPT", getPhactoriInputScript())); } else if (usePhactoriInputJSONON()) { - outputProperties->add(Ioss::Property("PHACTORI_JSON_SCRIPT", getPhactoriInputJSON())); + printMessage("SetUpDefaultProperties, usePhactoriInputJSONON true\n"); + if (getNumberOfPhactoriInputJSONs() == 1) { + printMessage("1 entry: " + getPhactoriInputJSON(0) + "\n"); + outputProperties->add(Ioss::Property("PHACTORI_JSON_SCRIPT", getPhactoriInputJSON(0))); + } } else if (useParaViewExportedScriptON()) { outputProperties->add(Ioss::Property("CATALYST_SCRIPT", getParaViewExportedScript())); diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/ioss2catalyst/IossApplication.h b/packages/seacas/libraries/ioss/src/visualization/catalyst/ioss2catalyst/IossApplication.h index 94605b45d6..f3dc357400 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/ioss2catalyst/IossApplication.h +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/ioss2catalyst/IossApplication.h @@ -54,9 +54,11 @@ class IossApplication std::string getPhactoriInputScript(); void setPhactoriInputScript(const std::string &scriptFilePath); - bool usePhactoriInputJSONON(); - std::string getPhactoriInputJSON(); - void setPhactoriInputJSON(const std::string &jsonFilePath); + bool usePhactoriInputJSONON(); + + int getNumberOfPhactoriInputJSONs(); + std::string getPhactoriInputJSON(int ndx); + void addPhactoriInputJSON(const std::string &jsonFilePath); bool useParaViewExportedScriptON(); std::string getParaViewExportedScript(); @@ -70,6 +72,9 @@ class IossApplication int getCatalystStopTimeStep(); void setCatalystStopTimeStep(int timeStep); + bool sendMultipleGridsToTheSamePipelineON(); + void setSendMultipleGridsToTheSamePipeline(bool onOffFlag); + std::string &getFileName(int ndx); int getNumberOfFileNames(); void addFileName(const std::string &name); @@ -98,7 +103,7 @@ class IossApplication void addAdditionalProperties(Ioss::PropertyManager *outputProperties); void callCatalystIOSSDatabaseOnRank(); void callCatalystIOSSDatabaseOnRankOneGrid(); - void callCatalystIOSSDatabaseOnRankMultiGrid(); + void callCatalystIOSSDatabaseOnRankMultiGrid(bool sendAllGridsToOnePipeline); void openInputIOSSDatabase(int ndx); void openInputIOSSDatabases(); void processCommandLine(int argc, char **argv); @@ -133,11 +138,13 @@ class IossApplication bool useIOSSInputDBType; bool hasCommandLineArguments; int applicationExitCode; + bool sendMultipleGridsToTheSamePipeline; std::string iossInputDBType; std::string phactoriInputScriptFilePath; std::string phactoriInputJSONFilePath; std::string paraViewExportedScriptFilePath; std::vector fileName; + std::vector phctriInptJSONFilePathList; std::string copyOutputDatabaseName = "iossDatabaseCopy"; std::string outputCatalystMeshFileName = "iossDatabaseCatalystMesh"; std::string iossReportFileName = "IossRegionReport"; diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystManager.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystManager.cxx index 35391782ee..a1fcb0964a 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystManager.cxx +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystManager.cxx @@ -13,17 +13,16 @@ #include "vtkCPInputDataDescription.h" #include "vtkCPProcessor.h" #include "vtkCPPythonPipeline.h" +#include "vtkDataObject.h" #include "vtkDoubleArray.h" #include "vtkFieldData.h" #include "vtkIntArray.h" #include "vtkMPIController.h" -#include "vtkMultiBlockDataSet.h" #include "vtkMultiProcessController.h" #include "vtkProcessModule.h" #include "vtkPython.h" #include "vtkStringArray.h" -#include "vtkTrivialProducer.h" -#include "vtkXMLPMultiBlockDataWriter.h" +#include "vtkPartitionedDataSetCollection.h" #include #include #include @@ -56,6 +55,8 @@ namespace Iovs { Py_DECREF(path); } + std::string CatalystManager::getCatalystPluginVersion() { return catalystPluginVersion; } + int CatalystManager::getCatalystOutputIDNumber() { return catalystOutputIDNumber; } void CatalystManager::initializeIfNeeded() @@ -94,7 +95,7 @@ namespace Iovs { cem->SetUnderscoreVectors(cmInit.underScoreVectors); cem->SetApplyDisplacements(cmInit.applyDisplacements); - registerMeshInPipeline(cmInit, cem->getMultiBlockDataSet(), cpi); + registerMeshInPipeline(cmInit, cem->getPartitionedDataSetCollection(), cpi); return std::unique_ptr( dynamic_cast(cem)); @@ -109,7 +110,7 @@ namespace Iovs { Iovs_cgns::CatalystCGNSMesh *cgm = new Iovs_cgns::CatalystCGNSMesh(this, cpi); - registerMeshInPipeline(cmInit, cgm->getMultiBlockDataSet(), cpi); + registerMeshInPipeline(cmInit, cgm->getPartitionedDataSetCollection(), cpi); return std::unique_ptr( dynamic_cast(cgm)); @@ -149,18 +150,18 @@ namespace Iovs { return id; } - void CatalystManager::registerMeshInPipeline(CatalystMeshInit &cmInit, vtkMultiBlockDataSet *mbds, + void CatalystManager::registerMeshInPipeline(CatalystMeshInit &cmInit, vtkDataObject *vobj, const CatalystPipelineInfo &cpi) { if (pipelines.find(cpi.catalystPipelineID) == pipelines.end()) { - initCatalystPipeline(cmInit, mbds, cpi); + initCatalystPipeline(cmInit, vobj, cpi); if (cmInit.enableLogging) { initCatalystLogging(cpi); } } else { - addInputToPipeline(mbds, cpi); + addInputToPipeline(vobj, cpi); } } @@ -208,7 +209,7 @@ namespace Iovs { } } - void CatalystManager::initCatalystPipeline(CatalystMeshInit &cmInit, vtkMultiBlockDataSet *mbds, + void CatalystManager::initCatalystPipeline(CatalystMeshInit &cmInit, vtkDataObject *vobj, const CatalystPipelineInfo &cpi) { @@ -227,7 +228,7 @@ namespace Iovs { pipelines[id] .getDataDescription() ->GetInputDescriptionByName(cpi.catalystInputName.c_str()) - ->SetGrid(mbds); + ->SetGrid(vobj); pipelines[id].getMeshWriter() = std::make_shared(); if (cmInit.writeCatalystMeshOneFile) { @@ -239,7 +240,7 @@ namespace Iovs { cmInit.catalystMeshFilePerProcPrefix); } - vtkFieldData * fd = vtkFieldData::New(); + vtkFieldData *fd = vtkFieldData::New(); vtkStringArray *sa = vtkStringArray::New(); sa->SetName("catalyst_sierra_data"); vtkIntArray *ec = vtkIntArray::New(); @@ -278,8 +279,7 @@ namespace Iovs { em->Delete(); } - void CatalystManager::addInputToPipeline(vtkMultiBlockDataSet * mbds, - const CatalystPipelineInfo &cpi) + void CatalystManager::addInputToPipeline(vtkDataObject *vobj, const CatalystPipelineInfo &cpi) { CatalystPipelineID id = cpi.catalystPipelineID; @@ -288,7 +288,7 @@ namespace Iovs { pipelines[id] .getDataDescription() ->GetInputDescriptionByName(cpi.catalystInputName.c_str()) - ->SetGrid(mbds); + ->SetGrid(vobj); } void CatalystManager::DeletePipeline(const CatalystPipelineInfo &cpi) @@ -312,8 +312,8 @@ namespace Iovs { finalizeIfNeeded(); } - void CatalystManager::PerformCoProcessing(std::vector & error_and_warning_codes, - std::vector & error_and_warning_messages, + void CatalystManager::PerformCoProcessing(std::vector &error_and_warning_codes, + std::vector &error_and_warning_messages, const CatalystPipelineInfo &cpi) { @@ -337,13 +337,13 @@ namespace Iovs { return; } - vtkCPPythonPipeline * pl = pipelines[id].getPipeline(); + vtkCPPythonPipeline *pl = pipelines[id].getPipeline(); vtkCPDataDescription *dataDescription = pipelines[id].getDataDescription(); coProcessor->AddPipeline(pl); coProcessor->CoProcess(dataDescription); vtkFieldData *fd = pipelines[id].getDataDescription()->GetUserData(); - vtkIntArray * ec = + vtkIntArray *ec = vtkIntArray::SafeDownCast(fd->GetAbstractArray("catalyst_sierra_error_codes")); vtkStringArray *em = vtkStringArray::SafeDownCast(fd->GetAbstractArray("catalyst_sierra_error_messages")); @@ -391,8 +391,8 @@ namespace Iovs { if (this->logging.find(id) != this->logging.end()) { vtksys::SystemInformation sysInfo; - vtkProcessModule * pm = vtkProcessModule::GetProcessModule(); - vtkMPIController * mpic = vtkMPIController::SafeDownCast(pm->GetGlobalController()); + vtkProcessModule *pm = vtkProcessModule::GetProcessModule(); + vtkMPIController *mpic = vtkMPIController::SafeDownCast(pm->GetGlobalController()); double measurements[3]; measurements[0] = sysInfo.GetProcMemoryUsed() * (1.0 / 1024.0); // Store in MB measurements[1] = sysInfo.GetHostMemoryUsed() * (1.0 / 1024.0); @@ -412,7 +412,7 @@ namespace Iovs { if (this->logging.find(id) != this->logging.end()) { vtkProcessModule *pm = vtkProcessModule::GetProcessModule(); vtkMPIController *mpic = vtkMPIController::SafeDownCast(pm->GetGlobalController()); - vtkDoubleArray * logData = this->logging[id].second; + vtkDoubleArray *logData = this->logging[id].second; clock_t begin_time = this->logging[id].first.first; if (mpic && mpic->GetNumberOfProcesses() > 1) { vtkDoubleArray *recvBufferMin = vtkDoubleArray::New(); @@ -473,12 +473,16 @@ namespace Iovs { bool CatalystManager::writeMeshON(const CatalystPipelineInfo &cpi) { + bool retVal = false; + CatalystPipelineID id = cpi.catalystPipelineID; if (pipelines.find(id) != pipelines.end()) { auto mw = pipelines[id].getMeshWriter(); - return mw->outputCatalystMeshOneFileON() || mw->outputCatalystMeshFilePerProcON(); + retVal = mw->outputCatalystMeshOneFileON() || mw->outputCatalystMeshFilePerProcON(); } + + return retVal; } void CatalystManager::writeMesh(const CatalystPipelineInfo &cpi) @@ -487,18 +491,17 @@ namespace Iovs { CatalystPipelineID id = cpi.catalystPipelineID; if (pipelines.find(id) != pipelines.end()) { - auto mw = pipelines[id].getMeshWriter(); - vtkMultiBlockDataSet *mbds = vtkMultiBlockDataSet::SafeDownCast( - pipelines[id] - .getDataDescription() - ->GetInputDescriptionByName(cpi.catalystInputName.c_str()) - ->GetGrid()); + auto mw = pipelines[id].getMeshWriter(); + vtkDataObject *vobj = pipelines[id] + .getDataDescription() + ->GetInputDescriptionByName(cpi.catalystInputName.c_str()) + ->GetGrid(); int timeStep = pipelines[id].getDataDescription()->GetTimeStep(); if (mw->outputCatalystMeshOneFileON()) { - mw->writeCatalystMeshOneFile(mbds, timeStep); + mw->writeCatalystMeshOneFile(vobj, timeStep); } if (mw->outputCatalystMeshFilePerProcON()) { - mw->writeCatalystMeshFilePerProc(mbds, timeStep); + mw->writeCatalystMeshFilePerProc(vobj, timeStep); } } } diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystManager.h b/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystManager.h index 59c6280979..f791fb3ce7 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystManager.h +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystManager.h @@ -17,7 +17,7 @@ class coProcessor; class vtkDoubleArray; class vtkCPPythonPipeline; class vtkCPProcessor; -class vtkMultiBlockDataSet; +class vtkDataObject; namespace Iovs { @@ -27,9 +27,10 @@ namespace Iovs { { public: - using CatalystPipelineID = unsigned int; - using CatalystInputName = std::string; - using CatalystMultiInputPipelineName = std::string; + const std::string catalystPluginVersion = "2.0.0"; + using CatalystPipelineID = unsigned int; + using CatalystInputName = std::string; + using CatalystMultiInputPipelineName = std::string; CatalystManager(); ~CatalystManager(); @@ -38,6 +39,8 @@ namespace Iovs { void parsePhactoriString(const std::string &phactori, ParseResult &pres); + std::string getCatalystPluginVersion(); + std::unique_ptr createCatalystExodusMesh(CatalystExodusMeshInit &cmInit); @@ -63,8 +66,8 @@ namespace Iovs { // Description: // Calls the ParaView Catalyst pipeline to run co-processing for this time iteration. - void PerformCoProcessing(std::vector & error_and_warning_codes, - std::vector & error_and_warning_messages, + void PerformCoProcessing(std::vector &error_and_warning_codes, + std::vector &error_and_warning_messages, const CatalystPipelineInfo &cpi); // Description: @@ -83,7 +86,6 @@ namespace Iovs { void WriteToLogFile(const CatalystPipelineInfo &cpi); private: - void initCatalystPythonSystemPaths(); class CatalystPipelineState @@ -142,7 +144,7 @@ namespace Iovs { typedef std::pair TimerPair; typedef std::pair LoggingPair; - CatalystManager(const CatalystManager &) = delete; + CatalystManager(const CatalystManager &) = delete; CatalystManager &operator=(const CatalystManager &) = delete; void initializeIfNeeded(); @@ -153,17 +155,17 @@ namespace Iovs { void writeMesh(const CatalystPipelineInfo &cpi); CatalystPipelineID getCatalystPipelineID(CatalystMeshInit &cmInit); - void initCatalystLogging(const CatalystPipelineInfo &cpi); - void initCatalystPipeline(CatalystMeshInit &cmInit, vtkMultiBlockDataSet *mbds, - const CatalystPipelineInfo &cpi); - void addInputToPipeline(vtkMultiBlockDataSet *mbds, const CatalystPipelineInfo &cpi); + void initCatalystLogging(const CatalystPipelineInfo &cpi); + void initCatalystPipeline(CatalystMeshInit &cmInit, vtkDataObject *vobj, + const CatalystPipelineInfo &cpi); + void addInputToPipeline(vtkDataObject *vobj, const CatalystPipelineInfo &cpi); CatalystPipelineInfo createCatalystPipelineInfo(CatalystMeshInit &cmInit); - void registerMeshInPipeline(CatalystMeshInit &cmInit, vtkMultiBlockDataSet *mbds, - const CatalystPipelineInfo &cpi); + void registerMeshInPipeline(CatalystMeshInit &cmInit, vtkDataObject *vobj, + const CatalystPipelineInfo &cpi); CatalystPipelineID catalystOutputIDNumber; CatalystPipelineID catalystOutputReferenceCount; - vtkCPProcessor * coProcessor; + vtkCPProcessor *coProcessor; std::map pipelines; std::map logging; std::map multiInputPipelines; diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystMeshWriter.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystMeshWriter.cxx index 1cb3f679f1..e8ceb70532 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystMeshWriter.cxx +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystMeshWriter.cxx @@ -5,82 +5,75 @@ // See packages/seacas/LICENSE for details #include "CatalystMeshWriter.h" -#include "vtkMultiBlockDataSet.h" -#include "vtkXMLPMultiBlockDataWriter.h" -#include "vtkXMLMultiBlockDataWriter.h" -#include "vtkTrivialProducer.h" #include "vtkMultiProcessController.h" +#include "vtkPartitionedDataSetCollection.h" +#include "vtkTrivialProducer.h" +#include "vtkXMLPartitionedDataSetCollectionWriter.h" +#include +#include namespace Iovs { -CatalystMeshWriter::CatalystMeshWriter() { - this->catalystMeshOneFile = false; + CatalystMeshWriter::CatalystMeshWriter() + { + this->catalystMeshOneFile = false; this->catalystMeshFilePerProc = false; -} - -CatalystMeshWriter::~CatalystMeshWriter() { + } -} + CatalystMeshWriter::~CatalystMeshWriter() {} -bool CatalystMeshWriter::outputCatalystMeshOneFileON() { - return this->catalystMeshOneFile; -} + bool CatalystMeshWriter::outputCatalystMeshOneFileON() { return this->catalystMeshOneFile; } -void CatalystMeshWriter::setOutputCatalystMeshOneFilePrefix( - std::string & prefix) { + void CatalystMeshWriter::setOutputCatalystMeshOneFilePrefix(std::string &prefix) + { this->catalystMeshOneFilePrefix = prefix; - this->catalystMeshOneFile = true; -} + this->catalystMeshOneFile = true; + } -bool CatalystMeshWriter::outputCatalystMeshFilePerProcON() { + bool CatalystMeshWriter::outputCatalystMeshFilePerProcON() + { return this->catalystMeshFilePerProc; -} + } -void CatalystMeshWriter::setOutputCatalystMeshFilePerProcPrefix( - std::string & prefix) { + void CatalystMeshWriter::setOutputCatalystMeshFilePerProcPrefix(std::string &prefix) + { this->catalystMeshFilePerProcPrefix = prefix; - this->catalystMeshFilePerProc = true; -} - -void CatalystMeshWriter::writeCatalystMeshOneFile(vtkMultiBlockDataSet* mbds, - int timeStep) { - - vtkTrivialProducer* producer = vtkTrivialProducer::New(); - producer->SetOutput(mbds); - vtkMultiProcessController* controller = - vtkMultiProcessController::GetGlobalController(); - int myRank = controller->GetLocalProcessId(); - int numRanks = controller->GetNumberOfProcesses(); - vtkXMLPMultiBlockDataWriter* writer = - vtkXMLPMultiBlockDataWriter::New(); + this->catalystMeshFilePerProc = true; + } + + void CatalystMeshWriter::writeCatalystMeshOneFile(vtkDataObject *dobj, int timeStep) + { + + vtkNew producer; + producer->SetOutput(dobj); + vtkMultiProcessController *controller = vtkMultiProcessController::GetGlobalController(); + int myRank = controller->GetLocalProcessId(); + int numRanks = controller->GetNumberOfProcesses(); + + vtkNew writer; writer->SetController(controller); writer->SetInputConnection(producer->GetOutputPort()); - writer->SetNumberOfPieces(numRanks); - writer->SetStartPiece(myRank); std::ostringstream extension; extension << "." << writer->GetDefaultFileExtension(); std::ostringstream time; time << timeStep; - std::string fileName = this->catalystMeshOneFilePrefix +\ - "_time_" + time.str() + extension.str(); + std::string fileName = + this->catalystMeshOneFilePrefix + "_time_" + time.str() + extension.str(); writer->SetFileName(fileName.c_str()); writer->Write(); - writer->Delete(); - producer->Delete(); -} - -void CatalystMeshWriter::writeCatalystMeshFilePerProc( - vtkMultiBlockDataSet* mbds, int timeStep) { - - vtkTrivialProducer* producer = vtkTrivialProducer::New(); - producer->SetOutput(mbds); - vtkMultiProcessController* controller = - vtkMultiProcessController::GetGlobalController(); - int myRank = controller->GetLocalProcessId(); - vtkXMLMultiBlockDataWriter* writer = - vtkXMLMultiBlockDataWriter::New(); + } + + void CatalystMeshWriter::writeCatalystMeshFilePerProc(vtkDataObject *dobj, int timeStep) + { + + vtkNew producer; + producer->SetOutput(dobj); + vtkMultiProcessController *controller = vtkMultiProcessController::GetGlobalController(); + int myRank = controller->GetLocalProcessId(); + + vtkNew writer; writer->SetInputConnection(producer->GetOutputPort()); std::ostringstream extension; extension << "." << writer->GetDefaultFileExtension(); @@ -88,12 +81,10 @@ void CatalystMeshWriter::writeCatalystMeshFilePerProc( time << timeStep; std::ostringstream proc; proc << myRank; - std::string fileName = this->catalystMeshFilePerProcPrefix +\ - "_proc_" + proc.str() + "_time_" + time.str() + extension.str(); + std::string fileName = this->catalystMeshFilePerProcPrefix + "_proc_" + proc.str() + "_time_" + + time.str() + extension.str(); writer->SetFileName(fileName.c_str()); writer->Write(); - writer->Delete(); - producer->Delete(); -} + } } // namespace Iovs diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystMeshWriter.h b/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystMeshWriter.h index 87ebb75fd4..199a34807e 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystMeshWriter.h +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/manager/CatalystMeshWriter.h @@ -9,7 +9,7 @@ #include -class vtkMultiBlockDataSet; +class vtkDataObject; namespace Iovs { @@ -26,8 +26,8 @@ class CatalystMeshWriter { bool outputCatalystMeshFilePerProcON(); void setOutputCatalystMeshFilePerProcPrefix(std::string & prefix); - void writeCatalystMeshOneFile(vtkMultiBlockDataSet* mbds, int timeStep); - void writeCatalystMeshFilePerProc(vtkMultiBlockDataSet* mbds, int timeStep); + void writeCatalystMeshOneFile(vtkDataObject* dobj, int timeStep); + void writeCatalystMeshFilePerProc(vtkDataObject* dobj, int timeStep); private: diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/parser/CMakeLists.txt b/packages/seacas/libraries/ioss/src/visualization/catalyst/parser/CMakeLists.txt index afcef80c27..af3ad3ab34 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/parser/CMakeLists.txt +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/parser/CMakeLists.txt @@ -34,8 +34,8 @@ ENDIF() SET_SOURCE_FILES_PROPERTIES(${FlexOutput} PROPERTIES GENERATED TRUE) SET_SOURCE_FILES_PROPERTIES(${BisonOutput} PROPERTIES GENERATED TRUE) -TRIBITS_INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR}) -TRIBITS_INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}) +INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR}) +INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}) FIND_PACKAGE(ParaView QUIET) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/parser/phactoriParser.ypp b/packages/seacas/libraries/ioss/src/visualization/catalyst/parser/phactoriParser.ypp index 3950c29508..d6f802dca9 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/parser/phactoriParser.ypp +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/parser/phactoriParser.ypp @@ -31,7 +31,7 @@ namespace { this->checkNodeIDRange = false; this->checkElementIDRange = false; } - + ~ParseData() { this->root.clear(); @@ -62,7 +62,7 @@ namespace { ParseData& c(void* pd) { return *(static_cast(pd)); } - + std::vector getTokensBeforeEqualsAsLowerCase( const std::string & line); std::string getStringAfterEquals(const std::string & line); @@ -463,10 +463,10 @@ bool check_color_name(YYLTYPE * llocp, yyscan_t yyscanner, ParseData& pd, const return false; } -bool check_plot_axes(YYLTYPE * llocp, - yyscan_t yyscanner, - ParseData& pd, - const Json::Value& c, +bool check_plot_axes(YYLTYPE * llocp, + yyscan_t yyscanner, + ParseData& pd, + const Json::Value& c, const std::string& axis) { if(c.isMember(axis + " axis range") && (c.isMember(axis + " axis use current data range") || @@ -1050,14 +1050,14 @@ void switch_variable_to_used(const std::string& name, } } -bool compare_variable_type(const std::string& name, +bool compare_variable_type(const std::string& name, Iovs::PhactoriParserInterface::varMap& v, Iovs::PhactoriParserInterface::VarType vt) { if(v.find(name) != v.end()) { - if( v[name] == vt || - v[name] == Iovs::PhactoriParserInterface::ALLTYPE || + if( v[name] == vt || + v[name] == Iovs::PhactoriParserInterface::ALLTYPE || v[name] == Iovs::PhactoriParserInterface::ALLTYPE_USED ) return true; else if( v[name] == Iovs::PhactoriParserInterface::SCALAR_USED && @@ -1066,7 +1066,7 @@ bool compare_variable_type(const std::string& name, else if( v[name] == Iovs::PhactoriParserInterface::VECTOR_USED && vt == Iovs::PhactoriParserInterface::VECTOR ) return true; - else if( v[name] == Iovs::PhactoriParserInterface::TENSOR_USED && + else if( v[name] == Iovs::PhactoriParserInterface::TENSOR_USED && vt == Iovs::PhactoriParserInterface::TENSOR ) return true; } @@ -1076,7 +1076,7 @@ bool compare_variable_type(const std::string& name, bool check_variable_name(YYLTYPE * llocp, yyscan_t yyscanner, ParseData& pd, - const std::string& name, + const std::string& name, Iovs::PhactoriParserInterface::VarType vt) { if (!pd.nodeVars.empty() && !pd.elementVars.empty() && !pd.globalVars.empty()) @@ -1471,8 +1471,8 @@ void four_argument_command(ParseData& pd, bool check_two_argument_command(YYLTYPE * llocp, yyscan_t yyscanner, ParseData& pd, - const std::string& command, - const std::string& position, + const std::string& command, + const std::string& position, double value) { if(value < 0 || value > 1) @@ -1530,7 +1530,7 @@ void no_argument_command(ParseData& pd, template void vector_command(ParseData& pd, - const std::string& command, + const std::string& command, std::vector& values) { Json::Value a(Json::arrayValue); @@ -1566,7 +1566,7 @@ void vector_command(ParseData& pd, } void string_vector_command(ParseData& pd, - const std::string& command, + const std::string& command, std::vector& values) { Json::Value a(Json::arrayValue); @@ -1584,7 +1584,7 @@ void string_vector_command(ParseData& pd, } void identifier_command(ParseData& pd, - const std::string& command, + const std::string& command, const std::string& identifier) { if (pd.cb == TOKCATALYST) @@ -1643,7 +1643,7 @@ void boolean_command(ParseData& pd, } void integer_command(ParseData& pd, - const std::string& command, + const std::string& command, int value) { if (pd.cb == TOKCATALYST) @@ -2349,9 +2349,9 @@ show_bouding_box ; color_by_scalar - : TOKCOLORBYSCALAR TOKEQUAL TOKIDENTIFIER - { - if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::SCALAR)) + : TOKCOLORBYSCALAR TOKEQUAL TOKIDENTIFIER + { + if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::SCALAR)) YYABORT; identifier_command(c(pd), "color by scalar", $3); } @@ -2360,7 +2360,7 @@ color_by_scalar color_by_vector_magnitude : TOKCOLORBYVECTORMAGNITUDE TOKEQUAL TOKIDENTIFIER { - if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::VECTOR)) + if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::VECTOR)) YYABORT; identifier_command(c(pd), "color by vector magnitude", $3); } @@ -2398,8 +2398,8 @@ color_by_solid_color c(pd).d.push_back($3); c(pd).d.push_back($4); c(pd).d.push_back($5); - vector_command(c(pd), "color by solid color", c(pd).d); - } + vector_command(c(pd), "color by solid color", c(pd).d); + } ; color_by_blockid @@ -3179,8 +3179,8 @@ background_color c(pd).d.push_back($3); c(pd).d.push_back($4); c(pd).d.push_back($5); - vector_command(c(pd), "background color", c(pd).d); - } + vector_command(c(pd), "background color", c(pd).d); + } ; surface_color @@ -3197,8 +3197,8 @@ surface_color c(pd).d.push_back($3); c(pd).d.push_back($4); c(pd).d.push_back($5); - vector_command(c(pd), "surface color", c(pd).d); - } + vector_command(c(pd), "surface color", c(pd).d); + } ; edge_color @@ -3215,8 +3215,8 @@ edge_color c(pd).d.push_back($3); c(pd).d.push_back($4); c(pd).d.push_back($5); - vector_command(c(pd), "edge color", c(pd).d); - } + vector_command(c(pd), "edge color", c(pd).d); + } ; text_color @@ -3233,8 +3233,8 @@ text_color c(pd).d.push_back($3); c(pd).d.push_back($4); c(pd).d.push_back($5); - vector_command(c(pd), "text color", c(pd).d); - } + vector_command(c(pd), "text color", c(pd).d); + } ; axes_color @@ -3251,8 +3251,8 @@ axes_color c(pd).d.push_back($3); c(pd).d.push_back($4); c(pd).d.push_back($5); - vector_command(c(pd), "axes color", c(pd).d); - } + vector_command(c(pd), "axes color", c(pd).d); + } ; threshold_shortcut @@ -3475,7 +3475,7 @@ absolute_point_on_plane c(pd).d.push_back($3); c(pd).d.push_back($4); c(pd).d.push_back($5); - vector_command(c(pd), "absolute point on plane", c(pd).d); + vector_command(c(pd), "absolute point on plane", c(pd).d); } | TOKABSOLUTEPOINTONPLANE point_location TOKEQUAL TOKVALUE TOKVALUE TOKVALUE { @@ -3485,7 +3485,7 @@ absolute_point_on_plane c(pd).d.push_back($4); c(pd).d.push_back($5); c(pd).d.push_back($6); - vector_command(c(pd), "absolute point on plane " + ct, c(pd).d); + vector_command(c(pd), "absolute point on plane " + ct, c(pd).d); } ; @@ -3506,7 +3506,7 @@ relative_point_on_plane c(pd).d.push_back($4); c(pd).d.push_back($5); c(pd).d.push_back($6); - vector_command(c(pd), "relative point on plane " + ct, c(pd).d); + vector_command(c(pd), "relative point on plane " + ct, c(pd).d); } ; @@ -3725,7 +3725,7 @@ center_at_absolute_point c(pd).d.push_back($3); c(pd).d.push_back($4); c(pd).d.push_back($5); - vector_command(c(pd), "center at absolute point", c(pd).d); + vector_command(c(pd), "center at absolute point", c(pd).d); } ; @@ -3736,7 +3736,7 @@ center_at_relative_point c(pd).d.push_back($3); c(pd).d.push_back($4); c(pd).d.push_back($5); - vector_command(c(pd), "center at relative point", c(pd).d); + vector_command(c(pd), "center at relative point", c(pd).d); } ; @@ -3864,18 +3864,18 @@ threshold_statement ; variable_scalar - : TOKVARIABLESCALAR TOKEQUAL TOKIDENTIFIER - { - if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::SCALAR)) + : TOKVARIABLESCALAR TOKEQUAL TOKIDENTIFIER + { + if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::SCALAR)) YYABORT; identifier_command(c(pd), "variable scalar", $3); } ; variable_vector_magnitude - : TOKVARIABLEVECTORMAGNITUDE TOKEQUAL TOKIDENTIFIER - { - if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::VECTOR)) + : TOKVARIABLEVECTORMAGNITUDE TOKEQUAL TOKIDENTIFIER + { + if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::VECTOR)) YYABORT; identifier_command(c(pd), "variable vector magnitude", $3); } @@ -4066,17 +4066,17 @@ all_variables ; x_axis_variable_scalar - : TOKXAXISVARIABLESCALAR TOKEQUAL TOKIDENTIFIER - { - if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::SCALAR)) + : TOKXAXISVARIABLESCALAR TOKEQUAL TOKIDENTIFIER + { + if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::SCALAR)) YYABORT; identifier_command(c(pd), "x axis variable scalar", $3); } ; y_axis_variable_scalar - : TOKYAXISVARIABLESCALAR TOKEQUAL TOKIDENTIFIER - { + : TOKYAXISVARIABLESCALAR TOKEQUAL TOKIDENTIFIER + { if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::SCALAR)) YYABORT; identifier_command(c(pd), "y axis variable scalar", $3); @@ -4084,8 +4084,8 @@ y_axis_variable_scalar ; x_axis_variable_vector_magnitude - : TOKXAXISVARIABLEVECTORMAGNITUDE TOKEQUAL TOKIDENTIFIER - { + : TOKXAXISVARIABLEVECTORMAGNITUDE TOKEQUAL TOKIDENTIFIER + { if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::VECTOR)) YYABORT; identifier_command(c(pd), "x axis variable vector magnitude", $3); @@ -4093,8 +4093,8 @@ x_axis_variable_vector_magnitude ; y_axis_variable_vector_magnitude - : TOKYAXISVARIABLEVECTORMAGNITUDE TOKEQUAL TOKIDENTIFIER - { + : TOKYAXISVARIABLEVECTORMAGNITUDE TOKEQUAL TOKIDENTIFIER + { if(!check_variable_name(&yylloc, scanner, c(pd), $3, Iovs::PhactoriParserInterface::VECTOR)) YYABORT; identifier_command(c(pd), "y axis variable vector magnitude", $3); diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriAppendLocationAttributesOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriAppendLocationAttributesOperation.py index 0410c6aa4b..67145dfed5 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriAppendLocationAttributesOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriAppendLocationAttributesOperation.py @@ -57,7 +57,7 @@ def ParseParametersFromJson(self, inJson): self.AppendPointLocations = 1 else: self.AppendPointLocations = 0 - + key2 = "append cell centers" if key2 in inJson: testval = inJson[key2] @@ -80,7 +80,7 @@ def CreateParaViewFilter(self, inInputFilter): if PhactoriDbg(100): myDebugPrint3('PhactoriAppendLocationAttributesOperation:CreateParaViewFilter entered\n', 100) #info in block class should already be parsed and checked - + if PhactoriDbg(100): myDebugPrint3('about to call UpdatePipelineWithCurrentTimeArgument\n', 100) UpdatePipelineWithCurrentTimeArgument(inInputFilter) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCSVExportOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCSVExportOperation.py index 98ae7a4e69..1b3f23be72 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCSVExportOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCSVExportOperation.py @@ -67,7 +67,7 @@ def ParseOutputFilenameParametersFromJson(self, inJson): if (self.Precision < 1) or (self.Precision > 100): myDebugPrint3AndException("PhactoriCSVExportOperation:\n" "precision must be 1-100, not " + str(self.Precision) + "\n") - + def ParseParametersFromJson(self, inJson): self.ParseOutputFilenameParametersFromJson(inJson) @@ -120,3 +120,4 @@ def ExportOperationData(self, datadescription): "ExportOperationData returning\n", 100) #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCalculatorOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCalculatorOperation.py index fb8ead3ea0..8338bd8bcb 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCalculatorOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCalculatorOperation.py @@ -107,7 +107,7 @@ def CreateParaViewFilter(self, inInputFilter): numArrays = inInputFilter.PointData.GetNumberOfArrays() for ii in range (0, numArrays): myDebugPrint3(" " + str(ii) + ": " + inInputFilter.PointData.GetArray(ii).GetName() + "\n") - + if PhactoriDbg(): myDebugPrint3(" calculator inInputFilter cell data arrays:\n") numArrays = inInputFilter.CellData.GetNumberOfArrays() diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCellDataToPointDataOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCellDataToPointDataOperation.py index 1f23a8be8b..62ea18b8e5 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCellDataToPointDataOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCellDataToPointDataOperation.py @@ -37,29 +37,37 @@ class PhactoriCellDataToPointDataOperation(PhactoriOperationSpecifics): def __init__(self): PhactoriOperationSpecifics.__init__(self) + self.passCellData = 0 + self.pieceInvariant = 0 return def ParseParametersFromJson(self, inJson): + key1 = "pass cell data" + if key1 in inJson: + self.passCellData = inJson[key1] + key1 = "piece invariant" + if key1 in inJson: + self.pieceInvariant = inJson[key1] return def CreateParaViewFilter(self, inInputFilter): if PhactoriDbg(100): myDebugPrint3('PhactoriCellDataToPointDataOperation:CreateParaViewFilter entered\n', 100) - #info in block class should already be parsed and checked - - if PhactoriDbg(100): - myDebugPrint3('about to call UpdatePipelineWithCurrentTimeArgument\n', 100) UpdatePipelineWithCurrentTimeArgument(inInputFilter) savedActiveSource = GetActiveSource() - if PhactoriDbg(100): - myDebugPrint3('about to call CellDatatoPointData\n', 100) newParaViewFilter = CellDatatoPointData(Input = inInputFilter) + if self.passCellData: + newParaViewFilter.PassCellData = 1 + else: + newParaViewFilter.PassCellData = 0 + if self.pieceInvariant: + newParaViewFilter.PieceInvariant = 1 + else: + newParaViewFilter.PieceInvariant = 0 SetActiveSource(newParaViewFilter) - if PhactoriDbg(100): - myDebugPrint3('about to call UpdatePipelineWithCurrentTimeArgument\n', 100) UpdatePipelineWithCurrentTimeArgument(newParaViewFilter) SetActiveSource(savedActiveSource) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCellEdgeAngleMetrics.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCellEdgeAngleMetrics.py index dd1d6e92fb..bb0f36aed7 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCellEdgeAngleMetrics.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCellEdgeAngleMetrics.py @@ -86,10 +86,10 @@ def ParseParametersFromJson(self, inJson): self.OffsetIndex = 0 keyval10 = "output angle cell variable name" - if keyval10 in inJson: + if keyval10 in inJson: self.OutputAngleCellVariableName = inJson[keyval10] keyval10 = "output height cell variable name" - if keyval10 in inJson: + if keyval10 in inJson: self.OutputHeightCellVariableName = inJson[keyval10] keyval11 = "do operation in createparaview method" diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCellSizeOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCellSizeOperation.py index e454d7a202..dea7bce044 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCellSizeOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriCellSizeOperation.py @@ -47,7 +47,7 @@ def CreateParaViewFilter(self, inInputFilter): myDebugPrint3('PhactoriCellSizeOperation:CreateParaViewFilter entered\n', 100) #info in block class should already be parsed and checked - + if PhactoriDbg(100): myDebugPrint3('about to call UpdatePipelineWithCurrentTimeArgument\n', 100) UpdatePipelineWithCurrentTimeArgument(inInputFilter) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriClipPlaneOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriClipPlaneOperation.py index 6ec0cebede..d36a4c4d74 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriClipPlaneOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriClipPlaneOperation.py @@ -191,3 +191,4 @@ def UpdateClip(self, inIncomingPvFilter, ioOutgoingPvFilter): if PhactoriDbg(): myDebugPrint3("PhactoriClipPlaneOperation::UpdateClip returning\n") #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriDataArtifactMetaDataControl.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriDataArtifactMetaDataControl.py index e418d17d0f..e7eb49e320 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriDataArtifactMetaDataControl.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriDataArtifactMetaDataControl.py @@ -111,3 +111,8 @@ def AddImageToDataArtifactOutputList(self, fileName): pdamdc.AddDataExportToDataArtifactOutputList("CatalystVtkDataOutput/test2.vtm") #phactori_combine_to_single_python_file_subpiece_end_1 + + + + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExodusIIExportOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExodusIIExportOperation.py index 65892598b8..6b06fa690d 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExodusIIExportOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExodusIIExportOperation.py @@ -107,3 +107,4 @@ def ExportOperationData(self, datadescription): "ExportOperationData returning\n", 100) #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExtractBlockOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExtractBlockOperation.py index b2384015a1..bc84d49be8 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExtractBlockOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExtractBlockOperation.py @@ -86,13 +86,9 @@ def __init__(self): PhactoriOperationSpecifics.__init__(self) #mIncludeblockList OR mExcludeBlockList will be filled in from parsing self.mIncludeBlockList = None + self.mExpandedIncludeBlockList = None self.mExcludeBlockList = None - self.mFlatBlockIndicesSpecifiedDirectly = False - - #this will be list of included block indicies, and is calculated from - #mIncludeBlockList / mExcludeBlockList and passed directly to - #ExcludeBlockFilter.BlockIndices - self.mBlockIndices = [] + self.mRemoveBlanksAndDashes = True def ParseParametersFromJson(self, inJson): @@ -102,269 +98,35 @@ def ParseParametersFromJson(self, inJson): if 'exclude blocks' in inJson: self.mExcludeBlockList = inJson['exclude blocks'] - if 'include blocks by flat index list' in inJson: - self.mFlatBlockIndicesSpecifiedDirectly = True - self.mBlockIndices = inJson['include blocks by flat index list'] - - if self.mIncludeBlockList == None and self.mExcludeBlockList == None and self.mFlatBlockIndicesSpecifiedDirectly == False: + if self.mIncludeBlockList == None and self.mExcludeBlockList == None: myDebugPrint3AndException( "PhactoriExtractBlockOperation::ParseParametersFromJson\n" - "Error: must have 'include block list' or 'exclude block list' or 'include blocks by flat index list'\n") - - def FigureBlockIndicesFromBlockListOneBlock(self, inMetaData, - ioFlatIndexCounter): - """determine if this one block should have it's flat index tripped on for - the extract block filter (leaf item of recursion)""" - - if inMetaData == None: - thisBlockName = None - else: - thisBlockName = inMetaData.Get(vtk.vtkCompositeDataSet.NAME()) + "Error: must have 'include block list' or 'exclude block list'\n") - if self.mIncludeBlockList != None: - if thisBlockName == None: - if PhactoriDbg(100): - myDebugPrint3("block with no name " + \ - " not in include list, not + to mBlockIndices (flat index " + \ - str(ioFlatIndexCounter[0] - 1) + ")\n") - elif thisBlockName in self.mIncludeBlockList: - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - global gDuplicateNameCounter - if thisBlockName in gDuplicateNameCounter: - oldCount = gDuplicateNameCounter[thisBlockName] - gDuplicateNameCounter[thisBlockName] = oldCount+1 - else: - gDuplicateNameCounter[thisBlockName] = 1 - if PhactoriDbg(100): - myDebugPrint3("block " + str(thisBlockName) + \ - " in include list, + to mBlockIndices (flat index " + \ - str(ioFlatIndexCounter[0] - 1) + ")\n") - else: - if PhactoriDbg(100): - myDebugPrint3("block " + str(thisBlockName) + \ - " not in include list, not + to mBlockIndices (flat index " + \ - str(ioFlatIndexCounter[0] - 1) + ")\n") - elif self.mExcludeBlockList != None: - if thisBlockName == None: - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - if PhactoriDbg(100): - myDebugPrint3("block with no name " + \ - " not in exclude list, + to mBlockIndices (flat index " + \ - str(ioFlatIndexCounter[0] - 1) + ")\n") - elif thisBlockName not in self.mExcludeBlockList: - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - if PhactoriDbg(100): - myDebugPrint3("block " + str(thisBlockName) + \ - " not in exclude list, + to mBlockIndices (flat index " + \ - str(ioFlatIndexCounter[0] - 1) + ")\n") - else: - if PhactoriDbg(100): - myDebugPrint3("block " + str(thisBlockName) + \ - " in exclude list, not + to mBlockIndices (flat index " + \ - str(ioFlatIndexCounter[0] - 1) + ")\n") - else: + #2022Aug09 only include blocks is working + if self.mIncludeBlockList == None: myDebugPrint3AndException( - "PhactoriExtractBlockOperation::" - "FigureBlockIndicesFromBlockListOneBlock\n" - "Error: must have include block list or exclude block list\n") - - def FigureBlockIndicesFromBlockListRecurse1(self, inCsdata, inMetaData, - ioFlatIndexCounter, inForceSetting): - """recursively go through multiblock dataset to determine flat indices - of blocks to be included; we are assuming only leaf blocks are - actually named""" - - icsdClassname = inCsdata.GetClassName() - - if PhactoriDbg(100): - if inMetaData == None: - thisBlockName = None - else: - thisBlockName = inMetaData.Get(vtk.vtkCompositeDataSet.NAME()) - myDebugPrint3("FigureBlockIndicesFromBlockListRecurse1 " + \ - str(thisBlockName) + " index: " + str(int(ioFlatIndexCounter[0])) + \ - " inForceSetting: " + str(inForceSetting) + " classname: " + \ - str(icsdClassname) + "\n") - - ioFlatIndexCounter[0] += 1 - - if icsdClassname == "vtkMultiBlockDataSet": - thisIsLeaf = False - nonLeafType = 0 - elif icsdClassname == "vtkExodusIIMultiBlockDataSet": - thisIsLeaf = False - nonLeafType = 1 - elif icsdClassname == "vtkMultiPieceDataSet": - thisIsLeaf = False - nonLeafType = 2 - elif icsdClassname == "vtkPartitionedDataSet": - thisIsLeaf = False - nonLeafType = 3 - else: - thisIsLeaf = True - nonLeafType = -1 - - if not thisIsLeaf: - if inForceSetting == 1: - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - includeOrExcludeAllSubBlocks = 1 - if PhactoriDbg(100): - myDebugPrint3("this non-leaf block added inForceSetting == 1\n") - elif inForceSetting == -1: - includeOrExcludeAllSubBlocks = -1 - if PhactoriDbg(100): - myDebugPrint3("this non-leaf block not added inForceSetting == -1\n") - else: - includeOrExcludeAllSubBlocks = 0 - #this is a non-leaf node, but we want to add it (or not) depending on - #the filter settings - if inMetaData == None: - thisBlockName = None - else: - thisBlockName = inMetaData.Get(vtk.vtkCompositeDataSet.NAME()) - if self.mIncludeBlockList != None: - if (thisBlockName != None) and (thisBlockName in self.mIncludeBlockList): - if PhactoriDbg(100): - myDebugPrint3("include list, append nonleaf " + str(thisBlockName) + \ - " ndx " + str(int(ioFlatIndexCounter[0]) - 1) + "\n") - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - includeOrExcludeAllSubBlocks = 1 - if PhactoriDbg(100): - myDebugPrint3("includeOrExcludeAllSubBlocks set to 1\n") - else: - if PhactoriDbg(100): - myDebugPrint3("include list, exclude nonleaf " + str(thisBlockName) + \ - " ndx " + str(int(ioFlatIndexCounter[0]) - 1) + "\n") - elif self.mExcludeBlockList != None: - if (thisBlockName == None) or (thisBlockName not in self.mExcludeBlockList): - if PhactoriDbg(100): - myDebugPrint3("exclude list, append nonleaf " + str(thisBlockName) + \ - " ndx " +str(int(ioFlatIndexCounter[0]) - 1) + "\n") - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - else: - if PhactoriDbg(100): - myDebugPrint3("exclude list, exclude nonleaf " + str(thisBlockName) + \ - " ndx " + str(int(ioFlatIndexCounter[0]) - 1) + "\n") - if (thisBlockName != None) and (thisBlockName in self.mExcludeBlockList): - includeOrExcludeAllSubBlocks = -1 - if PhactoriDbg(100): - myDebugPrint3("includeOrExcludeAllSubBlocks set to -1\n") - else: - myDebugPrint3AndException( - "PhactoriExtractBlockOperation::" - "FigureBlockIndicesFromBlockListRecurse1\n" - "Error: must have include block list or exclude block list\n") - - if nonLeafType == 2: - numBlocks = inCsdata.GetNumberOfPieces() - elif nonLeafType == 3: - numBlocks = inCsdata.GetNumberOfPartitions() - else: - numBlocks = inCsdata.GetNumberOfBlocks() - - if PhactoriDbg(100): - myDebugPrint3("recursing, flat index: " + \ - str(ioFlatIndexCounter[0]) + \ - " num blocks: " + \ - str(numBlocks) + "\n") - for ii in range(0, numBlocks): - if nonLeafType == 2: - oneBlock = inCsdata.GetPiece(ii) - elif nonLeafType == 3: - oneBlock = inCsdata.GetPartition(ii) - else: - oneBlock = inCsdata.GetBlock(ii) - oneBlockMetaData = inCsdata.GetMetaData(ii) - if PhactoriDbg(100): - myDebugPrint3("oneBlockMetaData: " + str(oneBlockMetaData) + "\n") - #myDebugPrint3("name: " + \ - # oneBlockMetaData.Get(vtk.vtkCompositeDataSet.NAME()) + "\n") - if oneBlock != None: - if oneBlockMetaData != None: - theBlockName = oneBlockMetaData.Get(vtk.vtkCompositeDataSet.NAME()) - if PhactoriDbg(100): - myDebugPrint3("name for block " + str(ii) + ": " + \ - str(theBlockName) + "\n") - else: - if PhactoriDbg(100): - myDebugPrint3("block " + str(ii) + " meta data was None\n") - self.FigureBlockIndicesFromBlockListRecurse1(oneBlock, - oneBlockMetaData, ioFlatIndexCounter, includeOrExcludeAllSubBlocks) + "PhactoriExtractBlockOperation::ParseParametersFromJson\n" + "Error: must have 'include block list'\n" + "currently (2022Aug09) exclude blocks is not working\n") + + def MakeExpandedIncludeBlockList(self): + if self.mExpandedIncludeBlockList == None: + self.mExpandedIncludeBlockList = list(self.mIncludeBlockList) + for oneItem in self.mIncludeBlockList: + #add leader, remove spaces and dashes, this might change + if self.mRemoveBlanksAndDashes: + baseItem = oneItem.replace(" ","") + baseItem = baseItem.replace("-","") else: - if PhactoriDbg(100): - myDebugPrint3("this sub block is None, now handle it\n") - #I think we need to count here to be okay with pruned stuff; maybe - #we need to set extract block to no pruning (?) - ioFlatIndexCounter[0] += 1 - if includeOrExcludeAllSubBlocks == 1: - if PhactoriDbg(100): - myDebugPrint3("leaf block None index " + \ - str(int(ioFlatIndexCounter[0]) - 1) + \ - " appended due to includeOrExcludeAllSubBlocks == 1\n") - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - else: - if PhactoriDbg(100): - myDebugPrint3("force include is not on, so check include list\n") - includeThisBlock = False - if (self.mIncludeBlockList != None) and (oneBlockMetaData != None): - thisBlockName = oneBlockMetaData.Get(vtk.vtkCompositeDataSet.NAME()) - if PhactoriDbg(100): - myDebugPrint3("include list not None, thisBlockName " + str(thisBlockName) + "\n" - "self.mIncludeBlockList " + str(self.mIncludeBlockList) + "\n") - myDebugPrint3("thisBlockName != None: " + str(thisBlockName != None) + "\n") - myDebugPrint3("in list: " + str(thisBlockName in self.mIncludeBlockList) + "\n") - if (thisBlockName != None) and (thisBlockName in self.mIncludeBlockList): - includeThisBlock = True - if PhactoriDbg(100): - myDebugPrint3("leaf block None index " + \ - str(int(ioFlatIndexCounter[0]) - 1) + \ - " included due to name being in self.mIncludeBlockList\n") - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - if includeThisBlock == False: - if PhactoriDbg(100): - myDebugPrint3("leaf block None index " + \ - str(int(ioFlatIndexCounter[0]) - 1) + \ - " excluded due to includeOrExcludeAllSubBlocks != 1\n") - else: - if inForceSetting == 1: - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - if PhactoriDbg(100): - myDebugPrint3("this leaf block added inForceSetting == 1\n") - elif inForceSetting != -1: - self.FigureBlockIndicesFromBlockListOneBlock(inMetaData, - ioFlatIndexCounter) - else: - if PhactoriDbg(100): - myDebugPrint3("this leaf block not added inForceSetting == -1\n") - #if icsdClassname == "vtkMultiPieceDataSet": - # numpieces = inCsdata.GetNumberOfPieces() - # # ioFlatIndexCounter[0] += numpieces - 1 - # ioFlatIndexCounter[0] += numpieces - - - def FigureBlockIndicesFromBlockList(self, inInputFilter): - """from the list of include/exclude blocks create a indices list - of blocks to put in filter""" - if PhactoriDbg(100): - myDebugPrint3("FigureBlockIndicesFromBlockList entered" - "\nself.mIncludeBlockList: " + str(self.mIncludeBlockList) + \ - "\nself.mExcludeBlockList: " + str(self.mExcludeBlockList) + "\n") - - global gDuplicateNameCounter - gDuplicateNameCounter = {} - csdata = inInputFilter.GetClientSideObject().GetOutputDataObject(0) - flatIndexCounter = [0] - self.FigureBlockIndicesFromBlockListRecurse1(csdata, None, - flatIndexCounter, 0) - - if PhactoriDbg(100): - myDebugPrint3("number of times existing block names found:\n") - for blknm, count in gDuplicateNameCounter.items(): - myDebugPrint3(blknm + ": " + str(count) + "\n"); + baseItem = oneItem + extraItem = "/Root/ElementBlocks/" + baseItem + self.mExpandedIncludeBlockList.append(extraItem) + extraItem = "/Root/Bases/Base/Zones/" + baseItem + self.mExpandedIncludeBlockList.append(extraItem) if PhactoriDbg(100): - myDebugPrint3("FigureBlockIndicesFromBlockList final indices list:\n" \ - + str(self.mBlockIndices) + \ - "\nFigureBlockIndicesFromBlockList returning\n") + myDebugPrint3("self.mExpandedIncludeBlockList:\n" + \ + str(self.mExpandedIncludeBlockList) + "\n") def CreateParaViewFilter(self, inInputFilter): """create the extract block filter for ParaView""" @@ -382,7 +144,7 @@ def CreateParaViewFilter(self, inInputFilter): numArrays = inInputFilter.PointData.GetNumberOfArrays() for ii in range (0, numArrays): myDebugPrint3(" " + str(ii) + ": " + inInputFilter.PointData.GetArray(ii).GetName() + "\n") - + if PhactoriDbg(): myDebugPrint3(" extractblock inInputFilter cell data arrays:\n") numArrays = inInputFilter.CellData.GetNumberOfArrays() @@ -390,15 +152,8 @@ def CreateParaViewFilter(self, inInputFilter): myDebugPrint3(" " + str(ii) + ": " + inInputFilter.CellData.GetArray(ii).GetName() + "\n") newParaViewFilter = ExtractBlock(inInputFilter) - - if self.mFlatBlockIndicesSpecifiedDirectly == False: - self.FigureBlockIndicesFromBlockList(inInputFilter) - - #newParaViewFilter.PruneOutput = 1 - #newParaViewFilter.MaintainStructure = 0 - newParaViewFilter.MaintainStructure = 1 - - newParaViewFilter.BlockIndices = self.mBlockIndices + self.MakeExpandedIncludeBlockList() + newParaViewFilter.Selectors = self.mExpandedIncludeBlockList SetActiveSource(newParaViewFilter) @@ -408,7 +163,7 @@ def CreateParaViewFilter(self, inInputFilter): numArrays = newParaViewFilter.PointData.GetNumberOfArrays() for ii in range (0, numArrays): myDebugPrint3(" " + str(ii) + ": " + newParaViewFilter.PointData.GetArray(ii).GetName() + "\n") - + if PhactoriDbg(): myDebugPrint3(" extractblock newParaViewFilter cell data arrays:\n") numArrays = newParaViewFilter.CellData.GetNumberOfArrays() diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExtractComponentOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExtractComponentOperation.py index 314159a2e4..43c1a54246 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExtractComponentOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExtractComponentOperation.py @@ -84,7 +84,7 @@ def CreateParaViewFilter(self, inInputFilter): if PhactoriDbg(100): myDebugPrint3("PhactoriExtractComponentOperation:CreateParaViewFilter entered\n", 100) #info in block class should already be parsed and checked - + if PhactoriDbg(100): myDebugPrint3("about to call UpdatePipelineWithCurrentTimeArgument\n", 100) UpdatePipelineWithCurrentTimeArgument(inInputFilter) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExtractStructuredMultiBlock.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExtractStructuredMultiBlock.py index 5df69d1fd2..ea12784fbe 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExtractStructuredMultiBlock.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriExtractStructuredMultiBlock.py @@ -255,7 +255,7 @@ def FigureBlockIndicesFromBlockList(includeBlockList, inInputFilter): listOfBlockIndicesToInclude = [] FigureBlockIndicesFromBlockListRecurse1(listOfBlockIndicesToInclude, includeBlockList, csdata, None, flatIndexCounter, 0) - + #if PhactoriDbg(100): # myDebugPrint3("number of times existing block names found:\n") # for blknm, count in gDuplicateNameCounter.items(): @@ -373,7 +373,7 @@ def ParseParametersFromJson(self, inJson): def MakeExtractBlockFilter(self, inInputFilter, blockName): if PhactoriDbg(100): myDebugPrint3("MakeExtractBlockFilter entered: " + str(blockName) + "\n") - newPvExtractBlockFilter = ExtractBlock(inInputFilter) + newPvExtractBlockFilter = ExtractBlock(inInputFilter) #newParaViewFilter.PruneOutput = 1 #newParaViewFilter.MaintainStructure = 0 #newParaViewFilter.MaintainStructure = 1 @@ -404,7 +404,7 @@ def CreateIjkRangeFromSettingsForThisBlock(self, ijkJson, blockExtent): rngFunc = [0,0,0,0,0,0] if rngFuncAllAbsolute: - retIjkRange = ijkJson["ijkrange"] + retIjkRange = ijkJson["ijkrange"] if PhactoriDbg(100): myDebugPrint3("rngFunc is [0,0,0,0,0,0], all absolute, " "so just return explicit ijkrange:\nretIjkRange: \n" + \ @@ -417,7 +417,7 @@ def CreateIjkRangeFromSettingsForThisBlock(self, ijkJson, blockExtent): return [0,-1,0,-1,0,-1] if "ijkrange" in ijkJson: - ijkRangeFromJson = ijkJson["ijkrange"] + ijkRangeFromJson = ijkJson["ijkrange"] else: ijkRangeFromJson = [0,0,0,0,0,0] @@ -458,22 +458,22 @@ def CreateIjkRangeFromSettingsForThisBlock(self, ijkJson, blockExtent): if hadToCorrect: if PhactoriDbg(100): myDebugPrint3("return ijkrange had to be corrected because it was outside block extent" - "\nblockExtent: " + str(blockExtent) + - "\nijkRangeFromJson: " + str(retIjkRange) + - "\nrngFunc (from json): " + str(rngFunc) + + "\nblockExtent: " + str(blockExtent) + + "\nijkRangeFromJson: " + str(retIjkRange) + + "\nrngFunc (from json): " + str(rngFunc) + "\nuncorrectedIjkRange: " + str(uncorrectedIjkRange) + "\nretIjkRange: " + str(retIjkRange) + "\n") else: if PhactoriDbg(100): myDebugPrint3("return ijkrange did not need correction" - "\nblockExtent: " + str(blockExtent) + + "\nblockExtent: " + str(blockExtent) + "\nijkRangeFromJson: " + str(retIjkRange) + - "\nrngFunc (from json): " + str(rngFunc) + + "\nrngFunc (from json): " + str(rngFunc) + "\nretIjkRange: " + str(retIjkRange) + "\n") return retIjkRange - - + + def MakeExtractSubsetFilter(self, extractBlockFilter, oneBlockExtractSubsetJson, oneBlockExtents): if PhactoriDbg(100): myDebugPrint3("MakeOneExtractBlockExtractSubsetFilter entered\n") @@ -523,7 +523,7 @@ def MakeGroupAllExtractSubsetsFilter(self): if PhactoriDbg(100): myDebugPrint3("MakeGroupAllExtractSubsetsFilter returning\n") - + def CreateParaViewFilter(self, inInputFilter): """create the PhactoriExtractStructuredMultiBlock filter for ParaView""" if PhactoriDbg(100): diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriFindCellEdgeLengths.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriFindCellEdgeLengths.py index 1beb74aa56..31b2274c95 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriFindCellEdgeLengths.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriFindCellEdgeLengths.py @@ -77,7 +77,7 @@ def ParseParametersFromJson(self, inJson): self.OutputShortestLongestIndex = 0 keyval10 = "output cell variable name" - if keyval10 in inJson: + if keyval10 in inJson: self.ProgrammableFilterOutputCellVariableName = inJson[keyval10] def CreateParaViewFilter(self, inInputFilter): diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriFollowSurfaceSide1.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriFollowSurfaceSide1.py index 8bf0a0bb73..ca57fde79b 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriFollowSurfaceSide1.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriFollowSurfaceSide1.py @@ -82,7 +82,7 @@ def ParseParametersFromJson(self, inJson): self.OffsetIndex = 0 keyval10 = "output cell variable name" - if keyval10 in inJson: + if keyval10 in inJson: self.ProgrammableFilterOutputCellVariableName = inJson[keyval10] def CreateParaViewFilter(self, inInputFilter): @@ -128,7 +128,7 @@ def CreateParaViewFilter(self, inInputFilter): # lvly[zz] = 0 # lvlz = lvly[zz] # lvly[zz] = lvlz + 1 - + @staticmethod def IncrementTouchingCellCountForAllPointsInOneCell(inInputCsData, inParameters, inCellIndex, cellsTouchingPointCount): @@ -389,7 +389,7 @@ def FindWhichSurfaceCellsTouchEachPoint(inInputCsData, surfaceCellMap): for ptId, cellList in cellsTouchingPoints: myDebugPrint(str(ptId) + " " + str(celllist) + "\n") return cellsTouchingPoints - + def FollowSurfaceSideFromSeedCell(inInputCsData, seedCellIndex, surfaceStatus): #get a list of all surface cells surfaceCellMap, seedCellIndex = FindSurfaceCells(surfaceStatus) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriGeometricCellSampler1.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriGeometricCellSampler1.py index 4f8c530b66..4e33171c00 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriGeometricCellSampler1.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriGeometricCellSampler1.py @@ -333,7 +333,7 @@ def GatherGeometricallySampledCellsInBlock(recursionObject, inInputCsData, inPar myDebugPrint3("None\n") else: myDebugPrint3(str(oneCellDataArray.GetNumberOfTuples()) + "\n") - + if dataArrayNumCmpnts != 0: defaultTuple = [] for ii in range(0, dataArrayNumCmpnts): @@ -513,7 +513,7 @@ def CreateInternalListOfDataControlledSampledCellsOnThisProcess(self): else: myDebugPrint3AndException("CreateInternalListOfDataControlledSampledCellsOnThisProcess:\n" +\ "bad self.DataControlledSamplingMethod\n") - + if PhactoriDbg(100): myDebugPrint3("CreateInternalListOfDataControlledSampledCellsOnThisProcess returning\n") @@ -576,7 +576,7 @@ def CollectDataOnSampledCellsInBlock(recursionObject, inInputCsData, inParameter myDebugPrint3("None\n") else: myDebugPrint3(str(oneCellDataArray.GetNumberOfTuples()) + "\n") - + if dataArrayNumCmpnts != 0: defaultTuple = [] for ii in range(0, dataArrayNumCmpnts): @@ -647,7 +647,7 @@ def CreateLeafRecursionTrackingStructure(self): for leafKey in self.GeometricallySampledCellsByRecursionLeaf: cellListForLeaf = self.GeometricallySampledCellsByRecursionLeaf[leafKey] myDebugPrint3(str(len(cellListForLeaf)) + " cells for leaf " + str(leafKey) + "\n") - + if PhactoriDbg(100): myDebugPrint3("CreateLeafRecursionTrackingStructure returning\n") @@ -866,7 +866,7 @@ def CreateProgrammableFilterString(self): scriptLines.append(" iter.GoToNextItem();\n") scriptLines.append("else:\n") scriptLines.append(" flatten(input, output)\n") - + self.mainScriptString = "".join(scriptLines) myCellIndexesToSet = [] @@ -884,10 +884,10 @@ def CreateProgrammableFilterString(self): myCellIndexesToSet.append(oneCellInfo.index) myMaskValuesToSet.append(maskValue) myLeafVisitCount.append(oneCellInfo.leafVisitCount) - - newstr1 = "cellIndexesToSet = " + str(myCellIndexesToSet) + "\n" - newstr2 = "maskValuesToSet = " + str(myMaskValuesToSet) + "\n" - newstr3 = "leafVisitCount = " + str(myLeafVisitCount) + "\n" + + newstr1 = "cellIndexesToSet = " + str(myCellIndexesToSet) + "\n" + newstr2 = "maskValuesToSet = " + str(myMaskValuesToSet) + "\n" + newstr3 = "leafVisitCount = " + str(myLeafVisitCount) + "\n" self.mProgFilterString = newstr1 + newstr2 + newstr3 + self.mainScriptString if PhactoriDbg(100): @@ -895,3 +895,4 @@ def CreateProgrammableFilterString(self): self.mProgFilterString) #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriGlyphOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriGlyphOperation.py index 1f4f7cb62a..f16d371863 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriGlyphOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriGlyphOperation.py @@ -52,7 +52,7 @@ def ParseParametersFromJson(self, inJson): if PhactoriDbg(100): myDebugPrint3("PhactoriGlyphOperation.ParseParametersFromJson " "entered\n", 100) - + key1 = "scale factor" if key1 in inJson: self.scaleFactor = inJson[key1] diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriGroupOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriGroupOperation.py index d0911c175f..938f92b775 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriGroupOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriGroupOperation.py @@ -83,7 +83,7 @@ def CreateParaViewFilter2(self, ioPipeAndViewsState): "Error: operation '" + str(ii) + "' paraview filter not " "constructed\n") self.mOperationList.append(inputOperationBlock.GetPvFilter()) - + newParaViewFilter = GroupDatasets(Input = self.mOperationList) SetActiveSource(newParaViewFilter) @@ -96,3 +96,4 @@ def CreateParaViewFilter2(self, ioPipeAndViewsState): return newParaViewFilter #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriIntegrateVariablesOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriIntegrateVariablesOperation.py index 1ac08416e3..22dfe96e98 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriIntegrateVariablesOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriIntegrateVariablesOperation.py @@ -53,7 +53,7 @@ def CreateParaViewFilter(self, inInputFilter): myDebugPrint3('PhactoriIntegrateVariablesOperation:CreateParaViewFilter entered\n', 100) #info in block class should already be parsed and checked - + if PhactoriDbg(100): myDebugPrint3('about to call UpdatePipelineWithCurrentTimeArgument\n', 100) UpdatePipelineWithCurrentTimeArgument(inInputFilter) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriMarkCellSurfaceStatus2.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriMarkCellSurfaceStatus2.py index 8127a512d6..217f6df293 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriMarkCellSurfaceStatus2.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriMarkCellSurfaceStatus2.py @@ -82,7 +82,7 @@ def ParseParametersFromJson(self, inJson): self.OffsetIndex = 0 keyval10 = "output cell variable name" - if keyval10 in inJson: + if keyval10 in inJson: self.OutputCellVariableName = inJson[keyval10] keyval11 = "do operation in createparaview method" diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriMergeBlocksOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriMergeBlocksOperation.py index 0ca22dadb8..c23b6eca66 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriMergeBlocksOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriMergeBlocksOperation.py @@ -70,8 +70,16 @@ class PhactoriMergeBlocksOperation(PhactoriOperationSpecifics): def __init__(self): PhactoriOperationSpecifics.__init__(self) + self.mergePoints = True + self.mergePartitionsOnly = False def ParseParametersFromJson(self, inJson): + key1 = "merge points" + if key1 in inJson: + self.mergePoints = inJson[key1] + key1 = "merge partitions only" + if key1 in inJson: + self.mergePartitionsOnly = inJson[key1] dummy = 0 def CreateParaViewFilter(self, inInputFilter): @@ -84,6 +92,14 @@ def CreateParaViewFilter(self, inInputFilter): UpdatePipelineWithCurrentTimeArgument(inInputFilter) newParaViewFilter = MergeBlocks(inInputFilter) + if self.mergePoints: + newParaViewFilter.MergePoints = 1 + else: + newParaViewFilter.MergePoints = 0 + if self.mergePartitionsOnly: + newParaViewFilter.MergePartitionsOnly = 1 + else: + newParaViewFilter.MergePartitionsOnly = 0 SetActiveSource(newParaViewFilter) UpdatePipelineWithCurrentTimeArgument(newParaViewFilter) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriMpiUtilities.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriMpiUtilities.py index acc222de91..08c9d70ec3 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriMpiUtilities.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriMpiUtilities.py @@ -172,7 +172,7 @@ def UseMpiToSendAllProcessesFloatArrayToOneProcess(thisProcessFloatArray, pidToC retVal = [] if PhactoriDbg(100): - if len(globalFloatArray) == 0: + if len(globalFloatArray) == 0: myDebugPrint3(str(len(globalFloatArray)) + "\n") else: myDebugPrint3(str(len(globalFloatArray)) + " " + str(globalFloatArray[0]) + " " + str(globalFloatArray[-1]) + "\n") @@ -230,3 +230,4 @@ def ReadAndMpiBroadcastJsonFile(inJsonFileName): return returnJson #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriOperationBlock.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriOperationBlock.py index 5e5676f777..80363d3599 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriOperationBlock.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriOperationBlock.py @@ -66,7 +66,7 @@ class PhactoriOperationBlock: Operations with multiple inputs and outputs are conceiveable, and may be added pending user requirements. The instance is presumed to contain a name unique amound the operation - blocks and keeps a reference to the input operation (by name), the + blocks and keeps a reference to the input operation (by name), the ParaView/Catalyst filter which is built, and some flags determining where we are in the construction process. """ @@ -226,7 +226,7 @@ def OutputElementListFromOneBlockToFile(self, inInputCsData, inParameters): myDebugPrint3("OutputElementListFromOneBlockToFile returning\n") class FindClosestNPointsToListParams: - """recursion structure for FindClosestNPointsToList(). Also servers to + """recursion structure for FindClosestNPointsToList(). Also servers to store/track data for passing back answer""" def __init__(self, inParentOperation, inNumToFind, inTargetGlobalNodeIdList, inTargetPointXyzList): @@ -343,7 +343,7 @@ def TestPointSub2(self, inSrcId, inSrcXyz, inTgtId, inTgtXyz, inNrstdist): # str(self.mTargetMatchXyzs.GetValue(gndx+2)) + "\n") #now find which in the current list has the biggest distance, as it is - #next in line for replacement (we do this to avoid having to shift + #next in line for replacement (we do this to avoid having to shift #elements every time self.mcfndx = 0 self.mMinDistSqrd = self.mDistSqrds.GetValue(0) @@ -414,7 +414,7 @@ def TestPointSub1(self, inId, inX, inY, inZ, tId, tX, tY, tZ): str(self.mTargetMatchXyzs.GetValue(gndx+2)) + "\n") #now find which in the current list has the biggest distance, as it is - #next in line for replacement (we do this to avoid having to shift + #next in line for replacement (we do this to avoid having to shift #elements every time self.mcfndx = 0 self.mMinDistSqrd = self.mDistSqrds.GetValue(0) @@ -530,7 +530,7 @@ def MakeListOfAllPoints1(self): self.DoMethodPerBlock(recursionItem) return recursionItem.mParameters.mGlobalNodeIdList, \ recursionItem.mParameters.mPointXYZList - + def MakeListOfAllPointsInBlock1(self, inInputCsData, inParameters): #if PhactoriDbg(100): # myDebugPrint3("MakeListOfAllPointsInBlock1 entered\n") diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriOperationUnitTest.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriOperationUnitTest.py index 6fca7b2581..fc2d7fae7a 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriOperationUnitTest.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriOperationUnitTest.py @@ -30,22 +30,33 @@ # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -from Operation.test_PhactoriVtkDataExportOperation import * -from Operation.test_PhactoriSegmentCellSampler3 import * -from Operation.test_PhactoriSegment import * -from Operation.test_PhactoriPointSourceFromJsonList import * -from Operation.test_PhactoriSampledCellInfo import * -from Operation.test_PhactoriGeometricCellSampler1 import * -from Operation.test_PhactoriVtkCellOperations import * -from Operation.test_PhactoriDataArtifactMetaDataControl import * -from Operation.test_PhactoriCreateSegmentsNormalToCells import * -from Operation.test_PhactoriMarkCellSurfaceStatus2 import * -from Operation.test_PhactoriSliceWithPlaneOperation import * -from Operation.test_PhactoriThresholdOperation import * -from Operation.test_PhactoriContourOperation import * -from Operation.test_PhactoriClipPlaneOperation import * +if True: + from Operation.test_PhactoriVtkDataExportOperation import * + from Operation.test_PhactoriSegmentCellSampler3 import * + from Operation.test_PhactoriSegment import * + from Operation.test_PhactoriPointSourceFromJsonList import * + from Operation.test_PhactoriSampledCellInfo import * + from Operation.test_PhactoriGeometricCellSampler1 import * + from Operation.test_PhactoriVtkCellOperations import * + from Operation.test_PhactoriVariableInfo import * + from Operation.test_PhactoriDataArtifactMetaDataControl import * + from Operation.test_PhactoriCreateSegmentsNormalToCells import * + from Operation.test_PhactoriMarkCellSurfaceStatus2 import * + from Operation.test_PhactoriSliceWithPlaneOperation import * + from Operation.test_PhactoriExtractBlockOperation import * + from Operation.test_PhactoriThresholdOperation import * + from Operation.test_PhactoriContourOperation import * + from Operation.test_PhactoriClipPlaneOperation import * + from Operation.test_PhactoriExtractSurfaceOperation import * + from Operation.test_PhactoriCellDataToPointDataOperation import * + from Operation.test_PhactoriPointDataToCellDataOperation import * + from Operation.test_PhactoriMergeBlocksOperation import * +if False: + print("if statement for temporarily moving tests during development") if __name__ == '__main__': cc = Cone() rr = Show() unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriOutputFileNameAndDirectoryManager.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriOutputFileNameAndDirectoryManager.py index c333114185..568b707022 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriOutputFileNameAndDirectoryManager.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriOutputFileNameAndDirectoryManager.py @@ -59,3 +59,4 @@ def GetOutputFilePath(self, counterValue, extraBasename): str(counterValue).zfill(self.NumCounterDigits) + self.Extension return retName #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriParallelGeometryUtilities.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriParallelGeometryUtilities.py index ff0ab895ae..65ce2a61b6 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriParallelGeometryUtilities.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriParallelGeometryUtilities.py @@ -143,7 +143,7 @@ def GetPidWithLeastValueListV5(inLocalDistSqrdList): pidWithDataList = UseReduceOnIntegerList(localPidList, 0) return pidWithDataList, globalDistSqrdList - + def UseMpiToGetGlobalCellPointsClosestV5(inInputFilter, inLocalCellPointList, inLocalDistSqrdList): if PhactoriDbg(100): diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriParaviewMultiBlockRecursion.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriParaviewMultiBlockRecursion.py index e7d6e7c8d5..5824fd9662 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriParaviewMultiBlockRecursion.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriParaviewMultiBlockRecursion.py @@ -92,7 +92,7 @@ def DebugPrintBlockName(csData, blockIndex): myDebugPrint3("oneBlockMetaData is None (2)\n") def PhactoriRecusivelyDoMethodPerBlockFromParaViewFilter(inRecursionControlItem, inPvFilter): - """grab client side data object, and use that to do recursion""" + """grab client side data object, and use that to do recursion""" pvClientSideData = inPvFilter.GetClientSideObject().GetOutputDataObject(0) if pvClientSideData == None: if PhactoriDbg(100): diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPlaneSource.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPlaneSource.py index 02e18a549b..5d82f33d81 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPlaneSource.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPlaneSource.py @@ -147,3 +147,4 @@ def CreateParaViewFilter(self, inInputFilter): return newParaViewFilter #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointDataToCellDataOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointDataToCellDataOperation.py new file mode 100644 index 0000000000..013fd931d8 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointDataToCellDataOperation.py @@ -0,0 +1,71 @@ +# Copyright(C) 1999-2020 National Technology & Engineering Solutions +# of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +# NTESS, the U.S. Government retains certain rights in this software. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are +# met: +# +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# * Redistributions in binary form must reproduce the above +# copyright notice, this list of conditions and the following +# disclaimer in the documentation and/or other materials provided +# with the distribution. +# +# * Neither the name of NTESS nor the names of its +# contributors may be used to endorse or promote products derived +# from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +from phactori import * +from paraview.simple import * + +#phactori_combine_to_single_python_file_subpiece_begin_1 +class PhactoriPointDataToCellDataOperation(PhactoriOperationSpecifics): + def __init__(self): + PhactoriOperationSpecifics.__init__(self) + self.passPointData = 0 + return + + def ParseParametersFromJson(self, inJson): + key1 = "pass point data" + if key1 in inJson: + self.passPointData = inJson[key1] + return + + def CreateParaViewFilter(self, inInputFilter): + if PhactoriDbg(100): + myDebugPrint3('PhactoriPointDataToCellDataOperation:CreateParaViewFilter entered\n', 100) + + UpdatePipelineWithCurrentTimeArgument(inInputFilter) + + savedActiveSource = GetActiveSource() + newParaViewFilter = PointDatatoCellData(Input = inInputFilter) + if self.passPointData: + newParaViewFilter.PassPointData = 1 + else: + newParaViewFilter.PassPointData = 0 + + SetActiveSource(newParaViewFilter) + UpdatePipelineWithCurrentTimeArgument(newParaViewFilter) + SetActiveSource(savedActiveSource) + + if PhactoriDbg(100): + myDebugPrint3('PhactoriPointDataToCellDataOperation.CreateParaViewFilter returning\n', 100) + + return newParaViewFilter + +#phactori_combine_to_single_python_file_subpiece_end_1 diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSource.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSource.py index f0bba8a685..edb385d335 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSource.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSource.py @@ -99,3 +99,4 @@ def CreateParaViewFilter(self, inInputFilter): return newParaViewFilter #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSourceFromJsonList.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSourceFromJsonList.py index 210cc7c92c..e309bb6d49 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSourceFromJsonList.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSourceFromJsonList.py @@ -69,7 +69,7 @@ def ValidateJsonPointList(self): myDebugPrint3AndException(errStr) return True - + def ParseParametersFromJson(self, inJson): if 'filename' in inJson: self.JsonListFileName = inJson['filename'] @@ -128,3 +128,4 @@ def CreateParaViewFilter(self, inInputFilter): return self.ParaviewPointSource #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSourceGeometrySampler1.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSourceGeometrySampler1.py index edb4c582c8..d9dcd53429 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSourceGeometrySampler1.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSourceGeometrySampler1.py @@ -70,7 +70,7 @@ def ValidateJsonPointList(self): errStr = "PhactoriPointSourceGeometrySampler1::ValidateJsonPointList\n" \ "point with index " + str(ptNdx) + "does not have three elements\n" myDebugPrint3AndException(errStr) - + def ParseParametersFromJson(self, inJson): if 'filename' in inJson: @@ -93,7 +93,7 @@ def GetPidWithLeastValueList(self, inLocalDistSqrdList): pidWithDataList = UseReduceOnIntegerList(localPidList, 0) return pidWithDataList, globalDistSqrdList - + def UseMpiToGetGlobalQuadsClosest(self, inLocalQuadList, inLocalDistSqrdList): if PhactoriDbg(100): myDebugPrint3("PhactoriPointSourceGeometrySampler1.UseMpiToGetGlobalQuadsClosest entered\n", 100) @@ -205,3 +205,4 @@ def CreateParaViewFilter(self, inInputFilter): return self.ParaviewPointSource #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSourceNearbyCorrelator.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSourceNearbyCorrelator.py index 0ae5050e87..14f2f525c0 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSourceNearbyCorrelator.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriPointSourceNearbyCorrelator.py @@ -72,7 +72,7 @@ def ValidateJsonPointList(self): errStr = "PhactoriPointSourceFromJsonList::ValidateJsonPointList\n" \ "point with index " + str(ptNdx) + "does not have three elements\n" myDebugPrint3AndException(errStr) - + def ParseParametersFromJson(self, inJson): if 'filename' in inJson: @@ -163,13 +163,13 @@ def UseMpiToFindGlobalNearestPointList(self, inTargetPointList, inDistanceSquare for idx in range(0, numSrcPnts): xyzIdx = idx*3 resultPoints.append([globalXyz[xyzIdx], globalXyz[xyzIdx+1], globalXyz[xyzIdx+2], globalNodeId[idx]]) - + if PhactoriDbg(100): myDebugPrint3("resultPoints:\n" + str(resultPoints) + "\n") if PhactoriDbg(100): myDebugPrint3("UseMpiToFindGlobalNearestPointList returning\n") - return resultPoints + return resultPoints def CalculateOneDisplacedPoint(self, srcPt, tgtPt, dispDist): deltaVec = vecFromAToB(srcPt, tgtPt) @@ -200,7 +200,7 @@ def FindCorrelatedInputOperationPoints(self, inInputFilter): """in parallel, using mpi to help, find the nodes from the input filter which are closest to the points in self.mJsonPointList, and record the 3d location of those points""" - + #grab local process points thisProcessPointList = self.mPhactoriOperationBlockOwner.MakeListOfAllPointsAndNodeIdsOnThisProcessFromParaViewFilter(inInputFilter) @@ -228,7 +228,7 @@ def FindCorrelatedInputOperationPoints(self, inInputFilter): distx = math.sqrt(distSqrd) myDebugPrint3(str(ndx) + ": " + str(sourcePt) + " " + str(distSqrd) + " " + str(distx) + " " + str(self.DisplacedPointList[ndx]) + "\n") - + def CreateParaViewFilter(self, inInputFilter): if PhactoriDbg(100): myDebugPrint3("PhactoriPointSourceFromJsonList.CreateParaViewFilter entered\n", 100) @@ -279,3 +279,4 @@ def CreateParaViewFilter(self, inInputFilter): return self.ParaviewPointSource #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriRepresentationBlock.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriRepresentationBlock.py new file mode 100644 index 0000000000..374bcfa214 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriRepresentationBlock.py @@ -0,0 +1,395 @@ +# Copyright(C) 1999-2022 National Technology & Engineering Solutions +# of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +# NTESS, the U.S. Government retains certain rights in this software. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are +# met: +# +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# * Redistributions in binary form must reproduce the above +# copyright notice, this list of conditions and the following +# disclaimer in the documentation and/or other materials provided +# with the distribution. +# +# * Neither the name of NTESS nor the names of its +# contributors may be used to endorse or promote products derived +# from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +from phactori import * +from paraview.simple import * + +#phactori_combine_to_single_python_file_subpiece_begin_1 +class PhactoriRepresentationBlock: + def __init__(self): + self.mName = "" + self.mColorVariableInfo = PhactoriVariableInfo() + self.mColorLegendFlag = True + #self.mColorLegendPositionAndSize = ['bottom', 1.0] + #self.mColorLegendPositionAndSize = ['right', 1.0] + self.mColorLegendPositionAndSize = ['bottom right', 1.0] + self.mTimeAnnotationSettings = PhactoriAnnotationViewSettings( + 'time', 'time') + self.mDataCubeAxesFlag = False + self.mDataCubeAxesInfo = PhactoriDataCubeAxesInfo() + #self.mColorByBlockFlag = True + self.mColorByBlockFlag = True + self.mColorByBlockExplicitlySet = False + self.mColorBySolidColorFlag = False + self.mSolidColor = None + self.mOpacitySetting = 1.0 + self.mOrientationAxesFlag = True + self.mFixedColorRange = None + self.mUseFixedColorRange = False + self.mColorRangeMinMaxTracker = PlotValMinMaxTrkC() + self.mUseHighlightSubranges = False + self.mHighlightSubranges = [] + self.mUseColorSubrange = False + self.mColorSubrange = [0.0, 1.0] + self.mFilenameAddon = "" + self.mColorSettings = PhactoriColorSettings() + self.mColorMapSettings = PhactoriColorMapSettings() + self.mPointSize = 2.0 + self.InterpretValuesAsCategories = False + self.CategoryAndColorJsonFile = None + self.Annotations = None + self.IndexedColors = None + self.IndexedOpacities = None + + def ParseSettingsFromJson(self, inRepresentationBlockJson): + """given a python dict (presumably from json) description of a + representation block, parse all the representation parameters out of + the block""" + + if PhactoriDbg(100): + myDebugPrint3('ParseSettingsFromJson entered\n', 100) + + inJsn = inRepresentationBlockJson + + #hack test for colors start + #inJsn['surface color'] = [1.0, 0.0, 0.0] + #inJsn['background color'] = [0.0, 0.0, 0.0] + #inJsn['edge color'] = [0.0, 1.0, 0.0] + ##inJsn['axes color'] = [0.0, 1.0, 1.0] + #inJsn['text color'] = [1.0, 1.0, 0.0] + #hack test for colors end + + #myDebugPrint3(' json: ' + str(inJsn) + '\n') + + if 'point size' in inJsn: + self.mPointSize = inJsn['point size'] + + #color by variable scalar/vector magnitude/vector component/tensor component + self.mColorVariableInfo.\ + ParseVariableNameAndVectorOrTensorComponent(inJsn, 'color by ') + + if self.mColorVariableInfo.mVariableName != '': + self.mColorByBlockFlag = False + self.mColorBySolidColorFlag = False + elif 'color by blockid' in inJsn: + self.mColorByBlockFlag = True + self.mColorByBlockExplicitlySet = True + self.mColorBySolidColorFlag = False + elif 'color by solid color' in inJsn: + self.mColorBySolidColorFlag = True + self.mColorByBlockFlag = False + self.mSolidColor = inJsn['color by solid color'] + + #color map range control + if 'color legend range' in inJsn: + self.mFixedColorRange = inJsn['color legend range'] + self.mUseFixedColorRange = True + else: + self.mUseFixedColorRange = False + + #highlight subranges with solid colors + if 'highlight subrange 1' in inJsn: + highlightSubrangeIndex = 1 + while True: + oneSubrangeKey = 'highlight subrange ' + str(highlightSubrangeIndex) + if oneSubrangeKey in inJsn: + subrangeArgs = inJsn[oneSubrangeKey] + highlightSubrangeIndex += 1 + if len(subrangeArgs) != 5: + if PhactoriDbg(): + myDebugPrint3("highlight subrange needs 5 values\n"); + PrintOnProcessZero("highlight subrange needs 5 values, skipping " + \ + oneSubrangeKey + "\n"); + continue + srmin = float(subrangeArgs[0]) + srmax = float(subrangeArgs[1]) + if srmin > srmax: + if PhactoriDbg(): + myDebugPrint3("subrange highlight min >= max: " + \ + str(srmin) + ", " + str(srmax) + "\nskipping " + \ + oneSubrangeKey + "\n", 100) + PrintOnProcessZero("subrange highlight min >= max: " + \ + str(srmin) + ", " + str(srmax) + "\nskipping " + \ + oneSubrangeKey + "\n") + continue + srColor = [float(subrangeArgs[2]), float(subrangeArgs[3]), + float(subrangeArgs[4])] + if (srColor[0] < 0.0) or (srColor[0] > 1.0) or \ + (srColor[1] < 0.0) or (srColor[1] > 1.0) or \ + (srColor[2] < 0.0) or (srColor[2] > 1.0): + srColor = [1.0, 1.0, 0.0] + if PhactoriDbg(): + myDebugPrint3(oneSubrangeKey + ": bad color " + "(component not 0.0-1.0), using rgb 1.0, 1.0, 0.0\n", 100) + PrintOnProcessZero(oneSubrangeKey + ": bad color " + "(component not 0.0-1.0), using rgb 1.0, 1.0, 0.0\n") + self.mHighlightSubranges.append( + [srmin, srmax, srColor]) + self.mUseHighlightSubranges = True + else: + break + if PhactoriDbg(): + myDebugPrint3("parsed highlight subranges:\n" + \ + str(self.mHighlightSubranges) + "\n", 100) + + #if 'highlight subranges' in inJsn: + # self.mUseHighlightSubranges = True + # sbrngsJsn = inJsn['highlight subranges'] + # for oneSubrange in sbrngsJsn: + # if 'range' in oneSubrange: + # srmin = oneSubrange['range'][0] + # srmax = oneSubrange['range'][1] + # if srmin < srmax: + # if 'color' in oneSubrange: + # srColor = oneSubrange['color'] + # else: + # srColor = [1.0, 1.0, 0.0] + # self.mHighlightSubranges.append( + # [srmin, srmax, srColor]) + # else: + # if PhactoriDbg(): + # myDebugPrint3("highlight min >= max: " + \ + # str(srmin) + ", " + str(srmax) + "\nskipping subrange\n", 100) + # PrintOnProcessZero("highlight min >= max: " + \ + # str(srmin) + ", " + str(srmax) + "\nskipping subrange\n") + # else: + # if PhactoriDbg(): + # myDebugPrint3("subrange is missing 'range' key; skipping\n") + # PrintOnProcessZero("subrange is missing 'range' key; skipping\n") + # if PhactoriDbg(): + # myDebugPrint3("parsed highlight subranges:\n" + \ + # str(self.mHighlightSubranges) + "\n", 100) + + #additional capability: use ratio-expressed subrange of + #range that would otherwise be used to increase concentration of + #dynamic range of color map in range of interest + if 'color legend subrange' in inJsn: + self.mUseColorSubrange = True + self.mColorSubrange = inJsn['color legend subrange'] + goodSubrange = True + if self.mColorSubrange[0] < 0.0: + goodSubrange = False + if self.mColorSubrange[1] > 1.0: + goodSubrange = False + if self.mColorSubrange[0] > \ + self.mColorSubrange[1]: + goodSubrange = False + if goodSubrange == False: + myDebugPrint3AndException( + "ParseOneRepresentationBlockC:\n" + "bad color legend subrange, must be 0.0 <= bottom <= top <= 1.0\n") + + #choose color map by name + self.mColorMapSettings.ParseColorMapSettings(inJsn) + + self.InterpretValuesAsCategories = \ + getParameterFromBlock(inJsn, "interpret values as categories", False) + if self.InterpretValuesAsCategories: + key1 = "category and color json file" + if key1 not in inJsn: + myDebugPrint3AndException( + "interpret values as categories is true but '" + key1 + \ + "' is missing\n") + self.CategoryAndColorJsonFile = \ + getParameterFromBlock(inJsn, key1, "dummy1.json") + elif 'color by scalar' in inJsn: + if inJsn['color by scalar'] == "ObjectId": + if PhactoriDbg(): + myDebugPrint3("variable is ObjectId, using categories\n") + self.InterpretValuesAsCategories = True + self.CategoryAndColorJsonFile = "ObjectIdBlockColors.json" + + showSurfacesFlag = getParameterFromBlock(inJsn, 'show surfaces', True) + showEdgesFlag = getParameterFromBlock(inJsn, 'show edges', False) + showPointsFlag = getParameterFromBlock(inJsn, 'show points', False) + + self.mOpacitySetting = getParameterFromBlock(inJsn, 'opacity', + self.mOpacitySetting) + + #doVolumeRenderingFlag = getParameterFromBlock(inJsn, 'volume rendering', True) + doVolumeRenderingFlag = getParameterFromBlock(inJsn, 'volume rendering', False) + self.mScalarOpacityUnitDistance = getParameterFromBlock( + inJsn, 'scalar opacity unit distance', -1.0) + + #self.mScalarOpacityUnitDistance = 0.01 + if PhactoriDbg(): + myDebugPrint3("doVolumeRenderingFlag: " + \ + str(doVolumeRenderingFlag) + "\n" + \ + "self.mScalarOpacityUnitDistance: " + \ + str(self.mScalarOpacityUnitDistance) + "\n") + + self.mPresetsImportFileName = getParameterFromBlock(inJsn, + 'color and opacity presets import file', None) + if self.mPresetsImportFileName != None: + retval = ImportPresets(self.mPresetsImportFileName) + if retval != True: + myDebugPrint3AndException( + "paraview.simple.ImportPresets failed with the file:\n" + \ + str(self.mPresetsImportFileName) + "\n") + self.mNameOfPresetToUse = getParameterFromBlock(inJsn, + 'color and opacity preset', None) + + showBoundingBoxFlag = getParameterFromBlock(inJsn, 'show bounding box', False) + + self.mMeshRenderControl = 'Surface' + if showBoundingBoxFlag: + self.mMeshRenderControl = 'Outline' + if showSurfacesFlag | showEdgesFlag | showPointsFlag: + if PhactoriDbg(): + myDebugPrint3(" warning: when show bounding box is true, \n" + \ + " show surfaces, show edges, and show points should be false\n") + elif showPointsFlag: + self.mMeshRenderControl = 'Points' + else: + if showSurfacesFlag: + if showEdgesFlag: + self.mMeshRenderControl = 'Surface With Edges' + else: + self.mMeshRenderControl = 'Surface' + else: + if showEdgesFlag: + self.mMeshRenderControl = 'Wireframe' + #self.mMeshRenderControl = 'Points' + else: + self.mMeshRenderControl = 'Outline' + + if doVolumeRenderingFlag: + if PhactoriDbg(100): + myDebugPrint3('doing volume rendering\n', 100) + self.mMeshRenderControl = 'Volume' + self.mDoingVolumeRendering = True + else: + self.mDoingVolumeRendering = False + + #color legend on/off + self.mColorLegendFlag = getParameterFromBlock(inJsn, + 'show color legend', self.mColorLegendFlag) + + self.mColorLegendPositionAndSize = \ + getParameterFromBlock(inJsn, 'color legend position', + self.mColorLegendPositionAndSize) + + if self.mColorLegendFlag == True: + if self.mColorVariableInfo.mVariableName == '': + self.mColorLegendFlag = False + + self.mColorRangeMinMaxTracker.PlotValMinMaxTrkCParseJson( + inJsn, "color legend ") + + self.mTimeAnnotationSettings.ParseAvsFromJson(inJsn) + + self.mDataCubeAxesFlag = getParameterFromBlock(inJsn, + 'show axes', self.mDataCubeAxesFlag) + + self.mDataCubeAxesInfo.DcaiParseParametersFromJson(inJsn) + + self.mOrientationAxesFlag = getParameterFromBlock(inJsn, + 'show orientation axes', self.mOrientationAxesFlag) + + if "image name addon" in inJsn: + self.mFilenameAddon = inJsn["image name addon"] + + self.mColorSettings.ParseColorSettingsFromJson(inJsn) + + if PhactoriDbg(100): + myDebugPrint3('ParseOneRepresentationBlockC returning\n', 100) + + def SetFromRestartInfo(self, inJson): + """given a map (json format), use the info in the map to set the + representation state--this reads the info created in + GetRestartInfo""" + + if 'mColorRangeMinMaxTracker' not in inJson: + if PhactoriDbg(): + myDebugPrint3("PhactoriRepresentationBlock::" + \ + "SetFromRestartInfo: no mColorRangeMinMaxTracker, return\n") + return + + if PhactoriDbg(): + myDebugPrint3("Representation::SetFromRestartInfo\n" + + "currently set to do something\n" + + "before tracker:\n" + self.mColorRangeMinMaxTracker.SelfToStr()) + + jsonItem = inJson['mColorRangeMinMaxTracker'] + self.mColorRangeMinMaxTracker.SetFromRestartInfo(jsonItem) + + if PhactoriDbg(): + myDebugPrint3("after tracker:\n" + + self.mColorRangeMinMaxTracker.SelfToStr()) + + def GetRestartInfo(self): + """construct, in python map/json format, the information from this + representation instance which contains the information + which would be needed to restore the representation to the proper + state after a simulation restart, particularly color range tracking + information. Return the restart info map/json""" + newRestartInfoJson = {} + newRestartInfoJson['mColorRangeMinMaxTracker'] = \ + self.mColorRangeMinMaxTracker.GetRestartInfo() + return newRestartInfoJson + + def CalculateDefaultScalarOpacityUnitDistance(self, inPhactoriOperation): + """given a phactori operation assumed to have an updated pipeline, + calculate a default scalar opacity unit distance the same as paraview, + with 0.05 * diagonal length of data bounding box""" + bnds = GetGlobalDataBoundsParallel(inPhactoriOperation.mParaViewFilter) + xxlen = bnds[1] - bnds[0] + yylen = bnds[3] - bnds[2] + zzlen = bnds[5] - bnds[4] + self.mScalarOpacityUnitDistance = \ + 0.05 * math.sqrt(xxlen*xxlen + yylen*yylen + zzlen*zzlen) + + def SetUpForInterpretValuesAsCateories(self, variableLookUpTable): + if PhactoriDbg(): + myDebugPrint3("SetUpForInterpretValuesAsCateories entered\n") + if(self.Annotations == None): + jsonCategories = ReadAndMpiBroadcastJsonFile(self.CategoryAndColorJsonFile) + jsonCategories = convertJsonUnicodeToStrings(jsonCategories) + self.Annotations = jsonCategories[0]["Annotations"] + self.IndexedColors = jsonCategories[0]["IndexedColors"] + self.IndexedOpacities = [] + numCategories = len(self.Annotations) // 2 + for ii in range(0, numCategories): + self.IndexedOpacities.append(1.0) + if PhactoriDbg(): + myDebugPrint3("self.Annotations:\n" + str(self.Annotations) + "\n") + myDebugPrint3("self.IndexedColors:\n" + str(self.IndexedColors) + "\n") + myDebugPrint3("self.IndexedOpacities:\n" + str(self.IndexedOpacities) + "\n") + variableLookUpTable.InterpretValuesAsCategories = 1 + variableLookUpTable.AnnotationsInitialized = 1 + variableLookUpTable.Annotations = self.Annotations + variableLookUpTable.IndexedColors = self.IndexedColors + variableLookUpTable.IndexedOpacities = self.IndexedOpacities + if PhactoriDbg(): + myDebugPrint3("SetUpForInterpretValuesAsCateories returning\n") +#phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriResampleWithDataset.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriResampleWithDataset.py index 53223d5935..0cf6d60007 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriResampleWithDataset.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriResampleWithDataset.py @@ -105,7 +105,7 @@ def CreateParaViewFilter2(self, inInputFilter, inPipeAndViewsState): self.InternalParaViewFilterPtr.CellLocator = 'Static Cell Locator' self.DebugPrintInputPortAndOutputPortInfo("pre filter update 1\n") - + SetActiveSource(self.InternalParaViewFilterPtr) SetActiveSource(savedActiveSource) @@ -119,7 +119,7 @@ def CreateParaViewFilter2(self, inInputFilter, inPipeAndViewsState): self.InternalParaViewFilterPtr.UpdatePipeline() self.DebugPrintInputPortAndOutputPortInfo("post filter update 1\n") - + if PhactoriDbg(100): myDebugPrint3("self.InternalParaViewFilterPtr: " + str(self.InternalParaViewFilterPtr) + "\n", 100) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSampledCellInfo.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSampledCellInfo.py index 86458e32f7..0f6f20917c 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSampledCellInfo.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSampledCellInfo.py @@ -445,9 +445,9 @@ def PhactoriLocalToGlobalCellsWithMinMaxDataUsingMPI(localPidMinMaxCellPair, tup globalMaxCell = PhactoriSampledCellInfo() globalMinCell.SerializeSetFromFloatAndIntArray(globalSerializedFloatArray, globalSerializedIntArray, 0, tupleSize) globalMaxCell.SerializeSetFromFloatAndIntArray(globalSerializedFloatArray, globalSerializedIntArray, 1, tupleSize) - + if PhactoriDbg(100): myDebugPrint3("PhactoriLocalToGlobalCellsWithMinMaxDataUsingMPI returning\n") - return [globalMinCell, globalMaxCell] - + return [globalMinCell, globalMaxCell] + #phactori_combine_to_single_python_file_subpiece_end_1 diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSegment.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSegment.py index 024a2df08c..992896ae96 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSegment.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSegment.py @@ -283,3 +283,4 @@ def IntersectsBoundingBoxProjected(self, boundingBox, projectionAxis): return intersectionFlag #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSegmentCellSampler3.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSegmentCellSampler3.py index a4f32df103..787464d177 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSegmentCellSampler3.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSegmentCellSampler3.py @@ -263,7 +263,7 @@ def ValidateJsonSegmentList(self, testlist): errStr = "PhactoriSegmentCellSampler3:ValidateJsonSegmentList\n" \ "segment with index " + str(segNdx) + " point 2 does not have 3 components\n" myDebugPrint3AndException(errStr) - + return True def ParseParametersFromJson(self, inJson): @@ -420,7 +420,7 @@ def CreateInternalSegmentListFromJson(self, segmentListJson): if PhactoriDbg(100): myDebugPrint3("PhactoriSegmentCellSampler3.ExportOperationData entered\n", 100) - if self.SegmentDefinitionFormat == "two geometric points": + if self.SegmentDefinitionFormat == "two geometric points": self.ValidateJsonSegmentList(segmentListJson) self.SegmentList = [] self.NearbyGeometryPointList = [] @@ -501,7 +501,7 @@ def CreateParaViewFilter(self, inInputFilter): savedActiveSource = GetActiveSource() segmentListJson = ReadAndMpiBroadcastJsonFile(self.JsonListFileName) - + self.myCopyOfInputFilter = inInputFilter UpdatePipelineWithCurrentTimeArgument(self.myCopyOfInputFilter) @@ -568,7 +568,7 @@ def GetPidWithLeastValueList(self, inLocalDistSqrdList): pidWithDataList = UseReduceOnIntegerList(localPidList, 0) return pidWithDataList, globalDistSqrdList - + def UseMpiToGetGlobalCellPointsClosestStructured(self, ioCellList, inLocalDistSqrdList): if PhactoriDbg(100): myDebugPrint3("PhactoriSegmentCellSampler3.UseMpiToGetGlobalCellPointsClosestStructured entered\n", 100) @@ -758,12 +758,12 @@ def SetMaskValueForCellsNearSegmentsInBlock(recursionObject, inInputCsData, inPa thisCellDataTuple = outputCellArray.GetTuple(cellIndex) newCellInfo = PhactoriSampledCellInfo() newCellInfo.SetFromList([cellTestPoint, [-1,-1,-1], thisCellDataTuple, myPid, leafVisitCount, cellIndex, segIndex, -1]) - + inParameters.markedCellSet[segIndex].append(newCellInfo) if PhactoriDbg(100): myDebugPrint3("new cell close to segment:\n") myDebugPrint3(newCellInfo.ToStr()) - + if PhactoriDbg(100): for idx, cellsForThisSegment in enumerate(inParameters.markedCellSet): @@ -1273,7 +1273,7 @@ def CreateProgrammableFilterString(self): scriptLines.append(" iter.GoToNextItem();\n") scriptLines.append("else:\n") scriptLines.append(" flatten(input, output)\n") - + mainScriptString = "".join(scriptLines) myCellIndexesToSet = [] @@ -1287,10 +1287,10 @@ def CreateProgrammableFilterString(self): myCellIndexesToSet.append(oneCellInfo.index) myMaskValuesToSet.append(maskValue) myLeafVisitCount.append(oneCellInfo.leafVisitCount) - - newstr1 = "cellIndexesToSet = " + str(myCellIndexesToSet) + "\n" - newstr2 = "maskValuesToSet = " + str(myMaskValuesToSet) + "\n" - newstr3 = "leafVisitCount = " + str(myLeafVisitCount) + "\n" + + newstr1 = "cellIndexesToSet = " + str(myCellIndexesToSet) + "\n" + newstr2 = "maskValuesToSet = " + str(myMaskValuesToSet) + "\n" + newstr3 = "leafVisitCount = " + str(myLeafVisitCount) + "\n" self.mProgFilterString = newstr1 + newstr2 + newstr3 + mainScriptString if PhactoriDbg(100): @@ -1298,3 +1298,4 @@ def CreateProgrammableFilterString(self): self.mProgFilterString) #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSliceOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSliceOperation.py index f7b5bd6849..ceb398cca6 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSliceOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSliceOperation.py @@ -112,3 +112,4 @@ def UpdateSlice(self, inIncomingPvFilter, ioOutgoingPvFilter): myDebugPrint3("PhactoriSlicePlaneOperation::UpdateSlice returning\n") #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSliceWithPlaneOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSliceWithPlaneOperation.py index 93e3bbbc87..cb847577e5 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSliceWithPlaneOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriSliceWithPlaneOperation.py @@ -85,7 +85,7 @@ class PhactoriSliceWithPlaneOperation(PhactoriPlaneOpBase): "plane normal":[1.0, 2.0, 3.0] } } - } + } the plane normal does not need to be a unit vector: Phactori will normalize it for you (again, see PhactoriClipPlaneOperation) @@ -118,7 +118,11 @@ def CreateParaViewFilter(self, inInputFilter): savedActiveSource = GetActiveSource() newParaViewFilter = SliceWithPlane(Input=inInputFilter) - newParaViewFilter.Plane = 'Plane' + global gParaViewCatalystVersionFlag + if gParaViewCatalystVersionFlag < 51100: + newParaViewFilter.Plane = 'Plane' + else: + newParaViewFilter.PlaneType = 'Plane' self.UpdateSlice(inInputFilter, newParaViewFilter) @@ -166,13 +170,17 @@ def UpdateSlice(self, inIncomingPvFilter, ioOutgoingPvFilter): if PhactoriDbg(): myDebugPrint3(' updateslice using normal: ' + \ str(normalToUse) + '\n') - ioOutgoingPvFilter.Plane.Normal = normalToUse - - if PhactoriDbg(): myDebugPrint3(' updateslice using origin: ' + str(originToUse) + '\n') - ioOutgoingPvFilter.Plane.Origin = originToUse + global gParaViewCatalystVersionFlag + if gParaViewCatalystVersionFlag < 51100: + ioOutgoingPvFilter.Plane.Normal = normalToUse + ioOutgoingPvFilter.Plane.Origin = originToUse + else: + ioOutgoingPvFilter.PlaneType.Normal = normalToUse + ioOutgoingPvFilter.PlaneType.Origin = originToUse if PhactoriDbg(): myDebugPrint3("PhactoriSliceWithPlanePlaneOperation::UpdateSlice returning\n") #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriStreamTracerOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriStreamTracerOperation.py index d77851f9e5..3928af4ccc 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriStreamTracerOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriStreamTracerOperation.py @@ -90,12 +90,12 @@ def CreateParaViewFilter(self, inInputFilter): myDebugPrint3("stido0 st: " + str(stido0.GetClassName()) + "\n") stido1 = stcso.GetInputDataObject(1,0) myDebugPrint3("stido1 st: " + str(stido1.GetClassName()) + " numcells " + str(stido1.GetNumberOfCells()) + " numpoints " + str(stido1.GetNumberOfPoints()) + "\n") - + SetActiveSource(newParaViewFilter) SetActiveSource(savedActiveSource) UpdatePipelineWithCurrentTimeArgument(newParaViewFilter) - + if PhactoriDbg(100): stcso = newParaViewFilter.GetClientSideObject() stodo = stcso.GetOutputDataObject(0) @@ -104,7 +104,7 @@ def CreateParaViewFilter(self, inInputFilter): myDebugPrint3("B stido0 st: " + str(stido0.GetClassName()) + "\n") stido1 = stcso.GetInputDataObject(1,0) myDebugPrint3("B stido1 st: " + str(stido1.GetClassName()) + " numcells " + str(stido1.GetNumberOfCells()) + " numpoints " + str(stido1.GetNumberOfPoints()) + "\n") - + if PhactoriDbg(100): myDebugPrint3('PhactoriStreamTracerOperation.CreateParaViewFilter returning\n', 100) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriStreamTracerSeedSourceOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriStreamTracerSeedSourceOperation.py index fee4c6e38b..bdb41b6cfb 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriStreamTracerSeedSourceOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriStreamTracerSeedSourceOperation.py @@ -104,14 +104,14 @@ def CreateParaViewFilter2(self, inInputFilter, inPipeAndViewsState): #self.InternalParaViewFilterPtr.InitialStepLength = 0.01 self.DebugPrintInputPortAndOutputPortInfo("pre filter update 1\n") - + SetActiveSource(self.InternalParaViewFilterPtr) SetActiveSource(savedActiveSource) UpdatePipelineWithCurrentTimeArgument(self.InternalParaViewFilterPtr) self.DebugPrintInputPortAndOutputPortInfo("post filter update 1\n") - + if PhactoriDbg(100): myDebugPrint3("self.InternalParaViewFilterPtr: " + str(self.InternalParaViewFilterPtr) + "\n", 100) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriStructuredGridSampler.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriStructuredGridSampler.py index b3d2525700..967a78e37d 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriStructuredGridSampler.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriStructuredGridSampler.py @@ -131,7 +131,7 @@ def GatherStructuredSampledCellsOnThisProcess(self): dataArrayNumCmpnts = -1 defaultTuple = [] - + def CreateParaViewFilter(self, inInputFilter): if PhactoriDbg(100): myDebugPrint3("PhactoriStructuredGridSampler.CreateParaViewFilter entered\n", 100) @@ -139,7 +139,7 @@ def CreateParaViewFilter(self, inInputFilter): savedActiveSource = GetActiveSource() ##segmentListJson = ReadAndMpiBroadcastJsonFile(self.JsonListFileName) - + self.myCopyOfInputFilter = inInputFilter UpdatePipelineWithCurrentTimeArgument(self.myCopyOfInputFilter) @@ -151,3 +151,4 @@ def CreateParaViewFilter(self, inInputFilter): myDebugPrint3("PhactoriStructuredGridSampler.CreateParaViewFilter returning\n", 100) #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriThresholdOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriThresholdOperation.py index 0527a2e00e..91e671751b 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriThresholdOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriThresholdOperation.py @@ -122,7 +122,7 @@ def DoUpdateDueToChangeInData(self, inIncomingPvFilter, if self.mVariableInfo.mVariableTypeNeedsDetection == False: UpdatePipelineWithCurrentTimeArgument(outOutgoingPvFilter) - + def ParseParametersFromJson(self, inJson): self.mBypassFlag = getParameterFromBlock(inJson, 'bypass flag', @@ -257,3 +257,4 @@ def CreateParaViewFilter(self, inInputFilter): return newParaViewFilter #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVariableInfo.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVariableInfo.py new file mode 100644 index 0000000000..42afce9391 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVariableInfo.py @@ -0,0 +1,312 @@ +# Copyright(C) 1999-2022 National Technology & Engineering Solutions +# of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +# NTESS, the U.S. Government retains certain rights in this software. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are +# met: +# +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# * Redistributions in binary form must reproduce the above +# copyright notice, this list of conditions and the following +# disclaimer in the documentation and/or other materials provided +# with the distribution. +# +# * Neither the name of NTESS nor the names of its +# contributors may be used to endorse or promote products derived +# from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +from phactori import * +from paraview.simple import * + +#phactori_combine_to_single_python_file_subpiece_begin_1 +class PhactoriVariableMinMaxAvgSumCntSave: + def __init__(self): + self.mStatsTestCounter = -1 + self.mMin = 0.0 + self.mMax = 0.0 + self.mSum = 0.0 + self.mCount = 0 + self.mIdsTestCounter = -1 + self.mLocalFoundMinId = False + self.mLocalMinIdCount = -1 + self.mMinId = -1; + self.mLocalFoundMaxId = False + self.mLocalMaxIdCount = -1 + self.mMaxId = -1; + +class PhactoriVariableInfo: + def __init__(self): + self.mVariableIntendedForUseFlag = False + self.mVariableName = "" + self.mVariableComponent = None + self.mVariableType = None + self.mVariableTypeNeedsDetection = False + self.mVariableTypeWasDetected = False + self.mVariableTypeWasCopied = False + self.mVariableIsVectorMagnitude = False + self.mVariableIsVectorComponent = False + self.mVectorBaseName = None + self.mStats = PhactoriVariableMinMaxAvgSumCntSave() + #as of 2022Aug09 we want this to default to False + self.mAddSeparatorToVectorVariableName = False + + def SelfToStr(self): + retStr = "PhactoriVariableInfo:\n" +\ + "\n mVariableName: " + str(self.mVariableName) +\ + "\n mVariableComponent: " + str(self.mVariableComponent) +\ + "\n mVariableType: " + str(self.mVariableType) +\ + "\n mVariableTypeNeedsDetection: " + str(self.mVariableTypeNeedsDetection) +\ + "\n mVariableTypeWasDetected: " + str(self.mVariableTypeWasDetected) +\ + "\n mVariableTypeWasCopied: " + str(self.mVariableTypeWasCopied) +\ + "\n mVariableIsVectorMagnitude: " + \ + str(self.mVariableIsVectorMagnitude) +\ + "\n mVariableIsVectorComponent: " + \ + str(self.mVariableIsVectorComponent) +\ + "\n mVectorBaseName: " + str(self.mVectorBaseName) +\ + "\n mVariableIntendedForUseFlag: " + str(self.mVariableIntendedForUseFlag) +\ + "\n" + return retStr + + def CheckAndParseScalarVariable1(self, inJson, inBaseString): + testKey = inBaseString + 'scalar' + if testKey in inJson: + self.mVariableName = inJson[testKey] + self.mVariableComponent = None + return True + else: + return False + + def CheckAndParseVectorComponentNumber1(self, inJson, inBaseString): + testKey = inBaseString + 'vector component number' + if testKey in inJson: + self.mVariableIsVectorComponent = True + varCompNumPair = inJson[testKey] + self.mVariableName = varCompNumPair[0] + self.mVariableComponent = int(varCompNumPair[1]) + return True + else: + return False + + def CheckAndParseVectorComponentSuffix(self, inJson, inBaseString): + testKey = inBaseString + 'vector component' + if testKey in inJson: + self.mVariableIsVectorComponent = True + varName = inJson[testKey] + resultPair = breakSpecialVarNameIntoBaseAndComponent(varName, + self.mAddSeparatorToVectorVariableName) + self.mVariableName = resultPair[0] + self.mVariableComponent = resultPair[1] + self.mVectorBaseName = resultPair[2] + return True + else: + return False + + def CheckAndParseVectorMagnitude(self, inJson, inBaseString): + testKey = inBaseString + 'vector magnitude' + if testKey in inJson: + self.mVariableIsVectorMagnitude = True + if self.mAddSeparatorToVectorVariableName: + self.mVariableName = inJson[testKey] + GetSeparatorString() + else: + self.mVariableName = inJson[testKey] + self.mVectorBaseName = inJson[testKey] + return True + else: + return False + + def CheckAndParseTensorComponent(self, inJson, inBaseString): + testKey = inBaseString + 'tensor component' + if testKey in inJson: + self.mVariableName = inJson[testKey] + return True + else: + return False + + def CheckAndParseVectorVariable1(self, inJson, inBaseString): + variableFoundFlag = False + variableFoundFlag = self.CheckAndParseVectorComponentNumber1(inJson, inBaseString) + if not variableFoundFlag: + variableFoundFlag = self.CheckAndParseVectorComponentSuffix(inJson, inBaseString) + if not variableFoundFlag: + variableFoundFlag = self.CheckAndParseVectorMagnitude(inJson, inBaseString) + if not variableFoundFlag: + variableFoundFlag = self.CheckAndParseTensorComponent(inJson, inBaseString) + if not variableFoundFlag: + variableFoundFlag = False + self.mVariableName = '' + self.mComponent = None + return variableFoundFlag + + def ParseVariableNameAndVectorOrTensorComponent(self, inJson, inBaseString): + "take a base string such as 'y axis variable ' or 'variable ', use it\n to construct keys to define a scalar variable, vector component, vector\n magnitude, or tensor component, and see if the json has those keys.\n If the json has a key, use it to grab the variable name and setup.\n Also look to see if the type of the variable is specifically defined\n (node or element) or needs to be detected\n " + variableFoundFlag = False + self.mVariableIsVectorComponent = False + self.mVariableIsVectorMagnitude = False + + if 'add separator to vector variable name' in inJson: + self.mAddSeparatorToVectorVariableName = \ + inJson['add separator to vector variable name'] + + variableFoundFlag = self.CheckAndParseScalarVariable1(inJson, inBaseString) + if not variableFoundFlag: + variableFoundFlag = self.CheckAndParseVectorVariable1(inJson, inBaseString) + if variableFoundFlag: + #it is now apparent variable is intended to be used, not ignored + self.mVariableIntendedForUseFlag = True + if 'variable type' in inJson: + variableType = inJson['variable type'] + self.mVariableType = variableType + if variableType != 'element' \ + and variableType != 'node' \ + and variableType != 'global' \ + and variableType != 'detect': + errStr = 'error! inJson has variable type is neither node nor '\ + 'element nor detect nor global in ParseVariableNameAndVectorOrTensorComponent\n' + if PhactoriDbg(): + myDebugPrint3(errStr) + raise Exception(errStr) + if variableType == 'detect': + self.mVariableType = 'element' + self.mVariableTypeNeedsDetection = True + self.mVariableTypeWasDetected = False + elif variableType == 'element': + self.mVariableType = 'element' + self.mVariableTypeNeedsDetection = False + self.mVariableTypeWasDetected = True + elif variableType == 'node': + self.mVariableType = 'node' + self.mVariableTypeNeedsDetection = False + self.mVariableTypeWasDetected = True + elif variableType == 'global': + self.mVariableType = 'global' + self.mVariableTypeNeedsDetection = False + self.mVariableTypeWasDetected = True + else: + self.mVariableType = 'element' + self.mVariableTypeNeedsDetection = True + self.mVariableTypeWasDetected = False + else: + self.mVariableType = None + + if PhactoriDbg(): + str1 = "ParseVariableNameAndVectorOrTensorComponent:\n" + str2 = "inBaseString:\n" + str(inBaseString) + "\n" + str3 = "inJson:\n" + str(inJson) + "\n" + str4 = "instance state after parsing:\n" + self.SelfToStr() + myDebugPrint3(str1 + str2 + str3 + str4) + return variableFoundFlag + + def CopyVariableTypeFrom(self, inSourceVariableInfo): + self.mVariableType = inSourceVariableInfo.mVariableType + self.mVariableTypeNeedsDetection = False + self.mVariableTypeWasDetected = True + self.mVariableTypeWasCopied = True + + def DetectVariableType(self, inInputCsData, inInputIsProxy = False, + inAllowGlobalVariableDetection = False): + + if self.mVariableTypeNeedsDetection == False: + return True + + #testing hack--force to cell + #self.mVariableTypeNeedsDetection = False + #self.mVariableTypeWasDetected = True + #self.mVariableType = 'element' + #return + + if PhactoriDbg(): + myDebugPrint3('PhactoriVariableInfo::DetectVariableType entered\n') + + if inInputIsProxy: + pointData = inInputCsData.PointData + else: + pointData = inInputCsData.GetPointData() + if pointData != None: + testPointArray = pointData.GetArray(self.mVariableName) + if testPointArray != None: + if PhactoriDbg(): + myDebugPrint3(' type node detected!\n') + self.mVariableType = 'node' + self.mVariableTypeNeedsDetection = False + self.mVariableTypeWasDetected = True + return True + + if inInputIsProxy: + cellData = inInputCsData.CellData + else: + cellData = inInputCsData.GetCellData() + if cellData != None: + testCellArray = cellData.GetArray(self.mVariableName) + if testCellArray != None: + if PhactoriDbg(): + myDebugPrint3(' type element detected!\n') + self.mVariableType = 'element' + self.mVariableTypeNeedsDetection = False + self.mVariableTypeWasDetected = True + return True + + if inAllowGlobalVariableDetection: + if inInputIsProxy: + fieldData = inInputCsData.FieldData + else: + fieldData = inInputCsData.GetFieldData() + if fieldData != None: + testFieldArray = fieldData.GetArray(self.mVariableName) + if testFieldArray != None: + if PhactoriDbg(): + myDebugPrint3(' type global detected!\n') + self.mVariableType = 'global' + self.mVariableTypeNeedsDetection = False + self.mVariableTypeWasDetected = True + return True + + if PhactoriDbg(): + myDebugPrint3(' type not detected!\n') + #default to 'element' type knowing assumption may be wrong, + #leave mVariableTypeNeedsDetection set to True so we know the variable + #type has not yet been successfully detected + self.mVariableType = 'element' + #self.mVariableType = 'node' + return False + + def GetXYPlotAxisTitle(self): + """for this variable info, construct the name to put on the axis of an XY + plot, e.g. with magnitude or component information""" + + if self.mVariableName[-1] == '_': + axisTitle = str(self.mVariableName[0:-1]) + else: + axisTitle = self.mVariableName + + if self.mVariableIsVectorComponent: + if self.mVariableComponent == 0: + axisTitle += ' X component' + elif self.mVariableComponent == 1: + axisTitle += ' Y component' + elif self.mVariableComponent == 2: + axisTitle += ' Z component' + else: + if PhactoriDbg(): + myDebugPrint3(" variable component is not 0, 1, or 2, using 0 (X)\n") + localVariableName = self.mVariableName + '_X' + elif self.mVariableIsVectorMagnitude: + axisTitle += " Magnitude" + + return axisTitle + +#phactori_combine_to_single_python_file_subpiece_end_1 diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVectorLibrary.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVectorLibrary.py index 4f04a73d2e..d4f993e69f 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVectorLibrary.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVectorLibrary.py @@ -196,3 +196,4 @@ def GetPhactoriVectorLibraryProgrammableFilterLines(pfLns): pfLns.append(" inVecA[2] + inMM * inVecB[2]]\n") #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVectorProject.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVectorProject.py index d36a9e2004..8ef5e08bd4 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVectorProject.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVectorProject.py @@ -102,3 +102,4 @@ def CreateParaViewFilter(self, inInputFilter): return newParaViewFilter #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVtkCellOperations.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVtkCellOperations.py index 6024b689f3..47d4985cce 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVtkCellOperations.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVtkCellOperations.py @@ -181,9 +181,9 @@ def PhactoriCountCellTouchingEachFace(inInputCsData): "\nnum faces with 1 cell: " + str(cctef.totalNumFacesWithOneCellTouching) + \ "\nnum faces with 2 cells: " + str(cctef.totalNumFacesWithTwoCellsTouching) + \ "\nnum faces with 3+ cells: " + str(cctef.totalNumFacesWith3plCellsTouching) + "\n") - + return countCellsTouchingEachFace - + def PhactoriCountCellTouchingEachPoint(inInputCsData): numCells = inInputCsData.GetNumberOfCells() numPoints = inInputCsData.GetNumberOfPoints() @@ -474,7 +474,7 @@ def PhactoriGetAverageOfCellPoints(inInputCsData, oneCell): avgFac = 1.0/float(numPoints) vecScaleInPlace(avgFac, retAvgPt) return retAvgPt - + def PhactoriFindSelectedAngleBetweenEdgeAndCellNormal(inInputCsData, oneCell, compareNormal, paramUseSmallestAngle, paramOffsetIndex): edgeCompareDotProdList = [] @@ -484,7 +484,7 @@ def PhactoriFindSelectedAngleBetweenEdgeAndCellNormal(inInputCsData, oneCell, vecNormalize2(oneEdgeVec, oneEdgeVec) edgeCompareDotProd = abs(vecDotProduct(compareNormal, oneEdgeVec)) edgeCompareDotProdList.append(edgeCompareDotProd) - + sortedEdgeCompareDotProdList = sorted(edgeCompareDotProdList) if paramUseSmallestAngle: @@ -499,7 +499,7 @@ def DebugPrintPhactoriFindHeightOfCell(inInputCsData, oneCell, compareNormal): if PhactoriDbg(100): dbght = [] dbglen = [] - dbgretHeight = -1.0 + dbgretHeight = -1.0 dbgretHeightIndex = -1 for ii in range(0, numCellEdges): oneCellEdgeVec = PhactoriGetCellEdgeVector(inInputCsData, oneCell, ii) @@ -528,7 +528,7 @@ def PhactoriFindHeightOfCell(inInputCsData, oneCell, compareNormal): #than the four shortest sides? numCellEdges = oneCell.GetNumberOfEdges() - retHeight = -1.0 + retHeight = -1.0 for ii in range(0, numCellEdges): #get edge vectory and project on to normal vector (which is unit length) #and find magnitude @@ -928,3 +928,4 @@ def GetPhactoriVtkCellOperationsProgrammableFilterLines(pfLns): pfLns.append(" return retAngle, retHeight\n") #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVtkDataExportOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVtkDataExportOperation.py index 76d29cb596..4389e4192e 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVtkDataExportOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/PhactoriVtkDataExportOperation.py @@ -187,3 +187,4 @@ def ExportOperationData(self, datadescription): "ExportOperationData returning\n", 100) #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/QuadInfoGQC.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/QuadInfoGQC.py index 64096d6aec..49c59b1a3b 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/QuadInfoGQC.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/QuadInfoGQC.py @@ -191,3 +191,4 @@ def MakePerpendicularSamplePoints(self): return self.MakeSamplePointsAlongRayStartingAtAveragePoint(self.normal, 50, 0.05) #phactori_combine_to_single_python_file_subpiece_end_1 + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/RecursivelyPrintMultiBlockStats.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/RecursivelyPrintMultiBlockStats.py index bd591d2df7..dc07583841 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/RecursivelyPrintMultiBlockStats.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/RecursivelyPrintMultiBlockStats.py @@ -89,3 +89,4 @@ def RecursivelyPrintMultiBlockStats(inFilter): PrintMultiBlockStatsRecurse1(csdata, None, recursionLevel, flatIndexCounter) myDebugPrint3("RecursivelyPrintMultiBlockStats returning\n") + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriCameraBlock.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriCameraBlock.py index be362b0f15..79fc49702a 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriCameraBlock.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriCameraBlock.py @@ -230,7 +230,7 @@ def getjson_ForTestHelper1(testname, thisTestJson): } } return testname, myjson - + @staticmethod def getjson_CameraLookDirectionWithDefaultLookAtPointZMinus1(): testname = "CameraLookDirectionWithDefaultLookAtPointZMinus1" @@ -255,7 +255,7 @@ def test_CameraLookDirectionWithDefaultLookAtPointZMinus1(self): baselineCamFocalPt = [5.0, -0.001999974250793457, -0.625] self.CheckCameraPostionAndFocalPoint(testOutFile, baselineCamPos, baselineCamFocalPt) self.RemoveTestOutputFiles2(testname); - + @staticmethod def getjson_CameraLookDirectionWithDefaultLookAtPointZPlus1(): testname = "CameraLookDirectionWithDefaultLookAtPointZPlus1" @@ -687,3 +687,4 @@ def test_CameraImageNameAddon(self): cc = Cone() rr = Show() unittest.main() + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriCellDataToPointDataOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriCellDataToPointDataOperation.py new file mode 100644 index 0000000000..d4d9cc54f4 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriCellDataToPointDataOperation.py @@ -0,0 +1,136 @@ +# Copyright(C) 1999-2022 National Technology & Engineering Solutions +# of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +# NTESS, the U.S. Government retains certain rights in this software. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are +# met: +# +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# * Redistributions in binary form must reproduce the above +# copyright notice, this list of conditions and the following +# disclaimer in the documentation and/or other materials provided +# with the distribution. +# +# * Neither the name of NTESS nor the names of its +# contributors may be used to endorse or promote products derived +# from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +from phactori import * +import unittest +#from vtk import * +import vtk +from Operation.PhactoriCellDataToPointDataOperation import * +import paraview.simple + +class TestPhactoriCellDataToPointDataOperation(unittest.TestCase): + + def localSetThresholdRange(self, threshOp, lowerValue, upperValue): + global gParaViewCatalystVersionFlag + if gParaViewCatalystVersionFlag < 51000: + threshOp.ThresholdRange = [lowerValue, upperValue] + else: + threshOp.LowerThreshold = lowerValue + threshOp.UpperThreshold = upperValue + threshOp.ThresholdMethod = vtk.vtkThreshold.THRESHOLD_BETWEEN + + def makeTestGroupWithCellArrayWithTwoThresholdsFromWavelet(self): + testWavelet = Wavelet() + testWavelet.UpdatePipeline() + + testThresh1 = Threshold(registrationName='Threshold3', Input=testWavelet) + testThresh1.Scalars = ['POINTS', 'RTData'] + self.localSetThresholdRange(testThresh1, 0.0, 100.0) + testThresh2 = Threshold(registrationName='Threshold4', Input=testWavelet) + testThresh2.Scalars = ['POINTS', 'RTData'] + self.localSetThresholdRange(testThresh2, 200.0, 300.0) + + testGroup = GroupDatasets(registrationName='testgroup1', Input=[testThresh1, testThresh2]) + + testGroup.UpdatePipeline() + testGroupWithCellData = PointDatatoCellData(registrationName='testGroupWithCellData', Input=testGroup) + testGroupWithCellData.UpdatePipeline() + return testGroupWithCellData + + def test_CellDataToPointData_Multiblock1(self): + if PhactoriDbg(100): + myDebugPrint3("test_CellDataToPointData1 entered\n") + testGroupWithCellData = self.makeTestGroupWithCellArrayWithTwoThresholdsFromWavelet() + newOperationBlock = PhactoriOperationBlock() + newOperationBlock.mName = "test_celltopoint" + operationParams = { + "input": "testgroup1", + "type": "element data to node data" + } + if PhactoriDbg(100): + myDebugPrint3("about to parse and construct, testGroup: " + str(testGroup) +"\n") + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'element data to node data', + PhactoriCellDataToPointDataOperation, + operationParams) + ConstructPipelineOperationFromParsedOperationBlockC_ForTest(newOperationBlock, testGroupWithCellData) + newOperationBlock.GetPvFilter().UpdatePipeline() + + csdata = newOperationBlock.GetPvFilter().GetClientSideObject().GetOutputDataObject(0) + blk0 = csdata.GetBlock(0) + cellArrays = blk0.GetCellData() + self.assertEqual(0, cellArrays.GetNumberOfArrays()) + ptArrays = blk0.GetPointData() + self.assertEqual(1, ptArrays.GetNumberOfArrays()) + self.assertEqual("RTData", ptArrays.GetArrayName(0)) + ptdata = ptArrays.GetArray("RTData") + self.assertNotEqual(ptdata, None) + self.assertEqual(newOperationBlock.GetPvFilter().PieceInvariant, 0) + + def test_CellDataToPointData_Multiblock2PassPointData(self): + if PhactoriDbg(100): + myDebugPrint3("test_CellDataToPointData1 entered\n") + testGroupWithCellData = self.makeTestGroupWithCellArrayWithTwoThresholdsFromWavelet() + newOperationBlock = PhactoriOperationBlock() + newOperationBlock.mName = "test_celltopoint" + operationParams = { + "input": "testgroup1", + "type": "element data to node data", + "pass cell data": 1, + "piece invariant": 1 + } + if PhactoriDbg(100): + myDebugPrint3("about to parse and construct, testGroup: " + str(testGroup) +"\n") + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'element data to node data', + PhactoriCellDataToPointDataOperation, + operationParams) + ConstructPipelineOperationFromParsedOperationBlockC_ForTest(newOperationBlock, testGroupWithCellData) + newOperationBlock.GetPvFilter().UpdatePipeline() + + csdata = newOperationBlock.GetPvFilter().GetClientSideObject().GetOutputDataObject(0) + blk0 = csdata.GetBlock(0) + cellArrays = blk0.GetCellData() + self.assertEqual(1, cellArrays.GetNumberOfArrays()) + ptArrays = blk0.GetPointData() + self.assertEqual(1, ptArrays.GetNumberOfArrays()) + self.assertEqual("RTData", ptArrays.GetArrayName(0)) + ptdata = ptArrays.GetArray("RTData") + self.assertNotEqual(ptdata, None) + self.assertEqual(newOperationBlock.GetPvFilter().PieceInvariant, 1) + +if __name__ == '__main__': + cc = Cone() + rr = Show() + unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriClipPlaneOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriClipPlaneOperation.py index cb7dfc7c1c..41dc57a83e 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriClipPlaneOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriClipPlaneOperation.py @@ -58,9 +58,13 @@ def test_ClipPlaneTest1(self): rtdataArry = pointData.GetArray("RTData") rtdataArry = pointData.GetArray("RTData") numPoints = rtdataArry.GetNumberOfTuples() - self.assertEqual(numPoints, 4571) + #self.assertEqual(numPoints, 4571) + #self.assertEqual(numPoints, 4570) + self.assertTrue(numPoints, ((numPoints == 4570) or (numPoints == 4571))) if __name__ == '__main__': cc = Cone() rr = Show() unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriContourOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriContourOperation.py index 56482e7d9b..06b5f5f7a1 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriContourOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriContourOperation.py @@ -63,3 +63,5 @@ def test_ContourTest1(self): cc = Cone() rr = Show() unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriCreateSegmentsNormalToCells.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriCreateSegmentsNormalToCells.py index af73a93c6a..2328b7b354 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriCreateSegmentsNormalToCells.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriCreateSegmentsNormalToCells.py @@ -50,9 +50,9 @@ def MakeOneHexahdtronGridFrom8Points1(self, pointList): points.InsertNextPoint(pointList[5]) points.InsertNextPoint(pointList[6]) points.InsertNextPoint(pointList[7]) - + # Create a hexahedron from the points - hex = vtk.vtkHexahedron() + hex = vtk.vtkHexahedron() hex.GetPointIds().SetId(0,0) hex.GetPointIds().SetId(1,1) hex.GetPointIds().SetId(2,2) @@ -61,11 +61,11 @@ def MakeOneHexahdtronGridFrom8Points1(self, pointList): hex.GetPointIds().SetId(5,5) hex.GetPointIds().SetId(6,6) hex.GetPointIds().SetId(7,7) - + # Add the hexahedron to a cell array hexs = vtk.vtkCellArray() hexs.InsertNextCell(hex) - + # Add the points and hexahedron to an unstructured grid uGrid = vtk.vtkUnstructuredGrid() uGrid.SetPoints(points) @@ -163,7 +163,7 @@ def test_Parse4(self): self.assertRaises(Exception, pcsntc1.ParseParametersFromJson, testJson1) testJson1 = {"segment direction reference point":13.5} self.assertRaises(Exception, pcsntc1.ParseParametersFromJson, testJson1) - + def test_CalculateGeometricProgressionSampleValues_linear(self): pcsntc1 = PhactoriCreateSegmentsNormalToCells() @@ -242,9 +242,10 @@ def test_CreateParaViewSourcesForSegments(self): pcsntc1 = PhactoriCreateSegmentsNormalToCells() pcsntc1.CreateSegmentsForAllCells(xfrm1) pcsntc1.CreateParaViewSourcesForSegments() - + if __name__ == '__main__': cc = Cone() rr = Show() unittest.main() + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriDataArtifactMetaDataControl.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriDataArtifactMetaDataControl.py index b16b2d61ab..48c7bdc82c 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriDataArtifactMetaDataControl.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriDataArtifactMetaDataControl.py @@ -90,3 +90,5 @@ def test_PhactoriDataArtifactMetaDataControl_output_enable(self): cc = Cone() rr = Show() unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriExtractBlockOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriExtractBlockOperation.py new file mode 100644 index 0000000000..8aa6f734fc --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriExtractBlockOperation.py @@ -0,0 +1,89 @@ +# Copyright(C) 1999-2020 National Technology & Engineering Solutions +# of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +# NTESS, the U.S. Government retains certain rights in this software. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are +# met: +# +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# * Redistributions in binary form must reproduce the above +# copyright notice, this list of conditions and the following +# disclaimer in the documentation and/or other materials provided +# with the distribution. +# +# * Neither the name of NTESS nor the names of its +# contributors may be used to endorse or promote products derived +# from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +from phactori import * +import unittest +#from vtk import * +import vtk +from Operation.PhactoriExtractBlockOperation import * +import paraview.simple + +class TestPhactoriExtractBlockOperation(unittest.TestCase): + + def test_ExtractOneBlockFromAGroupWithThreeBlocks(self): + cone1 = Cone(registrationName = "cone1") + sphere1 = Sphere(registrationName = "sphere1") + cylinder1 = Sphere(registrationName = "cylinder1") + group1 = GroupDatasets(registrationName = "group1", Input = [cone1, sphere1, cylinder1]) + group1.UpdatePipeline() + + newOperationBlock = PhactoriOperationBlock() + newOperationBlock.mName = "testoperation" + operationParams = {"include blocks": ["/Root/cone1"]} + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'extractblock', + PhactoriExtractBlockOperation, + operationParams) + ConstructPipelineOperationFromParsedOperationBlockC_ForTest(newOperationBlock, group1) + newOperationBlock.GetPvFilter().UpdatePipeline() + csdata = newOperationBlock.GetPvFilter().GetClientSideObject().GetOutputDataObject(0) + if PhactoriDbg(100): + myDebugPrint3("group number of blocks:" + str(csdata.GetNumberOfBlocks())) + self.assertEqual(csdata.GetNumberOfBlocks(), 1) + + def test_ExtractTwoBlocksFromAGroupWithThgeeBlocks(self): + cone1 = Cone(registrationName = "cone1") + sphere1 = Sphere(registrationName = "sphere1") + cylinder1 = Sphere(registrationName = "cylinder1") + group1 = GroupDatasets(registrationName = "group1", Input = [cone1, sphere1, cylinder1]) + group1.UpdatePipeline() + + newOperationBlock = PhactoriOperationBlock() + newOperationBlock.mName = "testoperation" + operationParams = {"include blocks": ["/Root/cone1", "/Root/cylinder1"]} + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'extractblock', + PhactoriExtractBlockOperation, + operationParams) + ConstructPipelineOperationFromParsedOperationBlockC_ForTest(newOperationBlock, group1) + newOperationBlock.GetPvFilter().UpdatePipeline() + csdata = newOperationBlock.GetPvFilter().GetClientSideObject().GetOutputDataObject(0) + if PhactoriDbg(100): + myDebugPrint3("group number of blocks:" + str(csdata.GetNumberOfBlocks())) + self.assertEqual(csdata.GetNumberOfBlocks(), 2) + +if __name__ == '__main__': + cc = Cone() + rr = Show() + unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriExtractSurfaceOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriExtractSurfaceOperation.py new file mode 100644 index 0000000000..65f14478bf --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriExtractSurfaceOperation.py @@ -0,0 +1,109 @@ +# Copyright(C) 1999-2022 National Technology & Engineering Solutions +# of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +# NTESS, the U.S. Government retains certain rights in this software. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are +# met: +# +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# * Redistributions in binary form must reproduce the above +# copyright notice, this list of conditions and the following +# disclaimer in the documentation and/or other materials provided +# with the distribution. +# +# * Neither the name of NTESS nor the names of its +# contributors may be used to endorse or promote products derived +# from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +from phactori import * +import unittest +#from vtk import * +import vtk +from Operation.PhactoriExtractSurfaceOperation import * +import paraview.simple + +class TestPhactoriExtractSurfaceOperation(unittest.TestCase): + + def localSetThresholdRange(self, threshOp, lowerValue, upperValue): + global gParaViewCatalystVersionFlag + if gParaViewCatalystVersionFlag < 51000: + threshOp.ThresholdRange = [lowerValue, upperValue] + else: + threshOp.LowerThreshold = lowerValue + threshOp.UpperThreshold = upperValue + threshOp.ThresholdMethod = vtk.vtkThreshold.THRESHOLD_BETWEEN + + def test_ExtractSurface1(self): + if PhactoriDbg(100): + myDebugPrint3("test_ExtractSurface1 entered\n") + testWavelet = Wavelet() + testWavelet.UpdatePipeline() + + testThresh1 = Threshold(registrationName='Threshold3', Input=testWavelet) + testThresh1.Scalars = ['POINTS', 'RTData'] + self.localSetThresholdRange(testThresh1, 200.0, 300.0) + #self.localSetThresholdRange(testThresh1, -10000000.0, 1000000000.0) + testGroup = GroupDatasets(registrationName='testgroup1', Input=[testThresh1]) + + #testGroup = GroupDatasets(registrationName='testgroup1', Input=[testWavelet]) + + testGroup.UpdatePipeline() + newOperationBlock = PhactoriOperationBlock() + newOperationBlock.mName = "test_extractsurface" + operationParams = { + "input": "testgroup1", + "type": "extractsurface" + } + if PhactoriDbg(100): + myDebugPrint3("about to parse and construct, testGroup: " + str(testGroup) +"\n") + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'extractsurface', + PhactoriExtractSurfaceOperation, + operationParams) + ConstructPipelineOperationFromParsedOperationBlockC_ForTest(newOperationBlock, testGroup) + if PhactoriDbg(100): + myDebugPrint3("done to parse and construct, newOperationBlock: " + str(newOperationBlock) +"\n") + newOperationBlock.GetPvFilter().UpdatePipeline() + + csdata = newOperationBlock.GetPvFilter().GetClientSideObject().GetOutputDataObject(0) + icsdClassname = csdata.GetClassName() + if PhactoriDbg(100): + myDebugPrint3("icsdClassname: " + str(icsdClassname) + "\n") + self.assertEqual(icsdClassname, "vtkMultiBlockDataSet") + + numBlocks = csdata.GetNumberOfBlocks() + if PhactoriDbg(100): + myDebugPrint3("numBlocks: " + str(numBlocks) + "\n") + + blk0 = csdata.GetBlock(0) + icsdClassname2 = blk0.GetClassName() + if PhactoriDbg(100): + myDebugPrint3("blk0 icsdClassname2: " + str(icsdClassname2) + "\n") + self.assertEqual(icsdClassname2, "vtkPolyData") + + numPoints = blk0.GetNumberOfPoints() + if PhactoriDbg(100): + myDebugPrint3("blk0 numPoints: " + str(numPoints) + "\n") + self.assertEqual(numPoints, 764) + +if __name__ == '__main__': + cc = Cone() + rr = Show() + unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriGeometricCellSampler1.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriGeometricCellSampler1.py index 2ca9687977..eb5d43ae42 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriGeometricCellSampler1.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriGeometricCellSampler1.py @@ -238,7 +238,7 @@ def test_CreateInternalListOfGeometricallySampledCellsOnThisProcess(self): [[-1.5, 3.5, 6.5], [-1, -1, -1], [204.49305725097656], 0, 1, 6668, -1, -1]] } """ - + goldJson = json.loads(goldTestStringJson) ff = open("test_PhactoriGeometricCellSampler1_1.json", "r") testJson = json.load(ff) @@ -567,3 +567,5 @@ def test_CollectDataOnSampledCellsOnThisProcess(self): cc = Cone() rr = Show() unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriMarkCellSurfaceStatus2.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriMarkCellSurfaceStatus2.py index 36910c063d..53f20b11a8 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriMarkCellSurfaceStatus2.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriMarkCellSurfaceStatus2.py @@ -155,3 +155,6 @@ def test_MarkNoFlatSurfaceCellsFromFlattendWavelet1(self): self.assertEqual(testStatus, 1) testStatus = ssAry.GetTuple1((20*20*20-1)-421) self.assertEqual(testStatus, 1) + + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriMergeBlocksOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriMergeBlocksOperation.py new file mode 100644 index 0000000000..ad7ab6cce5 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriMergeBlocksOperation.py @@ -0,0 +1,170 @@ +# Copyright(C) 1999-2022 National Technology & Engineering Solutions +# of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +# NTESS, the U.S. Government retains certain rights in this software. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are +# met: +# +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# * Redistributions in binary form must reproduce the above +# copyright notice, this list of conditions and the following +# disclaimer in the documentation and/or other materials provided +# with the distribution. +# +# * Neither the name of NTESS nor the names of its +# contributors may be used to endorse or promote products derived +# from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +from phactori import * +import unittest +#from vtk import * +import vtk +from Operation.PhactoriMergeBlocksOperation import * +import paraview.simple + +class TestPhactoriMergeBlocksOperation(unittest.TestCase): + + def localSetThresholdRange(self, threshOp, lowerValue, upperValue): + global gParaViewCatalystVersionFlag + if gParaViewCatalystVersionFlag < 51000: + threshOp.ThresholdRange = [lowerValue, upperValue] + else: + threshOp.LowerThreshold = lowerValue + threshOp.UpperThreshold = upperValue + threshOp.ThresholdMethod = vtk.vtkThreshold.THRESHOLD_BETWEEN + + def MakeTestGroup(self, threshrange1, threshrange2): + testWavelet = Wavelet() + testWavelet.UpdatePipeline() + + testThresh1 = Threshold(registrationName='Threshold3', Input=testWavelet) + testThresh1.Scalars = ['POINTS', 'RTData'] + self.localSetThresholdRange(testThresh1, threshrange1[0], threshrange1[1]) + testThresh2 = Threshold(registrationName='Threshold4', Input=testWavelet) + testThresh2.Scalars = ['POINTS', 'RTData'] + self.localSetThresholdRange(testThresh2, threshrange2[0], threshrange2[1]) + testGroup = GroupDatasets(registrationName='testgroup1', Input=[testThresh1, testThresh2]) + testGroup.UpdatePipeline() + return testGroup + + def test_MergeBlocks1(self): + if PhactoriDbg(100): + myDebugPrint3("test_MergeBlocks1 entered\n") + testGroup = self.MakeTestGroup([0.0, 100.0], [200.0, 300.0]) + newOperationBlock = PhactoriOperationBlock() + newOperationBlock.mName = "test_mergeblocks" + operationParams = { + "input": "testgroup1", + "type": "mergeblocks" + } + if PhactoriDbg(100): + myDebugPrint3("about to parse and construct, testGroup: " + str(testGroup) +"\n") + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'mergeblocks', + PhactoriMergeBlocksOperation, + operationParams) + ConstructPipelineOperationFromParsedOperationBlockC_ForTest(newOperationBlock, testGroup) + if PhactoriDbg(100): + myDebugPrint3("done to parse and construct, newOperationBlock: " + str(newOperationBlock) +"\n") + newOperationBlock.GetPvFilter().UpdatePipeline() + + csdata = newOperationBlock.GetPvFilter().GetClientSideObject().GetOutputDataObject(0) + icsdClassname = csdata.GetClassName() + if PhactoriDbg(100): + myDebugPrint3("icsdClassname: " + str(icsdClassname) + "\n") + self.assertEqual(icsdClassname, "vtkUnstructuredGrid") + + numPoints = csdata.GetNumberOfPoints() + if PhactoriDbg(100): + myDebugPrint3("csdata.GetNumberOfPoints(): " + str(numPoints) + "\n") + self.assertEqual(numPoints, 1680) + + def test_MergeBlocksWithoutMergingPoints(self): + if PhactoriDbg(100): + myDebugPrint3("test_MergeBlocks1 entered\n") + testGroup = self.MakeTestGroup([50.0, 150.0], [125.0, 200.0]) + + newOperationBlock = PhactoriOperationBlock() + newOperationBlock.mName = "test_mergeblocks" + operationParams = { + "input": "testgroup1", + "type": "mergeblocks", + "merge points": 1 + } + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'mergeblocks', + PhactoriMergeBlocksOperation, + operationParams) + ConstructPipelineOperationFromParsedOperationBlockC_ForTest(newOperationBlock, testGroup) + newOperationBlock.GetPvFilter().UpdatePipeline() + csdata = newOperationBlock.GetPvFilter().GetClientSideObject().GetOutputDataObject(0) + icsdClassname = csdata.GetClassName() + self.assertEqual(icsdClassname, "vtkUnstructuredGrid") + numPoints = csdata.GetNumberOfPoints() + self.assertEqual(numPoints, 7491) + + newOperationBlock = PhactoriOperationBlock() + newOperationBlock.mName = "test_mergeblocks" + operationParams = { + "input": "testgroup1", + "type": "mergeblocks", + "merge points": 0 + } + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'mergeblocks', + PhactoriMergeBlocksOperation, + operationParams) + ConstructPipelineOperationFromParsedOperationBlockC_ForTest(newOperationBlock, testGroup) + newOperationBlock.GetPvFilter().UpdatePipeline() + csdata = newOperationBlock.GetPvFilter().GetClientSideObject().GetOutputDataObject(0) + icsdClassname = csdata.GetClassName() + self.assertEqual(icsdClassname, "vtkUnstructuredGrid") + numPoints = csdata.GetNumberOfPoints() + self.assertEqual(numPoints, 8339) + + def test_MergeBlocksMergePartitionsOnly(self): + if PhactoriDbg(100): + myDebugPrint3("test_MergeBlocks1 entered\n") + testGroup = self.MakeTestGroup([50.0, 150.0], [125.0, 200.0]) + + newOperationBlock = PhactoriOperationBlock() + newOperationBlock.mName = "test_mergeblocks" + operationParams = { + "input": "testgroup1", + "type": "mergeblocks", + "merge partitions only": 1 + } + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'mergeblocks', + PhactoriMergeBlocksOperation, + operationParams) + ConstructPipelineOperationFromParsedOperationBlockC_ForTest(newOperationBlock, testGroup) + newOperationBlock.GetPvFilter().UpdatePipeline() + csdata = newOperationBlock.GetPvFilter().GetClientSideObject().GetOutputDataObject(0) + icsdClassname = csdata.GetClassName() + self.assertEqual(icsdClassname, "vtkMultiBlockDataSet") + self.assertEqual(newOperationBlock.GetPvFilter().MergePartitionsOnly, 1) + numPoints = csdata.GetNumberOfPoints() + self.assertEqual(numPoints, 8339) + +if __name__ == '__main__': + cc = Cone() + rr = Show() + unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriPointDataToCellDataOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriPointDataToCellDataOperation.py new file mode 100644 index 0000000000..9b5af371f6 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriPointDataToCellDataOperation.py @@ -0,0 +1,131 @@ +# Copyright(C) 1999-2022 National Technology & Engineering Solutions +# of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +# NTESS, the U.S. Government retains certain rights in this software. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are +# met: +# +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# * Redistributions in binary form must reproduce the above +# copyright notice, this list of conditions and the following +# disclaimer in the documentation and/or other materials provided +# with the distribution. +# +# * Neither the name of NTESS nor the names of its +# contributors may be used to endorse or promote products derived +# from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +from phactori import * +import unittest +#from vtk import * +import vtk +from Operation.PhactoriPointDataToCellDataOperation import * +import paraview.simple + +class TestPhactoriPointDataToCellDataOperation(unittest.TestCase): + + def localSetThresholdRange(self, threshOp, lowerValue, upperValue): + global gParaViewCatalystVersionFlag + if gParaViewCatalystVersionFlag < 51000: + threshOp.ThresholdRange = [lowerValue, upperValue] + else: + threshOp.LowerThreshold = lowerValue + threshOp.UpperThreshold = upperValue + threshOp.ThresholdMethod = vtk.vtkThreshold.THRESHOLD_BETWEEN + + def makeTestGroupWithTwoThresholdsFromWavelet(self): + testWavelet = Wavelet() + testWavelet.UpdatePipeline() + + testThresh1 = Threshold(registrationName='Threshold3', Input=testWavelet) + testThresh1.Scalars = ['POINTS', 'RTData'] + self.localSetThresholdRange(testThresh1, 0.0, 100.0) + testThresh2 = Threshold(registrationName='Threshold4', Input=testWavelet) + testThresh2.Scalars = ['POINTS', 'RTData'] + self.localSetThresholdRange(testThresh2, 200.0, 300.0) + + testGroup = GroupDatasets(registrationName='testgroup1', Input=[testThresh1, testThresh2]) + + testGroup.UpdatePipeline() + return testGroup + + def test_PointDataToCellData_Multiblock1(self): + if PhactoriDbg(100): + myDebugPrint3("test_PointDataToCellData1 entered\n") + testGroup = self.makeTestGroupWithTwoThresholdsFromWavelet() + newOperationBlock = PhactoriOperationBlock() + newOperationBlock.mName = "test_celltopoint" + operationParams = { + "input": "testgroup1", + "type": "node data to element data" + } + if PhactoriDbg(100): + myDebugPrint3("about to parse and construct, testGroup: " + str(testGroup) +"\n") + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'node data to element data', + PhactoriPointDataToCellDataOperation, + operationParams) + ConstructPipelineOperationFromParsedOperationBlockC_ForTest(newOperationBlock, testGroup) + newOperationBlock.GetPvFilter().UpdatePipeline() + + csdata = newOperationBlock.GetPvFilter().GetClientSideObject().GetOutputDataObject(0) + blk0 = csdata.GetBlock(0) + cellArrays = blk0.GetCellData() + self.assertEqual(1, cellArrays.GetNumberOfArrays()) + ptArrays = blk0.GetPointData() + self.assertEqual(0, ptArrays.GetNumberOfArrays()) + self.assertEqual("RTData", cellArrays.GetArrayName(0)) + celldata = cellArrays.GetArray("RTData") + self.assertNotEqual(celldata, None) + + def test_PointDataToCellData_Multiblock2PassCellData(self): + if PhactoriDbg(100): + myDebugPrint3("test_PointDataToCellData1 entered\n") + testGroupWithCellData = self.makeTestGroupWithTwoThresholdsFromWavelet() + newOperationBlock = PhactoriOperationBlock() + newOperationBlock.mName = "test_celltopoint" + operationParams = { + "input": "testgroup1", + "type": "node data to element data", + "pass point data": 1 + } + if PhactoriDbg(100): + myDebugPrint3("about to parse and construct, testGroup: " + str(testGroup) +"\n") + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'node data to element data', + PhactoriPointDataToCellDataOperation, + operationParams) + ConstructPipelineOperationFromParsedOperationBlockC_ForTest(newOperationBlock, testGroupWithCellData) + newOperationBlock.GetPvFilter().UpdatePipeline() + + csdata = newOperationBlock.GetPvFilter().GetClientSideObject().GetOutputDataObject(0) + blk0 = csdata.GetBlock(0) + cellArrays = blk0.GetCellData() + self.assertEqual(1, cellArrays.GetNumberOfArrays()) + ptArrays = blk0.GetPointData() + self.assertEqual(1, ptArrays.GetNumberOfArrays()) + self.assertEqual("RTData", ptArrays.GetArrayName(0)) + ptdata = ptArrays.GetArray("RTData") + self.assertNotEqual(ptdata, None) + +if __name__ == '__main__': + cc = Cone() + rr = Show() + unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriPointSourceFromJsonList.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriPointSourceFromJsonList.py index 9d7ba108b2..1e55b80fd2 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriPointSourceFromJsonList.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriPointSourceFromJsonList.py @@ -55,11 +55,11 @@ def test_ValidateJsonPointList(self): ] with self.assertRaises(Exception): theSource.ValidateJsonPointList() - + theSource.JsonList = [] with self.assertRaises(Exception): theSource.ValidateJsonPointList() - + def test_CreateVtkPolyDataFromJsonList(self): theSource = PhactoriPointSourceFromJsonList() @@ -77,8 +77,10 @@ def test_CreateVtkPolyDataFromJsonList(self): self.assertEqual(pt0, tuple(theSource.JsonList[0])) pt3 = vtkPts.GetPoint(3) self.assertEqual(pt3, tuple(theSource.JsonList[3])) - + if __name__ == '__main__': cc = Cone() rr = Show() unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSampledCellInfo.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSampledCellInfo.py index 98485f31c4..93cd1295d7 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSampledCellInfo.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSampledCellInfo.py @@ -98,3 +98,4 @@ def test_PhactoriFindCellWtihMinMaxDataUsingMPI(self): cc = Cone() rr = Show() unittest.main() + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSegment.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSegment.py index 693adacf74..f2a8720deb 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSegment.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSegment.py @@ -55,7 +55,7 @@ def test_FindNearestPointOnSegmentToPoint(self): self.assertEqual(testpt1, theSegment.ptB) testpt1 = theSegment.FindNearestPointOnSegmentToPoint([0.0, 0.0, 0.0]) self.assertEqual(testpt1, [-0.3793103448275862, -0.06896551724137923, 0.24137931034482762]) - + def test_FindDistanceSquaredToPoint(self): theSegment = PhactoriSegment() theSegment.SetPoints([-1.0, -1.0, -1.0], [1.0, 2.0, 3.0]) @@ -223,3 +223,5 @@ def test_IntersectsBoundingBoxProjected(self): cc = Cone() rr = Show() unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSegmentCellSampler3.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSegmentCellSampler3.py index f7e8148a80..2994953677 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSegmentCellSampler3.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSegmentCellSampler3.py @@ -154,7 +154,7 @@ def test_GetListOfCellTestPointsNearestListOfPoints(self): #myDebugPrint3('DoMethodPerBlock: pvClientSideData is None\n') #outstr3 = "num points in sphere: " + str(pvClientSideData.GetNumberOfPoints()) + "\n" #myDebugPrint3(outstr3) - + PhactoriSegmentCellSampler3Instance = newOperationBlock.mOperationSpecifics PhactoriSegmentCellSampler3Instance.myCopyOfInputFilter = testSphere thisProcessNearestCellPointList, thisProcDistSqrdList = PhactoriSegmentCellSampler3Instance.\ @@ -327,8 +327,8 @@ def test_GatherStructuredCellsFromSeedCells(self): localDataTuples.append(oneStructuredCell.dataTuple) self.assertEqual(localResultPoints, goldPoints[ii]) #myDebugPrint3("end cell test points for segment k axis " + str(ii) + "\n") - - #test j axis collection instead of k + + #test j axis collection instead of k operationParams = { "filename":"dummyfilename", "cell center to segment test distance":0.5, @@ -348,7 +348,7 @@ def test_GatherStructuredCellsFromSeedCells(self): self.assertTrue(PhactoriSegmentCellSampler3Instance.ValidateJsonStructuredSeedCellList(testGeometryPointsJson)) PhactoriSegmentCellSampler3Instance.CreateInternalStructuredSeedCellListFromJson(testGeometryPointsJson) testWavelet.UpdatePipeline() - + perSegmentStructuredCellList = PhactoriSegmentCellSampler3Instance.GatherStructuredCellsFromSeedCells() self.assertEqual(len(perSegmentStructuredCellList),len(PhactoriSegmentCellSampler3Instance.StructuredNearbyCellPointList)) @@ -365,8 +365,8 @@ def test_GatherStructuredCellsFromSeedCells(self): #myDebugPrint3(str(oneStructuredCell.cellTestPoint) + "\n") self.assertEqual(localResultPoints, goldPoints[ii]) #myDebugPrint3("end cell test points for segment j axis " + str(ii) + "\n") - - #test i axis collection instead of j or k + + #test i axis collection instead of j or k operationParams = { "filename":"dummyfilename", "cell center to segment test distance":0.5, @@ -375,7 +375,7 @@ def test_GatherStructuredCellsFromSeedCells(self): } PhactoriSegmentCellSampler3Instance.ParseParametersFromJson(operationParams) - + testGeometryPointsJson = [ {"geometric seed point":[0.5, 0.5, 0.5], "collection axis":"i"}, @@ -386,7 +386,7 @@ def test_GatherStructuredCellsFromSeedCells(self): self.assertTrue(PhactoriSegmentCellSampler3Instance.ValidateJsonStructuredSeedCellList(testGeometryPointsJson)) PhactoriSegmentCellSampler3Instance.CreateInternalStructuredSeedCellListFromJson(testGeometryPointsJson) testWavelet.UpdatePipeline() - + perSegmentStructuredCellList = PhactoriSegmentCellSampler3Instance.GatherStructuredCellsFromSeedCells() self.assertEqual(len(perSegmentStructuredCellList),len(PhactoriSegmentCellSampler3Instance.StructuredNearbyCellPointList)) @@ -509,7 +509,7 @@ def test_WriteAllDataFromOneProcessUsingMPI(self): testJson = json.load(ff) ff.close() self.assertEqual(goldJson, testJson) - + #remove file that got made during test os.remove(testFileName) @@ -847,9 +847,11 @@ def test_WriteAllDataFromOneProcessUsingMPIStructured(self): #remove file that got made during test os.remove(testFileName) - - + + if __name__ == '__main__': cc = Cone() rr = Show() unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSliceWithPlaneOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSliceWithPlaneOperation.py index 4448f1310b..292aa2c01d 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSliceWithPlaneOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriSliceWithPlaneOperation.py @@ -62,3 +62,5 @@ def test_DefaultSliceWithPlaneBehavior(self): cc = Cone() rr = Show() unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriThresholdOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriThresholdOperation.py index 94ba722248..51fea31442 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriThresholdOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriThresholdOperation.py @@ -63,3 +63,5 @@ def test_ThresholdTest1(self): cc = Cone() rr = Show() unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriVariableInfo.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriVariableInfo.py new file mode 100644 index 0000000000..46647f47c5 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriVariableInfo.py @@ -0,0 +1,245 @@ +# Copyright(C) 1999-2022 National Technology & Engineering Solutions +# of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +# NTESS, the U.S. Government retains certain rights in this software. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are +# met: +# +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# * Redistributions in binary form must reproduce the above +# copyright notice, this list of conditions and the following +# disclaimer in the documentation and/or other materials provided +# with the distribution. +# +# * Neither the name of NTESS nor the names of its +# contributors may be used to endorse or promote products derived +# from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +from phactori import * +import unittest +from paraview.simple import * + +class Test_PhactoriVariableInfo(unittest.TestCase): + + def test_ScalarVariableParsing(self): + testVarInfo = PhactoriVariableInfo() + testJson = {"color by scalar": "temperature"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableIntendedForUseFlag, True) + self.assertEqual(testVarInfo.mVariableName, "temperature") + self.assertEqual(testVarInfo.mVariableTypeNeedsDetection, True) + #defaults to variable type of element if needing detection + self.assertEqual(testVarInfo.mVariableType, "element") + self.assertEqual(testVarInfo.mVariableTypeWasDetected, False) + self.assertEqual(testVarInfo.mVariableIsVectorMagnitude, False) + self.assertEqual(testVarInfo.mVariableIsVectorComponent, False) + + def test_ScalarVariableWithCellOrNodeIdentificationParsing(self): + testVarInfo = PhactoriVariableInfo() + testJson = {"color by scalar": "pressure", "variable type": "element"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableIntendedForUseFlag, True) + self.assertEqual(testVarInfo.mVariableName, "pressure") + self.assertEqual(testVarInfo.mVariableTypeNeedsDetection, False) + self.assertEqual(testVarInfo.mVariableTypeWasDetected, True) + self.assertEqual(testVarInfo.mVariableIsVectorMagnitude, False) + self.assertEqual(testVarInfo.mVariableIsVectorComponent, False) + self.assertEqual(testVarInfo.mVariableType, "element") + testVarInfo = PhactoriVariableInfo() + testJson = {"color by scalar": "temperature", "variable type": "node"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableIntendedForUseFlag, True) + self.assertEqual(testVarInfo.mVariableName, "temperature") + self.assertEqual(testVarInfo.mVariableTypeNeedsDetection, False) + self.assertEqual(testVarInfo.mVariableTypeWasDetected, True) + self.assertEqual(testVarInfo.mVariableIsVectorMagnitude, False) + self.assertEqual(testVarInfo.mVariableIsVectorComponent, False) + self.assertEqual(testVarInfo.mVariableType, "node") + testJson = {"color by scalar": "speed", "variable type": "global"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableIntendedForUseFlag, True) + self.assertEqual(testVarInfo.mVariableName, "speed") + self.assertEqual(testVarInfo.mVariableTypeNeedsDetection, False) + self.assertEqual(testVarInfo.mVariableTypeWasDetected, True) + self.assertEqual(testVarInfo.mVariableIsVectorMagnitude, False) + self.assertEqual(testVarInfo.mVariableIsVectorComponent, False) + self.assertEqual(testVarInfo.mVariableType, "global") + testJson = {"color by scalar": "temperature", "variable type": "detect"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableIntendedForUseFlag, True) + self.assertEqual(testVarInfo.mVariableName, "temperature") + self.assertEqual(testVarInfo.mVariableTypeNeedsDetection, True) + self.assertEqual(testVarInfo.mVariableTypeWasDetected, False) + self.assertEqual(testVarInfo.mVariableIsVectorMagnitude, False) + self.assertEqual(testVarInfo.mVariableIsVectorComponent, False) + self.assertEqual(testVarInfo.mVariableType, "element") + + def test_VectorMagnitudeVariableParsing(self): + testVarInfo = PhactoriVariableInfo() + testJson = {"color by vector magnitude": "velocity"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableIntendedForUseFlag, True) + self.assertEqual(testVarInfo.mVariableName, "velocity") + self.assertEqual(testVarInfo.mVariableTypeNeedsDetection, True) + #defaults to variable type of element if needing detection + self.assertEqual(testVarInfo.mVariableType, "element") + self.assertEqual(testVarInfo.mVariableTypeWasDetected, False) + self.assertEqual(testVarInfo.mVariableIsVectorMagnitude, True) + self.assertEqual(testVarInfo.mVariableIsVectorComponent, False) + + def test_VectorComponentViaLetterSuffixVariableParsing1(self): + testVarInfo = PhactoriVariableInfo() + testJson = {"color by vector component": "velocityX"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableIntendedForUseFlag, True) + self.assertEqual(testVarInfo.mVariableName, "velocity") + self.assertEqual(testVarInfo.mVariableTypeNeedsDetection, True) + #defaults to variable type of element if needing detection + self.assertEqual(testVarInfo.mVariableType, "element") + self.assertEqual(testVarInfo.mVariableTypeWasDetected, False) + self.assertEqual(testVarInfo.mVariableIsVectorMagnitude, False) + self.assertEqual(testVarInfo.mVariableIsVectorComponent, True) + self.assertEqual(testVarInfo.mVariableComponent, 0) + testJson = {"color by vector component": "velocityY"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableComponent, 1) + testJson = {"color by vector component": "velocityZ"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableComponent, 2) + testJson = {"color by vector component": "velocityY"} + + def test_VectorComponentViaNumberSuffixVariableParsing1(self): + testVarInfo = PhactoriVariableInfo() + testJson = {"color by vector component": "velocity0"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableIntendedForUseFlag, True) + self.assertEqual(testVarInfo.mVariableName, "velocity") + self.assertEqual(testVarInfo.mVariableTypeNeedsDetection, True) + #defaults to variable type of element if needing detection + self.assertEqual(testVarInfo.mVariableType, "element") + self.assertEqual(testVarInfo.mVariableTypeWasDetected, False) + self.assertEqual(testVarInfo.mVariableIsVectorMagnitude, False) + self.assertEqual(testVarInfo.mVariableIsVectorComponent, True) + self.assertEqual(testVarInfo.mVariableComponent, 0) + testJson = {"color by vector component": "velocity2"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableComponent, 2) + testJson = {"color by vector component": "velocity10"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableComponent, 10) + testJson = {"color by vector component": "velocity11"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableComponent, 11) + testJson = {"color by vector component": "velocity99"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableComponent, 99) + + def test_VectorComponentViaLetterSuffixVariableWithSeparatorParsing1(self): + testVarInfo = PhactoriVariableInfo() + testVarInfo.mAddSeparatorToVectorVariableName = True + newRoot = PhactoriPipeAndViewsState() + SetgPipeAndViewStateForTesting(newRoot) + testJson = {"color by vector component": "velocity_Y"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableIntendedForUseFlag, True) + self.assertEqual(testVarInfo.mVariableName, "velocity_") + self.assertEqual(testVarInfo.mVariableTypeNeedsDetection, True) + #defaults to variable type of element if needing detection + self.assertEqual(testVarInfo.mVariableType, "element") + self.assertEqual(testVarInfo.mVariableTypeWasDetected, False) + self.assertEqual(testVarInfo.mVariableIsVectorMagnitude, False) + self.assertEqual(testVarInfo.mVariableIsVectorComponent, True) + self.assertEqual(testVarInfo.mVariableComponent, 1) + testVarInfo = PhactoriVariableInfo() + testJson = {"color by vector magnitude": "velocity"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableIntendedForUseFlag, True) + self.assertEqual(testVarInfo.mVariableName, "velocity") + self.assertEqual(testVarInfo.mVariableIsVectorMagnitude, True) + + def test_VectorComponentViaNumberParsing1(self): + testVarInfo = PhactoriVariableInfo() + testJson = {"color by vector component number": ["velocity", 0] } + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableIntendedForUseFlag, True) + self.assertEqual(testVarInfo.mVariableName, "velocity") + self.assertEqual(testVarInfo.mVariableTypeNeedsDetection, True) + #defaults to variable type of element if needing detection + self.assertEqual(testVarInfo.mVariableType, "element") + self.assertEqual(testVarInfo.mVariableTypeWasDetected, False) + self.assertEqual(testVarInfo.mVariableIsVectorMagnitude, False) + self.assertEqual(testVarInfo.mVariableIsVectorComponent, True) + self.assertEqual(testVarInfo.mVariableComponent, 0) + + testJson = {"variable vector component number": ["velocity", 1] } + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "variable ") + self.assertEqual(testVarInfo.mVariableComponent, 1) + + testJson = {"variable vector component number": ["velocity", 77] } + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "variable ") + self.assertEqual(testVarInfo.mVariableComponent, 77) + + def test_ScalarVariableWithCellOrNodeIdentificationParsing(self): + testVarInfo = PhactoriVariableInfo() + testJson = {"color by vector component number": ["velocity", 2], "variable type":"node"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableIntendedForUseFlag, True) + self.assertEqual(testVarInfo.mVariableName, "velocity") + self.assertEqual(testVarInfo.mVariableTypeNeedsDetection, False) + self.assertEqual(testVarInfo.mVariableType, "node") + self.assertEqual(testVarInfo.mVariableTypeWasDetected, True) + self.assertEqual(testVarInfo.mVariableIsVectorMagnitude, False) + self.assertEqual(testVarInfo.mVariableIsVectorComponent, True) + self.assertEqual(testVarInfo.mVariableComponent, 2) + testJson = {"color by vector component number": ["velocity", 3], "variable type":"element"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableType, "element") + self.assertEqual(testVarInfo.mVariableComponent, 3) + testJson = {"color by vector component number": ["velocity", 0], "variable type":"global"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableType, "global") + self.assertEqual(testVarInfo.mVariableComponent, 0) + testJson = {"color by vector component number": ["velocity", 7], "variable type":"detect"} + testVarInfo.ParseVariableNameAndVectorOrTensorComponent(testJson, "color by ") + self.assertEqual(testVarInfo.mVariableTypeNeedsDetection, True) + self.assertEqual(testVarInfo.mVariableTypeWasDetected, False) + #defaults to variable type of element if needing detection + self.assertEqual(testVarInfo.mVariableType, "element") + self.assertEqual(testVarInfo.mVariableComponent, 7) + + #def __init__(self): + # self.mVariableIntendedForUseFlag = False + # self.mVariableName = "" + # self.mVariableComponent = None + # self.mVariableType = None + # self.mVariableTypeNeedsDetection = False + # self.mVariableTypeWasDetected = False + # self.mVariableTypeWasCopied = False + # self.mVariableIsVectorMagnitude = False + # self.mVariableIsVectorComponent = False + # self.mVectorBaseName = None + # self.mStats = PhactoriVariableMinMaxAvgSumCntSave() + # #as of 2022Aug09 we want this to default to False + # self.mAddSeparatorToVectorVariableName = False + +if __name__ == '__main__': + cc = Cone() + rr = Show() + unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriVtkCellOperations.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriVtkCellOperations.py index c1856781c6..27fb01cc6d 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriVtkCellOperations.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriVtkCellOperations.py @@ -50,9 +50,9 @@ def MakeOneHexahdtronGridFrom8Points1(self, pointList): points.InsertNextPoint(pointList[5]) points.InsertNextPoint(pointList[6]) points.InsertNextPoint(pointList[7]) - + # Create a hexahedron from the points - hex = vtk.vtkHexahedron() + hex = vtk.vtkHexahedron() hex.GetPointIds().SetId(0,0) hex.GetPointIds().SetId(1,1) hex.GetPointIds().SetId(2,2) @@ -61,11 +61,11 @@ def MakeOneHexahdtronGridFrom8Points1(self, pointList): hex.GetPointIds().SetId(5,5) hex.GetPointIds().SetId(6,6) hex.GetPointIds().SetId(7,7) - + # Add the hexahedron to a cell array hexs = vtk.vtkCellArray() hexs.InsertNextCell(hex) - + # Add the points and hexahedron to an unstructured grid uGrid = vtk.vtkUnstructuredGrid() uGrid.SetPoints(points) @@ -268,9 +268,7 @@ def test_PhactoriFindSurfaceStatusForOneCellUsingFaceInfo_FlatCells(self): self.assertEqual(testStatus, 12) testStatus = PhactoriFindSurfaceStatusForOneCellUsingFaceInfo(wv1grid, 20, cellsTouchingEachFace) counts1 = cellsTouchingEachFace.GetNumberOfCellsTouchingEachFaceOfOneCell(20) - print(20, counts1) extList1 = cellsTouchingEachFace.GetListOfExteriorFacesOnCellByIndex(20) - print(20, extList1) self.assertEqual(testStatus, 6) testStatus = PhactoriFindSurfaceStatusForOneCellUsingFaceInfo(wv1grid, (20*20*20-1)-1, cellsTouchingEachFace) self.assertEqual(testStatus, 12) @@ -431,12 +429,12 @@ def test_PhactoriGetCellEdgeVector(self): self.assertEqual(testEdgeVec, [0.0, 0.0, 4.0]) testEdgeVec = PhactoriGetCellEdgeVector(testugrid1, testhex1, 11) self.assertEqual(testEdgeVec, [0.0, 0.0, 3.0]) - + def test_PhactoriFindCellEdgeAngleMetricsForOneCell(self): testugrid1 = self.MakeOneHexahdronGrid1() testAngle, testHeight = PhactoriFindCellEdgeAngleMetricsForOneCell(testugrid1, 0, True, 0) self.assertEqual(testAngle, 67.38013505195958) - self.assertEqual(testHeight, 3.692307692307693) + self.assertEqual(testHeight, 3.692307692307693) testugrid2 = self.MakeOneFlatHexahdronGrid1() testAngle, testHeight = PhactoriFindCellEdgeAngleMetricsForOneCell(testugrid2, 0, True, 0) self.assertEqual(testAngle, 10.024987862075733) @@ -450,3 +448,5 @@ def test_PhactoriFindCellEdgeAngleMetricsForOneCell(self): cc = Cone() rr = Show() unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriVtkDataExportOperation.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriVtkDataExportOperation.py index c8d6f8a231..3952aea103 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriVtkDataExportOperation.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/Operation/test_PhactoriVtkDataExportOperation.py @@ -152,3 +152,5 @@ def test_EmptyThresholdVtkMultiblockOutput(self): cc = Cone() rr = Show() unittest.main() + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/PhactoriCombineToOneFile.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/PhactoriCombineToOneFile.py index 9a53d0b731..58de09d924 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/PhactoriCombineToOneFile.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/PhactoriCombineToOneFile.py @@ -96,7 +96,7 @@ def RemoveTripleQuotes(inlines): print(chgLine) outlines.append(chgLine) ndx = qend_ndx + 1 - return outlines + return outlines @@ -248,3 +248,7 @@ def GetCombineSectionFromClass(inClassName): if frmphimprtlnfound == False: print("error, from phactori import * not found in PhactoriDriver_modular.py") exit(-12) + + + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/PhactoriDriver.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/PhactoriDriver.py index 75816336a4..c44fa53ed1 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/PhactoriDriver.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/PhactoriDriver.py @@ -97,6 +97,10 @@ def setgUseHardwiredJsonScriptFile(inScriptFileName): global gPipeAndViewsState gPipeAndViewsState = None +def SetgPipeAndViewStateForTesting(testPipe): + global gPipeAndViewsState + gPipeAndViewsState = testPipe + def GetFrameTagCounter(): global gPipeAndViewsState if gPipeAndViewsState == None: @@ -115,8 +119,9 @@ def GetFrameTagCounter(): #gParaViewCatalystVersionFlag = 40300 #gParaViewCatalystVersionFlag = 40100 #gParaViewCatalystVersionFlag = 50400 -gParaViewCatalystVersionFlag = 50502 +#gParaViewCatalystVersionFlag = 50502 #gParaViewCatalystVersionFlag = 51000 +gParaViewCatalystVersionFlag = 51100 #attempt to use paraview.simple.GetParaViewVersion() to set version try: @@ -151,6 +156,9 @@ def GetFrameTagCounter(): global TestUserDataForBypassScriptCompletedFlag TestUserDataForBypassScriptCompletedFlag = False +global gTemporaryGlobalImageTextColor +gTemporaryGlobalImageTextColor = [1.0, 1.0, 1.0] + global bccolli_controls global gCameraTestMode @@ -170,6 +178,8 @@ def SetCameraTestMode(onOffSetting): def HandleJsonScriptLoadProcessZero(catalyst_script_extra_file): if PhactoriDbg(): myDebugPrint3("HandleJsonScriptLoadProcessZero entered\n") + myDebugPrint3("catalyst_script_extra_file: " + \ + str(catalyst_script_extra_file) + "\n") try: with open(catalyst_script_extra_file) as data_file: if PhactoriDbg(100): @@ -680,7 +690,7 @@ def TestUserDataForBypassScript(datadescription): myDebugPrint3("no user data, no catalyst_script_extra_file (2)\n") return - if(sa.GetNumberOfValues() > 8): + if(sa.GetNumberOfValues() > 8): catalyst_script_extra_file = sa.GetValue(8) if PhactoriDbg(100): myDebugPrint3(" catalyst_script_extra_file: ->" + \ @@ -891,7 +901,7 @@ def ParseSettingsFromJson(self, inJsn): halfH - betweenEyeY, -eyeToScreenDistance ] - + def GetScreenBottomLeft(self, inLeftEyeFlag): if inLeftEyeFlag: return self.mLeftEyeScreenBottomLeft @@ -1380,9 +1390,10 @@ def GetEyePosition(self, inLeftEyeFlag): #----- global gDefaultTimeFormatString -gDefaultTimeFormatString = "Time: %.10e" #gDefaultTimeFormatString = "Time: %.6e" #gDefaultTimeFormatString = "Time: %f" +#gDefaultTimeFormatString = "Time: %.10e" +gDefaultTimeFormatString = "Time: {time:.6f}" global gDefaultImageSizeX gDefaultImageSizeX = 1920 @@ -1767,7 +1778,7 @@ def DebugPrintCellAndPointArrayInfo(label, pvFilter, priority): DebugPrintVtkDataArraysInfo("PointData:\n", theData, priority) theData = pvFilter.CellData DebugPrintVtkDataArraysInfo("CellData:\n", theData, priority) - + #def SetCpViewsAndCpWriters(inCpViews, inCpWriters): # global localCpViews # global localCpWriters @@ -2111,9 +2122,9 @@ def PhactoriCountCellTouchingEachFace(inInputCsData): "\nnum faces with 1 cell: " + str(cctef.totalNumFacesWithOneCellTouching) + \ "\nnum faces with 2 cells: " + str(cctef.totalNumFacesWithTwoCellsTouching) + \ "\nnum faces with 3+ cells: " + str(cctef.totalNumFacesWith3plCellsTouching) + "\n") - + return countCellsTouchingEachFace - + def PhactoriCountCellTouchingEachPoint(inInputCsData): numCells = inInputCsData.GetNumberOfCells() numPoints = inInputCsData.GetNumberOfPoints() @@ -2404,7 +2415,7 @@ def PhactoriGetAverageOfCellPoints(inInputCsData, oneCell): avgFac = 1.0/float(numPoints) vecScaleInPlace(avgFac, retAvgPt) return retAvgPt - + def PhactoriFindSelectedAngleBetweenEdgeAndCellNormal(inInputCsData, oneCell, compareNormal, paramUseSmallestAngle, paramOffsetIndex): edgeCompareDotProdList = [] @@ -2414,7 +2425,7 @@ def PhactoriFindSelectedAngleBetweenEdgeAndCellNormal(inInputCsData, oneCell, vecNormalize2(oneEdgeVec, oneEdgeVec) edgeCompareDotProd = abs(vecDotProduct(compareNormal, oneEdgeVec)) edgeCompareDotProdList.append(edgeCompareDotProd) - + sortedEdgeCompareDotProdList = sorted(edgeCompareDotProdList) if paramUseSmallestAngle: @@ -2429,7 +2440,7 @@ def DebugPrintPhactoriFindHeightOfCell(inInputCsData, oneCell, compareNormal): if PhactoriDbg(100): dbght = [] dbglen = [] - dbgretHeight = -1.0 + dbgretHeight = -1.0 dbgretHeightIndex = -1 for ii in range(0, numCellEdges): oneCellEdgeVec = PhactoriGetCellEdgeVector(inInputCsData, oneCell, ii) @@ -2458,7 +2469,7 @@ def PhactoriFindHeightOfCell(inInputCsData, oneCell, compareNormal): #than the four shortest sides? numCellEdges = oneCell.GetNumberOfEdges() - retHeight = -1.0 + retHeight = -1.0 for ii in range(0, numCellEdges): #get edge vectory and project on to normal vector (which is unit length) #and find magnitude @@ -2913,7 +2924,7 @@ def DebugPrintBlockName(csData, blockIndex): myDebugPrint3("oneBlockMetaData is None (2)\n") def PhactoriRecusivelyDoMethodPerBlockFromParaViewFilter(inRecursionControlItem, inPvFilter): - "grab client side data object, and use that to do recursion" + "grab client side data object, and use that to do recursion" pvClientSideData = inPvFilter.GetClientSideObject().GetOutputDataObject(0) if pvClientSideData == None: if PhactoriDbg(100): @@ -2998,7 +3009,7 @@ class PhactoriRenderViewInfo: def __init__(self): self.RenderView1 = None self.DataRepresentation1 = None - + #class PhactoriRenderViewInfo: # RenderView1 = None # DataRepresentation1 = None @@ -3145,12 +3156,12 @@ def SafeColorBy(inDataRepresentation, ptOrNodeAndVarname): if PhactoriDbg(100): myDebugPrint3("SafeColorBy returning (valid cell data)\n") return - + def SetDataRepresentationToDefault(inDataRepresentation): #a3_vel__PiecewiseFunction = CreatePiecewiseFunction( Points=[0.0, 0.0, 0.5, 0.0, 1.0, 1.0, 0.5, 0.0] ) - + inDataRepresentation.SelectionPointLabelColor = [0.5, 0.5, 0.5] inDataRepresentation.SelectionPointFieldDataArrayName = 'displ' inDataRepresentation.SuppressLOD = 0 @@ -3470,17 +3481,14 @@ def AddRenderView(inPhactoriImagesetInfo, inColorSettings, else: myDebugPrint3AndException("bad m_PlotType") else: - #UpdatePipelineWithCurrentTimeArgument(GetActiveSource()) SetParaViewViewToCurrentTime(RenderView1) - #myDebugPrint3(str(GetActiveView().ListProperties()) + "\n") - #myDebugPrint3("ViewTime: " + str(GetActiveView().ViewTime) + "\n") - DataRepresentation1 = Show() + DataRepresentation1 = Show(GetActiveSource(), RenderView1, 'UnstructuredGridRepresentation') if PhactoriDbg(): myDebugPrint3("representation made for 3d view:\n" + str(DataRepresentation1) + "\n") inPhactoriImagesetInfo.mPvDataRepresentation2 = DataRepresentation1 inPhactoriImagesetInfo.mVisiblePvDataReps[0] = DataRepresentation1 else: - DataRepresentation1 = inPhactoriImagesetInfo.mPvDataRepresentation2 + DataRepresentation1 = inPhactoriImagesetInfo.mPvDataRepresentation2 if PhactoriDbg(): myDebugPrint3("new DataRepresentation1: " + str(DataRepresentation1) + "\n") @@ -3503,7 +3511,7 @@ def AddRenderView(inPhactoriImagesetInfo, inColorSettings, if inPhactoriImagesetInfo.mVisiblePvDataReps[ii] == None: SetActiveSource(inPhactoriImagesetInfo.mVisibleOps[ii].\ mParaViewFilter) - newPvDataRep = Show() + newPvDataRep = Show(GetActiveSource(), RenderView1, 'UnstructuredGridRepresentation') SetDataRepresentationToDefault(newPvDataRep) inPhactoriImagesetInfo.mVisiblePvDataReps[ii] = newPvDataRep if PhactoriDbg(100): @@ -3623,9 +3631,9 @@ def CheckForParallelVector(vec1, vec2): if PhactoriDbg(): myDebugPrint3("same ratio between vectors, parallel\n") return True - + #given a bounds in the form [xmin, xmax, ymin, ymax, zmin, zmax], return the -# maximum dimension out of all those (max of xmax-xmin, ymax-ymin, and +# maximum dimension out of all those (max of xmax-xmin, ymax-ymin, and # zmax-zmin) def GetMaximumDimensionFromBounds(inBounds): maxDim = inBounds[1] - inBounds[0] @@ -4125,7 +4133,7 @@ def GetXyzForNodeOrElementParallelOneBlock(inInputCsData, inIdIsNode, def GetXyzForNodeOrElementParallelRecurse1(inInputCsData, inIdIsNode, inGlobalId, outXyz): "utility function used by GetXyzForNodeOrElementParallel\n\n looking for inGlobalId to potentially set outXyz, recurses through\n structure and calls GetXyzForNodeOrElementParallelOneBlock() on\n unstructured grids to do the real work of checking for the id and setting\n outXyz\n " - + #myDebugPrint3('GetXyzForNodeOrElementParallelRecurse1 entered\n', 100) icsdClassname = inInputCsData.GetClassName() @@ -4250,7 +4258,7 @@ def CalcRelativeCameraDistance2_AA(inFocalPoint, inNormCameraDir, "finds point X which is along the inNormCameraDir vector starting from\n point inFocalPoint, such that inTestPoint is visible. This is\n accomplished by taking a parametric value ss to move the camera position\n out from the focal point (along the inNormCameraDir vector) and finding\n the parametric value such that the angle between the vector from the\n camera position to the focal point and the camera position to inTestPoint\n is equal to (or greater than) the camera field of view. The parametric\n value is returned. We use the law of sines. assumes inNormCameraDir\n is normalized and pointing in the direction from inFocalPoint towards\n where we want to place the camera (the opposite of the look direction)" #angle between camera-to-focal point vector and camera-to-testpoint vector - #is equal to half the camera fOV. Call this angle AA. + #is equal to half the camera fOV. Call this angle AA. #The side opposite this angle has length equal to the distance between #the focal point and the test point. Call this distance aa. We also #know the angle between the focal point-to-camera vector and the focal @@ -4341,7 +4349,7 @@ def CalcRelativeCameraDistance2_BB(inFocalPoint, inNormCameraDir, myDebugPrint3("pointH: " + str(pointH) + "\n"); dd1 = CalcRelativeCameraDistance2_AA(inFocalPoint, inNormCameraDir, - pointH, inFovH) + pointH, inFovH) if PhactoriDbg(100): myDebugPrint3("dd1: " + str(dd1) + "\n"); dd2 = CalcRelativeCameraDistance2_AA(inFocalPoint, inNormCameraDir, @@ -4426,7 +4434,7 @@ def CalcRelativeCameraDistance2(inFocalPoint, inLookDirection, inUpVector, aspectRatio = float(inXyPixelSize[0]) / float(inXyPixelSize[1]) else: aspectRatio = float(pixelSizeWithBorder[0]) / float(pixelSizeWithBorder[1]) - + if PhactoriDbg(100): myDebugPrint3("bordered aspectRatio: " + str(aspectRatio) + "\n"); @@ -4550,7 +4558,7 @@ def SetParaViewRepresentationCameraParams(inXParaViewRenderView, inCameraC, if PhactoriDbg(): myDebugPrint3(' lookDirection ' + str(lookDirection) + '\n') - myViewBounds = viewBoundsIo[0] + myViewBounds = viewBoundsIo[0] if PhactoriDbg(): myDebugPrint3(' focalPoint ' + str(focalPoint) + '\n') @@ -5128,11 +5136,22 @@ def MakeFiltersFromViewMapOperationsC(ioPipeAndViewsState, inOperationBlocksJson 'cylinderclip', PhactoriCylinderClipOperation, operationParams) - elif operationParams['type'] == 'element data to node data': + elif (operationParams['type'] == 'element data to node data') or \ + (operationParams['type'] == 'elementdatatonodedata') or \ + (operationParams['type'] == 'cell data to point data') or \ + (operationParams['type'] == 'celldatatopointdata'): ParseOneFilterTypeFromViewMapOperation(newOperationBlock, 'element data to node data', PhactoriCellDataToPointDataOperation, operationParams) + elif (operationParams['type'] == 'node data to element data') or \ + (operationParams['type'] == 'nodedatatoelementdata') or \ + (operationParams['type'] == 'point data to cell data') or \ + (operationParams['type'] == 'pointdatatocelldata'): + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'node data to element data', + PhactoriPointDataToCellDataOperation, + operationParams) elif operationParams['type'] == 'extractcomponent': ParseOneFilterTypeFromViewMapOperation(newOperationBlock, 'extractcomponent', @@ -5297,11 +5316,11 @@ def MakeFiltersFromViewMapOperationsC(ioPipeAndViewsState, inOperationBlocksJson keepConstructing = False #at the beginning of the loop, we haven't seen any unconstructed operations for operationName, operationBlock in ioPipeAndViewsState.mOperationBlocks.items(): if operationBlock.mHasBeenConstructed == False: - #this one still needs constructing, and we'll have to loop again to + #this one still needs constructing, and we'll have to loop again to #make sure all are constructed keepConstructing = True - #determine whether or not we can construct this operation yet, or if + #determine whether or not we can construct this operation yet, or if #we need to wait for something else to be constructed canBeConstructedNow = True inputOperationNames = operationBlock.GetListOfInputOperationNames() @@ -5310,7 +5329,7 @@ def MakeFiltersFromViewMapOperationsC(ioPipeAndViewsState, inOperationBlocksJson if inputBlock.mHasBeenConstructed == False: canBeConstructedNow = False break - + if PhactoriDbg(100): myDebugPrint3("trying: " + str(operationName) + "\n" + \ "depends on: " + str(inputOperationNames) + "\n" + \ @@ -5321,7 +5340,7 @@ def MakeFiltersFromViewMapOperationsC(ioPipeAndViewsState, inOperationBlocksJson operationBlock.mHasBeenConstructed = True if PhactoriDbg(100): myDebugPrint3("done constructing all operation blocks\n",100) - + #helper method: given a block A which potentially contains a key B with @@ -5384,7 +5403,7 @@ def CreateParaViewRepresentationAndViewFromInfoC(inImageset, inLookDirection, in raise Exception(errStr) meshRenderControl = theRepresentation.mMeshRenderControl - + showColorLegend = theRepresentation.mColorLegendFlag colorLegendPositionAndSize = theRepresentation.mColorLegendPositionAndSize showDataCubeAxes = theRepresentation.mDataCubeAxesFlag @@ -5414,7 +5433,7 @@ def CreateParaViewRepresentationAndViewFromInfoC(inImageset, inLookDirection, in numArrays = pvPvGeomFilterFromOp.PointData.GetNumberOfArrays() for ii in range (0, numArrays): myDebugPrint3(" " + str(ii) + ": " + pvPvGeomFilterFromOp.PointData.GetArray(ii).GetName() + "\n") - + if PhactoriDbg(): myDebugPrint3(" operation cell data arrays:\n") numArrays = pvPvGeomFilterFromOp.CellData.GetNumberOfArrays() @@ -5498,8 +5517,10 @@ def CreateParaViewRepresentationAndViewFromInfoC(inImageset, inLookDirection, in if gPipeAndViewsState.mTimeAnnotationPv == None: gPipeAndViewsState.mTimeAnnotationPv = \ PhactoriAnnotationPv(timeAnnStngs) + global gTemporaryGlobalImageTextColor gPipeAndViewsState.mTimeAnnotationPv.CreateParaViewStuff( - inImageset.mRepresentation.mColorSettings.mTimeAnnotationColor, + #inImageset.mRepresentation.mColorSettings.mTimeAnnotationColor, + gTemporaryGlobalImageTextColor, inImageset) #if newParaViewRenderInfoC.mTimeAnnotationPv == None: @@ -5606,7 +5627,7 @@ def ParseOneCameraBlockC(ioCameraBlock, ioCameraBlockJson, inPipeAndViewsState): ioCameraBlock.mLookDirectionSpecifiedFlag = True else: ioCameraBlock.mLookDirectionSpecifiedFlag = False - + #get text to add to each image created with this camera, if any if "image name addon" in ioCameraBlockJson: ioCameraBlock.mFilenameAddon = ioCameraBlockJson["image name addon"] @@ -5656,7 +5677,9 @@ def ParseOneCameraBlockC(ioCameraBlock, ioCameraBlockJson, inPipeAndViewsState): #parse locking setup ioCameraBlock.LockAfterNCalls = getParameterFromBlock(ioCameraBlockJson, 'lock camera call count', -1) - + if "lockingcamera" in ioCameraBlock.mName: + ioCameraBlock.LockAfterNCalls = 1 + def localGet1or0(inJsn, inKey, inDefault): value = getParameterFromBlock(inJsn, inKey, inDefault) @@ -5665,240 +5688,8 @@ def localGet1or0(inJsn, inKey, inDefault): else: return 0 - def ParseOneRepresentationBlockC(ioRepresentationBlock, inRepresentationBlockJson, inPipeAndViewsState): - "given a python dict (presumably from json) description of a representation block, parse all the\n representation parameters out of the block" - - if PhactoriDbg(100): - myDebugPrint3('ParseOneRepresentationBlockC entered\n', 100) - - inJsn = inRepresentationBlockJson - - #hack test for colors start - #inJsn['surface color'] = [1.0, 0.0, 0.0] - #inJsn['background color'] = [0.0, 0.0, 0.0] - #inJsn['edge color'] = [0.0, 1.0, 0.0] - ##inJsn['axes color'] = [0.0, 1.0, 1.0] - #inJsn['text color'] = [1.0, 1.0, 0.0] - #hack test for colors end - - #myDebugPrint3(' json: ' + str(inJsn) + '\n') - - if 'point size' in inJsn: - ioRepresentationBlock.mPointSize = inJsn['point size'] - - #color by variable scalar/vector magnitude/vector component/tensor component - ioRepresentationBlock.mColorVariableInfo.\ - ParseVariableNameAndVectorOrTensorComponent(inJsn, 'color by ') - - if ioRepresentationBlock.mColorVariableInfo.mVariableName != '': - ioRepresentationBlock.mColorByBlockFlag = False - ioRepresentationBlock.mColorBySolidColorFlag = False - elif 'color by blockid' in inJsn: - ioRepresentationBlock.mColorByBlockFlag = True - ioRepresentationBlock.mColorByBlockExplicitlySet = True - ioRepresentationBlock.mColorBySolidColorFlag = False - elif 'color by solid color' in inJsn: - ioRepresentationBlock.mColorBySolidColorFlag = True - ioRepresentationBlock.mColorByBlockFlag = False - ioRepresentationBlock.mSolidColor = inJsn['color by solid color'] - - #color map range control - if 'color legend range' in inJsn: - ioRepresentationBlock.mFixedColorRange = inJsn['color legend range'] - ioRepresentationBlock.mUseFixedColorRange = True - else: - ioRepresentationBlock.mUseFixedColorRange = False - - #highlight subranges with solid colors - if 'highlight subrange 1' in inJsn: - highlightSubrangeIndex = 1 - while True: - oneSubrangeKey = 'highlight subrange ' + str(highlightSubrangeIndex) - if oneSubrangeKey in inJsn: - subrangeArgs = inJsn[oneSubrangeKey] - highlightSubrangeIndex += 1 - if len(subrangeArgs) != 5: - if PhactoriDbg(): - myDebugPrint3("highlight subrange needs 5 values\n"); - PrintOnProcessZero("highlight subrange needs 5 values, skipping " + \ - oneSubrangeKey + "\n"); - continue - srmin = float(subrangeArgs[0]) - srmax = float(subrangeArgs[1]) - if srmin > srmax: - if PhactoriDbg(): - myDebugPrint3("subrange highlight min >= max: " + \ - str(srmin) + ", " + str(srmax) + "\nskipping " + \ - oneSubrangeKey + "\n", 100) - PrintOnProcessZero("subrange highlight min >= max: " + \ - str(srmin) + ", " + str(srmax) + "\nskipping " + \ - oneSubrangeKey + "\n") - continue - srColor = [float(subrangeArgs[2]), float(subrangeArgs[3]), - float(subrangeArgs[4])] - if (srColor[0] < 0.0) or (srColor[0] > 1.0) or \ - (srColor[1] < 0.0) or (srColor[1] > 1.0) or \ - (srColor[2] < 0.0) or (srColor[2] > 1.0): - srColor = [1.0, 1.0, 0.0] - if PhactoriDbg(): - myDebugPrint3(oneSubrangeKey + ": bad color " - "(component not 0.0-1.0), using rgb 1.0, 1.0, 0.0\n", 100) - PrintOnProcessZero(oneSubrangeKey + ": bad color " - "(component not 0.0-1.0), using rgb 1.0, 1.0, 0.0\n") - ioRepresentationBlock.mHighlightSubranges.append( - [srmin, srmax, srColor]) - ioRepresentationBlock.mUseHighlightSubranges = True - else: - break - if PhactoriDbg(): - myDebugPrint3("parsed highlight subranges:\n" + \ - str(ioRepresentationBlock.mHighlightSubranges) + "\n", 100) - - #if 'highlight subranges' in inJsn: - # ioRepresentationBlock.mUseHighlightSubranges = True - # sbrngsJsn = inJsn['highlight subranges'] - # for oneSubrange in sbrngsJsn: - # if 'range' in oneSubrange: - # srmin = oneSubrange['range'][0] - # srmax = oneSubrange['range'][1] - # if srmin < srmax: - # if 'color' in oneSubrange: - # srColor = oneSubrange['color'] - # else: - # srColor = [1.0, 1.0, 0.0] - # ioRepresentationBlock.mHighlightSubranges.append( - # [srmin, srmax, srColor]) - # else: - # if PhactoriDbg(): - # myDebugPrint3("highlight min >= max: " + \ - # str(srmin) + ", " + str(srmax) + "\nskipping subrange\n", 100) - # PrintOnProcessZero("highlight min >= max: " + \ - # str(srmin) + ", " + str(srmax) + "\nskipping subrange\n") - # else: - # if PhactoriDbg(): - # myDebugPrint3("subrange is missing 'range' key; skipping\n") - # PrintOnProcessZero("subrange is missing 'range' key; skipping\n") - # if PhactoriDbg(): - # myDebugPrint3("parsed highlight subranges:\n" + \ - # str(ioRepresentationBlock.mHighlightSubranges) + "\n", 100) - - #additional capability: use ratio-expressed subrange of - #range that would otherwise be used to increase concentration of - #dynamic range of color map in range of interest - if 'color legend subrange' in inJsn: - ioRepresentationBlock.mUseColorSubrange = True - ioRepresentationBlock.mColorSubrange = inJsn['color legend subrange'] - goodSubrange = True - if ioRepresentationBlock.mColorSubrange[0] < 0.0: - goodSubrange = False - if ioRepresentationBlock.mColorSubrange[1] > 1.0: - goodSubrange = False - if ioRepresentationBlock.mColorSubrange[0] > \ - ioRepresentationBlock.mColorSubrange[1]: - goodSubrange = False - if goodSubrange == False: - myDebugPrint3AndException( - "ParseOneRepresentationBlockC:\n" - "bad color legend subrange, must be 0.0 <= bottom <= top <= 1.0\n") - - #choose color map by name - ioRepresentationBlock.mColorMapSettings.ParseColorMapSettings(inJsn) - - showSurfacesFlag = getParameterFromBlock(inJsn, 'show surfaces', True) - showEdgesFlag = getParameterFromBlock(inJsn, 'show edges', False) - showPointsFlag = getParameterFromBlock(inJsn, 'show points', False) - - ioRepresentationBlock.mOpacitySetting = getParameterFromBlock(inJsn, 'opacity', - ioRepresentationBlock.mOpacitySetting) - - #doVolumeRenderingFlag = getParameterFromBlock(inJsn, 'volume rendering', True) - doVolumeRenderingFlag = getParameterFromBlock(inJsn, 'volume rendering', False) - ioRepresentationBlock.mScalarOpacityUnitDistance = getParameterFromBlock( - inJsn, 'scalar opacity unit distance', -1.0) - - #ioRepresentationBlock.mScalarOpacityUnitDistance = 0.01 - if PhactoriDbg(): - myDebugPrint3("doVolumeRenderingFlag: " + \ - str(doVolumeRenderingFlag) + "\n" + \ - "ioRepresentationBlock.mScalarOpacityUnitDistance: " + \ - str(ioRepresentationBlock.mScalarOpacityUnitDistance) + "\n") - - ioRepresentationBlock.mPresetsImportFileName = getParameterFromBlock(inJsn, - 'color and opacity presets import file', None) - if ioRepresentationBlock.mPresetsImportFileName != None: - retval = ImportPresets(ioRepresentationBlock.mPresetsImportFileName) - if retval != True: - myDebugPrint3AndException( - "paraview.simple.ImportPresets failed with the file:\n" + \ - str(ioRepresentationBlock.mPresetsImportFileName) + "\n") - ioRepresentationBlock.mNameOfPresetToUse = getParameterFromBlock(inJsn, - 'color and opacity preset', None) - - showBoundingBoxFlag = getParameterFromBlock(inJsn, 'show bounding box', False) - - ioRepresentationBlock.mMeshRenderControl = 'Surface' - if showBoundingBoxFlag: - ioRepresentationBlock.mMeshRenderControl = 'Outline' - if showSurfacesFlag | showEdgesFlag | showPointsFlag: - if PhactoriDbg(): - myDebugPrint3(" warning: when show bounding box is true, \n" + \ - " show surfaces, show edges, and show points should be false\n") - elif showPointsFlag: - ioRepresentationBlock.mMeshRenderControl = 'Points' - else: - if showSurfacesFlag: - if showEdgesFlag: - ioRepresentationBlock.mMeshRenderControl = 'Surface With Edges' - else: - ioRepresentationBlock.mMeshRenderControl = 'Surface' - else: - if showEdgesFlag: - ioRepresentationBlock.mMeshRenderControl = 'Wireframe' - #ioRepresentationBlock.mMeshRenderControl = 'Points' - else: - ioRepresentationBlock.mMeshRenderControl = 'Outline' - - if doVolumeRenderingFlag: - if PhactoriDbg(100): - myDebugPrint3('doing volume rendering\n', 100) - ioRepresentationBlock.mMeshRenderControl = 'Volume' - ioRepresentationBlock.mDoingVolumeRendering = True - else: - ioRepresentationBlock.mDoingVolumeRendering = False - - #color legend on/off - ioRepresentationBlock.mColorLegendFlag = getParameterFromBlock(inJsn, - 'show color legend', ioRepresentationBlock.mColorLegendFlag) - - ioRepresentationBlock.mColorLegendPositionAndSize = \ - getParameterFromBlock(inJsn, 'color legend position', - ioRepresentationBlock.mColorLegendPositionAndSize) - - if ioRepresentationBlock.mColorLegendFlag == True: - if ioRepresentationBlock.mColorVariableInfo.mVariableName == '': - ioRepresentationBlock.mColorLegendFlag = False - - ioRepresentationBlock.mColorRangeMinMaxTracker.PlotValMinMaxTrkCParseJson( - inJsn, "color legend ") - - ioRepresentationBlock.mTimeAnnotationSettings.ParseAvsFromJson(inJsn) - - ioRepresentationBlock.mDataCubeAxesFlag = getParameterFromBlock(inJsn, - 'show axes', ioRepresentationBlock.mDataCubeAxesFlag) - - ioRepresentationBlock.mDataCubeAxesInfo.DcaiParseParametersFromJson(inJsn) - - ioRepresentationBlock.mOrientationAxesFlag = getParameterFromBlock(inJsn, - 'show orientation axes', ioRepresentationBlock.mOrientationAxesFlag) - - if "image name addon" in inJsn: - ioRepresentationBlock.mFilenameAddon = inJsn["image name addon"] - - ioRepresentationBlock.mColorSettings.ParseColorSettingsFromJson(inJsn) - - if PhactoriDbg(100): - myDebugPrint3('ParseOneRepresentationBlockC returning\n', 100) + ioRepresentationBlock.ParseSettingsFromJson(inRepresentationBlockJson) global gDefaultImageBasename gDefaultImageBasename = "csierra.view." @@ -5943,7 +5734,12 @@ def breakSpecialVarNameIntoBaseAndComponent(inSpecialVarName, raise Exception(errStr) #baseVarName = inSpecialVarName[0:(varNameLen-2)] + GetSeparatorString() - if inAddSeparatorFlag: + localinAddSeparatorFlag = inAddSeparatorFlag + #for Sierra, as of 2022Aug09, we need inAddSeparatorFlag to default to + #False but right here we need to strip the separator from the variable + #base name + #localinAddSeparatorFlag = True + if localinAddSeparatorFlag: lenToGrab = varNameLen - 1 - len(GetSeparatorString()) else: lenToGrab = varNameLen - 1 @@ -6066,6 +5862,17 @@ def ParseOneImagesetBlockC(ioImagesetBlock, ioImagesetBlockJson, if ioImagesetBlock.mName == 'PhactoriGoInteractive': ioPipeAndViewsState.mInteractionEnabled = True + #we need to get text color for time annotation and text annotation + #handled properly: for now we allow a "text color" setting in any + #imageset block to set the global text color + if 'text color' in ioImagesetBlockJson: + global gTemporaryGlobalImageTextColor + gTemporaryGlobalImageTextColor = getParameterFromBlock(ioImagesetBlockJson, + 'text color', [1.0, 1.0, 1.0]) + + ioImagesetBlock.mBackground = getParameterFromBlock(ioImagesetBlockJson, + 'background color', ioImagesetBlock.mBackground) + #parse on/off criteria if 'onoff criteria' in ioImagesetBlockJson: inCriteriaList = ioImagesetBlockJson['onoff criteria'] @@ -6241,6 +6048,9 @@ def ParseOnePlotOverTimeBlockC(ioPlotOverTimeBlock, inPlotOverTimeBlockJson, inP ioPlotOverTimeBlock.mImageFileNameCountSettings.\ ParseImageFileNameCountSettings(inPlotOverTimeBlockJson) + ioPlotOverTimeBlock.mBackground = getParameterFromBlock(inPlotOverTimeBlockJson, + 'background color', ioPlotOverTimeBlock.mBackground) + if PhactoriDbg(): myDebugPrint3(str(inPlotOverTimeBlockJson) + '\n') @@ -6622,7 +6432,7 @@ def GetCurrentGeometricPoint(self, inParaViewSource, ioViewBounds, if PhactoriDbg(): myDebugPrint3(errStr) raise Exception(errStr) - + if PhactoriDbg(100): myDebugPrint3("GetCurrentGeometricPoint returning: " + \ str(returnXyz) + "\n", 100) @@ -6702,7 +6512,7 @@ def ParseParametersFromJson(self, inJsn): if 'auto size 1 view angle delta in degrees' in inJsn: angleInDegrees = inJsn['auto size 1 view angle delta in degrees'] self.mAutoSize1ViewAngleDeltaInRadians = math.radians(angleInDegrees) - + def SetUpIfEnabled(self, inRenderView, ioCameraPosition, ioLookAtPoint, inViewUpVector): @@ -6802,7 +6612,7 @@ def ChangeEyeAndFocusInModelSpaceForStereo(self, lookDirection = vecFromAToB(ioEyePosition, ioFocalPoint) axisBetweenEyes = vecCrossProduct(lookDirection, inViewUpVector) axisBetweenEyesNorm = vecNormalize(axisBetweenEyes) - + if self.mLeftEyeFlag: modelCsHalfIpd = -self.mIpdInModelUnits * \ self.mVirtualSelfSizeMultiplier * 0.5 @@ -6896,7 +6706,9 @@ def HandleLockingOption(self, eyePosition, absoluteLookAtPoint): self.LockAfterNCalls = -1 - +#phactori_combine_to_single_python_file_parent_1 +#from Operation.PhactoriVariableInfo import * +#phactori_combine_to_single_python_file_subpiece_begin_1 class PhactoriVariableMinMaxAvgSumCntSave: def __init__(self): self.mStatsTestCounter = -1 @@ -6925,79 +6737,109 @@ def __init__(self): self.mVariableIsVectorComponent = False self.mVectorBaseName = None self.mStats = PhactoriVariableMinMaxAvgSumCntSave() - self.mAddSeparatorToVectorVariableName = True + #as of 2022Aug09 we want this to default to False + self.mAddSeparatorToVectorVariableName = False def SelfToStr(self): retStr = "PhactoriVariableInfo:\n" +\ "\n mVariableName: " + str(self.mVariableName) +\ "\n mVariableComponent: " + str(self.mVariableComponent) +\ "\n mVariableType: " + str(self.mVariableType) +\ + "\n mVariableTypeNeedsDetection: " + str(self.mVariableTypeNeedsDetection) +\ + "\n mVariableTypeWasDetected: " + str(self.mVariableTypeWasDetected) +\ + "\n mVariableTypeWasCopied: " + str(self.mVariableTypeWasCopied) +\ "\n mVariableIsVectorMagnitude: " + \ str(self.mVariableIsVectorMagnitude) +\ "\n mVariableIsVectorComponent: " + \ str(self.mVariableIsVectorComponent) +\ "\n mVectorBaseName: " + str(self.mVectorBaseName) +\ + "\n mVariableIntendedForUseFlag: " + str(self.mVariableIntendedForUseFlag) +\ "\n" return retStr - def ParseVariableNameAndVectorOrTensorComponent(self, inJson, inBaseString): - "take a base string such as 'y axis variable ' or 'variable ', use it\n to construct keys to define a scalar variable, vector component, vector\n magnitude, or tensor component, and see if the json has those keys.\n If the json has a key, use it to grab the variable name and setup.\n Also look to see if the type of the variable is specifically defined\n (node or element) or needs to be detected\n " - variableFoundFlag = False - self.mVariableIsVectorComponent = False - self.mVariableIsVectorMagnitude = False - - if 'add separator to vector variable name' in inJson: - self.mAddSeparatorToVectorVariableName = \ - inJson['add separator to vector variable name'] - + def CheckAndParseScalarVariable1(self, inJson, inBaseString): testKey = inBaseString + 'scalar' if testKey in inJson: - variableFoundFlag = True - if PhactoriDbg(): - myDebugPrint3(' scalar found\n') self.mVariableName = inJson[testKey] self.mVariableComponent = None + return True else: - testKey = inBaseString + 'vector component' - if testKey in inJson: - variableFoundFlag = True - self.mVariableIsVectorComponent = True - if PhactoriDbg(): - myDebugPrint3(' vector component found\n') - varName = inJson[testKey] - resultPair = breakSpecialVarNameIntoBaseAndComponent(varName, - self.mAddSeparatorToVectorVariableName) - self.mVariableName = resultPair[0] - self.mVariableComponent = resultPair[1] - self.mVectorBaseName = resultPair[2] - if PhactoriDbg(): - myDebugPrint3(' non comp name: ' + str(self.mVariableName) + '\n') + return False + + def CheckAndParseVectorComponentNumber1(self, inJson, inBaseString): + testKey = inBaseString + 'vector component number' + if testKey in inJson: + self.mVariableIsVectorComponent = True + varCompNumPair = inJson[testKey] + self.mVariableName = varCompNumPair[0] + self.mVariableComponent = int(varCompNumPair[1]) + return True + else: + return False + + def CheckAndParseVectorComponentSuffix(self, inJson, inBaseString): + testKey = inBaseString + 'vector component' + if testKey in inJson: + self.mVariableIsVectorComponent = True + varName = inJson[testKey] + resultPair = breakSpecialVarNameIntoBaseAndComponent(varName, + self.mAddSeparatorToVectorVariableName) + self.mVariableName = resultPair[0] + self.mVariableComponent = resultPair[1] + self.mVectorBaseName = resultPair[2] + return True + else: + return False + + def CheckAndParseVectorMagnitude(self, inJson, inBaseString): + testKey = inBaseString + 'vector magnitude' + if testKey in inJson: + self.mVariableIsVectorMagnitude = True + if self.mAddSeparatorToVectorVariableName: + self.mVariableName = inJson[testKey] + GetSeparatorString() else: - testKey = inBaseString + 'vector magnitude' - if testKey in inJson: - variableFoundFlag = True - self.mVariableIsVectorMagnitude = True - if PhactoriDbg(): - myDebugPrint3(' vector magnitude found\n') - if self.mAddSeparatorToVectorVariableName: - self.mVariableName = inJson[testKey] + GetSeparatorString() - else: - self.mVariableName = inJson[testKey] - self.mVectorBaseName = inJson[testKey] - else: - testKey = inBaseString + 'tensor component' - if testKey in inJson: - variableFoundFlag = True - if PhactoriDbg(): - myDebugPrint3(' tensor component found\n') - self.mVariableName = inJson[testKey] - else: + self.mVariableName = inJson[testKey] + self.mVectorBaseName = inJson[testKey] + return True + else: + return False + + def CheckAndParseTensorComponent(self, inJson, inBaseString): + testKey = inBaseString + 'tensor component' + if testKey in inJson: + self.mVariableName = inJson[testKey] + return True + else: + return False + + def CheckAndParseVectorVariable1(self, inJson, inBaseString): + variableFoundFlag = False + variableFoundFlag = self.CheckAndParseVectorComponentNumber1(inJson, inBaseString) + if not variableFoundFlag: + variableFoundFlag = self.CheckAndParseVectorComponentSuffix(inJson, inBaseString) + if not variableFoundFlag: + variableFoundFlag = self.CheckAndParseVectorMagnitude(inJson, inBaseString) + if not variableFoundFlag: + variableFoundFlag = self.CheckAndParseTensorComponent(inJson, inBaseString) + if not variableFoundFlag: variableFoundFlag = False - if PhactoriDbg(): - myDebugPrint3(' no variable found\n') self.mVariableName = '' self.mComponent = None + return variableFoundFlag + + def ParseVariableNameAndVectorOrTensorComponent(self, inJson, inBaseString): + "take a base string such as 'y axis variable ' or 'variable ', use it\n to construct keys to define a scalar variable, vector component, vector\n magnitude, or tensor component, and see if the json has those keys.\n If the json has a key, use it to grab the variable name and setup.\n Also look to see if the type of the variable is specifically defined\n (node or element) or needs to be detected\n " + variableFoundFlag = False + self.mVariableIsVectorComponent = False + self.mVariableIsVectorMagnitude = False + if 'add separator to vector variable name' in inJson: + self.mAddSeparatorToVectorVariableName = \ + inJson['add separator to vector variable name'] + + variableFoundFlag = self.CheckAndParseScalarVariable1(inJson, inBaseString) + if not variableFoundFlag: + variableFoundFlag = self.CheckAndParseVectorVariable1(inJson, inBaseString) if variableFoundFlag: #it is now apparent variable is intended to be used, not ignored self.mVariableIntendedForUseFlag = True @@ -7036,6 +6878,12 @@ def ParseVariableNameAndVectorOrTensorComponent(self, inJson, inBaseString): else: self.mVariableType = None + if PhactoriDbg(): + str1 = "ParseVariableNameAndVectorOrTensorComponent:\n" + str2 = "inBaseString:\n" + str(inBaseString) + "\n" + str3 = "inJson:\n" + str(inJson) + "\n" + str4 = "instance state after parsing:\n" + self.SelfToStr() + myDebugPrint3(str1 + str2 + str3 + str4) return variableFoundFlag def CopyVariableTypeFrom(self, inSourceVariableInfo): @@ -7135,7 +6983,7 @@ def GetXYPlotAxisTitle(self): return axisTitle - +#phactori_combine_to_single_python_file_subpiece_end_1 class PhactoriDataCubeOneAxisInfo: def __init__(self): @@ -7162,7 +7010,7 @@ def DcoaiParseParametersFromJson(self, parentAxesInfo, inJsn, inXyzKey): if theKey in inJsn: self.mUseLabelFlag = True self.mAxisLabel = getParameterFromBlock(inJsn, theKey, "") - + if PhactoriDbg(): myDebugPrint3('DcoaiParseParametersFromJson ' + inXyzKey + ' ' \ + str(parentAxesInfo.mShowTicks) + ' ' \ @@ -7196,74 +7044,6 @@ def ParseColorMapSettings(self, inJsn): self.mInvertColorMap = getParameterFromBlock(inJsn, 'invert color scale', self.mInvertColorMap) -class PhactoriRepresentationBlock: - def __init__(self): - self.mName = "" - self.mColorVariableInfo = PhactoriVariableInfo() - self.mColorLegendFlag = True - #self.mColorLegendPositionAndSize = ['bottom', 1.0] - #self.mColorLegendPositionAndSize = ['right', 1.0] - self.mColorLegendPositionAndSize = ['bottom right', 1.0] - self.mTimeAnnotationSettings = PhactoriAnnotationViewSettings( - 'time', 'time') - self.mDataCubeAxesFlag = False - self.mDataCubeAxesInfo = PhactoriDataCubeAxesInfo() - #self.mColorByBlockFlag = True - self.mColorByBlockFlag = True - self.mColorByBlockExplicitlySet = False - self.mColorBySolidColorFlag = False - self.mSolidColor = None - self.mOpacitySetting = 1.0 - self.mOrientationAxesFlag = True - self.mFixedColorRange = None - self.mUseFixedColorRange = False - self.mColorRangeMinMaxTracker = PlotValMinMaxTrkC() - self.mUseHighlightSubranges = False - self.mHighlightSubranges = [] - self.mUseColorSubrange = False - self.mColorSubrange = [0.0, 1.0] - self.mFilenameAddon = "" - self.mColorSettings = PhactoriColorSettings() - self.mColorMapSettings = PhactoriColorMapSettings() - self.mPointSize = 2.0 - - def SetFromRestartInfo(self, inJson): - "given a map (json format), use the info in the map to set the\n representation state--this reads the info created in \n GetRestartInfo" - - if 'mColorRangeMinMaxTracker' not in inJson: - if PhactoriDbg(): - myDebugPrint3("PhactoriRepresentationBlock::" + \ - "SetFromRestartInfo: no mColorRangeMinMaxTracker, return\n") - return - - if PhactoriDbg(): - myDebugPrint3("Representation::SetFromRestartInfo\n" + - "currently set to do something\n" + - "before tracker:\n" + self.mColorRangeMinMaxTracker.SelfToStr()) - - jsonItem = inJson['mColorRangeMinMaxTracker'] - self.mColorRangeMinMaxTracker.SetFromRestartInfo(jsonItem) - - if PhactoriDbg(): - myDebugPrint3("after tracker:\n" + - self.mColorRangeMinMaxTracker.SelfToStr()) - - def GetRestartInfo(self): - "construct, in python map/json format, the information from this\n representation instance which contains the information\n which would be needed to restore the representation to the proper\n state after a simulation restart, particularly color range tracking\n information. Return the restart info map/json" - newRestartInfoJson = {} - newRestartInfoJson['mColorRangeMinMaxTracker'] = \ - self.mColorRangeMinMaxTracker.GetRestartInfo() - return newRestartInfoJson - - def CalculateDefaultScalarOpacityUnitDistance(self, inPhactoriOperation): - "given a phactori operation assumed to have an updated pipeline,\n calculate a default scalar opacity unit distance the same as paraview,\n with 0.05 * diagonal length of data bounding box" - bnds = GetGlobalDataBoundsParallel(inPhactoriOperation.mParaViewFilter) - xxlen = bnds[1] - bnds[0] - yylen = bnds[3] - bnds[2] - zzlen = bnds[5] - bnds[4] - self.mScalarOpacityUnitDistance = \ - 0.05 * math.sqrt(xxlen*xxlen + yylen*yylen + zzlen*zzlen) - def GetThresholdContourHackVariableNameString(inVariableInfo): "gives altered variable name for magnitude or component\n in paraview, coloring by a vector component or magnitude is handled\n differently than thresholding or contouring by a vector component or\n magnitude. For the Contour and Threshold case, we add _X, _Y, or _Z to\n the variable name for component and _Magnitude for magnitude. In\n the coloring case, we specify component arguments and another argument\n as to whether to use magnitude or component. This routine takes the\n given variable info (name, whether or not vector component or magnitude)\n and creates a properly munged name to do the right thing" @@ -7356,7 +7136,7 @@ def DoUpdateDueToChangeInData(self, inIncomingPvFilter, if self.mVariableInfo.mVariableTypeNeedsDetection == False: UpdatePipelineWithCurrentTimeArgument(outOutgoingPvFilter) - + def ParseParametersFromJson(self, inJson): self.mBypassFlag = getParameterFromBlock(inJson, 'bypass flag', @@ -7812,7 +7592,7 @@ def CreateParaViewFilter(self, inInputFilter): numArrays = inInputFilter.PointData.GetNumberOfArrays() for ii in range (0, numArrays): myDebugPrint3(" " + str(ii) + ": " + inInputFilter.PointData.GetArray(ii).GetName() + "\n") - + if PhactoriDbg(): myDebugPrint3(" calculator inInputFilter cell data arrays:\n") numArrays = inInputFilter.CellData.GetNumberOfArrays() @@ -8152,13 +7932,13 @@ def IntersectWithOneRayViaBSPTree(self, inIndex, inRayStart, inRayDirection, if inPointOrCellData <= 0: oldvv = ioRaycastOperation.mPointNormalRayIntersectDistanceArray.\ GetValue(inIndex) - if (oldvv < 0.0) or (hitdist < oldvv): + if (oldvv < 0.0) or (hitdist < oldvv): ioRaycastOperation.mPointNormalRayIntersectDistanceArray.\ SetValue(inIndex, hitdist) else: oldvv = ioRaycastOperation.mCellNormalRayIntersectDistanceArray.\ GetValue(inIndex) - if (oldvv < 0.0) or (hitdist < oldvv): + if (oldvv < 0.0) or (hitdist < oldvv): ioRaycastOperation.mCellNormalRayIntersectDistanceArray.\ SetValue(inIndex, hitdist) @@ -8226,14 +8006,14 @@ def IntersectWithOneRay(self, inIndex, inRayStart, inRayDirection, oldvv = ioRaycastOperation.mPointNormalRayIntersectDistanceArray.\ GetValue(inIndex) newvv = hitPoint[3] - if (oldvv < 0.0) or (newvv < oldvv): + if (oldvv < 0.0) or (newvv < oldvv): ioRaycastOperation.mPointNormalRayIntersectDistanceArray.\ SetValue(inIndex, hitPoint[3]) else: oldvv = ioRaycastOperation.mCellNormalRayIntersectDistanceArray.\ GetValue(inIndex) newvv = hitPoint[3] - if (oldvv < 0.0) or (newvv < oldvv): + if (oldvv < 0.0) or (newvv < oldvv): ioRaycastOperation.mCellNormalRayIntersectDistanceArray.\ SetValue(inIndex, hitPoint[3]) @@ -8524,7 +8304,7 @@ def TestAndSet(self, inLengthSquared, inPt1, inPt2): self.LengthSquared = inLengthSquared vecCopy(self.Point1, inPt1) vecCopy(self.Point2, inPt2) - + class PhactoriSegmentGroup1: "manage a set of segments for purposes of showing raycast results" def __init__(self): @@ -9060,7 +8840,7 @@ def ParseOutputFilenameParametersFromJson(self, inJson): if (self.Precision < 1) or (self.Precision > 100): myDebugPrint3AndException("PhactoriCSVExportOperation:\n" "precision must be 1-100, not " + str(self.Precision) + "\n") - + def ParseParametersFromJson(self, inJson): self.ParseOutputFilenameParametersFromJson(inJson) @@ -9143,7 +8923,7 @@ def __init__(self): self.mCellNormalRayIntersectDistanceArray = None self.SegmentsFromPointRays = PhactoriSegmentGroup1() - self.SegmentsFromTriangleRays = PhactoriSegmentGroup1() + self.SegmentsFromTriangleRays = PhactoriSegmentGroup1() def ParseParametersFromJson(self, inJson): if "target operation" in inJson: @@ -9191,7 +8971,7 @@ def CreateParaViewFilter(self, inInputFilter): self.mTriangleRayLineSource = PVTrivialProducer() self.mTriangleRayLineSource.GetClientSideObject().SetOutput( self.SegmentsFromTriangleRays.mVtkPolyData) - + #newParaViewFilter = GroupDatasets(Input = []) #self.mGroupLineSource = newParaViewFilter @@ -9206,7 +8986,7 @@ def CreateParaViewFilter(self, inInputFilter): else: newParaViewFilter = PVTrivialProducer() passthru = inInputFilter.GetClientSideObject().GetOutputDataObject(0) - + numpts = passthru.GetNumberOfPoints() newvar = vtk.vtkDoubleArray() @@ -9305,7 +9085,7 @@ def RunCalculationToCastRays(self, ioPipeAndViewsState): #now loop through all processes; one process at a time share the triangles #from each process to the others and intersect with the local surface - #portion + #portion mypid = SmartGetLocalProcessId() @@ -9359,7 +9139,7 @@ def RunCalculationToCastRays(self, ioPipeAndViewsState): def ExportOperationData(self, datadescription): "this will be called once per callback (before WriteImages) to allow the\n operation to export any desired data which is not an image. The child\n class should override this method if it wants so do something.\n For PhactoriIntersectNodeNormalsWithSurface we will output information\n about the nearest and furthest intersections" - + if PhactoriDbg(100): myDebugPrint3( "PhactoriIntersectNodeNormalsWithSurface::ExportOperationData " @@ -9535,7 +9315,7 @@ def CreateParaViewFilter(self, inInputFilter): newParaViewFilter = Line() newParaViewFilter.Point1 = [0.0, 0.0, 0.0] newParaViewFilter.Point2 = [0.01, 0.01, 0.01] - + SetActiveSource(newParaViewFilter) SetActiveSource(savedActiveSource) @@ -9638,7 +9418,7 @@ def RunCalculationToFindNearestPoints(self, ioPipeAndViewsState): tgty = self.mClosestNPointsFromEachProcess.mTargetMatchXyzs.GetValue(pndx+1) tgtz = self.mClosestNPointsFromEachProcess.mTargetMatchXyzs.GetValue(pndx+2) - self.mLineSource.Point1 = [srcx, srcy, srcz] + self.mLineSource.Point1 = [srcx, srcy, srcz] self.mLineSource.Point2 = [tgtx, tgty, tgtz] self.mLineSource.UpdatePipeline() @@ -9681,7 +9461,7 @@ def OutputToTextAnnotation(self, ioPipeAndViewsState): tgty = clstpts.mTargetMatchXyzs.GetValue(pndx+1) tgtz = clstpts.mTargetMatchXyzs.GetValue(pndx+2) - if self.mTxtAntnFormatString == None: + if self.mTxtAntnFormatString == None: self.mTextAnnotationOutputTarget.mTextString = \ "nearest: " + str(dist) + "\n" \ "node id 1: " + str(srcndid) + "\n" \ @@ -9866,7 +9646,7 @@ def CreateParaViewFilter2(self, ioPipeAndViewsState): "Error: operation '" + str(ii) + "' paraview filter not " "constructed\n") self.mOperationList.append(inputOperationBlock.GetPvFilter()) - + newParaViewFilter = GroupDatasets(Input = self.mOperationList) SetActiveSource(newParaViewFilter) @@ -10008,8 +9788,16 @@ class PhactoriMergeBlocksOperation(PhactoriOperationSpecifics): def __init__(self): PhactoriOperationSpecifics.__init__(self) + self.mergePoints = True + self.mergePartitionsOnly = False def ParseParametersFromJson(self, inJson): + key1 = "merge points" + if key1 in inJson: + self.mergePoints = inJson[key1] + key1 = "merge partitions only" + if key1 in inJson: + self.mergePartitionsOnly = inJson[key1] dummy = 0 def CreateParaViewFilter(self, inInputFilter): @@ -10022,6 +9810,14 @@ def CreateParaViewFilter(self, inInputFilter): UpdatePipelineWithCurrentTimeArgument(inInputFilter) newParaViewFilter = MergeBlocks(inInputFilter) + if self.mergePoints: + newParaViewFilter.MergePoints = 1 + else: + newParaViewFilter.MergePoints = 0 + if self.mergePartitionsOnly: + newParaViewFilter.MergePartitionsOnly = 1 + else: + newParaViewFilter.MergePartitionsOnly = 0 SetActiveSource(newParaViewFilter) UpdatePipelineWithCurrentTimeArgument(newParaViewFilter) @@ -10544,7 +10340,7 @@ def ParseParametersFromJson(self, inJson): if PhactoriDbg(100): myDebugPrint3("PhactoriGlyphOperation.ParseParametersFromJson " "entered\n", 100) - + key1 = "scale factor" if key1 in inJson: self.scaleFactor = inJson[key1] @@ -10733,283 +10529,49 @@ class PhactoriExtractBlockOperation(PhactoriOperationSpecifics): def __init__(self): PhactoriOperationSpecifics.__init__(self) - #mIncludeblockList OR mExcludeBlockList will be filled in from parsing - self.mIncludeBlockList = None - self.mExcludeBlockList = None - self.mFlatBlockIndicesSpecifiedDirectly = False - - #this will be list of included block indicies, and is calculated from - #mIncludeBlockList / mExcludeBlockList and passed directly to - #ExcludeBlockFilter.BlockIndices - self.mBlockIndices = [] - - def ParseParametersFromJson(self, inJson): - - if 'include blocks' in inJson: - self.mIncludeBlockList = inJson['include blocks'] - - if 'exclude blocks' in inJson: - self.mExcludeBlockList = inJson['exclude blocks'] - - if 'include blocks by flat index list' in inJson: - self.mFlatBlockIndicesSpecifiedDirectly = True - self.mBlockIndices = inJson['include blocks by flat index list'] - - if self.mIncludeBlockList == None and self.mExcludeBlockList == None and self.mFlatBlockIndicesSpecifiedDirectly == False: - myDebugPrint3AndException( - "PhactoriExtractBlockOperation::ParseParametersFromJson\n" - "Error: must have 'include block list' or 'exclude block list' or 'include blocks by flat index list'\n") - - def FigureBlockIndicesFromBlockListOneBlock(self, inMetaData, - ioFlatIndexCounter): - "determine if this one block should have it's flat index tripped on for\n the extract block filter (leaf item of recursion)" - - if inMetaData == None: - thisBlockName = None - else: - thisBlockName = inMetaData.Get(vtk.vtkCompositeDataSet.NAME()) - - if self.mIncludeBlockList != None: - if thisBlockName == None: - if PhactoriDbg(100): - myDebugPrint3("block with no name " + \ - " not in include list, not + to mBlockIndices (flat index " + \ - str(ioFlatIndexCounter[0] - 1) + ")\n") - elif thisBlockName in self.mIncludeBlockList: - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - global gDuplicateNameCounter - if thisBlockName in gDuplicateNameCounter: - oldCount = gDuplicateNameCounter[thisBlockName] - gDuplicateNameCounter[thisBlockName] = oldCount+1 - else: - gDuplicateNameCounter[thisBlockName] = 1 - if PhactoriDbg(100): - myDebugPrint3("block " + str(thisBlockName) + \ - " in include list, + to mBlockIndices (flat index " + \ - str(ioFlatIndexCounter[0] - 1) + ")\n") - else: - if PhactoriDbg(100): - myDebugPrint3("block " + str(thisBlockName) + \ - " not in include list, not + to mBlockIndices (flat index " + \ - str(ioFlatIndexCounter[0] - 1) + ")\n") - elif self.mExcludeBlockList != None: - if thisBlockName == None: - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - if PhactoriDbg(100): - myDebugPrint3("block with no name " + \ - " not in exclude list, + to mBlockIndices (flat index " + \ - str(ioFlatIndexCounter[0] - 1) + ")\n") - elif thisBlockName not in self.mExcludeBlockList: - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - if PhactoriDbg(100): - myDebugPrint3("block " + str(thisBlockName) + \ - " not in exclude list, + to mBlockIndices (flat index " + \ - str(ioFlatIndexCounter[0] - 1) + ")\n") - else: - if PhactoriDbg(100): - myDebugPrint3("block " + str(thisBlockName) + \ - " in exclude list, not + to mBlockIndices (flat index " + \ - str(ioFlatIndexCounter[0] - 1) + ")\n") - else: - myDebugPrint3AndException( - "PhactoriExtractBlockOperation::" - "FigureBlockIndicesFromBlockListOneBlock\n" - "Error: must have include block list or exclude block list\n") - - def FigureBlockIndicesFromBlockListRecurse1(self, inCsdata, inMetaData, - ioFlatIndexCounter, inForceSetting): - "recursively go through multiblock dataset to determine flat indices\n of blocks to be included; we are assuming only leaf blocks are\n actually named" - - icsdClassname = inCsdata.GetClassName() - - if PhactoriDbg(100): - if inMetaData == None: - thisBlockName = None - else: - thisBlockName = inMetaData.Get(vtk.vtkCompositeDataSet.NAME()) - myDebugPrint3("FigureBlockIndicesFromBlockListRecurse1 " + \ - str(thisBlockName) + " index: " + str(int(ioFlatIndexCounter[0])) + \ - " inForceSetting: " + str(inForceSetting) + " classname: " + \ - str(icsdClassname) + "\n") - - ioFlatIndexCounter[0] += 1 - - if icsdClassname == "vtkMultiBlockDataSet": - thisIsLeaf = False - nonLeafType = 0 - elif icsdClassname == "vtkExodusIIMultiBlockDataSet": - thisIsLeaf = False - nonLeafType = 1 - elif icsdClassname == "vtkMultiPieceDataSet": - thisIsLeaf = False - nonLeafType = 2 - elif icsdClassname == "vtkPartitionedDataSet": - thisIsLeaf = False - nonLeafType = 3 - else: - thisIsLeaf = True - nonLeafType = -1 - - if not thisIsLeaf: - if inForceSetting == 1: - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - includeOrExcludeAllSubBlocks = 1 - if PhactoriDbg(100): - myDebugPrint3("this non-leaf block added inForceSetting == 1\n") - elif inForceSetting == -1: - includeOrExcludeAllSubBlocks = -1 - if PhactoriDbg(100): - myDebugPrint3("this non-leaf block not added inForceSetting == -1\n") - else: - includeOrExcludeAllSubBlocks = 0 - #this is a non-leaf node, but we want to add it (or not) depending on - #the filter settings - if inMetaData == None: - thisBlockName = None - else: - thisBlockName = inMetaData.Get(vtk.vtkCompositeDataSet.NAME()) - if self.mIncludeBlockList != None: - if (thisBlockName != None) and (thisBlockName in self.mIncludeBlockList): - if PhactoriDbg(100): - myDebugPrint3("include list, append nonleaf " + str(thisBlockName) + \ - " ndx " + str(int(ioFlatIndexCounter[0]) - 1) + "\n") - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - includeOrExcludeAllSubBlocks = 1 - if PhactoriDbg(100): - myDebugPrint3("includeOrExcludeAllSubBlocks set to 1\n") - else: - if PhactoriDbg(100): - myDebugPrint3("include list, exclude nonleaf " + str(thisBlockName) + \ - " ndx " + str(int(ioFlatIndexCounter[0]) - 1) + "\n") - elif self.mExcludeBlockList != None: - if (thisBlockName == None) or (thisBlockName not in self.mExcludeBlockList): - if PhactoriDbg(100): - myDebugPrint3("exclude list, append nonleaf " + str(thisBlockName) + \ - " ndx " +str(int(ioFlatIndexCounter[0]) - 1) + "\n") - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - else: - if PhactoriDbg(100): - myDebugPrint3("exclude list, exclude nonleaf " + str(thisBlockName) + \ - " ndx " + str(int(ioFlatIndexCounter[0]) - 1) + "\n") - if (thisBlockName != None) and (thisBlockName in self.mExcludeBlockList): - includeOrExcludeAllSubBlocks = -1 - if PhactoriDbg(100): - myDebugPrint3("includeOrExcludeAllSubBlocks set to -1\n") - else: - myDebugPrint3AndException( - "PhactoriExtractBlockOperation::" - "FigureBlockIndicesFromBlockListRecurse1\n" - "Error: must have include block list or exclude block list\n") - - if nonLeafType == 2: - numBlocks = inCsdata.GetNumberOfPieces() - elif nonLeafType == 3: - numBlocks = inCsdata.GetNumberOfPartitions() - else: - numBlocks = inCsdata.GetNumberOfBlocks() - - if PhactoriDbg(100): - myDebugPrint3("recursing, flat index: " + \ - str(ioFlatIndexCounter[0]) + \ - " num blocks: " + \ - str(numBlocks) + "\n") - for ii in range(0, numBlocks): - if nonLeafType == 2: - oneBlock = inCsdata.GetPiece(ii) - elif nonLeafType == 3: - oneBlock = inCsdata.GetPartition(ii) - else: - oneBlock = inCsdata.GetBlock(ii) - oneBlockMetaData = inCsdata.GetMetaData(ii) - if PhactoriDbg(100): - myDebugPrint3("oneBlockMetaData: " + str(oneBlockMetaData) + "\n") - #myDebugPrint3("name: " + \ - # oneBlockMetaData.Get(vtk.vtkCompositeDataSet.NAME()) + "\n") - if oneBlock != None: - if oneBlockMetaData != None: - theBlockName = oneBlockMetaData.Get(vtk.vtkCompositeDataSet.NAME()) - if PhactoriDbg(100): - myDebugPrint3("name for block " + str(ii) + ": " + \ - str(theBlockName) + "\n") - else: - if PhactoriDbg(100): - myDebugPrint3("block " + str(ii) + " meta data was None\n") - self.FigureBlockIndicesFromBlockListRecurse1(oneBlock, - oneBlockMetaData, ioFlatIndexCounter, includeOrExcludeAllSubBlocks) - else: - if PhactoriDbg(100): - myDebugPrint3("this sub block is None, now handle it\n") - #I think we need to count here to be okay with pruned stuff; maybe - #we need to set extract block to no pruning (?) - ioFlatIndexCounter[0] += 1 - if includeOrExcludeAllSubBlocks == 1: - if PhactoriDbg(100): - myDebugPrint3("leaf block None index " + \ - str(int(ioFlatIndexCounter[0]) - 1) + \ - " appended due to includeOrExcludeAllSubBlocks == 1\n") - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - else: - if PhactoriDbg(100): - myDebugPrint3("force include is not on, so check include list\n") - includeThisBlock = False - if (self.mIncludeBlockList != None) and (oneBlockMetaData != None): - thisBlockName = oneBlockMetaData.Get(vtk.vtkCompositeDataSet.NAME()) - if PhactoriDbg(100): - myDebugPrint3("include list not None, thisBlockName " + str(thisBlockName) + "\n" - "self.mIncludeBlockList " + str(self.mIncludeBlockList) + "\n") - myDebugPrint3("thisBlockName != None: " + str(thisBlockName != None) + "\n") - myDebugPrint3("in list: " + str(thisBlockName in self.mIncludeBlockList) + "\n") - if (thisBlockName != None) and (thisBlockName in self.mIncludeBlockList): - includeThisBlock = True - if PhactoriDbg(100): - myDebugPrint3("leaf block None index " + \ - str(int(ioFlatIndexCounter[0]) - 1) + \ - " included due to name being in self.mIncludeBlockList\n") - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - if includeThisBlock == False: - if PhactoriDbg(100): - myDebugPrint3("leaf block None index " + \ - str(int(ioFlatIndexCounter[0]) - 1) + \ - " excluded due to includeOrExcludeAllSubBlocks != 1\n") - else: - if inForceSetting == 1: - self.mBlockIndices.append(int(ioFlatIndexCounter[0]) - 1) - if PhactoriDbg(100): - myDebugPrint3("this leaf block added inForceSetting == 1\n") - elif inForceSetting != -1: - self.FigureBlockIndicesFromBlockListOneBlock(inMetaData, - ioFlatIndexCounter) - else: - if PhactoriDbg(100): - myDebugPrint3("this leaf block not added inForceSetting == -1\n") - #if icsdClassname == "vtkMultiPieceDataSet": - # numpieces = inCsdata.GetNumberOfPieces() - # # ioFlatIndexCounter[0] += numpieces - 1 - # ioFlatIndexCounter[0] += numpieces + #mIncludeblockList OR mExcludeBlockList will be filled in from parsing + self.mIncludeBlockList = None + self.mExpandedIncludeBlockList = None + self.mExcludeBlockList = None + self.mRemoveBlanksAndDashes = True + + def ParseParametersFromJson(self, inJson): + if 'include blocks' in inJson: + self.mIncludeBlockList = inJson['include blocks'] - def FigureBlockIndicesFromBlockList(self, inInputFilter): - "from the list of include/exclude blocks create a indices list\n of blocks to put in filter" - if PhactoriDbg(100): - myDebugPrint3("FigureBlockIndicesFromBlockList entered" - "\nself.mIncludeBlockList: " + str(self.mIncludeBlockList) + \ - "\nself.mExcludeBlockList: " + str(self.mExcludeBlockList) + "\n") + if 'exclude blocks' in inJson: + self.mExcludeBlockList = inJson['exclude blocks'] - global gDuplicateNameCounter - gDuplicateNameCounter = {} - csdata = inInputFilter.GetClientSideObject().GetOutputDataObject(0) - flatIndexCounter = [0] - self.FigureBlockIndicesFromBlockListRecurse1(csdata, None, - flatIndexCounter, 0) + if self.mIncludeBlockList == None and self.mExcludeBlockList == None: + myDebugPrint3AndException( + "PhactoriExtractBlockOperation::ParseParametersFromJson\n" + "Error: must have 'include block list' or 'exclude block list'\n") + #2022Aug09 only include blocks is working + if self.mIncludeBlockList == None: + myDebugPrint3AndException( + "PhactoriExtractBlockOperation::ParseParametersFromJson\n" + "Error: must have 'include block list'\n" + "currently (2022Aug09) exclude blocks is not working\n") + + def MakeExpandedIncludeBlockList(self): + if self.mExpandedIncludeBlockList == None: + self.mExpandedIncludeBlockList = list(self.mIncludeBlockList) + for oneItem in self.mIncludeBlockList: + #add leader, remove spaces and dashes, this might change + if self.mRemoveBlanksAndDashes: + baseItem = oneItem.replace(" ","") + baseItem = baseItem.replace("-","") + else: + baseItem = oneItem + extraItem = "/Root/ElementBlocks/" + baseItem + self.mExpandedIncludeBlockList.append(extraItem) + extraItem = "/Root/Bases/Base/Zones/" + baseItem + self.mExpandedIncludeBlockList.append(extraItem) if PhactoriDbg(100): - myDebugPrint3("number of times existing block names found:\n") - for blknm, count in gDuplicateNameCounter.items(): - myDebugPrint3(blknm + ": " + str(count) + "\n"); - if PhactoriDbg(100): - myDebugPrint3("FigureBlockIndicesFromBlockList final indices list:\n" \ - + str(self.mBlockIndices) + \ - "\nFigureBlockIndicesFromBlockList returning\n") + myDebugPrint3("self.mExpandedIncludeBlockList:\n" + \ + str(self.mExpandedIncludeBlockList) + "\n") def CreateParaViewFilter(self, inInputFilter): "create the extract block filter for ParaView" @@ -11027,7 +10589,7 @@ def CreateParaViewFilter(self, inInputFilter): numArrays = inInputFilter.PointData.GetNumberOfArrays() for ii in range (0, numArrays): myDebugPrint3(" " + str(ii) + ": " + inInputFilter.PointData.GetArray(ii).GetName() + "\n") - + if PhactoriDbg(): myDebugPrint3(" extractblock inInputFilter cell data arrays:\n") numArrays = inInputFilter.CellData.GetNumberOfArrays() @@ -11035,15 +10597,8 @@ def CreateParaViewFilter(self, inInputFilter): myDebugPrint3(" " + str(ii) + ": " + inInputFilter.CellData.GetArray(ii).GetName() + "\n") newParaViewFilter = ExtractBlock(inInputFilter) - - if self.mFlatBlockIndicesSpecifiedDirectly == False: - self.FigureBlockIndicesFromBlockList(inInputFilter) - - #newParaViewFilter.PruneOutput = 1 - #newParaViewFilter.MaintainStructure = 0 - newParaViewFilter.MaintainStructure = 1 - - newParaViewFilter.BlockIndices = self.mBlockIndices + self.MakeExpandedIncludeBlockList() + newParaViewFilter.Selectors = self.mExpandedIncludeBlockList SetActiveSource(newParaViewFilter) @@ -11053,7 +10608,7 @@ def CreateParaViewFilter(self, inInputFilter): numArrays = newParaViewFilter.PointData.GetNumberOfArrays() for ii in range (0, numArrays): myDebugPrint3(" " + str(ii) + ": " + newParaViewFilter.PointData.GetArray(ii).GetName() + "\n") - + if PhactoriDbg(): myDebugPrint3(" extractblock newParaViewFilter cell data arrays:\n") numArrays = newParaViewFilter.CellData.GetNumberOfArrays() @@ -11075,29 +10630,37 @@ def CreateParaViewFilter(self, inInputFilter): class PhactoriCellDataToPointDataOperation(PhactoriOperationSpecifics): def __init__(self): PhactoriOperationSpecifics.__init__(self) + self.passCellData = 0 + self.pieceInvariant = 0 return def ParseParametersFromJson(self, inJson): + key1 = "pass cell data" + if key1 in inJson: + self.passCellData = inJson[key1] + key1 = "piece invariant" + if key1 in inJson: + self.pieceInvariant = inJson[key1] return def CreateParaViewFilter(self, inInputFilter): if PhactoriDbg(100): myDebugPrint3('PhactoriCellDataToPointDataOperation:CreateParaViewFilter entered\n', 100) - #info in block class should already be parsed and checked - - if PhactoriDbg(100): - myDebugPrint3('about to call UpdatePipelineWithCurrentTimeArgument\n', 100) UpdatePipelineWithCurrentTimeArgument(inInputFilter) savedActiveSource = GetActiveSource() - if PhactoriDbg(100): - myDebugPrint3('about to call CellDatatoPointData\n', 100) newParaViewFilter = CellDatatoPointData(Input = inInputFilter) + if self.passCellData: + newParaViewFilter.PassCellData = 1 + else: + newParaViewFilter.PassCellData = 0 + if self.pieceInvariant: + newParaViewFilter.PieceInvariant = 1 + else: + newParaViewFilter.PieceInvariant = 0 SetActiveSource(newParaViewFilter) - if PhactoriDbg(100): - myDebugPrint3('about to call UpdatePipelineWithCurrentTimeArgument\n', 100) UpdatePipelineWithCurrentTimeArgument(newParaViewFilter) SetActiveSource(savedActiveSource) @@ -11161,7 +10724,7 @@ def CreateParaViewFilter(self, inInputFilter): if PhactoriDbg(100): myDebugPrint3("PhactoriExtractComponentOperation:CreateParaViewFilter entered\n", 100) #info in block class should already be parsed and checked - + if PhactoriDbg(100): myDebugPrint3("about to call UpdatePipelineWithCurrentTimeArgument\n", 100) UpdatePipelineWithCurrentTimeArgument(inInputFilter) @@ -11206,7 +10769,7 @@ def CreateParaViewFilter(self, inInputFilter): myDebugPrint3('PhactoriCellSizeOperation:CreateParaViewFilter entered\n', 100) #info in block class should already be parsed and checked - + if PhactoriDbg(100): myDebugPrint3('about to call UpdatePipelineWithCurrentTimeArgument\n', 100) UpdatePipelineWithCurrentTimeArgument(inInputFilter) @@ -11255,7 +10818,7 @@ def ParseParametersFromJson(self, inJson): self.AppendPointLocations = 1 else: self.AppendPointLocations = 0 - + key2 = "append cell centers" if key2 in inJson: testval = inJson[key2] @@ -11278,7 +10841,7 @@ def CreateParaViewFilter(self, inInputFilter): if PhactoriDbg(100): myDebugPrint3('PhactoriAppendLocationAttributesOperation:CreateParaViewFilter entered\n', 100) #info in block class should already be parsed and checked - + if PhactoriDbg(100): myDebugPrint3('about to call UpdatePipelineWithCurrentTimeArgument\n', 100) UpdatePipelineWithCurrentTimeArgument(inInputFilter) @@ -11325,7 +10888,7 @@ def CreateParaViewFilter(self, inInputFilter): myDebugPrint3('PhactoriIntegrateVariablesOperation:CreateParaViewFilter entered\n', 100) #info in block class should already be parsed and checked - + if PhactoriDbg(100): myDebugPrint3('about to call UpdatePipelineWithCurrentTimeArgument\n', 100) UpdatePipelineWithCurrentTimeArgument(inInputFilter) @@ -11774,7 +11337,11 @@ def CreateParaViewFilter(self, inInputFilter): savedActiveSource = GetActiveSource() newParaViewFilter = SliceWithPlane(Input=inInputFilter) - newParaViewFilter.Plane = 'Plane' + global gParaViewCatalystVersionFlag + if gParaViewCatalystVersionFlag < 51100: + newParaViewFilter.Plane = 'Plane' + else: + newParaViewFilter.PlaneType = 'Plane' self.UpdateSlice(inInputFilter, newParaViewFilter) @@ -11819,11 +11386,14 @@ def UpdateSlice(self, inIncomingPvFilter, ioOutgoingPvFilter): if PhactoriDbg(): myDebugPrint3(' updateslice using normal: ' + \ str(normalToUse) + '\n') - ioOutgoingPvFilter.Plane.Normal = normalToUse - - if PhactoriDbg(): myDebugPrint3(' updateslice using origin: ' + str(originToUse) + '\n') - ioOutgoingPvFilter.Plane.Origin = originToUse + global gParaViewCatalystVersionFlag + if gParaViewCatalystVersionFlag < 51100: + ioOutgoingPvFilter.Plane.Normal = normalToUse + ioOutgoingPvFilter.Plane.Origin = originToUse + else: + ioOutgoingPvFilter.PlaneType.Normal = normalToUse + ioOutgoingPvFilter.PlaneType.Origin = originToUse if PhactoriDbg(): myDebugPrint3("PhactoriSliceWithPlanePlaneOperation::UpdateSlice returning\n") @@ -12288,12 +11858,12 @@ def CreateParaViewFilter(self, inInputFilter): myDebugPrint3("stido0 st: " + str(stido0.GetClassName()) + "\n") stido1 = stcso.GetInputDataObject(1,0) myDebugPrint3("stido1 st: " + str(stido1.GetClassName()) + " numcells " + str(stido1.GetNumberOfCells()) + " numpoints " + str(stido1.GetNumberOfPoints()) + "\n") - + SetActiveSource(newParaViewFilter) SetActiveSource(savedActiveSource) UpdatePipelineWithCurrentTimeArgument(newParaViewFilter) - + if PhactoriDbg(100): stcso = newParaViewFilter.GetClientSideObject() stodo = stcso.GetOutputDataObject(0) @@ -12302,7 +11872,7 @@ def CreateParaViewFilter(self, inInputFilter): myDebugPrint3("B stido0 st: " + str(stido0.GetClassName()) + "\n") stido1 = stcso.GetInputDataObject(1,0) myDebugPrint3("B stido1 st: " + str(stido1.GetClassName()) + " numcells " + str(stido1.GetNumberOfCells()) + " numpoints " + str(stido1.GetNumberOfPoints()) + "\n") - + if PhactoriDbg(100): myDebugPrint3('PhactoriStreamTracerOperation.CreateParaViewFilter returning\n', 100) @@ -12382,14 +11952,14 @@ def CreateParaViewFilter2(self, inInputFilter, inPipeAndViewsState): #self.InternalParaViewFilterPtr.InitialStepLength = 0.01 self.DebugPrintInputPortAndOutputPortInfo("pre filter update 1\n") - + SetActiveSource(self.InternalParaViewFilterPtr) SetActiveSource(savedActiveSource) UpdatePipelineWithCurrentTimeArgument(self.InternalParaViewFilterPtr) self.DebugPrintInputPortAndOutputPortInfo("post filter update 1\n") - + if PhactoriDbg(100): myDebugPrint3("self.InternalParaViewFilterPtr: " + str(self.InternalParaViewFilterPtr) + "\n", 100) @@ -12473,7 +12043,7 @@ def CreateParaViewFilter2(self, inInputFilter, inPipeAndViewsState): self.InternalParaViewFilterPtr.CellLocator = 'Static Cell Locator' self.DebugPrintInputPortAndOutputPortInfo("pre filter update 1\n") - + SetActiveSource(self.InternalParaViewFilterPtr) SetActiveSource(savedActiveSource) @@ -12487,7 +12057,7 @@ def CreateParaViewFilter2(self, inInputFilter, inPipeAndViewsState): self.InternalParaViewFilterPtr.UpdatePipeline() self.DebugPrintInputPortAndOutputPortInfo("post filter update 1\n") - + if PhactoriDbg(100): myDebugPrint3("self.InternalParaViewFilterPtr: " + str(self.InternalParaViewFilterPtr) + "\n", 100) @@ -12529,7 +12099,7 @@ def ValidateJsonPointList(self): myDebugPrint3AndException(errStr) return True - + def ParseParametersFromJson(self, inJson): if 'filename' in inJson: self.JsonListFileName = inJson['filename'] @@ -12797,7 +12367,7 @@ def ValidateJsonPointList(self): errStr = "PhactoriPointSourceFromJsonList::ValidateJsonPointList\n" \ "point with index " + str(ptNdx) + "does not have three elements\n" myDebugPrint3AndException(errStr) - + def ParseParametersFromJson(self, inJson): if 'filename' in inJson: @@ -12888,13 +12458,13 @@ def UseMpiToFindGlobalNearestPointList(self, inTargetPointList, inDistanceSquare for idx in range(0, numSrcPnts): xyzIdx = idx*3 resultPoints.append([globalXyz[xyzIdx], globalXyz[xyzIdx+1], globalXyz[xyzIdx+2], globalNodeId[idx]]) - + if PhactoriDbg(100): myDebugPrint3("resultPoints:\n" + str(resultPoints) + "\n") if PhactoriDbg(100): myDebugPrint3("UseMpiToFindGlobalNearestPointList returning\n") - return resultPoints + return resultPoints def CalculateOneDisplacedPoint(self, srcPt, tgtPt, dispDist): deltaVec = vecFromAToB(srcPt, tgtPt) @@ -12921,7 +12491,7 @@ def CalculateDisplacedPointList(self): def FindCorrelatedInputOperationPoints(self, inInputFilter): "in parallel, using mpi to help, find the nodes from the input filter\n which are closest to the points in self.mJsonPointList, and record the\n 3d location of those points" - + #grab local process points thisProcessPointList = self.mPhactoriOperationBlockOwner.MakeListOfAllPointsAndNodeIdsOnThisProcessFromParaViewFilter(inInputFilter) @@ -12949,7 +12519,7 @@ def FindCorrelatedInputOperationPoints(self, inInputFilter): distx = math.sqrt(distSqrd) myDebugPrint3(str(ndx) + ": " + str(sourcePt) + " " + str(distSqrd) + " " + str(distx) + " " + str(self.DisplacedPointList[ndx]) + "\n") - + def CreateParaViewFilter(self, inInputFilter): if PhactoriDbg(100): myDebugPrint3("PhactoriPointSourceFromJsonList.CreateParaViewFilter entered\n", 100) @@ -13410,11 +12980,11 @@ def PhactoriLocalToGlobalCellsWithMinMaxDataUsingMPI(localPidMinMaxCellPair, tup globalMaxCell = PhactoriSampledCellInfo() globalMinCell.SerializeSetFromFloatAndIntArray(globalSerializedFloatArray, globalSerializedIntArray, 0, tupleSize) globalMaxCell.SerializeSetFromFloatAndIntArray(globalSerializedFloatArray, globalSerializedIntArray, 1, tupleSize) - + if PhactoriDbg(100): myDebugPrint3("PhactoriLocalToGlobalCellsWithMinMaxDataUsingMPI returning\n") - return [globalMinCell, globalMaxCell] - + return [globalMinCell, globalMaxCell] + #phactori_combine_to_single_python_file_subpiece_end_1 #phactori_combine_to_single_python_file_parent_1 @@ -13448,7 +13018,7 @@ def ValidateJsonPointList(self): errStr = "PhactoriPointSourceGeometrySampler1::ValidateJsonPointList\n" \ "point with index " + str(ptNdx) + "does not have three elements\n" myDebugPrint3AndException(errStr) - + def ParseParametersFromJson(self, inJson): if 'filename' in inJson: @@ -13471,7 +13041,7 @@ def GetPidWithLeastValueList(self, inLocalDistSqrdList): pidWithDataList = UseReduceOnIntegerList(localPidList, 0) return pidWithDataList, globalDistSqrdList - + def UseMpiToGetGlobalQuadsClosest(self, inLocalQuadList, inLocalDistSqrdList): if PhactoriDbg(100): myDebugPrint3("PhactoriPointSourceGeometrySampler1.UseMpiToGetGlobalQuadsClosest entered\n", 100) @@ -13805,7 +13375,7 @@ def ValidateJsonSegmentList(self, testlist): errStr = "PhactoriSegmentCellSampler3:ValidateJsonSegmentList\n" \ "segment with index " + str(segNdx) + " point 2 does not have 3 components\n" myDebugPrint3AndException(errStr) - + return True def ParseParametersFromJson(self, inJson): @@ -13962,7 +13532,7 @@ def CreateInternalSegmentListFromJson(self, segmentListJson): if PhactoriDbg(100): myDebugPrint3("PhactoriSegmentCellSampler3.ExportOperationData entered\n", 100) - if self.SegmentDefinitionFormat == "two geometric points": + if self.SegmentDefinitionFormat == "two geometric points": self.ValidateJsonSegmentList(segmentListJson) self.SegmentList = [] self.NearbyGeometryPointList = [] @@ -14043,7 +13613,7 @@ def CreateParaViewFilter(self, inInputFilter): savedActiveSource = GetActiveSource() segmentListJson = ReadAndMpiBroadcastJsonFile(self.JsonListFileName) - + self.myCopyOfInputFilter = inInputFilter UpdatePipelineWithCurrentTimeArgument(self.myCopyOfInputFilter) @@ -14110,7 +13680,7 @@ def GetPidWithLeastValueList(self, inLocalDistSqrdList): pidWithDataList = UseReduceOnIntegerList(localPidList, 0) return pidWithDataList, globalDistSqrdList - + def UseMpiToGetGlobalCellPointsClosestStructured(self, ioCellList, inLocalDistSqrdList): if PhactoriDbg(100): myDebugPrint3("PhactoriSegmentCellSampler3.UseMpiToGetGlobalCellPointsClosestStructured entered\n", 100) @@ -14300,12 +13870,12 @@ def SetMaskValueForCellsNearSegmentsInBlock(recursionObject, inInputCsData, inPa thisCellDataTuple = outputCellArray.GetTuple(cellIndex) newCellInfo = PhactoriSampledCellInfo() newCellInfo.SetFromList([cellTestPoint, [-1,-1,-1], thisCellDataTuple, myPid, leafVisitCount, cellIndex, segIndex, -1]) - + inParameters.markedCellSet[segIndex].append(newCellInfo) if PhactoriDbg(100): myDebugPrint3("new cell close to segment:\n") myDebugPrint3(newCellInfo.ToStr()) - + if PhactoriDbg(100): for idx, cellsForThisSegment in enumerate(inParameters.markedCellSet): @@ -14811,7 +14381,7 @@ def CreateProgrammableFilterString(self): scriptLines.append(" iter.GoToNextItem();\n") scriptLines.append("else:\n") scriptLines.append(" flatten(input, output)\n") - + mainScriptString = "".join(scriptLines) myCellIndexesToSet = [] @@ -14825,10 +14395,10 @@ def CreateProgrammableFilterString(self): myCellIndexesToSet.append(oneCellInfo.index) myMaskValuesToSet.append(maskValue) myLeafVisitCount.append(oneCellInfo.leafVisitCount) - - newstr1 = "cellIndexesToSet = " + str(myCellIndexesToSet) + "\n" - newstr2 = "maskValuesToSet = " + str(myMaskValuesToSet) + "\n" - newstr3 = "leafVisitCount = " + str(myLeafVisitCount) + "\n" + + newstr1 = "cellIndexesToSet = " + str(myCellIndexesToSet) + "\n" + newstr2 = "maskValuesToSet = " + str(myMaskValuesToSet) + "\n" + newstr3 = "leafVisitCount = " + str(myLeafVisitCount) + "\n" self.mProgFilterString = newstr1 + newstr2 + newstr3 + mainScriptString if PhactoriDbg(100): @@ -15126,7 +14696,7 @@ def GatherGeometricallySampledCellsInBlock(recursionObject, inInputCsData, inPar myDebugPrint3("None\n") else: myDebugPrint3(str(oneCellDataArray.GetNumberOfTuples()) + "\n") - + if dataArrayNumCmpnts != 0: defaultTuple = [] for ii in range(0, dataArrayNumCmpnts): @@ -15306,7 +14876,7 @@ def CreateInternalListOfDataControlledSampledCellsOnThisProcess(self): else: myDebugPrint3AndException("CreateInternalListOfDataControlledSampledCellsOnThisProcess:\n" +\ "bad self.DataControlledSamplingMethod\n") - + if PhactoriDbg(100): myDebugPrint3("CreateInternalListOfDataControlledSampledCellsOnThisProcess returning\n") @@ -15369,7 +14939,7 @@ def CollectDataOnSampledCellsInBlock(recursionObject, inInputCsData, inParameter myDebugPrint3("None\n") else: myDebugPrint3(str(oneCellDataArray.GetNumberOfTuples()) + "\n") - + if dataArrayNumCmpnts != 0: defaultTuple = [] for ii in range(0, dataArrayNumCmpnts): @@ -15439,7 +15009,7 @@ def CreateLeafRecursionTrackingStructure(self): for leafKey in self.GeometricallySampledCellsByRecursionLeaf: cellListForLeaf = self.GeometricallySampledCellsByRecursionLeaf[leafKey] myDebugPrint3(str(len(cellListForLeaf)) + " cells for leaf " + str(leafKey) + "\n") - + if PhactoriDbg(100): myDebugPrint3("CreateLeafRecursionTrackingStructure returning\n") @@ -15658,7 +15228,7 @@ def CreateProgrammableFilterString(self): scriptLines.append(" iter.GoToNextItem();\n") scriptLines.append("else:\n") scriptLines.append(" flatten(input, output)\n") - + self.mainScriptString = "".join(scriptLines) myCellIndexesToSet = [] @@ -15676,10 +15246,10 @@ def CreateProgrammableFilterString(self): myCellIndexesToSet.append(oneCellInfo.index) myMaskValuesToSet.append(maskValue) myLeafVisitCount.append(oneCellInfo.leafVisitCount) - - newstr1 = "cellIndexesToSet = " + str(myCellIndexesToSet) + "\n" - newstr2 = "maskValuesToSet = " + str(myMaskValuesToSet) + "\n" - newstr3 = "leafVisitCount = " + str(myLeafVisitCount) + "\n" + + newstr1 = "cellIndexesToSet = " + str(myCellIndexesToSet) + "\n" + newstr2 = "maskValuesToSet = " + str(myMaskValuesToSet) + "\n" + newstr3 = "leafVisitCount = " + str(myLeafVisitCount) + "\n" self.mProgFilterString = newstr1 + newstr2 + newstr3 + self.mainScriptString if PhactoriDbg(100): @@ -15821,7 +15391,7 @@ def GetPidWithLeastValueListV5(inLocalDistSqrdList): pidWithDataList = UseReduceOnIntegerList(localPidList, 0) return pidWithDataList, globalDistSqrdList - + def UseMpiToGetGlobalCellPointsClosestV5(inInputFilter, inLocalCellPointList, inLocalDistSqrdList): if PhactoriDbg(100): @@ -16214,7 +15784,7 @@ def FigureBlockIndicesFromBlockList(includeBlockList, inInputFilter): listOfBlockIndicesToInclude = [] FigureBlockIndicesFromBlockListRecurse1(listOfBlockIndicesToInclude, includeBlockList, csdata, None, flatIndexCounter, 0) - + #if PhactoriDbg(100): # myDebugPrint3("number of times existing block names found:\n") # for blknm, count in gDuplicateNameCounter.items(): @@ -16332,7 +15902,7 @@ def ParseParametersFromJson(self, inJson): def MakeExtractBlockFilter(self, inInputFilter, blockName): if PhactoriDbg(100): myDebugPrint3("MakeExtractBlockFilter entered: " + str(blockName) + "\n") - newPvExtractBlockFilter = ExtractBlock(inInputFilter) + newPvExtractBlockFilter = ExtractBlock(inInputFilter) #newParaViewFilter.PruneOutput = 1 #newParaViewFilter.MaintainStructure = 0 #newParaViewFilter.MaintainStructure = 1 @@ -16363,7 +15933,7 @@ def CreateIjkRangeFromSettingsForThisBlock(self, ijkJson, blockExtent): rngFunc = [0,0,0,0,0,0] if rngFuncAllAbsolute: - retIjkRange = ijkJson["ijkrange"] + retIjkRange = ijkJson["ijkrange"] if PhactoriDbg(100): myDebugPrint3("rngFunc is [0,0,0,0,0,0], all absolute, " "so just return explicit ijkrange:\nretIjkRange: \n" + \ @@ -16376,7 +15946,7 @@ def CreateIjkRangeFromSettingsForThisBlock(self, ijkJson, blockExtent): return [0,-1,0,-1,0,-1] if "ijkrange" in ijkJson: - ijkRangeFromJson = ijkJson["ijkrange"] + ijkRangeFromJson = ijkJson["ijkrange"] else: ijkRangeFromJson = [0,0,0,0,0,0] @@ -16417,22 +15987,22 @@ def CreateIjkRangeFromSettingsForThisBlock(self, ijkJson, blockExtent): if hadToCorrect: if PhactoriDbg(100): myDebugPrint3("return ijkrange had to be corrected because it was outside block extent" - "\nblockExtent: " + str(blockExtent) + - "\nijkRangeFromJson: " + str(retIjkRange) + - "\nrngFunc (from json): " + str(rngFunc) + + "\nblockExtent: " + str(blockExtent) + + "\nijkRangeFromJson: " + str(retIjkRange) + + "\nrngFunc (from json): " + str(rngFunc) + "\nuncorrectedIjkRange: " + str(uncorrectedIjkRange) + "\nretIjkRange: " + str(retIjkRange) + "\n") else: if PhactoriDbg(100): myDebugPrint3("return ijkrange did not need correction" - "\nblockExtent: " + str(blockExtent) + + "\nblockExtent: " + str(blockExtent) + "\nijkRangeFromJson: " + str(retIjkRange) + - "\nrngFunc (from json): " + str(rngFunc) + + "\nrngFunc (from json): " + str(rngFunc) + "\nretIjkRange: " + str(retIjkRange) + "\n") return retIjkRange - - + + def MakeExtractSubsetFilter(self, extractBlockFilter, oneBlockExtractSubsetJson, oneBlockExtents): if PhactoriDbg(100): myDebugPrint3("MakeOneExtractBlockExtractSubsetFilter entered\n") @@ -16482,7 +16052,7 @@ def MakeGroupAllExtractSubsetsFilter(self): if PhactoriDbg(100): myDebugPrint3("MakeGroupAllExtractSubsetsFilter returning\n") - + def CreateParaViewFilter(self, inInputFilter): "create the PhactoriExtractStructuredMultiBlock filter for ParaView" if PhactoriDbg(100): @@ -17319,7 +16889,7 @@ def TestPointSub2(self, inSrcId, inSrcXyz, inTgtId, inTgtXyz, inNrstdist): # str(self.mTargetMatchXyzs.GetValue(gndx+2)) + "\n") #now find which in the current list has the biggest distance, as it is - #next in line for replacement (we do this to avoid having to shift + #next in line for replacement (we do this to avoid having to shift #elements every time self.mcfndx = 0 self.mMinDistSqrd = self.mDistSqrds.GetValue(0) @@ -17387,7 +16957,7 @@ def TestPointSub1(self, inId, inX, inY, inZ, tId, tX, tY, tZ): str(self.mTargetMatchXyzs.GetValue(gndx+2)) + "\n") #now find which in the current list has the biggest distance, as it is - #next in line for replacement (we do this to avoid having to shift + #next in line for replacement (we do this to avoid having to shift #elements every time self.mcfndx = 0 self.mMinDistSqrd = self.mDistSqrds.GetValue(0) @@ -17491,7 +17061,7 @@ def MakeListOfAllPoints1(self): self.DoMethodPerBlock(recursionItem) return recursionItem.mParameters.mGlobalNodeIdList, \ recursionItem.mParameters.mPointXYZList - + def MakeListOfAllPointsInBlock1(self, inInputCsData, inParameters): #if PhactoriDbg(100): # myDebugPrint3("MakeListOfAllPointsInBlock1 entered\n") @@ -17858,7 +17428,7 @@ def ParseParametersFromJson(self, inJson): self.OutputShortestLongestIndex = 0 keyval10 = "output cell variable name" - if keyval10 in inJson: + if keyval10 in inJson: self.ProgrammableFilterOutputCellVariableName = inJson[keyval10] def CreateParaViewFilter(self, inInputFilter): @@ -18105,10 +17675,10 @@ def ParseParametersFromJson(self, inJson): self.OffsetIndex = 0 keyval10 = "output angle cell variable name" - if keyval10 in inJson: + if keyval10 in inJson: self.OutputAngleCellVariableName = inJson[keyval10] keyval10 = "output height cell variable name" - if keyval10 in inJson: + if keyval10 in inJson: self.OutputHeightCellVariableName = inJson[keyval10] keyval11 = "do operation in createparaview method" @@ -18358,7 +17928,7 @@ def ParseParametersFromJson(self, inJson): self.OffsetIndex = 0 keyval10 = "output cell variable name" - if keyval10 in inJson: + if keyval10 in inJson: self.OutputCellVariableName = inJson[keyval10] keyval11 = "do operation in createparaview method" @@ -18924,7 +18494,7 @@ def CreateParaViewStuff(self, inColor, inImageset = None): "to work off, and None was supplied\n") return self.mInputOperation = inImageset.mOperation - + savedActiveSource = GetActiveSource() inOprtn = self.mInputOperation if(inOprtn.mParaViewTimeAnnotationSource == None): @@ -18975,7 +18545,8 @@ def __init__(self, inName, inAnnotationType): self.mType = 'text' self.mText = 'Text' self.mSizeScale = 1.0 - self.mFontSize = 18 + #self.mFontSize = 18 + self.mFontSize = 36 self.mFont = 'Arial' self.mBold = False self.mItalic = False @@ -19073,11 +18644,11 @@ def SetSizeScale(self, inNewSizeScale): def SetWindowLocation(self, inNewPosition): global gParaViewCatalystVersionFlag if gParaViewCatalystVersionFlag < 51000: - validPositions = ['UpperLeftCorner', 'UpperRightCorner', + validPositions = ['UpperLeftCorner', 'UpperRightCorner', 'LowerLeftCorner', 'LowerRightCorner', 'UpperCenter', 'LowerCenter'] else: - validPositions = ['Upper Left Corner', 'Upper Right Corner', + validPositions = ['Upper Left Corner', 'Upper Right Corner', 'Lower Left Corner', 'Lower Right Corner', 'Upper Center', 'Lower Center'] if inNewPosition in validPositions: @@ -19187,7 +18758,7 @@ def GetImageFilename(self, datadescription, inImageSettings, inImageBasedirectory = inImageSettings.mImageBasedirectory inNumCounterDigits = inImageSettings.mNumCounterDigits inImageFormat = inImageSettings.mImageFormat - + timestep = datadescription.GetTimeStep() lastImagesetName = "" @@ -19222,7 +18793,7 @@ def GetImageFilename(self, datadescription, inImageSettings, while len(timestepString) < inNumCounterDigits: timestepString = "0" + timestepString myDebugPrint2("image fname: " + fname + "\ndigit count: " + str(inNumCounterDigits) + "\ntimestepString: " + timestepString + "\n") - + rplstr1 = None if self.mUseDateTime: ttnow = gPipeAndViewsState.mCallbackDateTime @@ -19252,7 +18823,7 @@ def GetImageFilename(self, datadescription, inImageSettings, fnameRR = fname.replace("%t", rplstr1) else: fnameRR = None - + fname = fname.replace("%t", timestepString) myDebugPrint2("fname after replace: ->" + fname + "<-\n") @@ -19281,7 +18852,7 @@ class PhactoriPlot1Base: def __init__(self): self.mName = "" self.m_DataCubeAxesInfo = PhactoriDataCubeAxesInfo() - + self.m_PlotType = "PhactoriPlot1Base" self.mImageSettings = PhactoriImageSettings() self.mImageSettings.mPixelBorderRatioXY = [0.175 / self.mImageSettings.GetAspectRatio(), 0.175] @@ -19319,6 +18890,8 @@ def __init__(self): #or not) self.mImageFileNameCountSettings = ImageFileNameCountSettings() + self.mBackground = [0.0, 0.0, 0.0] + def GetInputPhactoriOperation(self): #mainly for compatibility between plot blocks and imageset blocks, give #same access to phactori operation coming being visualized @@ -19338,7 +18911,7 @@ def WriteImages(self, datadescription): oneLookDirectionFilenameAddon = "" else: oneLookDirectionFilenameAddon = "" - + fname, fnameRR = self.mImageFileNameCountSettings.GetImageFilename( datadescription, self.mImageSettings, oneLookDirectionFilenameAddon, @@ -19353,6 +18926,9 @@ def WriteImages(self, datadescription): #SetUpViewAndRepresentationBeforeWriteImage(oneViewInfo) self.SetUpViewAndRepresentationBeforeWriteImage() + colorPalette = GetSettingsProxy('ColorPalette') + colorPalette.Background = self.mBackground + #only need to update color range for first look direction, rest #are same #if self.mRepresentation.mUseFixedColorRange == False: @@ -19603,6 +19179,9 @@ def ParseParametersFromJson(self, inJsn, inPipeAndViewsState): 'plot basename', 'plot basedirectory') self.mImageFileNameCountSettings.ParseImageFileNameCountSettings(inJsn) + self.mBackground = getParameterFromBlock(inJsn, + 'background color', self.mBackground) + #parse x axis variable self.m_XAxisVariableInfo.ParseVariableNameAndVectorOrTensorComponent(inJsn, 'x axis variable ') @@ -19659,7 +19238,6 @@ def ParseParametersFromJson(self, inJsn, inPipeAndViewsState): global gSharedLineChartView gSharedLineChartView = None - class PhactoriImagesetBlock: "contains information corresponding to an imageset block\n " def __init__(self): @@ -19721,6 +19299,9 @@ def __init__(self): #or not) self.mImageFileNameCountSettings = ImageFileNameCountSettings() + self.mBackground = [0.31999694819562063, 0.3400015259021897, + 0.4299992370489052] + def GetInputPhactoriOperation(self): #mainly for compatibility between plot blocks and imageset blocks, give #same access to phactori operation coming being visualized @@ -19845,6 +19426,9 @@ def WriteImagesPassedOnOffFilter(self, datadescription): #SetUpViewAndRepresentationBeforeWriteImage(oneViewInfo) self.SetUpViewAndRepresentationBeforeWriteImage(oneLookDirection, ii) + colorPalette = GetSettingsProxy('ColorPalette') + colorPalette.Background = self.mBackground + #only need to update color range for first look direction, rest #are same if ii == 0: @@ -20197,7 +19781,7 @@ def ParseOperationAndRepresentationPair(self, ioPipeAndViewsState, ioJson, "inOperationKey: " + str(inOperationKey) + "\n" "inRepresentationKey: " + str(inRepresentationKey) + "\n" "incoming json:\n" + str(ioJson) + "\n") - + if inOperationKey not in ioJson: if inSkipIfOperationKeyNotPresent: @@ -20260,7 +19844,6 @@ def ParseOperationAndRepresentationPair(self, ioPipeAndViewsState, ioJson, self.mVisiblePvDataReps.append(None) self.mColorLegendRepRefs.append(None) - class PhactoriPipeAndViewsState: "Top State Container--Pipeline, Cameras, Representations, Imagesets, Plots\n\n This is essentially the top-level class for wrapping up everything about the\n phactori-controlled viewing situation. It keeps a reference to the original\n json (assuming that was how the state was described originally), and stores\n and organizes all the other information. Presently that means that there\n six sets, each of which stores the class instances corresponding to one\n block type from the json input format. The block types stored are the\n camera blocks, the representation blocks, the operation blocks, the\n imageset blocks, the scatter plot blocks, and the plot over time blocks.\n A set for each type of block is kept, with the block name (assigned by the\n json author) as a key for that block. The Operation blocks are basically\n analagous to the ParaView/Catalyst Filters, the imagesets are roughly\n analagous to the ParaView Views (but with image endpoints rather than\n interactive rendering endpoints), the Representation blocks plus the\n camera blocks are analagous to the ParaView Representations. The\n scatter plot and plot over time blocks are simply specialized descriptions\n of requested plots, which are converted into ParaView filters and views\n to create plots which can be calculated and/or rendered in parallel at\n runtime, as opposed to bringing data to the client. An imageset block will\n reference a camera block, a representation block, and an operation block and\n contains some additional parameters (e.g. image size and file basename)\n which will describe a view to be rendered--repeatedly at different times\n when using insitu. The camera blocks describe 3-D viewpoints, sometimes in\n absoulte 3D terms, sometimes dependent on the data. The representation\n blocks control how the view looks, e.g. if element surface and edges are\n rendered or just surfaces and if we show axes and color legends. The\n operation blocks can describe a potentially complex data pipeline which can\n allow rendering at various points along the pipeline. The pipeline is\n currently assumed to have operations that only have one input and one\n output. Multiple operations can have the same input, so a 'tree' is\n possible, not just a single linear pipe. Operations with multiple inputs\n and outputs are conceivable but not currently implemented. One obvious\n possible upgrade would be to allow 'geometryoutput' blocks which would\n output geometry rather than images, presumably geometry which is at the\n back end of a pipeline (e.g. to extract isosurface and the decimate).\n " def __init__(self): @@ -20270,7 +19853,7 @@ def __init__(self): #default operation for incoming input self.mIncomingDefaultOperation = PhactoriOperationBlock() self.mIncomingDefaultOperation.mName = "default incoming input" - self.mIncomingOperationList = [] + #self.mIncomingOperationList = [] self.mOperationBlocks = {} self.mImagesetBlocks = {} self.mScatterPlotBlocks = {} @@ -20292,7 +19875,7 @@ def __init__(self): self.mOutputResultsBlockId = None self.mCurrentDatabaseDummyFileName = None self.mProducer = None - self.mIncomingGridProducerList = [] + #self.mIncomingGridProducerList = [] self.mPipeAndViewsState = None self.mRemeshRestartTag = None self.mSeparatorString = '_' @@ -20448,7 +20031,7 @@ def PerRendersetInitialization(datadescription): #cellDataInfo = paraviewSource.GetCellDataInformation() myDebugPrint3(" PerRendersetInitialization:\n num cells: " + str(pvsDi.GetNumberOfCells()) + "\n num points: " + str(pvsDi.GetNumberOfPoints()) + "\n") - #we assume to begin with that all global data bounds in operations are + #we assume to begin with that all global data bounds in operations are #invalid as data may have changed for oneOperationName, oneOperation in \ gPipeAndViewsState.mOperationBlocks.items(): @@ -20481,7 +20064,7 @@ def UpdateRepresentationColorBy(ioPhactoriImagesetBlock): if PhactoriDbg(100): myDebugPrint3("in PhactoriImagsetBlock named: " + \ ioPhactoriImagesetBlock.mName + "\n" + \ - "mColorLegendRepRefs " + str(ii) + + "mColorLegendRepRefs " + str(ii) + "is set to " + str(retVal) + "\n") ioPhactoriImagesetBlock.mColorLegendRepRefs[ii] = retVal @@ -20514,19 +20097,29 @@ def UpdateRepresentationColorBySub1(inPvView, inPvRep, if PhactoriDbg(100): myDebugPrint3('bad element type: returning\n', 100) return None - + if colorVarName != '': if inPhactoriRep.mColorVariableInfo.mVariableIsVectorComponent: ColorByVariableComponentOrMagnitudeXX(inPvRep, inPhactoriRep, colorVarName, 'Component', colorVarInfo.mVariableComponent, thePvVarType, inPhactoriRep.mColorMapSettings) + if colorVarInfo.mVariableComponent == 0: + componentString = "X" + elif colorVarInfo.mVariableComponent == 1: + componentString = "Y" + elif colorVarInfo.mVariableComponent == 2: + componentString = "Z" + else: + componentString = str(colorVarInfo.mVariableComponent) elif inPhactoriRep.mColorVariableInfo.mVariableIsVectorMagnitude: ColorByVariableComponentOrMagnitudeXX(inPvRep, inPhactoriRep, colorVarName, 'Magnitude', colorVarInfo.mVariableComponent, thePvVarType, inPhactoriRep.mColorMapSettings) + componentString = "Magnitude" else: ColorByVariableScalarXX(inPvRep, inPhactoriRep, colorVarName, thePvVarType, inPhactoriRep.mColorMapSettings) + componentString = "" #update the color legend widget if inPhactoriRep.mColorLegendFlag: @@ -20535,7 +20128,7 @@ def UpdateRepresentationColorBySub1(inPvView, inPvRep, onoffFlagString = 'off' retVal = ShowDataColorLegendXX(inPvView, onoffFlagString, inPhactoriRep.mColorLegendPositionAndSize, inPhactoriRep.mColorSettings, - inColorLegendRepRef, inPvRep) + inColorLegendRepRef, inPvRep, componentString) if PhactoriDbg(): myDebugPrint3("UpdateRepresentationColorBySub1 returning\n") @@ -20811,7 +20404,7 @@ def SaveRestartInfoCallback(): for onePlotOtName, onePlotOt in \ gPipeAndViewsState.mPlotOverTimeBlocks.items(): if PhactoriDbg(): - myDebugPrint3("making end vis callback json for plot over time: " + + myDebugPrint3("making end vis callback json for plot over time: " + onePlotOtName + "\n") plotsOverTimeJsonOut[onePlotOtName] = onePlotOt.GetRestartInfo() @@ -20918,7 +20511,7 @@ def HandleOperationShortcuts2(inBlockName, inJson, ioOperationBlocks, inCount): if PhactoriDbg(): myDebugPrint3(errStr) raise Exception(errStr) - #stuff should have 4 items + #stuff should have 4 items #[scalar|vector magnitude|vector component|tensor #component, component, namekeep between|keep above|keep #below, [, ]] @@ -20938,7 +20531,7 @@ def HandleOperationShortcuts2(inBlockName, inJson, ioOperationBlocks, inCount): if PhactoriDbg(): myDebugPrint3(errStr) raise Exception(errStr) - + if PhactoriDbg(): myDebugPrint3('got threshold operation shortcut ' + str(newOperationJson) + '\n') if lastShortcutOperationName != None: @@ -21537,7 +21130,7 @@ def CreateViewSetFromPhactoriViewMapC(inViewMapC): myDebugPrint3(str(inViewMapC) + "\n") global gPipeAndViewsState gPipeAndViewsState.mJsonDescription = inViewMapC - + #get pointers to the various block types (currently 6, camera, #representation, operation, imageset, plot over time, and scatter plot) @@ -21969,6 +21562,17 @@ def ColorByVariableScalarXX(inParaViewDataRepresentation, inPhactoriRepresentati pv_4_3_LUT.RGBPoints = myRGBPoints pv_4_3_LUT.ColorSpace = myColorSpace pv_4_3_LUT.NanColor = myNanColor + if inPhactoriRepresentation.InterpretValuesAsCategories: + if PhactoriDbg(): + myDebugPrint3("variable name is ObjectId, trying to do categories\n") + inPhactoriRepresentation.SetUpForInterpretValuesAsCateories(pv_4_3_LUT) + pv_4_3_LUT.InterpretValuesAsCategories = 1 + pv_4_3_LUT.AnnotationsInitialized = 1 + pv_4_3_LUT.Annotations = inPhactoriRepresentation.Annotations + pv_4_3_LUT.IndexedColors = inPhactoriRepresentation.IndexedColors + pv_4_3_LUT.IndexedOpacities = inPhactoriRepresentation.IndexedOpacities + else: + pv_4_3_LUT.InterpretValuesAsCategories = 0 return #rest of function for paraview 4.1 @@ -22119,7 +21723,7 @@ def ColorByBlock(inParaViewDataSource, inParaViewDataRepresentation, ColorByBlockRecurse1(csdata, blockAndLeafBlockCounter, inParaViewDataRepresentation.BlockColor, False) #inParaViewDataRepresentation.BlockColor = blockColorData - + if PhactoriDbg(100): myDebugPrint3(' block color data: ' + str(inParaViewDataRepresentation.BlockColor) + '\n', 100) if PhactoriDbg(100): @@ -22170,8 +21774,8 @@ def UseDataRangeForColorValues(inPvDataRepresentation, inRepresentation, if PhactoriDbg(): myDebugPrint3(" input:" + str(input) + "\n") UpdatePipelineWithCurrentTimeArgument(input) - - #assume point info + + #assume point info #datainformation = rep.Input.GetPointDataInformation() if pointsOrCellsType == gPointsString: @@ -22375,7 +21979,7 @@ def helpFindNewRgbPoint(inBaseRgbPts, inRatio): #print "deltaPt: ", deltaPt #print "ratioPt: ", ratioPt - subrangePt1 = [inRatio, + subrangePt1 = [inRatio, rr1 + ratioPt * (rr2 - rr1), gg1 + ratioPt * (gg2 - gg1), bb1 + ratioPt * (bb2 - bb1)] @@ -22702,11 +22306,11 @@ def ShowCubeAxesXX(inPvRenderView, inOnOrOff, inShowDataCubeAxesInfo = None): SetAxesGridVisibility(inPvRenderView, 0) if PhactoriDbg(100): myDebugPrint3("ShowCubeAxesXX returning\n", 100) - + def ShowDataColorLegendXX(inPvView, inOnOffSetting, inColorLegendPositionAndSize, inColorSettings, - inColorLegendRepRef, inPvDataRep): + inColorLegendRepRef, inPvDataRep, inComponentString): "Turns on or off the display of the color bar legend showing the mapping\n between the color and the data value (and the name of the data value.\n (note this is primarily to do the paraview-side work to turn bar on or\n off, on to set up for rendering in the shared view, off to turn off\n rendering in shared view. On or off state for rendering is stored\n as a flag in the ioPhactoriImagesetBlock instance" global gParaViewCatalystVersionFlag @@ -22748,6 +22352,7 @@ def ShowDataColorLegendXX(inPvView, inColorLegendRepRef.Visibility = myVisibility inColorLegendRepRef.LookupTable = inPvDataRep.LookupTable inColorLegendRepRef.Title = localColorArrayName + inColorLegendRepRef.ComponentTitle = inComponentString #ioPhactoriImagesetBlock.mColorLegendRepRef.Color = \ # inColorSettings.mTextColor if PhactoriDbg(100): @@ -22847,7 +22452,7 @@ def ShowDataColorLegendXX(inPvView, defaultMidPos = 0.5 - 0.5*defaultLegendLength #legendFontSize = 16 #legendSize = 1.0 - #validPositions = ['UpperLeftCorner', 'UpperRightCorner', + #validPositions = ['UpperLeftCorner', 'UpperRightCorner', # 'LowerLeftCorner', 'LowerRightCorner', # 'UpperCenter', 'LowerCenter'] legendPosition=[0.0, 0.0] @@ -22889,7 +22494,7 @@ def ShowDataColorLegendXX(inPvView, defaultMidPos = 0.5 - 0.5*defaultLegendLength #legendFontSize = 16 #legendSize = 1.0 - #validPositions = ['UpperLeftCorner', 'UpperRightCorner', + #validPositions = ['UpperLeftCorner', 'UpperRightCorner', # 'LowerLeftCorner', 'LowerRightCorner', # 'UpperCenter', 'LowerCenter'] legendPosition=[0.0, 0.0] @@ -23020,11 +22625,15 @@ def ShowDataColorLegendXX(inPvView, pv_4_3_LUT = GetColorTransferFunction(inPvDataRep.ColorArrayName[1]) newScalarBarWidgetRepresentation = GetScalarBar(pv_4_3_LUT, inPvView) newScalarBarWidgetRepresentation.Orientation = legendOrientation + global gTemporaryGlobalImageTextColor + newScalarBarWidgetRepresentation.TitleColor = gTemporaryGlobalImageTextColor + newScalarBarWidgetRepresentation.LabelColor = gTemporaryGlobalImageTextColor newScalarBarWidgetRepresentation.WindowLocation = legendWindowLocation if legendWindowLocation == 'AnyLocation': newScalarBarWidgetRepresentation.Position = legendPosition if PhactoriDbg(): nbwr = newScalarBarWidgetRepresentation + nbwr.ComponentTitle = "" myDebugPrint3("newScalarBarWidgetRepresentation:\n" +\ str(nbwr) + "\n" +\ " Title: " + str(nbwr.Title) + "\n" +\ @@ -23133,9 +22742,9 @@ def ExtractComponentFromVectorVariable(inVariableName, inWhichComponent, inResul newFunctionString = "" if(inWhichComponent == 0): newFunctionString = inVariableName + '_X' - elif(inWhichComponent == 1): + elif(inWhichComponent == 1): newFunctionString = inVariableName + '_Y' - elif(inWhichComponent == 2): + elif(inWhichComponent == 2): newFunctionString = inVariableName + '_Z' else: if PhactoriDbg(): @@ -23221,7 +22830,7 @@ def CollectCells2(inClientSideData, inBlockIndex, ioCollectList, ioTotalCellCoun appendCount += 1 if PhactoriDbg(): myDebugPrint3(' proc ' + str(SmartGetLocalProcessId()) + ' Leaving CollectCells2\n') - + def CollectCells1(cellVariableName, thresholdValue, thresholdDir): if PhactoriDbg(): @@ -23323,7 +22932,7 @@ def UseReduceToSpreadValues(ioListOfValues): if value != 0.0: value = -value ioListOfValues[ii] = value - + if PhactoriDbg(): myDebugPrint3(' ' + 'proc ' + str(SmartGetLocalProcessId()) + ' final values: ' + str(ioListOfValues) + '\n') if PhactoriDbg(100): @@ -23706,7 +23315,7 @@ def GetRestartInfo(self): # def SetRepresentationAndViewColors(self, ioRenderViewInfo): # myDebugPrint3('PlotColorInfo.SetRepresentationColors entered\n', 100) # rep1 = ioRenderViewInfo.DataRepresentation1 -# view1 = ioRenderViewInfo.RenderView1 +# view1 = ioRenderViewInfo.RenderView1 # view1.Background = self.m_BackgroundColor # rep1.EdgeColor = self.m_EdgeColor # rep1.DiffuseColor = self.m_DiffuseColor @@ -23715,7 +23324,7 @@ def GetRestartInfo(self): # rep1.BackfaceDiffuseColor = self.m_BackfaceDiffuseColor # rep1.CubeAxesColor = self.m_CubeAxesColor # myDebugPrint3('PlotColorInfo.SetRepresentationColors returning\n', 100) - + #global gPlotColorInfoPreset #gPlotColorInfoPreset = PlotColorInfo() @@ -24099,7 +23708,7 @@ def FindNodeOrElementIdForMinMax(inputcsData, inVariableInfo): myDebugPrint3("min/max not available, calculating\n", 100) DataMinMax = [0.0, 0.0, False] DataSumCnt = [0.0, 0] - FindMinMaxSumCntFromData(inputcsData, inVariableInfo, + FindMinMaxSumCntFromData(inputcsData, inVariableInfo, None, DataMinMax, DataSumCnt, None, None) else: @@ -24126,7 +23735,7 @@ def FindNodeOrElementIdForMinMax(inputcsData, inVariableInfo): inVariableInfo.mStats.mMaxId = idForMinAndidForMax[1] #mark done for this catalyst callback, so we won't do extra mpi - #communication if we call this routine again + #communication if we call this routine again inVariableInfo.mStats.mIdsTestCounter = gPipeAndViewsState.mFrameTagCounter if PhactoriDbg(100): @@ -24636,7 +24245,7 @@ def FindThisProcessorMinMaxForVar(inOperation, inVariableInfo): return myDataMinMax -def FindMinMaxSumCntFromData(inputcsData, inVariableInfo, +def FindMinMaxSumCntFromData(inputcsData, inVariableInfo, inSecondaryVariableInfo, DataMinMax, DataSumCnt, DataForIds, inPlotIdLineList): "fairly complex high level mpi-operation routine. This takes a paraview\n filter client side object, gets the client side data\n (which is presumably a multiblock\n dataset) and finds the min, max, sum, and count of items for a variable.\n It uses MPI (if the item is not global) to share values and get them\n across all processors. Used for plotting min/max/mean and for evaluating\n boolean criteria (such as whether or not to produce images) for min/max\n /mean/count. Data return is a bit messy and should be updated--it fills\n in DataMinMax, DataSumCnt, and DataForIds if it is not None" @@ -24644,7 +24253,7 @@ def FindMinMaxSumCntFromData(inputcsData, inVariableInfo, if PhactoriDbg(): myDebugPrint3("FindMinMaxSumCntFromData entered\n") - FindMinMaxSumCntFromDataRecurse1(inputcsData, inVariableInfo, + FindMinMaxSumCntFromDataRecurse1(inputcsData, inVariableInfo, inSecondaryVariableInfo, DataMinMax, DataSumCnt, DataForIds, inPlotIdLineList) @@ -24717,7 +24326,7 @@ def SetPlotOverTimePointsFromData(ioPlotInfo): DataForIds = None FindMinMaxSumCntFromData(inputcsData, - ioPlotInfo.m_YAxisVariableInfo, ioPlotInfo.m_XAxisVariableInfo, + ioPlotInfo.m_YAxisVariableInfo, ioPlotInfo.m_XAxisVariableInfo, DataMinMax, DataSumCnt, DataForIds, ioPlotInfo.m_IdPlotLineList) if DataSumCnt[1] == 0: @@ -24813,7 +24422,7 @@ def SetPlotPointsFromData(ioPlotInfo): #myDebugPrint3(' done updating ids\n') - + FindPlotXYZMinMax(plotPts, ioPlotInfo.m_xyzMinMaxTrkC) ScalePlotYForFit(plotPts, ioPlotInfo.m_xyzMinMaxTrkC, @@ -25249,7 +24858,7 @@ def UseMpiToSendAllProcessesFloatArrayToOneProcess(thisProcessFloatArray, pidToC retVal = [] if PhactoriDbg(100): - if len(globalFloatArray) == 0: + if len(globalFloatArray) == 0: myDebugPrint3(str(len(globalFloatArray)) + "\n") else: myDebugPrint3(str(len(globalFloatArray)) + " " + str(globalFloatArray[0]) + " " + str(globalFloatArray[-1]) + "\n") @@ -25772,6 +25381,357 @@ def HandleUserInteractionIfEnabled(ioPipeAndViewsState): myDebugPrint3("HandleUserInteractionIfEnabled returning\n") return doUpdate +#phactori_combine_to_single_python_file_parent_1 +#from Operation.PhactoriRepresentationBlock import * +#phactori_combine_to_single_python_file_subpiece_begin_1 +class PhactoriRepresentationBlock: + def __init__(self): + self.mName = "" + self.mColorVariableInfo = PhactoriVariableInfo() + self.mColorLegendFlag = True + #self.mColorLegendPositionAndSize = ['bottom', 1.0] + #self.mColorLegendPositionAndSize = ['right', 1.0] + self.mColorLegendPositionAndSize = ['bottom right', 1.0] + self.mTimeAnnotationSettings = PhactoriAnnotationViewSettings( + 'time', 'time') + self.mDataCubeAxesFlag = False + self.mDataCubeAxesInfo = PhactoriDataCubeAxesInfo() + #self.mColorByBlockFlag = True + self.mColorByBlockFlag = True + self.mColorByBlockExplicitlySet = False + self.mColorBySolidColorFlag = False + self.mSolidColor = None + self.mOpacitySetting = 1.0 + self.mOrientationAxesFlag = True + self.mFixedColorRange = None + self.mUseFixedColorRange = False + self.mColorRangeMinMaxTracker = PlotValMinMaxTrkC() + self.mUseHighlightSubranges = False + self.mHighlightSubranges = [] + self.mUseColorSubrange = False + self.mColorSubrange = [0.0, 1.0] + self.mFilenameAddon = "" + self.mColorSettings = PhactoriColorSettings() + self.mColorMapSettings = PhactoriColorMapSettings() + self.mPointSize = 2.0 + self.InterpretValuesAsCategories = False + self.CategoryAndColorJsonFile = None + self.Annotations = None + self.IndexedColors = None + self.IndexedOpacities = None + + def ParseSettingsFromJson(self, inRepresentationBlockJson): + "given a python dict (presumably from json) description of a\n representation block, parse all the representation parameters out of\n the block" + + if PhactoriDbg(100): + myDebugPrint3('ParseSettingsFromJson entered\n', 100) + + inJsn = inRepresentationBlockJson + + #hack test for colors start + #inJsn['surface color'] = [1.0, 0.0, 0.0] + #inJsn['background color'] = [0.0, 0.0, 0.0] + #inJsn['edge color'] = [0.0, 1.0, 0.0] + ##inJsn['axes color'] = [0.0, 1.0, 1.0] + #inJsn['text color'] = [1.0, 1.0, 0.0] + #hack test for colors end + + #myDebugPrint3(' json: ' + str(inJsn) + '\n') + + if 'point size' in inJsn: + self.mPointSize = inJsn['point size'] + + #color by variable scalar/vector magnitude/vector component/tensor component + self.mColorVariableInfo.\ + ParseVariableNameAndVectorOrTensorComponent(inJsn, 'color by ') + + if self.mColorVariableInfo.mVariableName != '': + self.mColorByBlockFlag = False + self.mColorBySolidColorFlag = False + elif 'color by blockid' in inJsn: + self.mColorByBlockFlag = True + self.mColorByBlockExplicitlySet = True + self.mColorBySolidColorFlag = False + elif 'color by solid color' in inJsn: + self.mColorBySolidColorFlag = True + self.mColorByBlockFlag = False + self.mSolidColor = inJsn['color by solid color'] + + #color map range control + if 'color legend range' in inJsn: + self.mFixedColorRange = inJsn['color legend range'] + self.mUseFixedColorRange = True + else: + self.mUseFixedColorRange = False + + #highlight subranges with solid colors + if 'highlight subrange 1' in inJsn: + highlightSubrangeIndex = 1 + while True: + oneSubrangeKey = 'highlight subrange ' + str(highlightSubrangeIndex) + if oneSubrangeKey in inJsn: + subrangeArgs = inJsn[oneSubrangeKey] + highlightSubrangeIndex += 1 + if len(subrangeArgs) != 5: + if PhactoriDbg(): + myDebugPrint3("highlight subrange needs 5 values\n"); + PrintOnProcessZero("highlight subrange needs 5 values, skipping " + \ + oneSubrangeKey + "\n"); + continue + srmin = float(subrangeArgs[0]) + srmax = float(subrangeArgs[1]) + if srmin > srmax: + if PhactoriDbg(): + myDebugPrint3("subrange highlight min >= max: " + \ + str(srmin) + ", " + str(srmax) + "\nskipping " + \ + oneSubrangeKey + "\n", 100) + PrintOnProcessZero("subrange highlight min >= max: " + \ + str(srmin) + ", " + str(srmax) + "\nskipping " + \ + oneSubrangeKey + "\n") + continue + srColor = [float(subrangeArgs[2]), float(subrangeArgs[3]), + float(subrangeArgs[4])] + if (srColor[0] < 0.0) or (srColor[0] > 1.0) or \ + (srColor[1] < 0.0) or (srColor[1] > 1.0) or \ + (srColor[2] < 0.0) or (srColor[2] > 1.0): + srColor = [1.0, 1.0, 0.0] + if PhactoriDbg(): + myDebugPrint3(oneSubrangeKey + ": bad color " + "(component not 0.0-1.0), using rgb 1.0, 1.0, 0.0\n", 100) + PrintOnProcessZero(oneSubrangeKey + ": bad color " + "(component not 0.0-1.0), using rgb 1.0, 1.0, 0.0\n") + self.mHighlightSubranges.append( + [srmin, srmax, srColor]) + self.mUseHighlightSubranges = True + else: + break + if PhactoriDbg(): + myDebugPrint3("parsed highlight subranges:\n" + \ + str(self.mHighlightSubranges) + "\n", 100) + + #if 'highlight subranges' in inJsn: + # self.mUseHighlightSubranges = True + # sbrngsJsn = inJsn['highlight subranges'] + # for oneSubrange in sbrngsJsn: + # if 'range' in oneSubrange: + # srmin = oneSubrange['range'][0] + # srmax = oneSubrange['range'][1] + # if srmin < srmax: + # if 'color' in oneSubrange: + # srColor = oneSubrange['color'] + # else: + # srColor = [1.0, 1.0, 0.0] + # self.mHighlightSubranges.append( + # [srmin, srmax, srColor]) + # else: + # if PhactoriDbg(): + # myDebugPrint3("highlight min >= max: " + \ + # str(srmin) + ", " + str(srmax) + "\nskipping subrange\n", 100) + # PrintOnProcessZero("highlight min >= max: " + \ + # str(srmin) + ", " + str(srmax) + "\nskipping subrange\n") + # else: + # if PhactoriDbg(): + # myDebugPrint3("subrange is missing 'range' key; skipping\n") + # PrintOnProcessZero("subrange is missing 'range' key; skipping\n") + # if PhactoriDbg(): + # myDebugPrint3("parsed highlight subranges:\n" + \ + # str(self.mHighlightSubranges) + "\n", 100) + + #additional capability: use ratio-expressed subrange of + #range that would otherwise be used to increase concentration of + #dynamic range of color map in range of interest + if 'color legend subrange' in inJsn: + self.mUseColorSubrange = True + self.mColorSubrange = inJsn['color legend subrange'] + goodSubrange = True + if self.mColorSubrange[0] < 0.0: + goodSubrange = False + if self.mColorSubrange[1] > 1.0: + goodSubrange = False + if self.mColorSubrange[0] > \ + self.mColorSubrange[1]: + goodSubrange = False + if goodSubrange == False: + myDebugPrint3AndException( + "ParseOneRepresentationBlockC:\n" + "bad color legend subrange, must be 0.0 <= bottom <= top <= 1.0\n") + + #choose color map by name + self.mColorMapSettings.ParseColorMapSettings(inJsn) + + self.InterpretValuesAsCategories = \ + getParameterFromBlock(inJsn, "interpret values as categories", False) + if self.InterpretValuesAsCategories: + key1 = "category and color json file" + if key1 not in inJsn: + myDebugPrint3AndException( + "interpret values as categories is true but '" + key1 + \ + "' is missing\n") + self.CategoryAndColorJsonFile = \ + getParameterFromBlock(inJsn, key1, "dummy1.json") + elif 'color by scalar' in inJsn: + if inJsn['color by scalar'] == "ObjectId": + if PhactoriDbg(): + myDebugPrint3("variable is ObjectId, using categories\n") + self.InterpretValuesAsCategories = True + self.CategoryAndColorJsonFile = "ObjectIdBlockColors.json" + + showSurfacesFlag = getParameterFromBlock(inJsn, 'show surfaces', True) + showEdgesFlag = getParameterFromBlock(inJsn, 'show edges', False) + showPointsFlag = getParameterFromBlock(inJsn, 'show points', False) + + self.mOpacitySetting = getParameterFromBlock(inJsn, 'opacity', + self.mOpacitySetting) + + #doVolumeRenderingFlag = getParameterFromBlock(inJsn, 'volume rendering', True) + doVolumeRenderingFlag = getParameterFromBlock(inJsn, 'volume rendering', False) + self.mScalarOpacityUnitDistance = getParameterFromBlock( + inJsn, 'scalar opacity unit distance', -1.0) + + #self.mScalarOpacityUnitDistance = 0.01 + if PhactoriDbg(): + myDebugPrint3("doVolumeRenderingFlag: " + \ + str(doVolumeRenderingFlag) + "\n" + \ + "self.mScalarOpacityUnitDistance: " + \ + str(self.mScalarOpacityUnitDistance) + "\n") + + self.mPresetsImportFileName = getParameterFromBlock(inJsn, + 'color and opacity presets import file', None) + if self.mPresetsImportFileName != None: + retval = ImportPresets(self.mPresetsImportFileName) + if retval != True: + myDebugPrint3AndException( + "paraview.simple.ImportPresets failed with the file:\n" + \ + str(self.mPresetsImportFileName) + "\n") + self.mNameOfPresetToUse = getParameterFromBlock(inJsn, + 'color and opacity preset', None) + + showBoundingBoxFlag = getParameterFromBlock(inJsn, 'show bounding box', False) + + self.mMeshRenderControl = 'Surface' + if showBoundingBoxFlag: + self.mMeshRenderControl = 'Outline' + if showSurfacesFlag | showEdgesFlag | showPointsFlag: + if PhactoriDbg(): + myDebugPrint3(" warning: when show bounding box is true, \n" + \ + " show surfaces, show edges, and show points should be false\n") + elif showPointsFlag: + self.mMeshRenderControl = 'Points' + else: + if showSurfacesFlag: + if showEdgesFlag: + self.mMeshRenderControl = 'Surface With Edges' + else: + self.mMeshRenderControl = 'Surface' + else: + if showEdgesFlag: + self.mMeshRenderControl = 'Wireframe' + #self.mMeshRenderControl = 'Points' + else: + self.mMeshRenderControl = 'Outline' + + if doVolumeRenderingFlag: + if PhactoriDbg(100): + myDebugPrint3('doing volume rendering\n', 100) + self.mMeshRenderControl = 'Volume' + self.mDoingVolumeRendering = True + else: + self.mDoingVolumeRendering = False + + #color legend on/off + self.mColorLegendFlag = getParameterFromBlock(inJsn, + 'show color legend', self.mColorLegendFlag) + + self.mColorLegendPositionAndSize = \ + getParameterFromBlock(inJsn, 'color legend position', + self.mColorLegendPositionAndSize) + + if self.mColorLegendFlag == True: + if self.mColorVariableInfo.mVariableName == '': + self.mColorLegendFlag = False + + self.mColorRangeMinMaxTracker.PlotValMinMaxTrkCParseJson( + inJsn, "color legend ") + + self.mTimeAnnotationSettings.ParseAvsFromJson(inJsn) + + self.mDataCubeAxesFlag = getParameterFromBlock(inJsn, + 'show axes', self.mDataCubeAxesFlag) + + self.mDataCubeAxesInfo.DcaiParseParametersFromJson(inJsn) + + self.mOrientationAxesFlag = getParameterFromBlock(inJsn, + 'show orientation axes', self.mOrientationAxesFlag) + + if "image name addon" in inJsn: + self.mFilenameAddon = inJsn["image name addon"] + + self.mColorSettings.ParseColorSettingsFromJson(inJsn) + + if PhactoriDbg(100): + myDebugPrint3('ParseOneRepresentationBlockC returning\n', 100) + + def SetFromRestartInfo(self, inJson): + "given a map (json format), use the info in the map to set the\n representation state--this reads the info created in \n GetRestartInfo" + + if 'mColorRangeMinMaxTracker' not in inJson: + if PhactoriDbg(): + myDebugPrint3("PhactoriRepresentationBlock::" + \ + "SetFromRestartInfo: no mColorRangeMinMaxTracker, return\n") + return + + if PhactoriDbg(): + myDebugPrint3("Representation::SetFromRestartInfo\n" + + "currently set to do something\n" + + "before tracker:\n" + self.mColorRangeMinMaxTracker.SelfToStr()) + + jsonItem = inJson['mColorRangeMinMaxTracker'] + self.mColorRangeMinMaxTracker.SetFromRestartInfo(jsonItem) + + if PhactoriDbg(): + myDebugPrint3("after tracker:\n" + + self.mColorRangeMinMaxTracker.SelfToStr()) + + def GetRestartInfo(self): + "construct, in python map/json format, the information from this\n representation instance which contains the information\n which would be needed to restore the representation to the proper\n state after a simulation restart, particularly color range tracking\n information. Return the restart info map/json" + newRestartInfoJson = {} + newRestartInfoJson['mColorRangeMinMaxTracker'] = \ + self.mColorRangeMinMaxTracker.GetRestartInfo() + return newRestartInfoJson + + def CalculateDefaultScalarOpacityUnitDistance(self, inPhactoriOperation): + "given a phactori operation assumed to have an updated pipeline,\n calculate a default scalar opacity unit distance the same as paraview,\n with 0.05 * diagonal length of data bounding box" + bnds = GetGlobalDataBoundsParallel(inPhactoriOperation.mParaViewFilter) + xxlen = bnds[1] - bnds[0] + yylen = bnds[3] - bnds[2] + zzlen = bnds[5] - bnds[4] + self.mScalarOpacityUnitDistance = \ + 0.05 * math.sqrt(xxlen*xxlen + yylen*yylen + zzlen*zzlen) + + def SetUpForInterpretValuesAsCateories(self, variableLookUpTable): + if PhactoriDbg(): + myDebugPrint3("SetUpForInterpretValuesAsCateories entered\n") + if(self.Annotations == None): + jsonCategories = ReadAndMpiBroadcastJsonFile(self.CategoryAndColorJsonFile) + jsonCategories = convertJsonUnicodeToStrings(jsonCategories) + self.Annotations = jsonCategories[0]["Annotations"] + self.IndexedColors = jsonCategories[0]["IndexedColors"] + self.IndexedOpacities = [] + numCategories = len(self.Annotations) // 2 + for ii in range(0, numCategories): + self.IndexedOpacities.append(1.0) + if PhactoriDbg(): + myDebugPrint3("self.Annotations:\n" + str(self.Annotations) + "\n") + myDebugPrint3("self.IndexedColors:\n" + str(self.IndexedColors) + "\n") + myDebugPrint3("self.IndexedOpacities:\n" + str(self.IndexedOpacities) + "\n") + variableLookUpTable.InterpretValuesAsCategories = 1 + variableLookUpTable.AnnotationsInitialized = 1 + variableLookUpTable.Annotations = self.Annotations + variableLookUpTable.IndexedColors = self.IndexedColors + variableLookUpTable.IndexedOpacities = self.IndexedOpacities + if PhactoriDbg(): + myDebugPrint3("SetUpForInterpretValuesAsCateories returning\n") +#phactori_combine_to_single_python_file_subpiece_end_1 class PhactoriCriteriaThreshold: "\n maintains a threshold value TT, and tracks when a min/max/mean/sum/count\n of a variable crosses the threshold; also keeps track of how many frames\n it has been since the crossing and if this is within a frame count setting\n and also tracks how many times it has been triggered and no longer triggers\n after a max has been reached\n " @@ -25937,7 +25897,7 @@ def TestForTruth(self, ioPipeAndViewsState): DataMinMax = [0.0, 0.0, False] DataSumCnt = [0.0, 0] - FindMinMaxSumCntFromData(inputcsData, self.mVariableInfo, None, + FindMinMaxSumCntFromData(inputcsData, self.mVariableInfo, None, DataMinMax, DataSumCnt, None, None) #just return false if there is no min/max found @@ -26255,13 +26215,18 @@ def WriteOutImagesTest(datadescription, coprocessor): def CreateAllProducersFromAllInputDescriptions(datadescription, inCoprocessor, newRoot): global gPipeAndViewsState - newRoot.mProducer = inCoprocessor.CreateProducer( datadescription, "input" ) + inputGrid0Name = datadescription.GetInputDescriptionName(0) + #newRoot.mProducer = inCoprocessor.CreateProducer( datadescription, "input" ) + newRoot.mProducer = inCoprocessor.CreateProducer( datadescription, inputGrid0Name) newRoot.mIncomingDefaultOperation.mHasBeenConstructed = True + newRoot.mIncomingDefaultOperation.mName = inputGrid0Name + newRoot.mIncomingDefaultOperation.mOperationSpecifics = PhactoriOperationSpecifics() + newRoot.mOperationBlocks[inputGrid0Name] = newRoot.mIncomingDefaultOperation numInputGrids = datadescription.GetNumberOfInputDescriptions() if PhactoriDbg(): myDebugPrint3("numInputGrids: " + str(numInputGrids) + "\n"); for ii in range(0,numInputGrids): - print(str(ii) + ": " + str(datadescription.GetInputDescriptionName(ii)) + "\n") + myDebugPrint3(str(ii) + ": " + str(datadescription.GetInputDescriptionName(ii)) + "\n") defSrc = GetActiveSource(); for ii in range(1,numInputGrids): incomingInputName = datadescription.GetInputDescriptionName(ii) @@ -26272,8 +26237,8 @@ def CreateAllProducersFromAllInputDescriptions(datadescription, inCoprocessor, n newIncomingOperationBlock.mParaViewFilter = newTrivialProducerForGrid newIncomingOperationBlock.mHasBeenConstructed = True newIncomingOperationBlock.mOperationSpecifics = PhactoriOperationSpecifics() - newRoot.mIncomingOperationList.append(newIncomingOperationBlock) - newRoot.mIncomingGridProducerList.append(newTrivialProducerForGrid) + #newRoot.mIncomingOperationList.append(newIncomingOperationBlock) + #newRoot.mIncomingGridProducerList.append(newTrivialProducerForGrid) newRoot.mOperationBlocks[newIncomingOperationBlock.mName] = newIncomingOperationBlock SetActiveSource(defSrc); @@ -26290,16 +26255,16 @@ def InitializePerPipeRoot(datadescription, inCoprocessor): sa4 = sa[4] sa5 = sa[5] dbDummyFname = sa[6] - if(len(sa) > 7): + if(len(sa) > 7): defaultDirectory = sa[7] else: defaultDirectory = "" - if(len(sa) > 8): + if(len(sa) > 8): catalyst_script_extra_file = sa[8] else: catalyst_script_extra_file = "" - outputResultBaseId, remeshRestartTag = parseDbDummyFname(dbDummyFname) + outputResultBaseId, remeshRestartTag = parseDbDummyFname(dbDummyFname) if PhactoriDbg(): myDebugPrint3(" extra data list:\n") if PhactoriDbg(): @@ -26638,6 +26603,9 @@ def GetColorMapInfoFromColorLegendCollection(inColorMapSettings, inMin, inMax): #def UseDataSetupMapB(inDataSetupMapB): # PhactoriScript.UseDataSetupMapB_ps(inDataSetupMapB) +global gMyInitialUpdateFrequencies +gMyInitialUpdateFrequencies = {} + def CreateCoProcessor(): def _CreatePipeline(coprocessor, datadescription): class Pipeline: @@ -26656,7 +26624,7 @@ class Pipeline: #reuse same coprocesor instance (?), then have LocalWriteImages3 only do the images for a given output results bloxk:q #PhactoriScript.CreatePipeline(datadescription) - + return Pipeline() class CoProcessor(coprocessing.CoProcessor): @@ -26669,11 +26637,29 @@ def LocalWriteImages3(self, datadescription, rescale_lookuptable=False): def LocalExportOperationsData3(self, datadescription, rescale_lookuptable=False): ExportOperationsDataForCurrentPipeAndViewsState(datadescription) - + def SetInitialUpdateFrequences(self, datadescription): + global gMyInitialUpdateFrequencies + freqsChanged = False + numInputGrids = datadescription.GetNumberOfInputDescriptions() + for ii in range(0,numInputGrids): + oneGridName = datadescription.GetInputDescriptionName(ii) + if PhactoriDbg(): + myDebugPrint3("SetInitialUpdateFrequences " + str(ii) + " " + str(oneGridName) + "\n") + if oneGridName not in gMyInitialUpdateFrequencies: + gMyInitialUpdateFrequencies[oneGridName] = [1] + freqsChanged = True + if PhactoriDbg(): + if freqsChanged: + myDebugPrint3("gMyInitialUpdateFrequencies changed:\n") + else: + myDebugPrint3("gMyInitialUpdateFrequencies not changed:\n") + myDebugPrint3(str(gMyInitialUpdateFrequencies) + "\n") + if freqsChanged: + self.SetUpdateFrequencies(gMyInitialUpdateFrequencies) coprocessor = CoProcessor() - freqs = {'input': [1]} - coprocessor.SetUpdateFrequencies(freqs) + #freqs = {'input': [1]} + #coprocessor.SetUpdateFrequencies(freqs) return coprocessor @@ -26787,7 +26773,7 @@ def compareTearDeath(tList, dList): myDebugPrint2('compareTearDeath entered\n') myDebugPrint2('compareTearDeath returning\n') #end tear/death persistence; not used now but may be useful later - + # ---------------------- Data Selection method ---------------------- @@ -26803,19 +26789,24 @@ def compareTearDeath(tList, dList): def RequestDataDescription(datadescription): myDebugPrint3("PhactoriDriver.RequestDataDescription entered: " + str(gDoCoProcessingCount)+ "\n"); + if PhactoriDbg(): + numInputGrids = datadescription.GetNumberOfInputDescriptions() + for ii in range(0,numInputGrids): + oneGridName = datadescription.GetInputDescriptionName(ii) + myDebugPrint3("RequestDataDescription " + str(ii) + " " + str(oneGridName) + "\n") TestUserDataForBypassScript(datadescription) if GetBypassUserDataFlag() == False: fd = datadescription.GetUserData() - + if fd == None: myDebugPrint2("no user data, returning {}\n") returnViewMapC = {} return returnViewMapC global gCatchAllExceptionsAndPassUpFlag - if gCatchAllExceptionsAndPassUpFlag: + if gCatchAllExceptionsAndPassUpFlag: try: return RequestDataDescriptionSub(datadescription) except: @@ -26833,7 +26824,7 @@ def RequestDataDescriptionSub(datadescription): if GetBypassUserDataFlag() == False: fd = datadescription.GetUserData() - + if fd == None: myDebugPrint2("no user data, returning {}\n") returnViewMapC = {} @@ -26851,8 +26842,11 @@ def RequestDataDescriptionSub(datadescription): gSkipCountdown = gSkipCountdown - 1 return 0 coprocessor = CreateCoProcessor() + coprocessor.SetInitialUpdateFrequences(datadescription) coprocessor.EnableLiveVisualization(False) gFirstTimeInDoCoProcessing = False + else: + coprocessor.SetInitialUpdateFrequences(datadescription) #import pdb #pdb.set_trace() @@ -26885,17 +26879,23 @@ def RequestDataDescriptionSub(datadescription): def DoCoProcessing(datadescription): myDebugPrint3("PhactoriDriver.DoCoProcessing entered: " + str(gDoCoProcessingCount)+ "\n"); + if PhactoriDbg(): + numInputGrids = datadescription.GetNumberOfInputDescriptions() + for ii in range(0,numInputGrids): + oneGridName = datadescription.GetInputDescriptionName(ii) + myDebugPrint3("DoCoProcessing " + str(ii) + " " + str(oneGridName) + "\n") - fd = datadescription.GetUserData() + fd = datadescription.GetUserData() + if GetBypassUserDataFlag() == False: if fd == None: myDebugPrint2("no user data, returning {}\n") returnViewMapC = {} return returnViewMapC - + global gCatchAllExceptionsAndPassUpFlag - if gCatchAllExceptionsAndPassUpFlag: + if gCatchAllExceptionsAndPassUpFlag: try: DoCoProcessingSub(datadescription) except: @@ -26915,13 +26915,13 @@ def DoCoProcessingSub(datadescription): fd = datadescription.GetUserData() - + if GetBypassUserDataFlag() == False: if fd == None: myDebugPrint2("no user data, returning {}\n") returnViewMapC = {} return returnViewMapC - + global coprocessor global gFirstTimeInDoCoProcessing global gSkipCountdown @@ -26932,8 +26932,11 @@ def DoCoProcessingSub(datadescription): if gSkipCountdown > 0: return coprocessor = CreateCoProcessor() + coprocessor.SetInitialUpdateFrequences(datadescription) coprocessor.EnableLiveVisualization(False) gFirstTimeInDoCoProcessing = False + else: + coprocessor.SetInitialUpdateFrequences(datadescription) #import pdb #pdb.set_trace() @@ -26991,7 +26994,7 @@ def DoCoProcessingSub(datadescription): coprocessor.WriteData(datadescription) coprocessor.LocalExportOperationsData3(datadescription) - + # Write image capture (Last arg: rescale lookup table), if appropriate. coprocessor.LocalWriteImages3(datadescription, rescale_lookuptable=False) @@ -27026,3 +27029,4 @@ def DoCoProcessingSub(datadescription): # Live Visualization, if enabled. coprocessor.DoLiveVisualization(datadescription, "localhost", 22222) + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/PhactoriDriver_modular.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/PhactoriDriver_modular.py index 2f5761fdc8..73dd77523a 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/PhactoriDriver_modular.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/PhactoriDriver_modular.py @@ -84,6 +84,9 @@ #def UseDataSetupMapB(inDataSetupMapB): # PhactoriScript.UseDataSetupMapB_ps(inDataSetupMapB) +global gMyInitialUpdateFrequencies +gMyInitialUpdateFrequencies = {} + def CreateCoProcessor(): def _CreatePipeline(coprocessor, datadescription): class Pipeline: @@ -102,7 +105,7 @@ class Pipeline: #reuse same coprocesor instance (?), then have LocalWriteImages3 only do the images for a given output results bloxk:q #PhactoriScript.CreatePipeline(datadescription) - + return Pipeline() class CoProcessor(coprocessing.CoProcessor): @@ -115,11 +118,29 @@ def LocalWriteImages3(self, datadescription, rescale_lookuptable=False): def LocalExportOperationsData3(self, datadescription, rescale_lookuptable=False): ExportOperationsDataForCurrentPipeAndViewsState(datadescription) - + def SetInitialUpdateFrequences(self, datadescription): + global gMyInitialUpdateFrequencies + freqsChanged = False + numInputGrids = datadescription.GetNumberOfInputDescriptions() + for ii in range(0,numInputGrids): + oneGridName = datadescription.GetInputDescriptionName(ii) + if PhactoriDbg(): + myDebugPrint3("SetInitialUpdateFrequences " + str(ii) + " " + str(oneGridName) + "\n") + if oneGridName not in gMyInitialUpdateFrequencies: + gMyInitialUpdateFrequencies[oneGridName] = [1] + freqsChanged = True + if PhactoriDbg(): + if freqsChanged: + myDebugPrint3("gMyInitialUpdateFrequencies changed:\n") + else: + myDebugPrint3("gMyInitialUpdateFrequencies not changed:\n") + myDebugPrint3(str(gMyInitialUpdateFrequencies) + "\n") + if freqsChanged: + self.SetUpdateFrequencies(gMyInitialUpdateFrequencies) coprocessor = CoProcessor() - freqs = {'input': [1]} - coprocessor.SetUpdateFrequencies(freqs) + #freqs = {'input': [1]} + #coprocessor.SetUpdateFrequencies(freqs) return coprocessor @@ -233,7 +254,7 @@ def compareTearDeath(tList, dList): myDebugPrint2('compareTearDeath entered\n') myDebugPrint2('compareTearDeath returning\n') #end tear/death persistence; not used now but may be useful later - + # ---------------------- Data Selection method ---------------------- @@ -249,19 +270,24 @@ def compareTearDeath(tList, dList): def RequestDataDescription(datadescription): myDebugPrint3("PhactoriDriver.RequestDataDescription entered: " + str(gDoCoProcessingCount)+ "\n"); + if PhactoriDbg(): + numInputGrids = datadescription.GetNumberOfInputDescriptions() + for ii in range(0,numInputGrids): + oneGridName = datadescription.GetInputDescriptionName(ii) + myDebugPrint3("RequestDataDescription " + str(ii) + " " + str(oneGridName) + "\n") TestUserDataForBypassScript(datadescription) if GetBypassUserDataFlag() == False: fd = datadescription.GetUserData() - + if fd == None: myDebugPrint2("no user data, returning {}\n") returnViewMapC = {} return returnViewMapC global gCatchAllExceptionsAndPassUpFlag - if gCatchAllExceptionsAndPassUpFlag: + if gCatchAllExceptionsAndPassUpFlag: try: return RequestDataDescriptionSub(datadescription) except: @@ -279,7 +305,7 @@ def RequestDataDescriptionSub(datadescription): if GetBypassUserDataFlag() == False: fd = datadescription.GetUserData() - + if fd == None: myDebugPrint2("no user data, returning {}\n") returnViewMapC = {} @@ -297,8 +323,11 @@ def RequestDataDescriptionSub(datadescription): gSkipCountdown = gSkipCountdown - 1 return 0 coprocessor = CreateCoProcessor() + coprocessor.SetInitialUpdateFrequences(datadescription) coprocessor.EnableLiveVisualization(False) gFirstTimeInDoCoProcessing = False + else: + coprocessor.SetInitialUpdateFrequences(datadescription) #import pdb #pdb.set_trace() @@ -331,17 +360,23 @@ def RequestDataDescriptionSub(datadescription): def DoCoProcessing(datadescription): myDebugPrint3("PhactoriDriver.DoCoProcessing entered: " + str(gDoCoProcessingCount)+ "\n"); + if PhactoriDbg(): + numInputGrids = datadescription.GetNumberOfInputDescriptions() + for ii in range(0,numInputGrids): + oneGridName = datadescription.GetInputDescriptionName(ii) + myDebugPrint3("DoCoProcessing " + str(ii) + " " + str(oneGridName) + "\n") - fd = datadescription.GetUserData() + fd = datadescription.GetUserData() + if GetBypassUserDataFlag() == False: if fd == None: myDebugPrint2("no user data, returning {}\n") returnViewMapC = {} return returnViewMapC - + global gCatchAllExceptionsAndPassUpFlag - if gCatchAllExceptionsAndPassUpFlag: + if gCatchAllExceptionsAndPassUpFlag: try: DoCoProcessingSub(datadescription) except: @@ -361,13 +396,13 @@ def DoCoProcessingSub(datadescription): fd = datadescription.GetUserData() - + if GetBypassUserDataFlag() == False: if fd == None: myDebugPrint2("no user data, returning {}\n") returnViewMapC = {} return returnViewMapC - + global coprocessor global gFirstTimeInDoCoProcessing global gSkipCountdown @@ -378,8 +413,11 @@ def DoCoProcessingSub(datadescription): if gSkipCountdown > 0: return coprocessor = CreateCoProcessor() + coprocessor.SetInitialUpdateFrequences(datadescription) coprocessor.EnableLiveVisualization(False) gFirstTimeInDoCoProcessing = False + else: + coprocessor.SetInitialUpdateFrequences(datadescription) #import pdb #pdb.set_trace() @@ -437,7 +475,7 @@ def DoCoProcessingSub(datadescription): coprocessor.WriteData(datadescription) coprocessor.LocalExportOperationsData3(datadescription) - + # Write image capture (Last arg: rescale lookup table), if appropriate. coprocessor.LocalWriteImages3(datadescription, rescale_lookuptable=False) @@ -472,3 +510,4 @@ def DoCoProcessingSub(datadescription): # Live Visualization, if enabled. coprocessor.DoLiveVisualization(datadescription, "localhost", 22222) + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/RunPhactoriUnitTests.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/RunPhactoriUnitTests.py index 3cd2ce1a1d..7063cf4d56 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/RunPhactoriUnitTests.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/RunPhactoriUnitTests.py @@ -6,3 +6,4 @@ cc = Cone() rr = Show() unittest.main() + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/phactori.py b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/phactori.py index e7934d9cb0..21c97885f0 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/phactori.py +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/phactori/phactori.py @@ -55,6 +55,10 @@ def setgUseHardwiredJsonScriptFile(inScriptFileName): global gPipeAndViewsState gPipeAndViewsState = None +def SetgPipeAndViewStateForTesting(testPipe): + global gPipeAndViewsState + gPipeAndViewsState = testPipe + def GetFrameTagCounter(): global gPipeAndViewsState if gPipeAndViewsState == None: @@ -73,8 +77,9 @@ def GetFrameTagCounter(): #gParaViewCatalystVersionFlag = 40300 #gParaViewCatalystVersionFlag = 40100 #gParaViewCatalystVersionFlag = 50400 -gParaViewCatalystVersionFlag = 50502 +#gParaViewCatalystVersionFlag = 50502 #gParaViewCatalystVersionFlag = 51000 +gParaViewCatalystVersionFlag = 51100 #attempt to use paraview.simple.GetParaViewVersion() to set version try: @@ -109,6 +114,9 @@ def GetFrameTagCounter(): global TestUserDataForBypassScriptCompletedFlag TestUserDataForBypassScriptCompletedFlag = False +global gTemporaryGlobalImageTextColor +gTemporaryGlobalImageTextColor = [1.0, 1.0, 1.0] + global bccolli_controls global gCameraTestMode @@ -128,6 +136,8 @@ def SetCameraTestMode(onOffSetting): def HandleJsonScriptLoadProcessZero(catalyst_script_extra_file): if PhactoriDbg(): myDebugPrint3("HandleJsonScriptLoadProcessZero entered\n") + myDebugPrint3("catalyst_script_extra_file: " + \ + str(catalyst_script_extra_file) + "\n") try: with open(catalyst_script_extra_file) as data_file: if PhactoriDbg(100): @@ -638,7 +648,7 @@ def TestUserDataForBypassScript(datadescription): myDebugPrint3("no user data, no catalyst_script_extra_file (2)\n") return - if(sa.GetNumberOfValues() > 8): + if(sa.GetNumberOfValues() > 8): catalyst_script_extra_file = sa.GetValue(8) if PhactoriDbg(100): myDebugPrint3(" catalyst_script_extra_file: ->" + \ @@ -858,7 +868,7 @@ def ParseSettingsFromJson(self, inJsn): halfH - betweenEyeY, -eyeToScreenDistance ] - + def GetScreenBottomLeft(self, inLeftEyeFlag): if inLeftEyeFlag: return self.mLeftEyeScreenBottomLeft @@ -1347,9 +1357,10 @@ def GetEyePosition(self, inLeftEyeFlag): #----- global gDefaultTimeFormatString -gDefaultTimeFormatString = "Time: %.10e" #gDefaultTimeFormatString = "Time: %.6e" #gDefaultTimeFormatString = "Time: %f" +#gDefaultTimeFormatString = "Time: %.10e" +gDefaultTimeFormatString = "Time: {time:.6f}" global gDefaultImageSizeX gDefaultImageSizeX = 1920 @@ -1740,7 +1751,7 @@ def DebugPrintCellAndPointArrayInfo(label, pvFilter, priority): DebugPrintVtkDataArraysInfo("PointData:\n", theData, priority) theData = pvFilter.CellData DebugPrintVtkDataArraysInfo("CellData:\n", theData, priority) - + #def SetCpViewsAndCpWriters(inCpViews, inCpWriters): # global localCpViews # global localCpWriters @@ -1788,7 +1799,7 @@ class PhactoriRenderViewInfo: def __init__(self): self.RenderView1 = None self.DataRepresentation1 = None - + #class PhactoriRenderViewInfo: # RenderView1 = None # DataRepresentation1 = None @@ -1935,12 +1946,12 @@ def SafeColorBy(inDataRepresentation, ptOrNodeAndVarname): if PhactoriDbg(100): myDebugPrint3("SafeColorBy returning (valid cell data)\n") return - + def SetDataRepresentationToDefault(inDataRepresentation): #a3_vel__PiecewiseFunction = CreatePiecewiseFunction( Points=[0.0, 0.0, 0.5, 0.0, 1.0, 1.0, 0.5, 0.0] ) - + inDataRepresentation.SelectionPointLabelColor = [0.5, 0.5, 0.5] inDataRepresentation.SelectionPointFieldDataArrayName = 'displ' inDataRepresentation.SuppressLOD = 0 @@ -2260,17 +2271,14 @@ def AddRenderView(inPhactoriImagesetInfo, inColorSettings, else: myDebugPrint3AndException("bad m_PlotType") else: - #UpdatePipelineWithCurrentTimeArgument(GetActiveSource()) SetParaViewViewToCurrentTime(RenderView1) - #myDebugPrint3(str(GetActiveView().ListProperties()) + "\n") - #myDebugPrint3("ViewTime: " + str(GetActiveView().ViewTime) + "\n") - DataRepresentation1 = Show() + DataRepresentation1 = Show(GetActiveSource(), RenderView1, 'UnstructuredGridRepresentation') if PhactoriDbg(): myDebugPrint3("representation made for 3d view:\n" + str(DataRepresentation1) + "\n") inPhactoriImagesetInfo.mPvDataRepresentation2 = DataRepresentation1 inPhactoriImagesetInfo.mVisiblePvDataReps[0] = DataRepresentation1 else: - DataRepresentation1 = inPhactoriImagesetInfo.mPvDataRepresentation2 + DataRepresentation1 = inPhactoriImagesetInfo.mPvDataRepresentation2 if PhactoriDbg(): myDebugPrint3("new DataRepresentation1: " + str(DataRepresentation1) + "\n") @@ -2293,7 +2301,7 @@ def AddRenderView(inPhactoriImagesetInfo, inColorSettings, if inPhactoriImagesetInfo.mVisiblePvDataReps[ii] == None: SetActiveSource(inPhactoriImagesetInfo.mVisibleOps[ii].\ mParaViewFilter) - newPvDataRep = Show() + newPvDataRep = Show(GetActiveSource(), RenderView1, 'UnstructuredGridRepresentation') SetDataRepresentationToDefault(newPvDataRep) inPhactoriImagesetInfo.mVisiblePvDataReps[ii] = newPvDataRep if PhactoriDbg(100): @@ -2413,9 +2421,9 @@ def CheckForParallelVector(vec1, vec2): if PhactoriDbg(): myDebugPrint3("same ratio between vectors, parallel\n") return True - + #given a bounds in the form [xmin, xmax, ymin, ymax, zmin, zmax], return the -# maximum dimension out of all those (max of xmax-xmin, ymax-ymin, and +# maximum dimension out of all those (max of xmax-xmin, ymax-ymin, and # zmax-zmin) def GetMaximumDimensionFromBounds(inBounds): maxDim = inBounds[1] - inBounds[0] @@ -2890,7 +2898,7 @@ def GetXyzForNodeOrElementParallelRecurse1(inInputCsData, unstructured grids to do the real work of checking for the id and setting outXyz """ - + #myDebugPrint3('GetXyzForNodeOrElementParallelRecurse1 entered\n', 100) icsdClassname = inInputCsData.GetClassName() @@ -3035,7 +3043,7 @@ def CalcRelativeCameraDistance2_AA(inFocalPoint, inNormCameraDir, where we want to place the camera (the opposite of the look direction)""" #angle between camera-to-focal point vector and camera-to-testpoint vector - #is equal to half the camera fOV. Call this angle AA. + #is equal to half the camera fOV. Call this angle AA. #The side opposite this angle has length equal to the distance between #the focal point and the test point. Call this distance aa. We also #know the angle between the focal point-to-camera vector and the focal @@ -3131,7 +3139,7 @@ def CalcRelativeCameraDistance2_BB(inFocalPoint, inNormCameraDir, myDebugPrint3("pointH: " + str(pointH) + "\n"); dd1 = CalcRelativeCameraDistance2_AA(inFocalPoint, inNormCameraDir, - pointH, inFovH) + pointH, inFovH) if PhactoriDbg(100): myDebugPrint3("dd1: " + str(dd1) + "\n"); dd2 = CalcRelativeCameraDistance2_AA(inFocalPoint, inNormCameraDir, @@ -3216,7 +3224,7 @@ def CalcRelativeCameraDistance2(inFocalPoint, inLookDirection, inUpVector, aspectRatio = float(inXyPixelSize[0]) / float(inXyPixelSize[1]) else: aspectRatio = float(pixelSizeWithBorder[0]) / float(pixelSizeWithBorder[1]) - + if PhactoriDbg(100): myDebugPrint3("bordered aspectRatio: " + str(aspectRatio) + "\n"); @@ -3340,7 +3348,7 @@ def SetParaViewRepresentationCameraParams(inXParaViewRenderView, inCameraC, if PhactoriDbg(): myDebugPrint3(' lookDirection ' + str(lookDirection) + '\n') - myViewBounds = viewBoundsIo[0] + myViewBounds = viewBoundsIo[0] if PhactoriDbg(): myDebugPrint3(' focalPoint ' + str(focalPoint) + '\n') @@ -3920,11 +3928,22 @@ def MakeFiltersFromViewMapOperationsC(ioPipeAndViewsState, inOperationBlocksJson 'cylinderclip', PhactoriCylinderClipOperation, operationParams) - elif operationParams['type'] == 'element data to node data': + elif (operationParams['type'] == 'element data to node data') or \ + (operationParams['type'] == 'elementdatatonodedata') or \ + (operationParams['type'] == 'cell data to point data') or \ + (operationParams['type'] == 'celldatatopointdata'): ParseOneFilterTypeFromViewMapOperation(newOperationBlock, 'element data to node data', PhactoriCellDataToPointDataOperation, operationParams) + elif (operationParams['type'] == 'node data to element data') or \ + (operationParams['type'] == 'nodedatatoelementdata') or \ + (operationParams['type'] == 'point data to cell data') or \ + (operationParams['type'] == 'pointdatatocelldata'): + ParseOneFilterTypeFromViewMapOperation(newOperationBlock, + 'node data to element data', + PhactoriPointDataToCellDataOperation, + operationParams) elif operationParams['type'] == 'extractcomponent': ParseOneFilterTypeFromViewMapOperation(newOperationBlock, 'extractcomponent', @@ -4089,11 +4108,11 @@ def MakeFiltersFromViewMapOperationsC(ioPipeAndViewsState, inOperationBlocksJson keepConstructing = False #at the beginning of the loop, we haven't seen any unconstructed operations for operationName, operationBlock in ioPipeAndViewsState.mOperationBlocks.items(): if operationBlock.mHasBeenConstructed == False: - #this one still needs constructing, and we'll have to loop again to + #this one still needs constructing, and we'll have to loop again to #make sure all are constructed keepConstructing = True - #determine whether or not we can construct this operation yet, or if + #determine whether or not we can construct this operation yet, or if #we need to wait for something else to be constructed canBeConstructedNow = True inputOperationNames = operationBlock.GetListOfInputOperationNames() @@ -4102,7 +4121,7 @@ def MakeFiltersFromViewMapOperationsC(ioPipeAndViewsState, inOperationBlocksJson if inputBlock.mHasBeenConstructed == False: canBeConstructedNow = False break - + if PhactoriDbg(100): myDebugPrint3("trying: " + str(operationName) + "\n" + \ "depends on: " + str(inputOperationNames) + "\n" + \ @@ -4113,7 +4132,7 @@ def MakeFiltersFromViewMapOperationsC(ioPipeAndViewsState, inOperationBlocksJson operationBlock.mHasBeenConstructed = True if PhactoriDbg(100): myDebugPrint3("done constructing all operation blocks\n",100) - + #helper method: given a block A which potentially contains a key B with @@ -4176,7 +4195,7 @@ def CreateParaViewRepresentationAndViewFromInfoC(inImageset, inLookDirection, in raise Exception(errStr) meshRenderControl = theRepresentation.mMeshRenderControl - + showColorLegend = theRepresentation.mColorLegendFlag colorLegendPositionAndSize = theRepresentation.mColorLegendPositionAndSize showDataCubeAxes = theRepresentation.mDataCubeAxesFlag @@ -4206,7 +4225,7 @@ def CreateParaViewRepresentationAndViewFromInfoC(inImageset, inLookDirection, in numArrays = pvPvGeomFilterFromOp.PointData.GetNumberOfArrays() for ii in range (0, numArrays): myDebugPrint3(" " + str(ii) + ": " + pvPvGeomFilterFromOp.PointData.GetArray(ii).GetName() + "\n") - + if PhactoriDbg(): myDebugPrint3(" operation cell data arrays:\n") numArrays = pvPvGeomFilterFromOp.CellData.GetNumberOfArrays() @@ -4290,8 +4309,10 @@ def CreateParaViewRepresentationAndViewFromInfoC(inImageset, inLookDirection, in if gPipeAndViewsState.mTimeAnnotationPv == None: gPipeAndViewsState.mTimeAnnotationPv = \ PhactoriAnnotationPv(timeAnnStngs) + global gTemporaryGlobalImageTextColor gPipeAndViewsState.mTimeAnnotationPv.CreateParaViewStuff( - inImageset.mRepresentation.mColorSettings.mTimeAnnotationColor, + #inImageset.mRepresentation.mColorSettings.mTimeAnnotationColor, + gTemporaryGlobalImageTextColor, inImageset) #if newParaViewRenderInfoC.mTimeAnnotationPv == None: @@ -4400,7 +4421,7 @@ def ParseOneCameraBlockC(ioCameraBlock, ioCameraBlockJson, inPipeAndViewsState): ioCameraBlock.mLookDirectionSpecifiedFlag = True else: ioCameraBlock.mLookDirectionSpecifiedFlag = False - + #get text to add to each image created with this camera, if any if "image name addon" in ioCameraBlockJson: ioCameraBlock.mFilenameAddon = ioCameraBlockJson["image name addon"] @@ -4450,7 +4471,9 @@ def ParseOneCameraBlockC(ioCameraBlock, ioCameraBlockJson, inPipeAndViewsState): #parse locking setup ioCameraBlock.LockAfterNCalls = getParameterFromBlock(ioCameraBlockJson, 'lock camera call count', -1) - + if "lockingcamera" in ioCameraBlock.mName: + ioCameraBlock.LockAfterNCalls = 1 + def localGet1or0(inJsn, inKey, inDefault): value = getParameterFromBlock(inJsn, inKey, inDefault) @@ -4459,241 +4482,8 @@ def localGet1or0(inJsn, inKey, inDefault): else: return 0 - def ParseOneRepresentationBlockC(ioRepresentationBlock, inRepresentationBlockJson, inPipeAndViewsState): - """given a python dict (presumably from json) description of a representation block, parse all the - representation parameters out of the block""" - - if PhactoriDbg(100): - myDebugPrint3('ParseOneRepresentationBlockC entered\n', 100) - - inJsn = inRepresentationBlockJson - - #hack test for colors start - #inJsn['surface color'] = [1.0, 0.0, 0.0] - #inJsn['background color'] = [0.0, 0.0, 0.0] - #inJsn['edge color'] = [0.0, 1.0, 0.0] - ##inJsn['axes color'] = [0.0, 1.0, 1.0] - #inJsn['text color'] = [1.0, 1.0, 0.0] - #hack test for colors end - - #myDebugPrint3(' json: ' + str(inJsn) + '\n') - - if 'point size' in inJsn: - ioRepresentationBlock.mPointSize = inJsn['point size'] - - #color by variable scalar/vector magnitude/vector component/tensor component - ioRepresentationBlock.mColorVariableInfo.\ - ParseVariableNameAndVectorOrTensorComponent(inJsn, 'color by ') - - if ioRepresentationBlock.mColorVariableInfo.mVariableName != '': - ioRepresentationBlock.mColorByBlockFlag = False - ioRepresentationBlock.mColorBySolidColorFlag = False - elif 'color by blockid' in inJsn: - ioRepresentationBlock.mColorByBlockFlag = True - ioRepresentationBlock.mColorByBlockExplicitlySet = True - ioRepresentationBlock.mColorBySolidColorFlag = False - elif 'color by solid color' in inJsn: - ioRepresentationBlock.mColorBySolidColorFlag = True - ioRepresentationBlock.mColorByBlockFlag = False - ioRepresentationBlock.mSolidColor = inJsn['color by solid color'] - - #color map range control - if 'color legend range' in inJsn: - ioRepresentationBlock.mFixedColorRange = inJsn['color legend range'] - ioRepresentationBlock.mUseFixedColorRange = True - else: - ioRepresentationBlock.mUseFixedColorRange = False - - #highlight subranges with solid colors - if 'highlight subrange 1' in inJsn: - highlightSubrangeIndex = 1 - while True: - oneSubrangeKey = 'highlight subrange ' + str(highlightSubrangeIndex) - if oneSubrangeKey in inJsn: - subrangeArgs = inJsn[oneSubrangeKey] - highlightSubrangeIndex += 1 - if len(subrangeArgs) != 5: - if PhactoriDbg(): - myDebugPrint3("highlight subrange needs 5 values\n"); - PrintOnProcessZero("highlight subrange needs 5 values, skipping " + \ - oneSubrangeKey + "\n"); - continue - srmin = float(subrangeArgs[0]) - srmax = float(subrangeArgs[1]) - if srmin > srmax: - if PhactoriDbg(): - myDebugPrint3("subrange highlight min >= max: " + \ - str(srmin) + ", " + str(srmax) + "\nskipping " + \ - oneSubrangeKey + "\n", 100) - PrintOnProcessZero("subrange highlight min >= max: " + \ - str(srmin) + ", " + str(srmax) + "\nskipping " + \ - oneSubrangeKey + "\n") - continue - srColor = [float(subrangeArgs[2]), float(subrangeArgs[3]), - float(subrangeArgs[4])] - if (srColor[0] < 0.0) or (srColor[0] > 1.0) or \ - (srColor[1] < 0.0) or (srColor[1] > 1.0) or \ - (srColor[2] < 0.0) or (srColor[2] > 1.0): - srColor = [1.0, 1.0, 0.0] - if PhactoriDbg(): - myDebugPrint3(oneSubrangeKey + ": bad color " - "(component not 0.0-1.0), using rgb 1.0, 1.0, 0.0\n", 100) - PrintOnProcessZero(oneSubrangeKey + ": bad color " - "(component not 0.0-1.0), using rgb 1.0, 1.0, 0.0\n") - ioRepresentationBlock.mHighlightSubranges.append( - [srmin, srmax, srColor]) - ioRepresentationBlock.mUseHighlightSubranges = True - else: - break - if PhactoriDbg(): - myDebugPrint3("parsed highlight subranges:\n" + \ - str(ioRepresentationBlock.mHighlightSubranges) + "\n", 100) - - #if 'highlight subranges' in inJsn: - # ioRepresentationBlock.mUseHighlightSubranges = True - # sbrngsJsn = inJsn['highlight subranges'] - # for oneSubrange in sbrngsJsn: - # if 'range' in oneSubrange: - # srmin = oneSubrange['range'][0] - # srmax = oneSubrange['range'][1] - # if srmin < srmax: - # if 'color' in oneSubrange: - # srColor = oneSubrange['color'] - # else: - # srColor = [1.0, 1.0, 0.0] - # ioRepresentationBlock.mHighlightSubranges.append( - # [srmin, srmax, srColor]) - # else: - # if PhactoriDbg(): - # myDebugPrint3("highlight min >= max: " + \ - # str(srmin) + ", " + str(srmax) + "\nskipping subrange\n", 100) - # PrintOnProcessZero("highlight min >= max: " + \ - # str(srmin) + ", " + str(srmax) + "\nskipping subrange\n") - # else: - # if PhactoriDbg(): - # myDebugPrint3("subrange is missing 'range' key; skipping\n") - # PrintOnProcessZero("subrange is missing 'range' key; skipping\n") - # if PhactoriDbg(): - # myDebugPrint3("parsed highlight subranges:\n" + \ - # str(ioRepresentationBlock.mHighlightSubranges) + "\n", 100) - - #additional capability: use ratio-expressed subrange of - #range that would otherwise be used to increase concentration of - #dynamic range of color map in range of interest - if 'color legend subrange' in inJsn: - ioRepresentationBlock.mUseColorSubrange = True - ioRepresentationBlock.mColorSubrange = inJsn['color legend subrange'] - goodSubrange = True - if ioRepresentationBlock.mColorSubrange[0] < 0.0: - goodSubrange = False - if ioRepresentationBlock.mColorSubrange[1] > 1.0: - goodSubrange = False - if ioRepresentationBlock.mColorSubrange[0] > \ - ioRepresentationBlock.mColorSubrange[1]: - goodSubrange = False - if goodSubrange == False: - myDebugPrint3AndException( - "ParseOneRepresentationBlockC:\n" - "bad color legend subrange, must be 0.0 <= bottom <= top <= 1.0\n") - - #choose color map by name - ioRepresentationBlock.mColorMapSettings.ParseColorMapSettings(inJsn) - - showSurfacesFlag = getParameterFromBlock(inJsn, 'show surfaces', True) - showEdgesFlag = getParameterFromBlock(inJsn, 'show edges', False) - showPointsFlag = getParameterFromBlock(inJsn, 'show points', False) - - ioRepresentationBlock.mOpacitySetting = getParameterFromBlock(inJsn, 'opacity', - ioRepresentationBlock.mOpacitySetting) - - #doVolumeRenderingFlag = getParameterFromBlock(inJsn, 'volume rendering', True) - doVolumeRenderingFlag = getParameterFromBlock(inJsn, 'volume rendering', False) - ioRepresentationBlock.mScalarOpacityUnitDistance = getParameterFromBlock( - inJsn, 'scalar opacity unit distance', -1.0) - - #ioRepresentationBlock.mScalarOpacityUnitDistance = 0.01 - if PhactoriDbg(): - myDebugPrint3("doVolumeRenderingFlag: " + \ - str(doVolumeRenderingFlag) + "\n" + \ - "ioRepresentationBlock.mScalarOpacityUnitDistance: " + \ - str(ioRepresentationBlock.mScalarOpacityUnitDistance) + "\n") - - ioRepresentationBlock.mPresetsImportFileName = getParameterFromBlock(inJsn, - 'color and opacity presets import file', None) - if ioRepresentationBlock.mPresetsImportFileName != None: - retval = ImportPresets(ioRepresentationBlock.mPresetsImportFileName) - if retval != True: - myDebugPrint3AndException( - "paraview.simple.ImportPresets failed with the file:\n" + \ - str(ioRepresentationBlock.mPresetsImportFileName) + "\n") - ioRepresentationBlock.mNameOfPresetToUse = getParameterFromBlock(inJsn, - 'color and opacity preset', None) - - showBoundingBoxFlag = getParameterFromBlock(inJsn, 'show bounding box', False) - - ioRepresentationBlock.mMeshRenderControl = 'Surface' - if showBoundingBoxFlag: - ioRepresentationBlock.mMeshRenderControl = 'Outline' - if showSurfacesFlag | showEdgesFlag | showPointsFlag: - if PhactoriDbg(): - myDebugPrint3(" warning: when show bounding box is true, \n" + \ - " show surfaces, show edges, and show points should be false\n") - elif showPointsFlag: - ioRepresentationBlock.mMeshRenderControl = 'Points' - else: - if showSurfacesFlag: - if showEdgesFlag: - ioRepresentationBlock.mMeshRenderControl = 'Surface With Edges' - else: - ioRepresentationBlock.mMeshRenderControl = 'Surface' - else: - if showEdgesFlag: - ioRepresentationBlock.mMeshRenderControl = 'Wireframe' - #ioRepresentationBlock.mMeshRenderControl = 'Points' - else: - ioRepresentationBlock.mMeshRenderControl = 'Outline' - - if doVolumeRenderingFlag: - if PhactoriDbg(100): - myDebugPrint3('doing volume rendering\n', 100) - ioRepresentationBlock.mMeshRenderControl = 'Volume' - ioRepresentationBlock.mDoingVolumeRendering = True - else: - ioRepresentationBlock.mDoingVolumeRendering = False - - #color legend on/off - ioRepresentationBlock.mColorLegendFlag = getParameterFromBlock(inJsn, - 'show color legend', ioRepresentationBlock.mColorLegendFlag) - - ioRepresentationBlock.mColorLegendPositionAndSize = \ - getParameterFromBlock(inJsn, 'color legend position', - ioRepresentationBlock.mColorLegendPositionAndSize) - - if ioRepresentationBlock.mColorLegendFlag == True: - if ioRepresentationBlock.mColorVariableInfo.mVariableName == '': - ioRepresentationBlock.mColorLegendFlag = False - - ioRepresentationBlock.mColorRangeMinMaxTracker.PlotValMinMaxTrkCParseJson( - inJsn, "color legend ") - - ioRepresentationBlock.mTimeAnnotationSettings.ParseAvsFromJson(inJsn) - - ioRepresentationBlock.mDataCubeAxesFlag = getParameterFromBlock(inJsn, - 'show axes', ioRepresentationBlock.mDataCubeAxesFlag) - - ioRepresentationBlock.mDataCubeAxesInfo.DcaiParseParametersFromJson(inJsn) - - ioRepresentationBlock.mOrientationAxesFlag = getParameterFromBlock(inJsn, - 'show orientation axes', ioRepresentationBlock.mOrientationAxesFlag) - - if "image name addon" in inJsn: - ioRepresentationBlock.mFilenameAddon = inJsn["image name addon"] - - ioRepresentationBlock.mColorSettings.ParseColorSettingsFromJson(inJsn) - - if PhactoriDbg(100): - myDebugPrint3('ParseOneRepresentationBlockC returning\n', 100) + ioRepresentationBlock.ParseSettingsFromJson(inRepresentationBlockJson) global gDefaultImageBasename gDefaultImageBasename = "csierra.view." @@ -4738,7 +4528,12 @@ def breakSpecialVarNameIntoBaseAndComponent(inSpecialVarName, raise Exception(errStr) #baseVarName = inSpecialVarName[0:(varNameLen-2)] + GetSeparatorString() - if inAddSeparatorFlag: + localinAddSeparatorFlag = inAddSeparatorFlag + #for Sierra, as of 2022Aug09, we need inAddSeparatorFlag to default to + #False but right here we need to strip the separator from the variable + #base name + #localinAddSeparatorFlag = True + if localinAddSeparatorFlag: lenToGrab = varNameLen - 1 - len(GetSeparatorString()) else: lenToGrab = varNameLen - 1 @@ -4861,6 +4656,17 @@ def ParseOneImagesetBlockC(ioImagesetBlock, ioImagesetBlockJson, if ioImagesetBlock.mName == 'PhactoriGoInteractive': ioPipeAndViewsState.mInteractionEnabled = True + #we need to get text color for time annotation and text annotation + #handled properly: for now we allow a "text color" setting in any + #imageset block to set the global text color + if 'text color' in ioImagesetBlockJson: + global gTemporaryGlobalImageTextColor + gTemporaryGlobalImageTextColor = getParameterFromBlock(ioImagesetBlockJson, + 'text color', [1.0, 1.0, 1.0]) + + ioImagesetBlock.mBackground = getParameterFromBlock(ioImagesetBlockJson, + 'background color', ioImagesetBlock.mBackground) + #parse on/off criteria if 'onoff criteria' in ioImagesetBlockJson: inCriteriaList = ioImagesetBlockJson['onoff criteria'] @@ -5036,6 +4842,9 @@ def ParseOnePlotOverTimeBlockC(ioPlotOverTimeBlock, inPlotOverTimeBlockJson, inP ioPlotOverTimeBlock.mImageFileNameCountSettings.\ ParseImageFileNameCountSettings(inPlotOverTimeBlockJson) + ioPlotOverTimeBlock.mBackground = getParameterFromBlock(inPlotOverTimeBlockJson, + 'background color', ioPlotOverTimeBlock.mBackground) + if PhactoriDbg(): myDebugPrint3(str(inPlotOverTimeBlockJson) + '\n') @@ -5421,7 +5230,7 @@ def GetCurrentGeometricPoint(self, inParaViewSource, ioViewBounds, if PhactoriDbg(): myDebugPrint3(errStr) raise Exception(errStr) - + if PhactoriDbg(100): myDebugPrint3("GetCurrentGeometricPoint returning: " + \ str(returnXyz) + "\n", 100) @@ -5501,7 +5310,7 @@ def ParseParametersFromJson(self, inJsn): if 'auto size 1 view angle delta in degrees' in inJsn: angleInDegrees = inJsn['auto size 1 view angle delta in degrees'] self.mAutoSize1ViewAngleDeltaInRadians = math.radians(angleInDegrees) - + def SetUpIfEnabled(self, inRenderView, ioCameraPosition, ioLookAtPoint, inViewUpVector): @@ -5601,7 +5410,7 @@ def ChangeEyeAndFocusInModelSpaceForStereo(self, lookDirection = vecFromAToB(ioEyePosition, ioFocalPoint) axisBetweenEyes = vecCrossProduct(lookDirection, inViewUpVector) axisBetweenEyesNorm = vecNormalize(axisBetweenEyes) - + if self.mLeftEyeFlag: modelCsHalfIpd = -self.mIpdInModelUnits * \ self.mVirtualSelfSizeMultiplier * 0.5 @@ -5806,7 +5615,7 @@ class PhactoriCameraBlock: look at the point where pressure is maximum: -:: +:: "mycam10":{ "type":"camera", @@ -5903,253 +5712,8 @@ def HandleLockingOption(self, eyePosition, absoluteLookAtPoint): self.LockAfterNCalls = -1 - -class PhactoriVariableMinMaxAvgSumCntSave: - def __init__(self): - self.mStatsTestCounter = -1 - self.mMin = 0.0 - self.mMax = 0.0 - self.mSum = 0.0 - self.mCount = 0 - self.mIdsTestCounter = -1 - self.mLocalFoundMinId = False - self.mLocalMinIdCount = -1 - self.mMinId = -1; - self.mLocalFoundMaxId = False - self.mLocalMaxIdCount = -1 - self.mMaxId = -1; - -class PhactoriVariableInfo: - def __init__(self): - self.mVariableIntendedForUseFlag = False - self.mVariableName = "" - self.mVariableComponent = None - self.mVariableType = None - self.mVariableTypeNeedsDetection = False - self.mVariableTypeWasDetected = False - self.mVariableTypeWasCopied = False - self.mVariableIsVectorMagnitude = False - self.mVariableIsVectorComponent = False - self.mVectorBaseName = None - self.mStats = PhactoriVariableMinMaxAvgSumCntSave() - self.mAddSeparatorToVectorVariableName = True - - def SelfToStr(self): - retStr = "PhactoriVariableInfo:\n" +\ - "\n mVariableName: " + str(self.mVariableName) +\ - "\n mVariableComponent: " + str(self.mVariableComponent) +\ - "\n mVariableType: " + str(self.mVariableType) +\ - "\n mVariableIsVectorMagnitude: " + \ - str(self.mVariableIsVectorMagnitude) +\ - "\n mVariableIsVectorComponent: " + \ - str(self.mVariableIsVectorComponent) +\ - "\n mVectorBaseName: " + str(self.mVectorBaseName) +\ - "\n" - return retStr - - def ParseVariableNameAndVectorOrTensorComponent(self, inJson, inBaseString): - """take a base string such as 'y axis variable ' or 'variable ', use it - to construct keys to define a scalar variable, vector component, vector - magnitude, or tensor component, and see if the json has those keys. - If the json has a key, use it to grab the variable name and setup. - Also look to see if the type of the variable is specifically defined - (node or element) or needs to be detected - """ - variableFoundFlag = False - self.mVariableIsVectorComponent = False - self.mVariableIsVectorMagnitude = False - - if 'add separator to vector variable name' in inJson: - self.mAddSeparatorToVectorVariableName = \ - inJson['add separator to vector variable name'] - - testKey = inBaseString + 'scalar' - if testKey in inJson: - variableFoundFlag = True - if PhactoriDbg(): - myDebugPrint3(' scalar found\n') - self.mVariableName = inJson[testKey] - self.mVariableComponent = None - else: - testKey = inBaseString + 'vector component' - if testKey in inJson: - variableFoundFlag = True - self.mVariableIsVectorComponent = True - if PhactoriDbg(): - myDebugPrint3(' vector component found\n') - varName = inJson[testKey] - resultPair = breakSpecialVarNameIntoBaseAndComponent(varName, - self.mAddSeparatorToVectorVariableName) - self.mVariableName = resultPair[0] - self.mVariableComponent = resultPair[1] - self.mVectorBaseName = resultPair[2] - if PhactoriDbg(): - myDebugPrint3(' non comp name: ' + str(self.mVariableName) + '\n') - else: - testKey = inBaseString + 'vector magnitude' - if testKey in inJson: - variableFoundFlag = True - self.mVariableIsVectorMagnitude = True - if PhactoriDbg(): - myDebugPrint3(' vector magnitude found\n') - if self.mAddSeparatorToVectorVariableName: - self.mVariableName = inJson[testKey] + GetSeparatorString() - else: - self.mVariableName = inJson[testKey] - self.mVectorBaseName = inJson[testKey] - else: - testKey = inBaseString + 'tensor component' - if testKey in inJson: - variableFoundFlag = True - if PhactoriDbg(): - myDebugPrint3(' tensor component found\n') - self.mVariableName = inJson[testKey] - else: - variableFoundFlag = False - if PhactoriDbg(): - myDebugPrint3(' no variable found\n') - self.mVariableName = '' - self.mComponent = None - - if variableFoundFlag: - #it is now apparent variable is intended to be used, not ignored - self.mVariableIntendedForUseFlag = True - if 'variable type' in inJson: - variableType = inJson['variable type'] - self.mVariableType = variableType - if variableType != 'element' \ - and variableType != 'node' \ - and variableType != 'global' \ - and variableType != 'detect': - errStr = 'error! inJson has variable type is neither node nor '\ - 'element nor detect nor global in ParseVariableNameAndVectorOrTensorComponent\n' - if PhactoriDbg(): - myDebugPrint3(errStr) - raise Exception(errStr) - if variableType == 'detect': - self.mVariableType = 'element' - self.mVariableTypeNeedsDetection = True - self.mVariableTypeWasDetected = False - elif variableType == 'element': - self.mVariableType = 'element' - self.mVariableTypeNeedsDetection = False - self.mVariableTypeWasDetected = True - elif variableType == 'node': - self.mVariableType = 'node' - self.mVariableTypeNeedsDetection = False - self.mVariableTypeWasDetected = True - elif variableType == 'global': - self.mVariableType = 'global' - self.mVariableTypeNeedsDetection = False - self.mVariableTypeWasDetected = True - else: - self.mVariableType = 'element' - self.mVariableTypeNeedsDetection = True - self.mVariableTypeWasDetected = False - else: - self.mVariableType = None - - return variableFoundFlag - - def CopyVariableTypeFrom(self, inSourceVariableInfo): - self.mVariableType = inSourceVariableInfo.mVariableType - self.mVariableTypeNeedsDetection = False - self.mVariableTypeWasDetected = True - self.mVariableTypeWasCopied = True - - def DetectVariableType(self, inInputCsData, inInputIsProxy = False, - inAllowGlobalVariableDetection = False): - - if self.mVariableTypeNeedsDetection == False: - return True - - #testing hack--force to cell - #self.mVariableTypeNeedsDetection = False - #self.mVariableTypeWasDetected = True - #self.mVariableType = 'element' - #return - - if PhactoriDbg(): - myDebugPrint3('PhactoriVariableInfo::DetectVariableType entered\n') - - if inInputIsProxy: - pointData = inInputCsData.PointData - else: - pointData = inInputCsData.GetPointData() - if pointData != None: - testPointArray = pointData.GetArray(self.mVariableName) - if testPointArray != None: - if PhactoriDbg(): - myDebugPrint3(' type node detected!\n') - self.mVariableType = 'node' - self.mVariableTypeNeedsDetection = False - self.mVariableTypeWasDetected = True - return True - - if inInputIsProxy: - cellData = inInputCsData.CellData - else: - cellData = inInputCsData.GetCellData() - if cellData != None: - testCellArray = cellData.GetArray(self.mVariableName) - if testCellArray != None: - if PhactoriDbg(): - myDebugPrint3(' type element detected!\n') - self.mVariableType = 'element' - self.mVariableTypeNeedsDetection = False - self.mVariableTypeWasDetected = True - return True - - if inAllowGlobalVariableDetection: - if inInputIsProxy: - fieldData = inInputCsData.FieldData - else: - fieldData = inInputCsData.GetFieldData() - if fieldData != None: - testFieldArray = fieldData.GetArray(self.mVariableName) - if testFieldArray != None: - if PhactoriDbg(): - myDebugPrint3(' type global detected!\n') - self.mVariableType = 'global' - self.mVariableTypeNeedsDetection = False - self.mVariableTypeWasDetected = True - return True - - if PhactoriDbg(): - myDebugPrint3(' type not detected!\n') - #default to 'element' type knowing assumption may be wrong, - #leave mVariableTypeNeedsDetection set to True so we know the variable - #type has not yet been successfully detected - self.mVariableType = 'element' - #self.mVariableType = 'node' - return False - - def GetXYPlotAxisTitle(self): - """for this variable info, construct the name to put on the axis of an XY - plot, e.g. with magnitude or component information""" - - if self.mVariableName[-1] == '_': - axisTitle = str(self.mVariableName[0:-1]) - else: - axisTitle = self.mVariableName - - if self.mVariableIsVectorComponent: - if self.mVariableComponent == 0: - axisTitle += ' X component' - elif self.mVariableComponent == 1: - axisTitle += ' Y component' - elif self.mVariableComponent == 2: - axisTitle += ' Z component' - else: - if PhactoriDbg(): - myDebugPrint3(" variable component is not 0, 1, or 2, using 0 (X)\n") - localVariableName = self.mVariableName + '_X' - elif self.mVariableIsVectorMagnitude: - axisTitle += " Magnitude" - - return axisTitle - - +#phactori_combine_to_single_python_file_parent_1 +from Operation.PhactoriVariableInfo import * class PhactoriDataCubeOneAxisInfo: def __init__(self): @@ -6176,7 +5740,7 @@ def DcoaiParseParametersFromJson(self, parentAxesInfo, inJsn, inXyzKey): if theKey in inJsn: self.mUseLabelFlag = True self.mAxisLabel = getParameterFromBlock(inJsn, theKey, "") - + if PhactoriDbg(): myDebugPrint3('DcoaiParseParametersFromJson ' + inXyzKey + ' ' \ + str(parentAxesInfo.mShowTicks) + ' ' \ @@ -6210,82 +5774,6 @@ def ParseColorMapSettings(self, inJsn): self.mInvertColorMap = getParameterFromBlock(inJsn, 'invert color scale', self.mInvertColorMap) -class PhactoriRepresentationBlock: - def __init__(self): - self.mName = "" - self.mColorVariableInfo = PhactoriVariableInfo() - self.mColorLegendFlag = True - #self.mColorLegendPositionAndSize = ['bottom', 1.0] - #self.mColorLegendPositionAndSize = ['right', 1.0] - self.mColorLegendPositionAndSize = ['bottom right', 1.0] - self.mTimeAnnotationSettings = PhactoriAnnotationViewSettings( - 'time', 'time') - self.mDataCubeAxesFlag = False - self.mDataCubeAxesInfo = PhactoriDataCubeAxesInfo() - #self.mColorByBlockFlag = True - self.mColorByBlockFlag = True - self.mColorByBlockExplicitlySet = False - self.mColorBySolidColorFlag = False - self.mSolidColor = None - self.mOpacitySetting = 1.0 - self.mOrientationAxesFlag = True - self.mFixedColorRange = None - self.mUseFixedColorRange = False - self.mColorRangeMinMaxTracker = PlotValMinMaxTrkC() - self.mUseHighlightSubranges = False - self.mHighlightSubranges = [] - self.mUseColorSubrange = False - self.mColorSubrange = [0.0, 1.0] - self.mFilenameAddon = "" - self.mColorSettings = PhactoriColorSettings() - self.mColorMapSettings = PhactoriColorMapSettings() - self.mPointSize = 2.0 - - def SetFromRestartInfo(self, inJson): - """given a map (json format), use the info in the map to set the - representation state--this reads the info created in - GetRestartInfo""" - - if 'mColorRangeMinMaxTracker' not in inJson: - if PhactoriDbg(): - myDebugPrint3("PhactoriRepresentationBlock::" + \ - "SetFromRestartInfo: no mColorRangeMinMaxTracker, return\n") - return - - if PhactoriDbg(): - myDebugPrint3("Representation::SetFromRestartInfo\n" + - "currently set to do something\n" + - "before tracker:\n" + self.mColorRangeMinMaxTracker.SelfToStr()) - - jsonItem = inJson['mColorRangeMinMaxTracker'] - self.mColorRangeMinMaxTracker.SetFromRestartInfo(jsonItem) - - if PhactoriDbg(): - myDebugPrint3("after tracker:\n" + - self.mColorRangeMinMaxTracker.SelfToStr()) - - def GetRestartInfo(self): - """construct, in python map/json format, the information from this - representation instance which contains the information - which would be needed to restore the representation to the proper - state after a simulation restart, particularly color range tracking - information. Return the restart info map/json""" - newRestartInfoJson = {} - newRestartInfoJson['mColorRangeMinMaxTracker'] = \ - self.mColorRangeMinMaxTracker.GetRestartInfo() - return newRestartInfoJson - - def CalculateDefaultScalarOpacityUnitDistance(self, inPhactoriOperation): - """given a phactori operation assumed to have an updated pipeline, - calculate a default scalar opacity unit distance the same as paraview, - with 0.05 * diagonal length of data bounding box""" - bnds = GetGlobalDataBoundsParallel(inPhactoriOperation.mParaViewFilter) - xxlen = bnds[1] - bnds[0] - yylen = bnds[3] - bnds[2] - zzlen = bnds[5] - bnds[4] - self.mScalarOpacityUnitDistance = \ - 0.05 * math.sqrt(xxlen*xxlen + yylen*yylen + zzlen*zzlen) - def GetThresholdContourHackVariableNameString(inVariableInfo): """gives altered variable name for magnitude or component in paraview, coloring by a vector component or magnitude is handled @@ -6616,13 +6104,13 @@ def IntersectWithOneRayViaBSPTree(self, inIndex, inRayStart, inRayDirection, if inPointOrCellData <= 0: oldvv = ioRaycastOperation.mPointNormalRayIntersectDistanceArray.\ GetValue(inIndex) - if (oldvv < 0.0) or (hitdist < oldvv): + if (oldvv < 0.0) or (hitdist < oldvv): ioRaycastOperation.mPointNormalRayIntersectDistanceArray.\ SetValue(inIndex, hitdist) else: oldvv = ioRaycastOperation.mCellNormalRayIntersectDistanceArray.\ GetValue(inIndex) - if (oldvv < 0.0) or (hitdist < oldvv): + if (oldvv < 0.0) or (hitdist < oldvv): ioRaycastOperation.mCellNormalRayIntersectDistanceArray.\ SetValue(inIndex, hitdist) @@ -6691,14 +6179,14 @@ def IntersectWithOneRay(self, inIndex, inRayStart, inRayDirection, oldvv = ioRaycastOperation.mPointNormalRayIntersectDistanceArray.\ GetValue(inIndex) newvv = hitPoint[3] - if (oldvv < 0.0) or (newvv < oldvv): + if (oldvv < 0.0) or (newvv < oldvv): ioRaycastOperation.mPointNormalRayIntersectDistanceArray.\ SetValue(inIndex, hitPoint[3]) else: oldvv = ioRaycastOperation.mCellNormalRayIntersectDistanceArray.\ GetValue(inIndex) newvv = hitPoint[3] - if (oldvv < 0.0) or (newvv < oldvv): + if (oldvv < 0.0) or (newvv < oldvv): ioRaycastOperation.mCellNormalRayIntersectDistanceArray.\ SetValue(inIndex, hitPoint[3]) @@ -6989,7 +6477,7 @@ def TestAndSet(self, inLengthSquared, inPt1, inPt2): self.LengthSquared = inLengthSquared vecCopy(self.Point1, inPt1) vecCopy(self.Point2, inPt2) - + class PhactoriSegmentGroup1: """manage a set of segments for purposes of showing raycast results""" def __init__(self): @@ -7080,7 +6568,7 @@ def __init__(self): self.mCellNormalRayIntersectDistanceArray = None self.SegmentsFromPointRays = PhactoriSegmentGroup1() - self.SegmentsFromTriangleRays = PhactoriSegmentGroup1() + self.SegmentsFromTriangleRays = PhactoriSegmentGroup1() def ParseParametersFromJson(self, inJson): if "target operation" in inJson: @@ -7128,7 +6616,7 @@ def CreateParaViewFilter(self, inInputFilter): self.mTriangleRayLineSource = PVTrivialProducer() self.mTriangleRayLineSource.GetClientSideObject().SetOutput( self.SegmentsFromTriangleRays.mVtkPolyData) - + #newParaViewFilter = GroupDatasets(Input = []) #self.mGroupLineSource = newParaViewFilter @@ -7143,7 +6631,7 @@ def CreateParaViewFilter(self, inInputFilter): else: newParaViewFilter = PVTrivialProducer() passthru = inInputFilter.GetClientSideObject().GetOutputDataObject(0) - + numpts = passthru.GetNumberOfPoints() newvar = vtk.vtkDoubleArray() @@ -7254,7 +6742,7 @@ def RunCalculationToCastRays(self, ioPipeAndViewsState): #now loop through all processes; one process at a time share the triangles #from each process to the others and intersect with the local surface - #portion + #portion mypid = SmartGetLocalProcessId() @@ -7312,7 +6800,7 @@ def ExportOperationData(self, datadescription): class should override this method if it wants so do something. For PhactoriIntersectNodeNormalsWithSurface we will output information about the nearest and furthest intersections""" - + if PhactoriDbg(100): myDebugPrint3( "PhactoriIntersectNodeNormalsWithSurface::ExportOperationData " @@ -7498,7 +6986,7 @@ def CreateParaViewFilter(self, inInputFilter): newParaViewFilter = Line() newParaViewFilter.Point1 = [0.0, 0.0, 0.0] newParaViewFilter.Point2 = [0.01, 0.01, 0.01] - + SetActiveSource(newParaViewFilter) SetActiveSource(savedActiveSource) @@ -7601,7 +7089,7 @@ def RunCalculationToFindNearestPoints(self, ioPipeAndViewsState): tgty = self.mClosestNPointsFromEachProcess.mTargetMatchXyzs.GetValue(pndx+1) tgtz = self.mClosestNPointsFromEachProcess.mTargetMatchXyzs.GetValue(pndx+2) - self.mLineSource.Point1 = [srcx, srcy, srcz] + self.mLineSource.Point1 = [srcx, srcy, srcz] self.mLineSource.Point2 = [tgtx, tgty, tgtz] self.mLineSource.UpdatePipeline() @@ -7644,7 +7132,7 @@ def OutputToTextAnnotation(self, ioPipeAndViewsState): tgty = clstpts.mTargetMatchXyzs.GetValue(pndx+1) tgtz = clstpts.mTargetMatchXyzs.GetValue(pndx+2) - if self.mTxtAntnFormatString == None: + if self.mTxtAntnFormatString == None: self.mTextAnnotationOutputTarget.mTextString = \ "nearest: " + str(dist) + "\n" \ "node id 1: " + str(srcndid) + "\n" \ @@ -8630,7 +8118,7 @@ def CreateParaViewStuff(self, inColor, inImageset = None): "to work off, and None was supplied\n") return self.mInputOperation = inImageset.mOperation - + savedActiveSource = GetActiveSource() inOprtn = self.mInputOperation if(inOprtn.mParaViewTimeAnnotationSource == None): @@ -8681,7 +8169,8 @@ def __init__(self, inName, inAnnotationType): self.mType = 'text' self.mText = 'Text' self.mSizeScale = 1.0 - self.mFontSize = 18 + #self.mFontSize = 18 + self.mFontSize = 36 self.mFont = 'Arial' self.mBold = False self.mItalic = False @@ -8779,11 +8268,11 @@ def SetSizeScale(self, inNewSizeScale): def SetWindowLocation(self, inNewPosition): global gParaViewCatalystVersionFlag if gParaViewCatalystVersionFlag < 51000: - validPositions = ['UpperLeftCorner', 'UpperRightCorner', + validPositions = ['UpperLeftCorner', 'UpperRightCorner', 'LowerLeftCorner', 'LowerRightCorner', 'UpperCenter', 'LowerCenter'] else: - validPositions = ['Upper Left Corner', 'Upper Right Corner', + validPositions = ['Upper Left Corner', 'Upper Right Corner', 'Lower Left Corner', 'Lower Right Corner', 'Upper Center', 'Lower Center'] if inNewPosition in validPositions: @@ -8915,7 +8404,7 @@ def GetImageFilename(self, datadescription, inImageSettings, inImageBasedirectory = inImageSettings.mImageBasedirectory inNumCounterDigits = inImageSettings.mNumCounterDigits inImageFormat = inImageSettings.mImageFormat - + timestep = datadescription.GetTimeStep() lastImagesetName = "" @@ -8950,7 +8439,7 @@ def GetImageFilename(self, datadescription, inImageSettings, while len(timestepString) < inNumCounterDigits: timestepString = "0" + timestepString myDebugPrint2("image fname: " + fname + "\ndigit count: " + str(inNumCounterDigits) + "\ntimestepString: " + timestepString + "\n") - + rplstr1 = None if self.mUseDateTime: ttnow = gPipeAndViewsState.mCallbackDateTime @@ -8980,7 +8469,7 @@ def GetImageFilename(self, datadescription, inImageSettings, fnameRR = fname.replace("%t", rplstr1) else: fnameRR = None - + fname = fname.replace("%t", timestepString) myDebugPrint2("fname after replace: ->" + fname + "<-\n") @@ -9009,7 +8498,7 @@ class PhactoriPlot1Base: def __init__(self): self.mName = "" self.m_DataCubeAxesInfo = PhactoriDataCubeAxesInfo() - + self.m_PlotType = "PhactoriPlot1Base" self.mImageSettings = PhactoriImageSettings() self.mImageSettings.mPixelBorderRatioXY = [0.175 / self.mImageSettings.GetAspectRatio(), 0.175] @@ -9047,6 +8536,8 @@ def __init__(self): #or not) self.mImageFileNameCountSettings = ImageFileNameCountSettings() + self.mBackground = [0.0, 0.0, 0.0] + def GetInputPhactoriOperation(self): #mainly for compatibility between plot blocks and imageset blocks, give #same access to phactori operation coming being visualized @@ -9068,7 +8559,7 @@ def WriteImages(self, datadescription): oneLookDirectionFilenameAddon = "" else: oneLookDirectionFilenameAddon = "" - + fname, fnameRR = self.mImageFileNameCountSettings.GetImageFilename( datadescription, self.mImageSettings, oneLookDirectionFilenameAddon, @@ -9083,6 +8574,9 @@ def WriteImages(self, datadescription): #SetUpViewAndRepresentationBeforeWriteImage(oneViewInfo) self.SetUpViewAndRepresentationBeforeWriteImage() + colorPalette = GetSettingsProxy('ColorPalette') + colorPalette.Background = self.mBackground + #only need to update color range for first look direction, rest #are same #if self.mRepresentation.mUseFixedColorRange == False: @@ -9218,7 +8712,7 @@ def __init__(self): def SetFromRestartInfo(self, inJson): """given a map (json format), use the info in the map to set the - plot state--this reads the info created by out in + plot state--this reads the info created by out in GetRestartInfo. It should only occur on a restart, and it fills in the data that had been generated during the earlier run of the system""" @@ -9350,6 +8844,9 @@ def ParseParametersFromJson(self, inJsn, inPipeAndViewsState): 'plot basename', 'plot basedirectory') self.mImageFileNameCountSettings.ParseImageFileNameCountSettings(inJsn) + self.mBackground = getParameterFromBlock(inJsn, + 'background color', self.mBackground) + #parse x axis variable self.m_XAxisVariableInfo.ParseVariableNameAndVectorOrTensorComponent(inJsn, 'x axis variable ') @@ -9406,7 +8903,6 @@ def ParseParametersFromJson(self, inJsn, inPipeAndViewsState): global gSharedLineChartView gSharedLineChartView = None - class PhactoriImagesetBlock: """contains information corresponding to an imageset block """ @@ -9469,6 +8965,9 @@ def __init__(self): #or not) self.mImageFileNameCountSettings = ImageFileNameCountSettings() + self.mBackground = [0.31999694819562063, 0.3400015259021897, + 0.4299992370489052] + def GetInputPhactoriOperation(self): #mainly for compatibility between plot blocks and imageset blocks, give #same access to phactori operation coming being visualized @@ -9601,6 +9100,9 @@ def WriteImagesPassedOnOffFilter(self, datadescription): #SetUpViewAndRepresentationBeforeWriteImage(oneViewInfo) self.SetUpViewAndRepresentationBeforeWriteImage(oneLookDirection, ii) + colorPalette = GetSettingsProxy('ColorPalette') + colorPalette.Background = self.mBackground + #only need to update color range for first look direction, rest #are same if ii == 0: @@ -9963,7 +9465,7 @@ def ParseOperationAndRepresentationPair(self, ioPipeAndViewsState, ioJson, "inOperationKey: " + str(inOperationKey) + "\n" "inRepresentationKey: " + str(inRepresentationKey) + "\n" "incoming json:\n" + str(ioJson) + "\n") - + if inOperationKey not in ioJson: if inSkipIfOperationKeyNotPresent: @@ -10026,7 +9528,6 @@ def ParseOperationAndRepresentationPair(self, ioPipeAndViewsState, ioJson, self.mVisiblePvDataReps.append(None) self.mColorLegendRepRefs.append(None) - class PhactoriPipeAndViewsState: """Top State Container--Pipeline, Cameras, Representations, Imagesets, Plots @@ -10072,7 +9573,7 @@ def __init__(self): #default operation for incoming input self.mIncomingDefaultOperation = PhactoriOperationBlock() self.mIncomingDefaultOperation.mName = "default incoming input" - self.mIncomingOperationList = [] + #self.mIncomingOperationList = [] self.mOperationBlocks = {} self.mImagesetBlocks = {} self.mScatterPlotBlocks = {} @@ -10094,7 +9595,7 @@ def __init__(self): self.mOutputResultsBlockId = None self.mCurrentDatabaseDummyFileName = None self.mProducer = None - self.mIncomingGridProducerList = [] + #self.mIncomingGridProducerList = [] self.mPipeAndViewsState = None self.mRemeshRestartTag = None self.mSeparatorString = '_' @@ -10273,7 +9774,7 @@ def PerRendersetInitialization(datadescription): #cellDataInfo = paraviewSource.GetCellDataInformation() myDebugPrint3(" PerRendersetInitialization:\n num cells: " + str(pvsDi.GetNumberOfCells()) + "\n num points: " + str(pvsDi.GetNumberOfPoints()) + "\n") - #we assume to begin with that all global data bounds in operations are + #we assume to begin with that all global data bounds in operations are #invalid as data may have changed for oneOperationName, oneOperation in \ gPipeAndViewsState.mOperationBlocks.items(): @@ -10309,7 +9810,7 @@ def UpdateRepresentationColorBy(ioPhactoriImagesetBlock): if PhactoriDbg(100): myDebugPrint3("in PhactoriImagsetBlock named: " + \ ioPhactoriImagesetBlock.mName + "\n" + \ - "mColorLegendRepRefs " + str(ii) + + "mColorLegendRepRefs " + str(ii) + "is set to " + str(retVal) + "\n") ioPhactoriImagesetBlock.mColorLegendRepRefs[ii] = retVal @@ -10342,19 +9843,29 @@ def UpdateRepresentationColorBySub1(inPvView, inPvRep, if PhactoriDbg(100): myDebugPrint3('bad element type: returning\n', 100) return None - + if colorVarName != '': if inPhactoriRep.mColorVariableInfo.mVariableIsVectorComponent: ColorByVariableComponentOrMagnitudeXX(inPvRep, inPhactoriRep, colorVarName, 'Component', colorVarInfo.mVariableComponent, thePvVarType, inPhactoriRep.mColorMapSettings) + if colorVarInfo.mVariableComponent == 0: + componentString = "X" + elif colorVarInfo.mVariableComponent == 1: + componentString = "Y" + elif colorVarInfo.mVariableComponent == 2: + componentString = "Z" + else: + componentString = str(colorVarInfo.mVariableComponent) elif inPhactoriRep.mColorVariableInfo.mVariableIsVectorMagnitude: ColorByVariableComponentOrMagnitudeXX(inPvRep, inPhactoriRep, colorVarName, 'Magnitude', colorVarInfo.mVariableComponent, thePvVarType, inPhactoriRep.mColorMapSettings) + componentString = "Magnitude" else: ColorByVariableScalarXX(inPvRep, inPhactoriRep, colorVarName, thePvVarType, inPhactoriRep.mColorMapSettings) + componentString = "" #update the color legend widget if inPhactoriRep.mColorLegendFlag: @@ -10363,7 +9874,7 @@ def UpdateRepresentationColorBySub1(inPvView, inPvRep, onoffFlagString = 'off' retVal = ShowDataColorLegendXX(inPvView, onoffFlagString, inPhactoriRep.mColorLegendPositionAndSize, inPhactoriRep.mColorSettings, - inColorLegendRepRef, inPvRep) + inColorLegendRepRef, inPvRep, componentString) if PhactoriDbg(): myDebugPrint3("UpdateRepresentationColorBySub1 returning\n") @@ -10591,7 +10102,7 @@ def HandleRestartUpdateForOutputResultsBlock(ioPipeAndViewsState): """this method is a companion to SaveRestartInfoCallback. It is called after the pipeline is first initialized for the given output block, and it will read the data stored by SaveRestartInfoCallback in a file. - The presumption is that the pipeline will be initialized for the + The presumption is that the pipeline will be initialized for the given output block only once when the system starts or only once when the system restarts. The intent is to deal with restart by allowing persistent @@ -10656,7 +10167,7 @@ def SaveRestartInfoCallback(): for onePlotOtName, onePlotOt in \ gPipeAndViewsState.mPlotOverTimeBlocks.items(): if PhactoriDbg(): - myDebugPrint3("making end vis callback json for plot over time: " + + myDebugPrint3("making end vis callback json for plot over time: " + onePlotOtName + "\n") plotsOverTimeJsonOut[onePlotOtName] = onePlotOt.GetRestartInfo() @@ -10763,7 +10274,7 @@ def HandleOperationShortcuts2(inBlockName, inJson, ioOperationBlocks, inCount): if PhactoriDbg(): myDebugPrint3(errStr) raise Exception(errStr) - #stuff should have 4 items + #stuff should have 4 items #[scalar|vector magnitude|vector component|tensor #component, component, namekeep between|keep above|keep #below, [, ]] @@ -10783,7 +10294,7 @@ def HandleOperationShortcuts2(inBlockName, inJson, ioOperationBlocks, inCount): if PhactoriDbg(): myDebugPrint3(errStr) raise Exception(errStr) - + if PhactoriDbg(): myDebugPrint3('got threshold operation shortcut ' + str(newOperationJson) + '\n') if lastShortcutOperationName != None: @@ -11408,7 +10919,7 @@ def CreateViewSetFromPhactoriViewMapC(inViewMapC): myDebugPrint3(str(inViewMapC) + "\n") global gPipeAndViewsState gPipeAndViewsState.mJsonDescription = inViewMapC - + #get pointers to the various block types (currently 6, camera, #representation, operation, imageset, plot over time, and scatter plot) @@ -11841,6 +11352,17 @@ def ColorByVariableScalarXX(inParaViewDataRepresentation, inPhactoriRepresentati pv_4_3_LUT.RGBPoints = myRGBPoints pv_4_3_LUT.ColorSpace = myColorSpace pv_4_3_LUT.NanColor = myNanColor + if inPhactoriRepresentation.InterpretValuesAsCategories: + if PhactoriDbg(): + myDebugPrint3("variable name is ObjectId, trying to do categories\n") + inPhactoriRepresentation.SetUpForInterpretValuesAsCateories(pv_4_3_LUT) + pv_4_3_LUT.InterpretValuesAsCategories = 1 + pv_4_3_LUT.AnnotationsInitialized = 1 + pv_4_3_LUT.Annotations = inPhactoriRepresentation.Annotations + pv_4_3_LUT.IndexedColors = inPhactoriRepresentation.IndexedColors + pv_4_3_LUT.IndexedOpacities = inPhactoriRepresentation.IndexedOpacities + else: + pv_4_3_LUT.InterpretValuesAsCategories = 0 return #rest of function for paraview 4.1 @@ -11991,7 +11513,7 @@ def ColorByBlock(inParaViewDataSource, inParaViewDataRepresentation, ColorByBlockRecurse1(csdata, blockAndLeafBlockCounter, inParaViewDataRepresentation.BlockColor, False) #inParaViewDataRepresentation.BlockColor = blockColorData - + if PhactoriDbg(100): myDebugPrint3(' block color data: ' + str(inParaViewDataRepresentation.BlockColor) + '\n', 100) if PhactoriDbg(100): @@ -12042,8 +11564,8 @@ def UseDataRangeForColorValues(inPvDataRepresentation, inRepresentation, if PhactoriDbg(): myDebugPrint3(" input:" + str(input) + "\n") UpdatePipelineWithCurrentTimeArgument(input) - - #assume point info + + #assume point info #datainformation = rep.Input.GetPointDataInformation() if pointsOrCellsType == gPointsString: @@ -12247,7 +11769,7 @@ def helpFindNewRgbPoint(inBaseRgbPts, inRatio): #print "deltaPt: ", deltaPt #print "ratioPt: ", ratioPt - subrangePt1 = [inRatio, + subrangePt1 = [inRatio, rr1 + ratioPt * (rr2 - rr1), gg1 + ratioPt * (gg2 - gg1), bb1 + ratioPt * (bb2 - bb1)] @@ -12574,11 +12096,11 @@ def ShowCubeAxesXX(inPvRenderView, inOnOrOff, inShowDataCubeAxesInfo = None): SetAxesGridVisibility(inPvRenderView, 0) if PhactoriDbg(100): myDebugPrint3("ShowCubeAxesXX returning\n", 100) - + def ShowDataColorLegendXX(inPvView, inOnOffSetting, inColorLegendPositionAndSize, inColorSettings, - inColorLegendRepRef, inPvDataRep): + inColorLegendRepRef, inPvDataRep, inComponentString): """Turns on or off the display of the color bar legend showing the mapping between the color and the data value (and the name of the data value. (note this is primarily to do the paraview-side work to turn bar on or @@ -12625,6 +12147,7 @@ def ShowDataColorLegendXX(inPvView, inColorLegendRepRef.Visibility = myVisibility inColorLegendRepRef.LookupTable = inPvDataRep.LookupTable inColorLegendRepRef.Title = localColorArrayName + inColorLegendRepRef.ComponentTitle = inComponentString #ioPhactoriImagesetBlock.mColorLegendRepRef.Color = \ # inColorSettings.mTextColor if PhactoriDbg(100): @@ -12724,7 +12247,7 @@ def ShowDataColorLegendXX(inPvView, defaultMidPos = 0.5 - 0.5*defaultLegendLength #legendFontSize = 16 #legendSize = 1.0 - #validPositions = ['UpperLeftCorner', 'UpperRightCorner', + #validPositions = ['UpperLeftCorner', 'UpperRightCorner', # 'LowerLeftCorner', 'LowerRightCorner', # 'UpperCenter', 'LowerCenter'] legendPosition=[0.0, 0.0] @@ -12766,7 +12289,7 @@ def ShowDataColorLegendXX(inPvView, defaultMidPos = 0.5 - 0.5*defaultLegendLength #legendFontSize = 16 #legendSize = 1.0 - #validPositions = ['UpperLeftCorner', 'UpperRightCorner', + #validPositions = ['UpperLeftCorner', 'UpperRightCorner', # 'LowerLeftCorner', 'LowerRightCorner', # 'UpperCenter', 'LowerCenter'] legendPosition=[0.0, 0.0] @@ -12897,11 +12420,15 @@ def ShowDataColorLegendXX(inPvView, pv_4_3_LUT = GetColorTransferFunction(inPvDataRep.ColorArrayName[1]) newScalarBarWidgetRepresentation = GetScalarBar(pv_4_3_LUT, inPvView) newScalarBarWidgetRepresentation.Orientation = legendOrientation + global gTemporaryGlobalImageTextColor + newScalarBarWidgetRepresentation.TitleColor = gTemporaryGlobalImageTextColor + newScalarBarWidgetRepresentation.LabelColor = gTemporaryGlobalImageTextColor newScalarBarWidgetRepresentation.WindowLocation = legendWindowLocation if legendWindowLocation == 'AnyLocation': newScalarBarWidgetRepresentation.Position = legendPosition if PhactoriDbg(): nbwr = newScalarBarWidgetRepresentation + nbwr.ComponentTitle = "" myDebugPrint3("newScalarBarWidgetRepresentation:\n" +\ str(nbwr) + "\n" +\ " Title: " + str(nbwr.Title) + "\n" +\ @@ -13010,9 +12537,9 @@ def ExtractComponentFromVectorVariable(inVariableName, inWhichComponent, inResul newFunctionString = "" if(inWhichComponent == 0): newFunctionString = inVariableName + '_X' - elif(inWhichComponent == 1): + elif(inWhichComponent == 1): newFunctionString = inVariableName + '_Y' - elif(inWhichComponent == 2): + elif(inWhichComponent == 2): newFunctionString = inVariableName + '_Z' else: if PhactoriDbg(): @@ -13098,7 +12625,7 @@ def CollectCells2(inClientSideData, inBlockIndex, ioCollectList, ioTotalCellCoun appendCount += 1 if PhactoriDbg(): myDebugPrint3(' proc ' + str(SmartGetLocalProcessId()) + ' Leaving CollectCells2\n') - + def CollectCells1(cellVariableName, thresholdValue, thresholdDir): if PhactoriDbg(): @@ -13200,7 +12727,7 @@ def UseReduceToSpreadValues(ioListOfValues): if value != 0.0: value = -value ioListOfValues[ii] = value - + if PhactoriDbg(): myDebugPrint3(' ' + 'proc ' + str(SmartGetLocalProcessId()) + ' final values: ' + str(ioListOfValues) + '\n') if PhactoriDbg(100): @@ -13600,7 +13127,7 @@ def GetRestartInfo(self): # def SetRepresentationAndViewColors(self, ioRenderViewInfo): # myDebugPrint3('PlotColorInfo.SetRepresentationColors entered\n', 100) # rep1 = ioRenderViewInfo.DataRepresentation1 -# view1 = ioRenderViewInfo.RenderView1 +# view1 = ioRenderViewInfo.RenderView1 # view1.Background = self.m_BackgroundColor # rep1.EdgeColor = self.m_EdgeColor # rep1.DiffuseColor = self.m_DiffuseColor @@ -13609,7 +13136,7 @@ def GetRestartInfo(self): # rep1.BackfaceDiffuseColor = self.m_BackfaceDiffuseColor # rep1.CubeAxesColor = self.m_CubeAxesColor # myDebugPrint3('PlotColorInfo.SetRepresentationColors returning\n', 100) - + #global gPlotColorInfoPreset #gPlotColorInfoPreset = PlotColorInfo() @@ -13997,7 +13524,7 @@ def FindNodeOrElementIdForMinMax(inputcsData, inVariableInfo): myDebugPrint3("min/max not available, calculating\n", 100) DataMinMax = [0.0, 0.0, False] DataSumCnt = [0.0, 0] - FindMinMaxSumCntFromData(inputcsData, inVariableInfo, + FindMinMaxSumCntFromData(inputcsData, inVariableInfo, None, DataMinMax, DataSumCnt, None, None) else: @@ -14024,7 +13551,7 @@ def FindNodeOrElementIdForMinMax(inputcsData, inVariableInfo): inVariableInfo.mStats.mMaxId = idForMinAndidForMax[1] #mark done for this catalyst callback, so we won't do extra mpi - #communication if we call this routine again + #communication if we call this routine again inVariableInfo.mStats.mIdsTestCounter = gPipeAndViewsState.mFrameTagCounter if PhactoriDbg(100): @@ -14534,7 +14061,7 @@ def FindThisProcessorMinMaxForVar(inOperation, inVariableInfo): return myDataMinMax -def FindMinMaxSumCntFromData(inputcsData, inVariableInfo, +def FindMinMaxSumCntFromData(inputcsData, inVariableInfo, inSecondaryVariableInfo, DataMinMax, DataSumCnt, DataForIds, inPlotIdLineList): """fairly complex high level mpi-operation routine. This takes a paraview @@ -14550,7 +14077,7 @@ def FindMinMaxSumCntFromData(inputcsData, inVariableInfo, if PhactoriDbg(): myDebugPrint3("FindMinMaxSumCntFromData entered\n") - FindMinMaxSumCntFromDataRecurse1(inputcsData, inVariableInfo, + FindMinMaxSumCntFromDataRecurse1(inputcsData, inVariableInfo, inSecondaryVariableInfo, DataMinMax, DataSumCnt, DataForIds, inPlotIdLineList) @@ -14623,7 +14150,7 @@ def SetPlotOverTimePointsFromData(ioPlotInfo): DataForIds = None FindMinMaxSumCntFromData(inputcsData, - ioPlotInfo.m_YAxisVariableInfo, ioPlotInfo.m_XAxisVariableInfo, + ioPlotInfo.m_YAxisVariableInfo, ioPlotInfo.m_XAxisVariableInfo, DataMinMax, DataSumCnt, DataForIds, ioPlotInfo.m_IdPlotLineList) if DataSumCnt[1] == 0: @@ -14719,7 +14246,7 @@ def SetPlotPointsFromData(ioPlotInfo): #myDebugPrint3(' done updating ids\n') - + FindPlotXYZMinMax(plotPts, ioPlotInfo.m_xyzMinMaxTrkC) ScalePlotYForFit(plotPts, ioPlotInfo.m_xyzMinMaxTrkC, @@ -15435,7 +14962,7 @@ def HandleUserInteractionIfEnabled(ioPipeAndViewsState): trigger which will cause a read-and-update of the state. Provides control to skip interaction when it is not enabled, the default case. Allows for a wait for an interaction trigger of N tries at M seconds - per try, mainly to deal with situations where images are being + per try, mainly to deal with situations where images are being rendered quickly. Eventually may be altered to help deal with cases where we want to keep re-rendering with changed pipeline states until we are happy and then let the simulation return to operation""" @@ -15501,6 +15028,8 @@ def HandleUserInteractionIfEnabled(ioPipeAndViewsState): myDebugPrint3("HandleUserInteractionIfEnabled returning\n") return doUpdate +#phactori_combine_to_single_python_file_parent_1 +from Operation.PhactoriRepresentationBlock import * class PhactoriCriteriaThreshold: """ @@ -15679,7 +15208,7 @@ def TestForTruth(self, ioPipeAndViewsState): DataMinMax = [0.0, 0.0, False] DataSumCnt = [0.0, 0] - FindMinMaxSumCntFromData(inputcsData, self.mVariableInfo, None, + FindMinMaxSumCntFromData(inputcsData, self.mVariableInfo, None, DataMinMax, DataSumCnt, None, None) #just return false if there is no min/max found @@ -16003,13 +15532,18 @@ def WriteOutImagesTest(datadescription, coprocessor): def CreateAllProducersFromAllInputDescriptions(datadescription, inCoprocessor, newRoot): global gPipeAndViewsState - newRoot.mProducer = inCoprocessor.CreateProducer( datadescription, "input" ) + inputGrid0Name = datadescription.GetInputDescriptionName(0) + #newRoot.mProducer = inCoprocessor.CreateProducer( datadescription, "input" ) + newRoot.mProducer = inCoprocessor.CreateProducer( datadescription, inputGrid0Name) newRoot.mIncomingDefaultOperation.mHasBeenConstructed = True + newRoot.mIncomingDefaultOperation.mName = inputGrid0Name + newRoot.mIncomingDefaultOperation.mOperationSpecifics = PhactoriOperationSpecifics() + newRoot.mOperationBlocks[inputGrid0Name] = newRoot.mIncomingDefaultOperation numInputGrids = datadescription.GetNumberOfInputDescriptions() if PhactoriDbg(): myDebugPrint3("numInputGrids: " + str(numInputGrids) + "\n"); for ii in range(0,numInputGrids): - print(str(ii) + ": " + str(datadescription.GetInputDescriptionName(ii)) + "\n") + myDebugPrint3(str(ii) + ": " + str(datadescription.GetInputDescriptionName(ii)) + "\n") defSrc = GetActiveSource(); for ii in range(1,numInputGrids): incomingInputName = datadescription.GetInputDescriptionName(ii) @@ -16020,8 +15554,8 @@ def CreateAllProducersFromAllInputDescriptions(datadescription, inCoprocessor, n newIncomingOperationBlock.mParaViewFilter = newTrivialProducerForGrid newIncomingOperationBlock.mHasBeenConstructed = True newIncomingOperationBlock.mOperationSpecifics = PhactoriOperationSpecifics() - newRoot.mIncomingOperationList.append(newIncomingOperationBlock) - newRoot.mIncomingGridProducerList.append(newTrivialProducerForGrid) + #newRoot.mIncomingOperationList.append(newIncomingOperationBlock) + #newRoot.mIncomingGridProducerList.append(newTrivialProducerForGrid) newRoot.mOperationBlocks[newIncomingOperationBlock.mName] = newIncomingOperationBlock SetActiveSource(defSrc); @@ -16038,16 +15572,16 @@ def InitializePerPipeRoot(datadescription, inCoprocessor): sa4 = sa[4] sa5 = sa[5] dbDummyFname = sa[6] - if(len(sa) > 7): + if(len(sa) > 7): defaultDirectory = sa[7] else: defaultDirectory = "" - if(len(sa) > 8): + if(len(sa) > 8): catalyst_script_extra_file = sa[8] else: catalyst_script_extra_file = "" - outputResultBaseId, remeshRestartTag = parseDbDummyFname(dbDummyFname) + outputResultBaseId, remeshRestartTag = parseDbDummyFname(dbDummyFname) if PhactoriDbg(): myDebugPrint3(" extra data list:\n") if PhactoriDbg(): @@ -16338,3 +15872,5 @@ def GetColorMapInfoFromColorLegendCollection(inColorMapSettings, inMin, inMax): myDebugPrint3("gParaViewCatalystVersionFlag is: " + str(gParaViewCatalystVersionFlag) +"\n") + + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/CMakeLists.txt b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/CMakeLists.txt index 2bfbc81158..441cd81a90 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/CMakeLists.txt +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/CMakeLists.txt @@ -35,3 +35,4 @@ ADD_SUBDIRECTORY(logging) ADD_SUBDIRECTORY(parser) ADD_SUBDIRECTORY(phactori) ADD_SUBDIRECTORY(pipeline) +ADD_SUBDIRECTORY(version) diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/CMakeLists.txt b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/CMakeLists.txt index 4acbfaa940..1f3b1e288d 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/CMakeLists.txt +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/CMakeLists.txt @@ -10,6 +10,7 @@ ADD_LIBRARY(catalystiosstest SHARED TARGET_LINK_LIBRARIES(catalystiosstest catalystiossapp VTK::jsoncpp + VTK::IOParallelXML MPI::MPI_C) TARGET_INCLUDE_DIRECTORIES(catalystiosstest PUBLIC diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/CatalystTestFixture.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/CatalystTestFixture.cxx index 01e0d8a8cb..f8760feaa0 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/CatalystTestFixture.cxx +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/CatalystTestFixture.cxx @@ -7,6 +7,18 @@ #include "CatalystTestFixture.h" #include "TestDataDirectoryPath.h" #include "catch.hpp" +#include "vtkAbstractArray.h" +#include "vtkCellData.h" +#include "vtkDataAssembly.h" +#include "vtkDataObjectTreeIterator.h" +#include "vtkDataSet.h" +#include "vtkFieldData.h" +#include "vtkInformation.h" +#include "vtkNew.h" +#include "vtkPartitionedDataSet.h" +#include "vtkPartitionedDataSetCollection.h" +#include "vtkPointData.h" +#include "vtkXMLPartitionedDataSetCollectionReader.h" #include #include @@ -24,12 +36,106 @@ void CatalystTestFixture::runParaViewGuiScriptTest(const std::string &pythonScri REQUIRE(ioapp.getApplicationExitCode() == EXIT_SUCCESS); } +void CatalystTestFixture::checkMeshOutputVariables(const std::string &inputFile, + const VarAndCompCountVec &cellVars, + const VarAndCompCountVec &pointVars, + const VarAndCompCountVec &globalVars, + const std::string &blockPath) +{ + vtkNew vpdcr; + + vpdcr->SetFileName(inputFile.c_str()); + vpdcr->Update(); + vtkPartitionedDataSetCollection *vpdc = + vtkPartitionedDataSetCollection::SafeDownCast(vpdcr->GetOutput()); + REQUIRE(vpdc->GetDataAssembly() != nullptr); + + auto assembly = vpdc->GetDataAssembly(); + auto childNodes = assembly->GetChildNodes(assembly->GetFirstNodeByPath(blockPath.c_str())); + bool foundBlockThatHasAllVars = false; + for (int i = 0; i < childNodes.size(); i++) { + auto dsi = assembly->GetDataSetIndices(childNodes[i]); + for (int j = 0; j < dsi.size(); j++) { + auto pds = vpdc->GetPartitionedDataSet(dsi[j]); + for (int k = 0; k < pds->GetNumberOfPartitions(); k++) { + vtkDataSet *ds = pds->GetPartition(k); + if (ds == nullptr) { + continue; + } + + auto hasAllVars = [](vtkFieldData *fd, const VarAndCompCountVec &vars) { + for (auto vv : vars) { + vtkAbstractArray *ar = fd->GetAbstractArray(vv.first.c_str()); + if (ar == nullptr) { + return false; + } + if (ar->GetNumberOfComponents() != vv.second) { + return false; + } + } + return true; + }; + + if (hasAllVars(ds->GetCellData(), cellVars) && hasAllVars(ds->GetPointData(), pointVars) && + hasAllVars(ds->GetFieldData(), globalVars)) { + foundBlockThatHasAllVars = true; + } + } + } + } + + REQUIRE(foundBlockThatHasAllVars); +} + +void CatalystTestFixture::checkPartitionedDataSetCollectionStructure(const std::string &inputFile, + const StringVec &partitions, + int numCells, + const StringVec &searchQueries) +{ + + vtkNew vpdcr; + + vpdcr->SetFileName(inputFile.c_str()); + vpdcr->Update(); + vtkPartitionedDataSetCollection *vpdc = + vtkPartitionedDataSetCollection::SafeDownCast(vpdcr->GetOutput()); + REQUIRE(vpdc->GetDataAssembly() != nullptr); + REQUIRE(vpdc->GetDataAssembly()->GetRootNodeName() == std::string("IOSS")); + REQUIRE(vpdc->GetNumberOfPartitionedDataSets() == partitions.size()); + int numCellsCount = 0; + for (int i = 0; i < vpdc->GetNumberOfPartitionedDataSets(); i++) { + REQUIRE(vpdc->HasMetaData(i)); + REQUIRE(vpdc->GetMetaData(i)->Get(vtkCompositeDataSet::NAME()) == partitions[i]); + auto pds = vpdc->GetPartitionedDataSet(i); + REQUIRE(pds != nullptr); + auto num_parts = pds->GetNumberOfPartitions(); + for (int j = 0; j < num_parts; j++) { + auto ds = pds->GetPartition(j); + int partNumCells = pds->GetPartition(j)->GetNumberOfCells(); + REQUIRE(partNumCells > 0); + numCellsCount += partNumCells; + } + } + REQUIRE(numCells == numCellsCount); + auto ids = vpdc->GetDataAssembly()->SelectNodes(searchQueries); + REQUIRE(ids.size() == searchQueries.size()); +} + +void CatalystTestFixture::runCatalystMultiBlockMeshTest(const std::string &inputFile) +{ + std::string td = std::string(TEST_DATA_DIRECTORY_PATH); + ioapp.addFileName(td + inputFile); + ioapp.setOutputCatalystMeshOneFile(true); + ioapp.runApplication(); + REQUIRE(ioapp.getApplicationExitCode() == EXIT_SUCCESS); +} + void CatalystTestFixture::runPhactoriJSONTest(const std::string &jsonFile, const std::string &inputFile) { std::string td = std::string(TEST_DATA_DIRECTORY_PATH); - ioapp.setPhactoriInputJSON(td + jsonFile); + ioapp.addPhactoriInputJSON(td + jsonFile); ioapp.addFileName(td + inputFile); ioapp.runApplication(); REQUIRE(ioapp.getApplicationExitCode() == EXIT_SUCCESS); @@ -41,16 +147,33 @@ void CatalystTestFixture::runPhactoriJSONTestTwoGrid(const std::string &jsonFile { std::string td = std::string(TEST_DATA_DIRECTORY_PATH); - ioapp.setPhactoriInputJSON(td + jsonFile); + ioapp.addPhactoriInputJSON(td + jsonFile); + ioapp.addFileName(td + inputFileA); + ioapp.addFileName(td + inputFileB); + ioapp.runApplication(); + REQUIRE(ioapp.getApplicationExitCode() == EXIT_SUCCESS); +} + +void CatalystTestFixture::runPhactoriJSONTestTwoGridTwoPipe(const std::string &jsonFileA, + const std::string &inputFileA, + const std::string &jsonFileB, + const std::string &inputFileB) +{ + + ioapp.setSendMultipleGridsToTheSamePipeline(false); + std::string td = std::string(TEST_DATA_DIRECTORY_PATH); + ioapp.addPhactoriInputJSON(td + jsonFileA); ioapp.addFileName(td + inputFileA); + ioapp.addPhactoriInputJSON(td + jsonFileB); ioapp.addFileName(td + inputFileB); ioapp.runApplication(); REQUIRE(ioapp.getApplicationExitCode() == EXIT_SUCCESS); + ioapp.setSendMultipleGridsToTheSamePipeline(true); } void CatalystTestFixture::runCatalystLoggingTest(Ioss::PropertyManager *logging_properties, - const std::string & jsonFile, - const std::string & inputFile) + const std::string &jsonFile, + const std::string &inputFile) { ioapp.setAdditionalProperties(logging_properties); runPhactoriJSONTest(jsonFile, inputFile); @@ -219,5 +342,4 @@ bool CatalystTestFixture::isFileExists(const char *fileName) fclose(fp); } return outputFileExists; - REQUIRE(outputFileExists); } diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/CatalystTestFixture.h b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/CatalystTestFixture.h index 1a2694c353..a6679b8bed 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/CatalystTestFixture.h +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/CatalystTestFixture.h @@ -14,6 +14,9 @@ class CatalystTestFixture { public: + typedef std::vector> VarAndCompCountVec; + typedef std::vector StringVec; + CatalystTestFixture(); ~CatalystTestFixture(); @@ -27,11 +30,26 @@ class CatalystTestFixture void runPhactoriJSONTestTwoGrid(const std::string &jsonFile, const std::string &inputFileA, const std::string &inputFileB); + void runPhactoriJSONTestTwoGridTwoPipe(const std::string &jsonFileA, + const std::string &inputFileA, + const std::string &jsonFileB, + const std::string &inputFileB); + void runParaViewGuiScriptTest(const std::string &pythonScript, const std::string &inputFile); void runCatalystLoggingTest(Ioss::PropertyManager *logging_properties, const std::string &jsonFile, const std::string &inputFile); + void runCatalystMultiBlockMeshTest(const std::string &inputFile); + + void checkMeshOutputVariables(const std::string &inputFile, const VarAndCompCountVec &cellVars, + const VarAndCompCountVec &pointVars, + const VarAndCompCountVec &globalVars, const std::string &blockPath); + + void checkPartitionedDataSetCollectionStructure(const std::string &inputFile, + const StringVec &partitions, int numCells, + const StringVec &searchQueries); + static bool isFileExists(const char *fileName); static void checkTestOutputFileExists(const char *fileName); static void checkTestOutputFileDoesNotExist(const char *fileName); diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/test_data/test9a.json b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/test_data/test9a.json new file mode 100644 index 0000000000..c3bbfd171b --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/test_data/test9a.json @@ -0,0 +1,27 @@ +{ +"camera blocks":{ + "camxyz1":{"camera type":"camera","look direction":[-1,-1,-1]} +}, +"representation blocks":{ + "rep_vonmises":{"color by scalar":"vonmises"}, + "rep_pressure":{"color by scalar":"pressure"}, + "rep_density":{"color by scalar":"density"}, + "rep_temperature":{"color by scalar":"temperature"} +}, +"imageset blocks":{ + "is_test9a":{ + "camera":"camxyz1", + "representation":"rep_temperature", + "image basedirectory":"CatalystOutput_test9", + "image basename":"test9_inputA." + } +}, +"operation blocks":{}, +"text annotation blocks":{}, +"scatter plot blocks":{}, +"plot over time blocks":{}, +"experimental blocks":{}, +"onoff criteria blocks":{}, +"visual marker blocks":{} +} + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/test_data/test9b.json b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/test_data/test9b.json new file mode 100644 index 0000000000..29c4fa7db1 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/fixture/test_data/test9b.json @@ -0,0 +1,28 @@ +{ +"camera blocks":{ + "camxyz1":{"camera type":"camera","look direction":[-1,-1,-1]} +}, +"representation blocks":{ + "rep_vonmises":{"color by scalar":"vonmises"}, + "rep_pressure":{"color by scalar":"pressure"}, + "rep_density":{"color by scalar":"density"}, + "rep_temperature":{"color by scalar":"temperature"} +}, +"imageset blocks":{ + "is_test9b":{ + "operation":"inputB", + "camera":"camxyz1", + "representation":"rep_vonmises", + "image basedirectory":"CatalystOutput_test9", + "image basename":"test9_inputB." + } +}, +"operation blocks":{}, +"text annotation blocks":{}, +"scatter plot blocks":{}, +"plot over time blocks":{}, +"experimental blocks":{}, +"onoff criteria blocks":{}, +"visual marker blocks":{} +} + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/CMakeLists.txt b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/CMakeLists.txt index 879ed9dd67..68c7d5c252 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/CMakeLists.txt +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/CMakeLists.txt @@ -33,6 +33,16 @@ ADD_EXECUTABLE(CatalystV2ScriptFromParaViewGuiTest1 TARGET_LINK_LIBRARIES(CatalystV2ScriptFromParaViewGuiTest1 catalystiosstest) +ADD_EXECUTABLE(CatalystPartitionedDataSetCollectionTests + CatalystPartitionedDataSetCollectionTests.cxx) +TARGET_LINK_LIBRARIES(CatalystPartitionedDataSetCollectionTests + catalystiosstest) + +ADD_EXECUTABLE(TwoGridsTwoPipelinesTests + TwoGridsTwoPipelinesTests.cxx) +TARGET_LINK_LIBRARIES(TwoGridsTwoPipelinesTests + catalystiosstest) + addCatalystTest("Catalyst_Logging_Pipeline" "1;4" ${CMAKE_CURRENT_BINARY_DIR}/CatalystLoggingPipelineTests "") @@ -53,3 +63,10 @@ addCatalystTest("Two_Grids_Catalyst_Script3" "1;4" addCatalystTest("CatalystV2ScriptFromParaViewGuiTest1" "1;4" ${CMAKE_CURRENT_BINARY_DIR}/CatalystV2ScriptFromParaViewGuiTest1 "") + +addCatalystTest("CatalystPartitionedDataSetCollectionTests" "1;4" + ${CMAKE_CURRENT_BINARY_DIR}/CatalystPartitionedDataSetCollectionTests "") + +addCatalystTest("TwoGridsTwoPipelinesTests" "1;4" + ${CMAKE_CURRENT_BINARY_DIR}/TwoGridsTwoPipelinesTests "") + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/CatalystPartitionedDataSetCollectionTests.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/CatalystPartitionedDataSetCollectionTests.cxx new file mode 100644 index 0000000000..c01b7fb09e --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/CatalystPartitionedDataSetCollectionTests.cxx @@ -0,0 +1,70 @@ +// Copyright(C) 1999-2021 National Technology & Engineering Solutions +// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +// NTESS, the U.S. Government retains certain rights in this software. +// +// See packages/seacas/LICENSE for details + +#include "CatalystTestFixture.h" +#include "catch.hpp" + +TEST_CASE_METHOD(CatalystTestFixture, "CatalystCGNSVariableComponents", + "[catalyst partitioned data set collection]") +{ + + runCatalystMultiBlockMeshTest("aero_blunt_wedge_test3.cgns"); + checkTestOutputFileExists("iossDatabaseCatalystMesh_time_0.vtpc"); + checkTestOutputFileExists("iossDatabaseCatalystMesh_time_1.vtpc"); + checkTestOutputFileExists("iossDatabaseCatalystMesh_time_2.vtpc"); + checkTestOutputFileExists("iossDatabaseCatalystMesh_time_3.vtpc"); + checkTestOutputFileExists("iossDatabaseCatalystMesh_time_4.vtpc"); + + CatalystTestFixture::VarAndCompCountVec cellVariables = {{"density", 1}, {"pressure", 1}, + {"temperature", 1}, {"velocity", 3}, + {"object_id", 1}, {"cell_ids", 1}}; + CatalystTestFixture::VarAndCompCountVec pointVariables = {{"cell_node_ids", 1}}; + CatalystTestFixture::VarAndCompCountVec globalVariables; + + checkMeshOutputVariables("iossDatabaseCatalystMesh_time_4.vtpc", cellVariables, pointVariables, + globalVariables, "/IOSS/structured_blocks"); +} + +TEST_CASE_METHOD(CatalystTestFixture, "CatalystExodusVariableComponents", + "[catalyst partitioned data set collection]") +{ + + runCatalystMultiBlockMeshTest("block_crush_1.ex2"); + checkTestOutputFileExists("iossDatabaseCatalystMesh_time_0.vtpc"); + checkTestOutputFileExists("iossDatabaseCatalystMesh_time_10.vtpc"); + + CatalystTestFixture::VarAndCompCountVec cellVariables = { + {"vonmises", 1}, {"stress", 6}, {"object_id", 1}, {"ids", 1}}; + CatalystTestFixture::VarAndCompCountVec pointVariables = { + {"cetan", 1}, {"cftan", 1}, {"vel", 3}, {"displ", 3}, {"ids", 1}}; + CatalystTestFixture::VarAndCompCountVec globalVariables = {{"momentum", 3}, {"kineticenergy", 1}}; + + checkMeshOutputVariables("iossDatabaseCatalystMesh_time_0.vtpc", cellVariables, pointVariables, + globalVariables, "/IOSS/element_blocks"); +} + +TEST_CASE_METHOD(CatalystTestFixture, "CatalystCGNSPartitionedDataSetCollectionStructure", + "[catalyst partitioned data set collection]") +{ + + runCatalystMultiBlockMeshTest("aero_blunt_wedge_test3.cgns"); + StringVec partitions = {"blk-1"}; + StringVec searchQueries = {"/IOSS/structured_blocks/blk-1"}; + checkPartitionedDataSetCollectionStructure("iossDatabaseCatalystMesh_time_4.vtpc", partitions, 16, + searchQueries); +} + +TEST_CASE_METHOD(CatalystTestFixture, "CatalystExodusPartitionedDataSetCollectionStructure", + "[catalyst partitioned data set collection]") +{ + + runCatalystMultiBlockMeshTest("block_crush_1.ex2"); + StringVec partitions = {"block_1", "block_2", "rigidbodyoutputpart"}; + StringVec searchQueries = {"/IOSS/element_blocks/block_1", "/IOSS/element_blocks/block_2", + "/IOSS/element_blocks/rigidbodyoutputpart"}; + checkPartitionedDataSetCollectionStructure("iossDatabaseCatalystMesh_time_10.vtpc", partitions, + 132, searchQueries); +} diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/CatalystV2ScriptFromParaViewGuiTest1.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/CatalystV2ScriptFromParaViewGuiTest1.cxx index 50652c94f2..f22c3dbb21 100644 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/CatalystV2ScriptFromParaViewGuiTest1.cxx +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/CatalystV2ScriptFromParaViewGuiTest1.cxx @@ -10,7 +10,6 @@ TEST_CASE_METHOD(CatalystTestFixture, "CatalystV2ScriptFromParaViewGuiTest1", "[paraview gui generated catalyst script]") { - //runPhactoriJSONTestTwoGrid("test7.json", "aero_blunt_wedge_test3.cgns", "aero_blunt_wedge_wall_test3.ex2"); runParaViewGuiScriptTest("aero_blunt_wedge_pv590_script_1.py", "aero_blunt_wedge_test3.cgns"); checkTestOutputFileExists("test8_000004.png"); } diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/TwoGridsTwoPipelinesTests.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/TwoGridsTwoPipelinesTests.cxx new file mode 100644 index 0000000000..0ec9653707 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/pipeline/TwoGridsTwoPipelinesTests.cxx @@ -0,0 +1,21 @@ +// Copyright(C) 1999-2021 National Technology & Engineering Solutions +// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +// NTESS, the U.S. Government retains certain rights in this software. +// +// See packages/seacas/LICENSE for details + +#include "CatalystTestFixture.h" +#include "catch.hpp" + +TEST_CASE_METHOD(CatalystTestFixture, + "TwoGridInputTest1_cgns_ex2", "[cgns to catalyst script]") { + //runPhactoriJSONTestTwoGridTwoPipe("test9a.json", "aero_blunt_wedge_test3.cgns", + // "test9b.json", "block_crush_1.ex2"); + runPhactoriJSONTestTwoGridTwoPipe( + "test9a.json", "aero_blunt_wedge_test3.cgns", + "test9b.json", "block_crush_1.ex2" + ); + checkTestOutputFileExists("CatalystOutput_test9/test9_inputA.0000.png"); + checkTestOutputFileExists("CatalystOutput_test9/test9_inputB.0000.png"); +} + diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/version/CMakeLists.txt b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/version/CMakeLists.txt new file mode 100644 index 0000000000..e74c9cbac5 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/version/CMakeLists.txt @@ -0,0 +1,7 @@ +ADD_EXECUTABLE(CatalystVersionTests + CatalystVersionTests.cxx) +TARGET_LINK_LIBRARIES(CatalystVersionTests + catalystiosstest) + +addCatalystTest("Catalyst_Version" "1" + ${CMAKE_CURRENT_BINARY_DIR}/CatalystVersionTests "") diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/test/version/CatalystVersionTests.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/version/CatalystVersionTests.cxx new file mode 100644 index 0000000000..61c4f9eb06 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/catalyst/test/version/CatalystVersionTests.cxx @@ -0,0 +1,38 @@ +// Copyright(C) 1999-2021 National Technology & Engineering Solutions +// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +// NTESS, the U.S. Government retains certain rights in this software. +// +// See packages/seacas/LICENSE for details + +#include "catch.hpp" +#include + +TEST_CASE_METHOD(Iovs::CatalystVersion, "CatalystVersion", "[catalystVersion]") +{ + + REQUIRE(getIOSSCatalystInterfaceVersion() == iossCatalystInterfaceVersion); +} + +TEST_CASE_METHOD(Iovs::CatalystVersion, "PluginInterfaceSameVersion", "[catalystVersion]") +{ + + REQUIRE(isInterfaceCompatibleWithPlugin("1.0.0", "1.0.0") == true); + REQUIRE(isInterfaceCompatibleWithPlugin("1.3.0", "1.3.0") == true); + REQUIRE(isInterfaceCompatibleWithPlugin("1.3.7", "1.3.7") == true); +} + +TEST_CASE_METHOD(Iovs::CatalystVersion, "InterfaceOlderVersionThanPlugin", "[catalystVersion]") +{ + + REQUIRE(isInterfaceCompatibleWithPlugin("1.0.0", "2.0.0") == false); + REQUIRE(isInterfaceCompatibleWithPlugin("1.3.0", "1.4.0") == true); + REQUIRE(isInterfaceCompatibleWithPlugin("1.5.72", "1.5.99") == true); +} + +TEST_CASE_METHOD(Iovs::CatalystVersion, "InterfaceNewerVersionThanPlugin", "[catalystVersion]") +{ + + REQUIRE(isInterfaceCompatibleWithPlugin("4.0.0", "1.0.0") == false); + REQUIRE(isInterfaceCompatibleWithPlugin("2.7.2", "2.6.4") == false); + REQUIRE(isInterfaceCompatibleWithPlugin("2.7.98", "2.7.90") == false); +} diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/vtkCGNSMultiBlockDataSet.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/vtkCGNSMultiBlockDataSet.cxx deleted file mode 100644 index 0914787154..0000000000 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/vtkCGNSMultiBlockDataSet.cxx +++ /dev/null @@ -1,168 +0,0 @@ -// Copyright(C) 1999-2021 National Technology & Engineering Solutions -// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with -// NTESS, the U.S. Government retains certain rights in this software. -// -// See packages/seacas/LICENSE for details - -#include "include/vtkCGNSMultiBlockDataSet.h" -#include "vtkObjectFactory.h" -#include "vtkInformation.h" -#include "vtkStructuredGrid.h" -#include "vtkPoints.h" -#include "vtkDoubleArray.h" -#include "vtkPointData.h" -#include "vtkCellData.h" -#include - -namespace { - -const unsigned int BASES_BLOCK_ID = 0; -const char * BASES_BLOCK_NAME = "Bases"; - -const unsigned int ZONES_BLOCK_ID = 0; -const char * ZONES_BLOCK_NAME = "Zones"; - -} - -vtkStandardNewMacro(vtkCGNSMultiBlockDataSet); - -vtkCGNSMultiBlockDataSet::vtkCGNSMultiBlockDataSet() -{ - vtkMultiBlockDataSet* b = vtkMultiBlockDataSet::New(); - this->SetBlock(BASES_BLOCK_ID, b); - this->GetMetaData(BASES_BLOCK_ID)->Set(vtkCompositeDataSet::NAME(), BASES_BLOCK_NAME); - b->Delete(); -} - -vtkCGNSMultiBlockDataSet::~vtkCGNSMultiBlockDataSet() -{ -} - -void vtkCGNSMultiBlockDataSet::CreateBase(int base_id, - const std::string& base_name) -{ - if(base_id_to_base_map.find(base_id) != - base_id_to_base_map.end()) { - return; - } - - vtkMultiBlockDataSet *b = vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(BASES_BLOCK_ID)); - vtkMultiBlockDataSet *nb = vtkMultiBlockDataSet::New(); - vtkMultiBlockDataSet *zb = vtkMultiBlockDataSet::New(); - nb->SetBlock(ZONES_BLOCK_ID, zb); - nb->GetMetaData(ZONES_BLOCK_ID)->Set(vtkCompositeDataSet::NAME(), ZONES_BLOCK_NAME); - int location = b->GetNumberOfBlocks(); - b->SetBlock(location, nb); - b->GetMetaData(location)->Set(vtkCompositeDataSet::NAME(), base_name); - nb->Delete(); - zb->Delete(); - - base bs; - bs.base_location = location; - - base_id_to_base_map[base_id] = bs; -} - -void vtkCGNSMultiBlockDataSet::AddStructuredZoneData(int base_id, - int zone_id, - const std::string& zone_name, - const std::string& data_name, - int ni, - int nj, - int nk, - int comp_count, - bool is_cell_field, - char field_suffix_separator, - double* data, - int size) -{ - if(base_id_to_base_map.find(base_id) == - base_id_to_base_map.end()) { - return; - } - - base& bs = base_id_to_base_map[base_id]; - int dims[3] = {ni+1,nj+1,nk+1}; - vtkMultiBlockDataSet *bases = vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(BASES_BLOCK_ID)); - vtkMultiBlockDataSet *base = vtkMultiBlockDataSet::SafeDownCast(bases->GetBlock(bs.base_location)); - vtkMultiBlockDataSet *zones = vtkMultiBlockDataSet::SafeDownCast(base->GetBlock(ZONES_BLOCK_ID)); - - //if this is an empty block, we just need to make a NULL grid with the - //proper name, and we don't need to add any data variables - //alternative is to make block with dims of (I think) -1,-1,-1 - //or extents of [0,-1,0,-1,0,-1] (I think) - if((ni == 0) or (nj == 0) or (nk == 0)) { - if(bs.zone_id_to_zone_location_map.find(zone_id) == - bs.zone_id_to_zone_location_map.end()) { - int location = zones->GetNumberOfBlocks(); - vtkStructuredGrid* sg = NULL; - zones->SetBlock(location, sg); - zones->GetMetaData(location)->Set(vtkCompositeDataSet::NAME(), zone_name); - bs.zone_id_to_zone_location_map[zone_id] = location; - } - return; - } - - if(bs.zone_id_to_zone_location_map.find(zone_id) == - bs.zone_id_to_zone_location_map.end()) { - int location = zones->GetNumberOfBlocks(); - vtkStructuredGrid* sg = vtkStructuredGrid::New(); - vtkPoints* pts = vtkPoints::New(); - sg->SetDimensions(dims); - pts->Allocate(dims[0]*dims[1]*dims[2]); - sg->SetPoints(pts); - zones->SetBlock(location, sg); - zones->GetMetaData(location)->Set(vtkCompositeDataSet::NAME(), zone_name); - sg->Delete(); - pts->Delete(); - bs.zone_id_to_zone_location_map[zone_id] = location; - } - - int zone_location = bs.zone_id_to_zone_location_map[zone_id]; - vtkStructuredGrid *sg = vtkStructuredGrid::SafeDownCast(zones->GetBlock(zone_location)); - - int index = -1; - if(data_name == "mesh_model_coordinates_x") { - index = 0; - } - else if(data_name == "mesh_model_coordinates_y") { - index = 1; - } - else if(data_name == "mesh_model_coordinates_z") { - index = 2; - } - - if(index >= 0) { - vtkPoints* pts = sg->GetPoints(); - for(int i=0; iGetPoint(i, p); - p[index] = data[i]; - pts->InsertPoint(i, p); - } - } - else { - - for(int i=0; iSetName((data_name + field_suffix_separator + oss.str()).c_str()); - da->SetNumberOfComponents(1); - da->SetNumberOfTuples(size); - for(int j=0; jInsertValue(j, data[comp_count * j + i]); - } - - if(is_cell_field) { - sg->GetCellData()->AddArray(da); - } - else { - sg->GetPointData()->AddArray(da); - } - da->Delete(); - } - } -} - -void vtkCGNSMultiBlockDataSet::PrintSelf(ostream &os, vtkIndent indent) {} diff --git a/packages/seacas/libraries/ioss/src/visualization/catalyst/vtkExodusIIMultiBlockDataSet.cxx b/packages/seacas/libraries/ioss/src/visualization/catalyst/vtkExodusIIMultiBlockDataSet.cxx deleted file mode 100644 index 721b882adc..0000000000 --- a/packages/seacas/libraries/ioss/src/visualization/catalyst/vtkExodusIIMultiBlockDataSet.cxx +++ /dev/null @@ -1,1040 +0,0 @@ -// Copyright(C) 1999-2021 National Technology & Engineering Solutions -// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with -// NTESS, the U.S. Government retains certain rights in this software. -// -// See packages/seacas/LICENSE for details - -#include "vtkExodusIIMultiBlockDataSet.h" -#include "vtkCell.h" -#include "vtkCellData.h" -#include "vtkCellType.h" -#include "vtkCompositeDataIterator.h" -#include "vtkDoubleArray.h" -#include "vtkFieldData.h" -#include "vtkInformation.h" -#include "vtkObjectFactory.h" -#include "vtkPointData.h" -#include "vtkUnstructuredGrid.h" -#include "vtksys/SystemTools.hxx" -#include -#include - -const unsigned int ELEMENT_BLOCK_MBDS_ID = 0; -const char * ELEMENT_BLOCK_MBDS_NAME = "Element Blocks"; - -const unsigned int FACE_BLOCKS_MBDS_ID = 1; -const char * FACE_BLOCKS_MBDS_NAME = "Face Blocks"; - -const unsigned int EDGE_BLOCKS_MBDS_ID = 2; -const char * EDGE_BLOCKS_MBDS_NAME = "Edge Blocks"; - -const unsigned int ELEMENT_SETS_MBDS_ID = 3; -const char * ELEMENT_SETS_MBDS_NAME = "Element Sets"; - -const unsigned int SIDE_SETS_MBDS_ID = 4; -const char * SIDE_SETS_MBDS_NAME = "Side Sets"; - -const unsigned int FACE_SETS_MBDS_ID = 5; -const char * FACE_SETS_MBDS_NAME = "Face Sets"; - -const unsigned int EDGE_SETS_MBDS_ID = 6; -const char * EDGE_SETS_MBDS_NAME = "Edge Sets"; - -const unsigned int NODE_SETS_MBDS_ID = 7; -const char * NODE_SETS_MBDS_NAME = "Node Sets"; - -const int HEXAHEDRON_FACE_MAP[6] = {2, 1, 3, 0, 4, 5}; -const int WEDGE_FACE_MAP[5] = {2, 3, 4, 0, 1}; - -vtkStandardNewMacro(vtkExodusIIMultiBlockDataSet); - -vtkExodusIIMultiBlockDataSet::vtkExodusIIMultiBlockDataSet() -{ - this->global_points = 0; - this->num_global_points = 0; - this->UnderscoreVectors = 1; - this->ApplyDisplacements = 1; -} - -Ve2mSideSetInfo::Ve2mSideSetInfo() { this->bid = -1; } - -Ve2mSideSetInfo::~Ve2mSideSetInfo() -{ - this->unique_points.clear(); - this->object_ids.clear(); -} - -vtkExodusIIMultiBlockDataSet::~vtkExodusIIMultiBlockDataSet() -{ - this->ReleaseGlobalPoints(); - this->ebmap.clear(); - this->ebmap_reverse.clear(); - this->global_elem_id_map.clear(); - this->global_point_id_to_global_elem_id.clear(); - this->ebidmap.clear(); - this->nsmap.clear(); - this->nsidmap.clear(); - this->ssmap.clear(); - this->ssidmap.clear(); - std::map::iterator ssinfomapiter; - for (ssinfomapiter = this->ssinfomap.begin(); ssinfomapiter != this->ssinfomap.end(); - ssinfomapiter++) { - if (ssinfomapiter->second != NULL) { - delete ssinfomapiter->second; - } - } - this->ssinfomap.clear(); -} - -void vtkExodusIIMultiBlockDataSet::ReleaseGlobalPoints() -{ - if (this->global_points) { - this->global_points->Delete(); - this->global_points = 0; - } -} - -void vtkExodusIIMultiBlockDataSet::InitializeGlobalPoints(int num_points, int dimension, - const double *data) -{ - this->global_point_id_to_global_elem_id.resize(num_points); - this->num_global_points = num_points; - this->global_points = vtkPoints::New(); - this->global_points->SetNumberOfPoints(num_points); - vtkDoubleArray *coords = vtkDoubleArray::New(); - coords->SetNumberOfComponents(3); - coords->SetNumberOfTuples(num_points); - int index = 0; - for (int i = 0; i < num_points; i++) { - coords->SetComponent(i, 0, data[index++]); - coords->SetComponent(i, 1, data[index++]); - if (dimension != 2) - coords->SetComponent(i, 2, data[index++]); - else - coords->SetComponent(i, 2, 0.0); - } - this->global_points->SetData(coords); - coords->Delete(); -} - -void vtkExodusIIMultiBlockDataSet::InitializeElementBlocks( - const std::vector &element_block_id_list) -{ - this->Initialize(); - this->ReleaseGlobalPoints(); - this->ebmap.clear(); - this->ebmap_reverse.clear(); - this->global_elem_id_map.clear(); - this->global_point_id_to_global_elem_id.clear(); - this->ebidmap.clear(); - this->nsmap.clear(); - this->nsidmap.clear(); - this->ssmap.clear(); - this->ssidmap.clear(); - - vtkMultiBlockDataSet *eb = vtkMultiBlockDataSet::New(); - this->SetBlock(ELEMENT_BLOCK_MBDS_ID, eb); - this->GetMetaData(ELEMENT_BLOCK_MBDS_ID) - ->Set(vtkCompositeDataSet::NAME(), ELEMENT_BLOCK_MBDS_NAME); - - for (unsigned int i = 0; i < element_block_id_list.size(); i++) { - this->ebidmap[element_block_id_list[i]] = i; - vtkUnstructuredGrid *ug = vtkUnstructuredGrid::New(); - eb->SetBlock(i, ug); - ug->Delete(); - } - - eb->Delete(); - - eb = vtkMultiBlockDataSet::New(); - this->SetBlock(FACE_BLOCKS_MBDS_ID, eb); - this->GetMetaData(FACE_BLOCKS_MBDS_ID)->Set(vtkCompositeDataSet::NAME(), FACE_BLOCKS_MBDS_NAME); - eb->Delete(); - - eb = vtkMultiBlockDataSet::New(); - this->SetBlock(EDGE_BLOCKS_MBDS_ID, eb); - this->GetMetaData(EDGE_BLOCKS_MBDS_ID)->Set(vtkCompositeDataSet::NAME(), EDGE_BLOCKS_MBDS_NAME); - eb->Delete(); - - eb = vtkMultiBlockDataSet::New(); - this->SetBlock(ELEMENT_SETS_MBDS_ID, eb); - this->GetMetaData(ELEMENT_SETS_MBDS_ID)->Set(vtkCompositeDataSet::NAME(), ELEMENT_SETS_MBDS_NAME); - eb->Delete(); - - eb = vtkMultiBlockDataSet::New(); - this->SetBlock(SIDE_SETS_MBDS_ID, eb); - this->GetMetaData(SIDE_SETS_MBDS_ID)->Set(vtkCompositeDataSet::NAME(), SIDE_SETS_MBDS_NAME); - eb->Delete(); - - eb = vtkMultiBlockDataSet::New(); - this->SetBlock(FACE_SETS_MBDS_ID, eb); - this->GetMetaData(FACE_SETS_MBDS_ID)->Set(vtkCompositeDataSet::NAME(), FACE_SETS_MBDS_NAME); - eb->Delete(); - - eb = vtkMultiBlockDataSet::New(); - this->SetBlock(EDGE_SETS_MBDS_ID, eb); - this->GetMetaData(EDGE_SETS_MBDS_ID)->Set(vtkCompositeDataSet::NAME(), EDGE_SETS_MBDS_NAME); - eb->Delete(); - - eb = vtkMultiBlockDataSet::New(); - this->SetBlock(NODE_SETS_MBDS_ID, eb); - this->GetMetaData(NODE_SETS_MBDS_ID)->Set(vtkCompositeDataSet::NAME(), NODE_SETS_MBDS_NAME); - eb->Delete(); -} - -void vtkExodusIIMultiBlockDataSet::CreateGlobalVariableInternal( - std::vector &component_names, vtkMultiBlockDataSet *eb, unsigned int bid, - vtkVariant &v, const void *data) -{ - int number_data_components = 1; - std::vector prefix_name; - this->ContainsVector(component_names, prefix_name); - std::vector component_names_buffer = component_names; - if (prefix_name.size() == 1) { - number_data_components = component_names.size(); - component_names_buffer = prefix_name; - } - - vtkUnstructuredGrid *ug = vtkUnstructuredGrid::SafeDownCast(eb->GetBlock(bid)); - assert(ug != 0); - vtkFieldData * field_data = ug->GetFieldData(); - std::vector data_arrays; - for (std::vector::iterator it = component_names_buffer.begin(); - it != component_names_buffer.end(); ++it) { - vtkDataArray *da = field_data->GetArray((*it).c_str()); - if (da) - field_data->RemoveArray((*it).c_str()); - vtkDataArray *arr = vtkDataArray::CreateDataArray(v.GetType()); - arr->SetName((*it).c_str()); - arr->SetNumberOfComponents(number_data_components); - arr->SetNumberOfTuples(1); - field_data->AddArray(arr); - data_arrays.push_back(arr); - arr->Delete(); - } - - int index = 0; - for (std::vector::iterator it = data_arrays.begin(); it != data_arrays.end(); - ++it) { - for (int c = 0; c < number_data_components; c++) { - (*it)->SetComponent(0, c, this->GetArrayValue(v, data, index++)); - } - } -} - -void vtkExodusIIMultiBlockDataSet::CreateGlobalVariable(std::vector &component_names, - vtkVariant &v, const void *data) -{ - vtkMultiBlockDataSet *eb = - vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(ELEMENT_BLOCK_MBDS_ID)); - assert(eb != 0); - - for (std::map::iterator iter = this->ebidmap.begin(); - iter != this->ebidmap.end(); ++iter) { - this->CreateGlobalVariableInternal(component_names, eb, iter->second, v, data); - } - - eb = vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(NODE_SETS_MBDS_ID)); - assert(eb != 0); - - for (std::map::iterator iter = this->nsidmap.begin(); - iter != this->nsidmap.end(); ++iter) { - this->CreateGlobalVariableInternal(component_names, eb, iter->second, v, data); - } - - eb = vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(SIDE_SETS_MBDS_ID)); - assert(eb != 0); - - for (std::map::iterator iter = this->ssidmap.begin(); - iter != this->ssidmap.end(); ++iter) { - this->CreateGlobalVariableInternal(component_names, eb, iter->second, v, data); - } -} - -void vtkExodusIIMultiBlockDataSet::CreateElementBlock(const char * elem_block_name, - int elem_block_id, - const std::string &elem_type, - int nodes_per_elem, int num_elem, - vtkVariant &v, const int64_t *global_elem_ids, - void *connectivity) -{ - assert(this->global_points != 0); - - std::string elemType(vtksys::SystemTools::UpperCase(elem_type)); - - int point_count; - int vtk_type; - - // Check for quadratic elements - if ((elemType.substr(0, 3) == "TRI") && (nodes_per_elem == 6)) { - vtk_type = VTK_QUADRATIC_TRIANGLE; - point_count = 6; - } - else if ((elemType.substr(0, 3) == "SHE") && (nodes_per_elem == 8)) { - vtk_type = VTK_QUADRATIC_QUAD; - point_count = 8; - } - else if ((elemType.substr(0, 3) == "SHE") && (nodes_per_elem == 9)) { - vtk_type = VTK_QUADRATIC_QUAD; - point_count = 8; - } - else if ((elemType.substr(0, 3) == "TET") && (nodes_per_elem == 10)) { - vtk_type = VTK_QUADRATIC_TETRA; - point_count = 10; - } - else if ((elemType.substr(0, 3) == "TET") && (nodes_per_elem == 11)) { - vtk_type = VTK_QUADRATIC_TETRA; - point_count = 10; - } - else if ((elemType.substr(0, 3) == "WED") && (nodes_per_elem == 15)) { - vtk_type = VTK_QUADRATIC_WEDGE; - point_count = 15; - } - else if (((elemType.substr(0, 3) == "HEX") && (nodes_per_elem == 20)) || - ((elemType.substr(0, 3) == "HEX") && (nodes_per_elem == 21))) { - vtk_type = VTK_QUADRATIC_HEXAHEDRON; - point_count = 20; - } - else if ((elemType.substr(0, 3) == "HEX") && (nodes_per_elem == 27)) { - vtk_type = VTK_TRIQUADRATIC_HEXAHEDRON; - point_count = 27; - } - else if ((elemType.substr(0, 3) == "QUA") && (nodes_per_elem == 8)) { - vtk_type = VTK_QUADRATIC_QUAD; - point_count = 8; - } - else if ((elemType.substr(0, 3) == "QUA") && (nodes_per_elem == 9)) { - vtk_type = VTK_BIQUADRATIC_QUAD; - point_count = 9; - } - else if ((elemType.substr(0, 3) == "TRU") && (nodes_per_elem == 3)) { - vtk_type = VTK_QUADRATIC_EDGE; - point_count = 3; - } - else if ((elemType.substr(0, 3) == "BEA") && (nodes_per_elem == 3)) { - vtk_type = VTK_QUADRATIC_EDGE; - point_count = 3; - } - else if ((elemType.substr(0, 3) == "BAR") && (nodes_per_elem == 3)) { - vtk_type = VTK_QUADRATIC_EDGE; - point_count = 3; - } - else if ((elemType.substr(0, 3) == "EDG") && (nodes_per_elem == 3)) { - vtk_type = VTK_QUADRATIC_EDGE; - point_count = 3; - } - - // Check for linear elements - else if (elemType.substr(0, 3) == "CIR") { - vtk_type = VTK_VERTEX; - point_count = 1; - } - else if (elemType.substr(0, 3) == "SPH") { - vtk_type = VTK_VERTEX; - point_count = 1; - } - else if (elemType.substr(0, 3) == "BAR") { - vtk_type = VTK_LINE; - point_count = 2; - } - else if (elemType.substr(0, 3) == "TRU") { - vtk_type = VTK_LINE; - point_count = 2; - } - else if (elemType.substr(0, 3) == "BEA") { - vtk_type = VTK_LINE; - point_count = 2; - } - else if (elemType.substr(0, 3) == "EDG") { - vtk_type = VTK_LINE; - point_count = 2; - } - else if (elemType.substr(0, 3) == "TRI") { - vtk_type = VTK_TRIANGLE; - point_count = 3; - } - else if (elemType.substr(0, 3) == "QUA") { - vtk_type = VTK_QUAD; - point_count = 4; - } - else if (elemType.substr(0, 3) == "TET") { - vtk_type = VTK_TETRA; - point_count = 4; - } - else if (elemType.substr(0, 3) == "PYR") { - vtk_type = VTK_PYRAMID; - point_count = 5; - } - else if (elemType.substr(0, 3) == "WED") { - vtk_type = VTK_WEDGE; - point_count = 6; - } - else if (elemType.substr(0, 3) == "HEX") { - vtk_type = VTK_HEXAHEDRON; - point_count = 8; - } - else if (elemType.substr(0, 3) == "NSI") { - vtk_type = VTK_POLYGON; - point_count = 0; - } - else if (elemType.substr(0, 3) == "NFA") { - vtk_type = VTK_POLYHEDRON; - point_count = 0; - } - else if ((elemType.substr(0, 3) == "SHE") && (nodes_per_elem == 3)) { - vtk_type = VTK_TRIANGLE; - point_count = 3; - } - else if ((elemType.substr(0, 3) == "SHE") && (nodes_per_elem == 4)) { - vtk_type = VTK_QUAD; - point_count = 4; - } - else if ((elemType.substr(0, 8) == "STRAIGHT") && (nodes_per_elem == 2)) { - vtk_type = VTK_LINE; - point_count = 2; - } - else if (elemType.substr(0, 3) == "SUP") { - vtk_type = VTK_POLY_VERTEX; - point_count = nodes_per_elem; - } - else if ((elemType.substr(0, 4) == "NULL") && (num_elem == 0)) { - vtkErrorMacro("NULL element block found"); - vtkErrorMacro("Unable to create element block " << elem_block_name); - this->RemoveBlock(ELEMENT_BLOCK_MBDS_ID); - return; // silently ignore empty element blocks - } - else { - vtkErrorMacro("Unsupported element type: " << elemType.c_str()); - vtkErrorMacro("Unable to create element block " << elem_block_name); - this->RemoveBlock(ELEMENT_BLOCK_MBDS_ID); - return; - // cell types not currently handled - // quadratic wedge - 15,16 nodes - // quadratic pyramid - 13 nodes - } - - vtkIdType cell_vertex_order[point_count]; - for (int p = 0; p < point_count; p++) { - cell_vertex_order[p] = p; - } - - if (vtk_type == VTK_QUADRATIC_WEDGE) { - cell_vertex_order[12] = 9; - cell_vertex_order[13] = 10; - cell_vertex_order[14] = 11; - - cell_vertex_order[9] = 12; - cell_vertex_order[10] = 13; - cell_vertex_order[11] = 14; - } - else if (vtk_type == VTK_QUADRATIC_HEXAHEDRON) { - cell_vertex_order[16] = 12; - cell_vertex_order[17] = 13; - cell_vertex_order[18] = 14; - cell_vertex_order[19] = 15; - - cell_vertex_order[12] = 16; - cell_vertex_order[13] = 17; - cell_vertex_order[14] = 18; - cell_vertex_order[15] = 19; - } - else if (vtk_type == VTK_TRIQUADRATIC_HEXAHEDRON) { - cell_vertex_order[16] = 12; - cell_vertex_order[17] = 13; - cell_vertex_order[18] = 14; - cell_vertex_order[19] = 15; - - cell_vertex_order[12] = 16; - cell_vertex_order[13] = 17; - cell_vertex_order[14] = 18; - cell_vertex_order[15] = 19; - - cell_vertex_order[23] = 20; - cell_vertex_order[24] = 21; - cell_vertex_order[25] = 22; - cell_vertex_order[26] = 23; - - cell_vertex_order[21] = 24; - cell_vertex_order[22] = 25; - cell_vertex_order[20] = 26; - } - - vtkIdType pts[point_count]; - int index = 0; - while (index < num_elem * point_count) { - for (int p = 0; p < point_count; p++) { - int index_orig = index; - - int64_t conn_ind = this->GetArrayValue(v, connectivity, index_orig) - 1; - this->ebmap[elem_block_id][conn_ind] = -1; - - /*this->ebmap[elem_block_id][(vtkIdType) connectivity[index_orig] - 1] = -1; */ - - index++; - } - if (point_count < nodes_per_elem) { - for (int p = 0; p < (nodes_per_elem - point_count); p++) - index++; - } - } - - vtkMultiBlockDataSet *eb = - vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(ELEMENT_BLOCK_MBDS_ID)); - assert(eb != 0); - vtkUnstructuredGrid *ug = - vtkUnstructuredGrid::SafeDownCast(eb->GetBlock(this->ebidmap[elem_block_id])); - assert(ug != 0); - vtkPoints *points = vtkPoints::New(); - double x[3]; - vtkIdType i = 0; - for (std::map::iterator ii = this->ebmap[elem_block_id].begin(); - ii != this->ebmap[elem_block_id].end(); ++ii) { - this->global_points->GetPoint((*ii).first, x); - (*ii).second = i; - this->ebmap_reverse[elem_block_id][i] = (*ii).first; - points->InsertNextPoint(x); - i++; - } - - index = 0; - std::vector object_ids; - while (index < num_elem * point_count) { - for (int p = 0; p < point_count; p++) { - int64_t conn_ind = this->GetArrayValue(v, connectivity, index) - 1; - this->global_point_id_to_global_elem_id[conn_ind] = global_elem_ids[ug->GetNumberOfCells()]; - - conn_ind = this->GetArrayValue(v, connectivity, index++) - 1; - pts[cell_vertex_order[p]] = this->ebmap[elem_block_id][conn_ind]; - - /*this->global_point_id_to_global_elem_id[(vtkIdType) connectivity[index] - 1] = - this->GetArrayValue(v,global_elem_ids,ug->GetNumberOfCells()); - pts[cell_vertex_order[p]] = this->ebmap[elem_block_id][(vtkIdType) connectivity[index++] - 1]; - */ - } - if (point_count < nodes_per_elem) { - for (int p = 0; p < (nodes_per_elem - point_count); p++) { - int64_t conn_ind = this->GetArrayValue(v, connectivity, index) - 1; - this->global_point_id_to_global_elem_id[conn_ind] = global_elem_ids[ug->GetNumberOfCells()]; - - /* this->global_point_id_to_global_elem_id[(vtkIdType) connectivity[index] - 1] = - this->GetArrayValue(v,global_elem_ids,ug->GetNumberOfCells()); */ - - index++; - } - } - - this->global_elem_id_map[elem_block_id][global_elem_ids[ug->GetNumberOfCells()]] = - ug->GetNumberOfCells(); - - /* this->global_elem_id_map[elem_block_id][this->GetArrayValue(v,global_elem_ids,ug->GetNumberOfCells())] - * = ug->GetNumberOfCells(); */ - - ug->InsertNextCell(vtk_type, point_count, pts); - object_ids.push_back(this->ebidmap[elem_block_id]); - } - - ug->SetPoints(points); - eb->GetMetaData(this->ebidmap[elem_block_id])->Set(vtkCompositeDataSet::NAME(), elem_block_name); - points->Delete(); - - std::vector element_block_name; - element_block_name.push_back("ElementBlockIds"); - vtkVariant vb((int)this->ebidmap[elem_block_id]); - int bid = this->ebidmap[elem_block_id]; - this->CreateGlobalVariableInternal(element_block_name, eb, this->ebidmap[elem_block_id], vb, - &bid); - - std::vector component_names; - component_names.push_back("ObjectId"); - this->CreateElementVariableInternal(component_names, eb, bid, vb, &object_ids[0]); -} - -void vtkExodusIIMultiBlockDataSet::CreateElementVariableInternal( - std::vector &component_names, vtkMultiBlockDataSet *eb, unsigned int bid, - vtkVariant &v, const void *data) -{ - vtkUnstructuredGrid *ug = vtkUnstructuredGrid::SafeDownCast(eb->GetBlock(bid)); - assert(ug != 0); - - int number_data_components = 1; - std::vector prefix_name; - this->ContainsVector(component_names, prefix_name); - std::vector component_names_buffer = component_names; - if (prefix_name.size() == 1) { - number_data_components = component_names.size(); - component_names_buffer = prefix_name; - } - - vtkFieldData * cell_data = ug->GetCellData(); - std::vector data_arrays; - for (std::vector::iterator it = component_names_buffer.begin(); - it != component_names_buffer.end(); ++it) { - vtkDataArray *da = cell_data->GetArray((*it).c_str()); - if (da) - cell_data->RemoveArray((*it).c_str()); - vtkDataArray *arr = vtkDataArray::CreateDataArray(v.GetType()); - arr->SetName((*it).c_str()); - arr->SetNumberOfComponents(number_data_components); - arr->SetNumberOfTuples(ug->GetNumberOfCells()); - cell_data->AddArray(arr); - data_arrays.push_back(arr); - arr->Delete(); - } - - const double *dp = static_cast(data); - int index = 0; - for (int i = 0; i < ug->GetNumberOfCells(); i++) { - for (std::vector::iterator it = data_arrays.begin(); it != data_arrays.end(); - ++it) { - for (int c = 0; c < number_data_components; c++) { - (*it)->SetComponent(i, c, this->GetArrayValue(v, data, index++)); - } - } - } -} - -void vtkExodusIIMultiBlockDataSet::CreateElementVariable(std::vector &component_names, - int elem_block_id, vtkVariant &v, - const void *data) -{ - vtkMultiBlockDataSet *eb = - vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(ELEMENT_BLOCK_MBDS_ID)); - assert(eb != 0); - - this->CreateElementVariableInternal(component_names, eb, this->ebidmap[elem_block_id], v, data); -} - -void vtkExodusIIMultiBlockDataSet::CreateNodalVariableInternal( - std::vector &component_names, vtkMultiBlockDataSet *eb, - std::map &id_map, std::map> &point_map, - vtkVariant &v, const void *data) -{ - // std::cerr << "vtkExodusIIMultiBlockDataSet::CreateNodalVariableInternal entered\n"; - int number_data_components = 1; - std::vector prefix_name; - bool displace_nodes = false; - this->ContainsVector(component_names, prefix_name); - std::vector component_names_buffer = component_names; - if (prefix_name.size() == 1) { - number_data_components = component_names.size(); - component_names_buffer = prefix_name; - if (this->ApplyDisplacements && (number_data_components <= 3) && - (prefix_name[0].length() >= 3)) { - if ((prefix_name[0].substr(0, 3) == "DIS") || (prefix_name[0].substr(0, 3) == "dis")) - displace_nodes = true; - } - } - - for (std::map::iterator iter = id_map.begin(); iter != id_map.end(); ++iter) { - vtkUnstructuredGrid *ug = vtkUnstructuredGrid::SafeDownCast(eb->GetBlock(iter->second)); - if (!ug) { - continue; - } - if (ug->GetNumberOfCells() == 0) { - continue; - } - vtkFieldData * point_data = ug->GetPointData(); - std::vector data_arrays; - - for (std::vector::iterator it = component_names_buffer.begin(); - it != component_names_buffer.end(); ++it) { - vtkDataArray *da = point_data->GetArray((*it).c_str()); - if (da) { - point_data->RemoveArray((*it).c_str()); - } - vtkDataArray *arr = vtkDataArray::CreateDataArray(v.GetType()); - arr->SetName((*it).c_str()); - arr->SetNumberOfComponents(number_data_components); - arr->SetNumberOfTuples(ug->GetPoints()->GetNumberOfPoints()); - point_data->AddArray(arr); - data_arrays.push_back(arr); - arr->Delete(); - } - - int index = 0; - for (int i = 0; i < this->num_global_points; i++) { - std::map::iterator mit = point_map[iter->first].find(i); - for (std::vector::iterator it = data_arrays.begin(); it != data_arrays.end(); - ++it) { - for (int c = 0; c < number_data_components; c++) { - if (mit != point_map[iter->first].end()) { - (*it)->SetComponent(point_map[iter->first][i], c, - this->GetArrayValue(v, data, index++)); - } - else { - index++; - } - } - - if (displace_nodes) { - if (mit != point_map[iter->first].end()) { - vtkPoints *points = ug->GetPoints(); - double x[3]; - this->global_points->GetPoint(i, x); - for (int c = 0; c < number_data_components; c++) - x[c] += (*it)->GetComponent(point_map[iter->first][i], c); - points->SetPoint(point_map[iter->first][i], x); - } - } - } - } - } - // std::cerr << "vtkExodusIIMultiBlockDataSet::CreateNodalVariableInternal returning\n"; -} - -void vtkExodusIIMultiBlockDataSet::CreateNodalVariable(std::vector &component_names, - vtkVariant &v, const void *data) -{ - // std::cerr << "vtkExodusIIMultiBlockDataSet::CreateNodalVariable entered\n"; - - vtkMultiBlockDataSet *eb = - vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(ELEMENT_BLOCK_MBDS_ID)); - assert(eb != 0); - - this->CreateNodalVariableInternal(component_names, eb, this->ebidmap, this->ebmap, v, data); - - eb = vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(NODE_SETS_MBDS_ID)); - assert(eb != 0); - - this->CreateNodalVariableInternal(component_names, eb, this->nsidmap, this->nsmap, v, data); - - eb = vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(SIDE_SETS_MBDS_ID)); - assert(eb != 0); - - this->CreateNodalVariableInternal(component_names, eb, this->ssidmap, this->ssmap, v, data); - // std::cerr << "vtkExodusIIMultiBlockDataSet::CreateNodalVariable returning\n"; -} - -void vtkExodusIIMultiBlockDataSet::CreateNodeSet(const char *node_set_name, int node_set_id, - int num_ids, vtkVariant &v, const void *ids) -{ - vtkMultiBlockDataSet *eb = vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(NODE_SETS_MBDS_ID)); - assert(eb != 0); - unsigned int bid = eb->GetNumberOfBlocks(); - vtkUnstructuredGrid *ug = vtkUnstructuredGrid::New(); - vtkPoints * points = vtkPoints::New(); - points->SetNumberOfPoints(num_ids); - this->nsidmap[node_set_id] = bid; - std::vector object_ids; - std::vector global_element_id; - - for (int i = 0; i < num_ids; i++) { - double x[3]; - vtkIdType ptids[1]; - int id = (int)this->GetArrayValue(v, ids, i) - 1; - this->global_points->GetPoint(id, x); - ptids[0] = (vtkIdType)i; - points->SetPoint(i, x); - ug->InsertNextCell(VTK_VERTEX, 1, ptids); - this->nsmap[node_set_id][id] = i; - object_ids.push_back(node_set_id); - - global_element_id.push_back(this->global_point_id_to_global_elem_id[id]); - } - - ug->SetPoints(points); - eb->SetBlock(bid, ug); - eb->GetMetaData(bid)->Set(vtkCompositeDataSet::NAME(), node_set_name); - ug->Delete(); - points->Delete(); - - if (num_ids > 0) { - std::vector component_names; - component_names.push_back("ObjectId"); - vtkVariant val((int)0); - this->CreateElementVariableInternal(component_names, eb, bid, val, &object_ids[0]); - - component_names.clear(); - component_names.push_back("GlobalElementId"); - this->CreateElementVariableInternal(component_names, eb, bid, val, &global_element_id[0]); - } -} - -void vtkExodusIIMultiBlockDataSet::CreateSideSet(/*const char* side_set_name,*/ - const char *ss_owner_name, int side_set_id, - int num_ids, vtkVariant &v, - const void *element_ids, const void *face_ids) -{ - /* - std::cerr << "vtkExodusIIMultiBlockDataSet::CreateSideSet entered (3)\n" - //"side_set_name: " << side_set_name << "\n" - "ss_owner_name: " << ss_owner_name << "\n" - "side_set_id: " << side_set_id << "\n" - "num_ids: " << num_ids << "\n" - "vtkVariant: " << v << "\n" - "element_ids: " << element_ids << "\n" - "face_ids: " << face_ids << "\n"; - */ - - vtkMultiBlockDataSet *ssb = vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(SIDE_SETS_MBDS_ID)); - vtkMultiBlockDataSet *eb = - vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(ELEMENT_BLOCK_MBDS_ID)); - assert(ssb != 0); - assert(eb != 0); - - // side set can span multiple blocks; we appear to get callback for same - // side set once per block in which the side set exists - // we need to track this situation and only construct one unstructured grid - // per sideset, but put info from every block the sideset spans into the - // unstructured grid (and the map of the point ids) - int newSideSetFlag; - vtkPoints * points = NULL; - vtkUnstructuredGrid *ug = NULL; - unsigned int bid = -1; - - Ve2mSideSetInfo * ssinfo = NULL; - std::map::iterator ssinfomapiter; - ssinfomapiter = this->ssinfomap.find(side_set_id); - if (ssinfomapiter != ssinfomap.end()) { - // std::cerr << "side_set_id already in ssinfomap, so we are adding info\n" - // "from another block\n"; - // we have already seen this side_set_id, so we add this side set rather - // than constructing a new one - newSideSetFlag = 0; - ssinfo = ssinfomapiter->second; - bid = ssinfo->bid; - // ug = ssb->GetBlock(bid); - ug = vtkUnstructuredGrid::SafeDownCast(ssb->GetBlock(bid)); - - points = ug->GetPoints(); - // std::cerr << "prior bid: " << bid << "\n" - // "number of preexisting points: " << points->GetNumberOfPoints() << "\n" - // "prior num of unique points: " << ssinfo->unique_points.size() << "\n" - // "prior num of object_ids: " << ssinfo->object_ids.size() << "\n"; - } - else { - // we have not seen this side_set_id, so we need to create it and add - // it to the map of information about existing side sets - newSideSetFlag = 1; - bid = ssb->GetNumberOfBlocks(); - ug = vtkUnstructuredGrid::New(); - points = vtkPoints::New(); - ssinfo = new Ve2mSideSetInfo(); - ssinfomap[side_set_id] = ssinfo; - ssinfo->bid = bid; - this->ssidmap[side_set_id] = bid; - // std::cerr << "side_set_id not ssinfomap, creating new side set\n" - // "new bid: " << bid << "\n" - // "number of preexisting points: " << points->GetNumberOfPoints() << "\n" - // "new num of unique points: " << ssinfo->unique_points.size() << "\n" - // "new num of object_ids: " << ssinfo->object_ids.size() << "\n"; - } - - // vtkIdType point_index = 0; - // tracking unique points over multiple blocks for same sidesets - vtkIdType point_index = ssinfo->unique_points.size(); - // std::cerr << "point_index starting value: " << point_index << "\n"; - - for (int i = 0; i < num_ids; i++) { - int e_id; - int e_bid; - int face_id; - vtkUnstructuredGrid *eb_ug = 0; - vtkCell * cell = 0; - - for (std::map::iterator iter = this->ebidmap.begin(); - iter != this->ebidmap.end(); ++iter) { - eb_ug = vtkUnstructuredGrid::SafeDownCast(eb->GetBlock(this->ebidmap[iter->first])); - assert(eb_ug != 0); - e_id = this->GetArrayValue(v, element_ids, i); - if (this->global_elem_id_map[iter->first].find(e_id) != - this->global_elem_id_map[iter->first].end()) { - face_id = this->GetArrayValue(v, face_ids, i) - 1; - e_id = this->global_elem_id_map[iter->first][e_id]; - e_bid = iter->first; - cell = eb_ug->GetCell(e_id); - break; - } - } - - if (cell != 0 && cell->GetCellType() != VTK_EMPTY_CELL) { - if (cell->GetCellType() == VTK_HEXAHEDRON || - cell->GetCellType() == VTK_QUADRATIC_HEXAHEDRON || - cell->GetCellType() == VTK_TRIQUADRATIC_HEXAHEDRON) { - face_id = HEXAHEDRON_FACE_MAP[face_id]; - } - else if (cell->GetCellType() == VTK_WEDGE || cell->GetCellType() == VTK_QUADRATIC_WEDGE) { - face_id = WEDGE_FACE_MAP[face_id]; - } - else { - // std::cerr << "cell type was not of 5 selected types:\n"; - // std::cerr << "face id remains: " << face_id << "\n"; - // std::cerr << "cell type was: " << cell->GetCellType() << "\n"; - } - - vtkCell *face = eb_ug->GetCell(e_id)->GetFace(face_id); - if (!face) - face = eb_ug->GetCell(e_id)->GetEdge(face_id); - assert(face != 0); - vtkPoints *face_points = face->GetPoints(); - double x[3]; - vtkIdType pts[face_points->GetNumberOfPoints()]; - - for (int j = 0; j < face_points->GetNumberOfPoints(); j++) { - int global_point_id = this->ebmap_reverse[e_bid][face->GetPointId(j)]; - if (ssinfo->unique_points.find(global_point_id) != ssinfo->unique_points.end()) { - pts[j] = ssinfo->unique_points[global_point_id]; - // std::cerr << "found point: " << pts[j] << "\n"; - // std::cerr << " point index used: " << pts[j] << "\n" - // " point index counter: " << point_index << "\n" - // " num points at find: " << points->GetNumberOfPoints() << "\n"; - if (pts[j] >= points->GetNumberOfPoints()) { - std::cerr << "ERROR!!! BAD INDEX\n"; - } - } - else { - // std::cerr << "about to add new point in side set:\n" - // " point index: " << point_index << "\n" - // " num points before add: " << points->GetNumberOfPoints() << "\n"; - if (point_index > points->GetNumberOfPoints()) { - std::cerr << "ERROR!!! BAD INDEX\n"; - } - ssinfo->unique_points[global_point_id] = point_index; - this->ssmap[side_set_id][global_point_id] = point_index; - pts[j] = point_index++; - face_points->GetPoint(j, x); - points->InsertNextPoint(x); - // std::cerr << "did not find point, added: " << pts[j] << "\n"; - // std::cerr << x[0] << ", " << x[1] << ", " << x[2] << "\n"; - } - } - ug->InsertNextCell(face->GetCellType(), face->GetNumberOfPoints(), pts); - ssinfo->object_ids.push_back(side_set_id); - } - } - - if (newSideSetFlag) { - ug->SetPoints(points); - ssb->SetBlock(bid, ug); - // name may need fixing - // ssb->GetMetaData(bid)->Set(vtkCompositeDataSet::NAME(), side_set_name); - ssb->GetMetaData(bid)->Set(vtkCompositeDataSet::NAME(), ss_owner_name); - ug->Delete(); - points->Delete(); - } - - if (num_ids > 0) { - std::vector component_names; - component_names.push_back("ObjectId"); - vtkVariant val((int)0); - this->CreateElementVariableInternal(component_names, ssb, bid, val, &(ssinfo->object_ids)[0]); - } - - // std::cerr << "vtkExodusIIMultiBlockDataSet::CreateSideSet returning (3)\n"; -} - -void vtkExodusIIMultiBlockDataSet::ReleaseMemoryInternal(vtkMultiBlockDataSet *eb) -{ - vtkCompositeDataIterator *iter = eb->NewIterator(); - for (iter->InitTraversal(); !iter->IsDoneWithTraversal(); iter->GoToNextItem()) { - vtkUnstructuredGrid *ug = vtkUnstructuredGrid::SafeDownCast(iter->GetCurrentDataObject()); - vtkFieldData * data = ug->GetCellData(); - vtkDataArray * global_element_ids = 0; - vtkDataArray * object_id = 0; - while (data->GetNumberOfArrays() > 0) { - if (std::string(data->GetArray(0)->GetName()) == "GlobalElementId") { - global_element_ids = data->GetArray(0); - global_element_ids->Register(0); - } - if (std::string(data->GetArray(0)->GetName()) == "ObjectId") { - object_id = data->GetArray(0); - object_id->Register(0); - } - data->RemoveArray(data->GetArray(0)->GetName()); - } - - if (global_element_ids) { - data->AddArray(global_element_ids); - global_element_ids->Delete(); - } - - if (object_id) { - data->AddArray(object_id); - object_id->Delete(); - } - - data = ug->GetPointData(); - vtkDataArray *global_node_ids = 0; - while (data->GetNumberOfArrays() > 0) { - if (std::string(data->GetArray(0)->GetName()) == "GlobalNodeId") { - global_node_ids = data->GetArray(0); - global_node_ids->Register(0); - } - data->RemoveArray(data->GetArray(0)->GetName()); - } - - if (global_node_ids) { - data->AddArray(global_node_ids); - global_node_ids->Delete(); - } - } - iter->Delete(); -} - -void vtkExodusIIMultiBlockDataSet::ReleaseMemory() -{ - vtkMultiBlockDataSet *eb = - vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(ELEMENT_BLOCK_MBDS_ID)); - assert(eb != 0); - this->ReleaseMemoryInternal(eb); - - eb = vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(NODE_SETS_MBDS_ID)); - assert(eb != 0); - this->ReleaseMemoryInternal(eb); - - eb = vtkMultiBlockDataSet::SafeDownCast(this->GetBlock(SIDE_SETS_MBDS_ID)); - assert(eb != 0); - this->ReleaseMemoryInternal(eb); - - this->ebmap_reverse.clear(); - this->global_elem_id_map.clear(); - this->global_point_id_to_global_elem_id.clear(); -} - -void vtkExodusIIMultiBlockDataSet::ContainsVector(std::vector &component_names, - std::vector &prefix_name) -{ - if (component_names.size() == 3) { - if ((*component_names[0].rbegin() == 'X' || *component_names[0].rbegin() == 'x') && - (*component_names[1].rbegin() == 'Y' || *component_names[1].rbegin() == 'y') && - (*component_names[2].rbegin() == 'Z' || *component_names[2].rbegin() == 'z')) { - prefix_name.push_back(component_names[0].substr(0, component_names[0].size() - 1)); - } - } - else if (component_names.size() == 2) { - if ((*component_names[0].rbegin() == 'X' || *component_names[0].rbegin() == 'x') && - (*component_names[1].rbegin() == 'Y' || *component_names[1].rbegin() == 'y')) { - prefix_name.push_back(component_names[0].substr(0, component_names[0].size() - 1)); - } - } - if (!this->UnderscoreVectors && prefix_name.size() == 1) { - if (*prefix_name[0].rbegin() == '_') { - prefix_name[0] = prefix_name[0].substr(0, prefix_name[0].size() - 1); - } - } -} - -double vtkExodusIIMultiBlockDataSet::GetArrayValue(vtkVariant &v, const void *data, int index) -{ - if (v.IsDouble()) { - return ((double)static_cast(data)[index]); - } - else if (v.IsFloat()) { - return ((double)static_cast(data)[index]); - } - else if (v.IsInt()) { - return ((double)static_cast(data)[index]); - } - else if (v.IsLongLong()) { - return ((double)static_cast(data)[index]); - } - else if (v.IsLong()) { - return ((double)static_cast(data)[index]); - } - else { - vtkErrorMacro("Unhandled type found in GetArrayValue: " << v.GetTypeAsString()); - return 0.0; - } -} - -void vtkExodusIIMultiBlockDataSet::PrintSelf(ostream &os, vtkIndent indent) {} diff --git a/packages/seacas/libraries/ioss/src/visualization/cgns/CatalystCGNSMeshBase.h b/packages/seacas/libraries/ioss/src/visualization/cgns/CatalystCGNSMeshBase.h index 8d02adced2..87b2c320df 100644 --- a/packages/seacas/libraries/ioss/src/visualization/cgns/CatalystCGNSMeshBase.h +++ b/packages/seacas/libraries/ioss/src/visualization/cgns/CatalystCGNSMeshBase.h @@ -7,7 +7,11 @@ #ifndef __CATALYST_CGNS_MESH_BASE_H #define __CATALYST_CGNS_MESH_BASE_H +#ifndef __CATALYST_PLUGIN_BUILD #include "iovs_export.h" +#else +#define IOVS_EXPORT +#endif #include #include @@ -23,7 +27,7 @@ namespace Iovs_cgns { // Description: // Calls the ParaView Catalyst pipeline to run co-processing for this time iteration. - virtual void PerformCoProcessing(std::vector & error_and_warning_codes, + virtual void PerformCoProcessing(std::vector &error_and_warning_codes, std::vector &error_and_warning_messages) = 0; // Description: @@ -33,7 +37,7 @@ namespace Iovs_cgns { virtual void SetTimeData(double currentTime, int timeStep) = 0; // Description: - // Clears all nodal and element variables from the vtkMultiBlockDataSet. + // Clears all nodal and element variables // Clears the global vtkPoints. virtual void ReleaseMemory() = 0; @@ -46,12 +50,26 @@ namespace Iovs_cgns { virtual void Delete() = 0; - virtual void CreateBase(int base_id, const std::string &base_name) = 0; + struct ZoneData + { + int zone_id; + std::string zone_name; + std::string data_name; + int ni; + int nj; + int nk; + int comp_count; + bool is_cell_field; + enum { T_DOUBLE, T_INT, T_INT64 } data_type; + union { + int *p_int; + int64_t *p_int64; + double *p_double; + } data; + int size; + }; - virtual void AddStructuredZoneData(int base_id, int zone_id, const std::string &zone_name, - const std::string &data_name, int ni, int nj, int nk, - int comp_count, bool is_cell_field, - char field_suffix_separator, double *data, int size) = 0; + virtual void AddStructuredZoneData(const ZoneData &zoneData) = 0; }; } // namespace Iovs_cgns diff --git a/packages/seacas/libraries/ioss/src/visualization/cgns/Iovs_cgns_DatabaseIO.C b/packages/seacas/libraries/ioss/src/visualization/cgns/Iovs_cgns_DatabaseIO.C index 974b05b004..c0988da501 100644 --- a/packages/seacas/libraries/ioss/src/visualization/cgns/Iovs_cgns_DatabaseIO.C +++ b/packages/seacas/libraries/ioss/src/visualization/cgns/Iovs_cgns_DatabaseIO.C @@ -1,4 +1,4 @@ -// Copyright(C) 1999-2022 National Technology & Engineering Solutions +// Copyright(C) 1999-2021 National Technology & Engineering Solutions // of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with // NTESS, the U.S. Government retains certain rights in this software. // @@ -27,6 +27,7 @@ namespace Iovs_cgns { dbinfo.databaseFilename = this->DBFilename; dbinfo.separatorCharacter = std::string(1, this->get_field_separator()); dbinfo.parallelUtils = &this->util(); + isIdOutputCreated = false; Iovs::Utils::getInstance().checkDbUsage(db_usage); Iovs::Utils::getInstance().createDatabaseOutputFile(dbinfo); @@ -37,7 +38,7 @@ namespace Iovs_cgns { DatabaseIO::~DatabaseIO() { this->catCGNSMesh->Delete(); } - bool DatabaseIO::begin__(Ioss::State) { return true; } + bool DatabaseIO::begin__(Ioss::State /*state*/) { return true; } bool DatabaseIO::end__(Ioss::State state) { @@ -54,11 +55,15 @@ namespace Iovs_cgns { bool DatabaseIO::begin_state__(int state, double time) { this->catCGNSMesh->ReleaseMemory(); + if (!isIdOutputCreated) { + createIdOutput(); + isIdOutputCreated = true; + } this->catCGNSMesh->SetTimeData(time, state - 1); return true; } - bool DatabaseIO::end_state__(int, double) + bool DatabaseIO::end_state__(int /*state*/, double /*time*/) { std::vector error_codes; std::vector error_messages; @@ -75,99 +80,135 @@ namespace Iovs_cgns { void DatabaseIO::write_meta_data() { - this->catCGNSMesh->CreateBase(0, "Base"); - const auto &structured_blocks = this->get_region()->get_structured_blocks(); - int base = 0; - int zone = 0; + const auto &structured_blocks = get_region()->get_structured_blocks(); + int zone = 1; for (const auto &sb : structured_blocks) { sb->property_update("zone", zone); - sb->property_update("base", base); zone++; } } - int64_t DatabaseIO::put_field_internal(const Ioss::StructuredBlock *sb, const Ioss::Field &field, - void *data, size_t data_size) const + void DatabaseIO::createIdOutput() + { + const auto &structured_blocks = get_region()->get_structured_blocks(); + for (const auto &sb : structured_blocks) { + size_t node_count = sb->get_property("node_count").get_int(); + std::vector ids; + ids.resize(node_count); + sb->get_cell_node_ids(ids.data(), true); + bool isCellField = false; + outputId("cell_node_ids", ids, isCellField, sb); + + size_t cell_count = sb->get_property("cell_count").get_int(); + ids.resize(cell_count); + sb->get_cell_ids(ids.data(), true); + isCellField = true; + outputId("cell_ids", ids, isCellField, sb); + + auto zone_id = sb->get_property("zone").get_int(); + std::vector object_id(cell_count, zone_id); + outputId("object_id", object_id, isCellField, sb); + } + } + + void DatabaseIO::outputId(const std::string idName, std::vector &ids, bool isCellField, + const Ioss::StructuredBlock *sb) { + CatalystCGNSMeshBase::ZoneData zoneData; + initZoneDataFromStructuredBlock(zoneData, sb); + zoneData.data_name = idName; + zoneData.comp_count = 1; + zoneData.is_cell_field = isCellField; + zoneData.size = ids.size(); + zoneData.data_type = zoneData.T_INT64; + zoneData.data.p_int64 = ids.data(); + + this->catCGNSMesh->AddStructuredZoneData(zoneData); + } - Ioss::Field::RoleType role = field.get_role(); - size_t base = sb->get_property("base").get_int(); - size_t zone = sb->get_property("zone").get_int(); - size_t node_count = sb->get_property("node_count").get_int(); - size_t num_to_get = field.verify(data_size); + void DatabaseIO::initZoneDataFromStructuredBlock(CatalystCGNSMeshBase::ZoneData &zoneData, + const Ioss::StructuredBlock *sb) const + { + zoneData.zone_id = sb->get_property("zone").get_int(); + zoneData.zone_name = sb->name(); + zoneData.ni = sb->get_property("ni").get_int(); + zoneData.nj = sb->get_property("nj").get_int(); + zoneData.nk = sb->get_property("nk").get_int(); + } - auto var_type = field.transformed_storage(); - int comp_count = var_type->component_count(); - char field_suffix_separator = get_field_separator(); + int64_t DatabaseIO::put_field_internal(const Ioss::StructuredBlock *sb, const Ioss::Field &field, + void *data, size_t data_size) const + { + size_t node_count = sb->get_property("node_count").get_int(); + size_t num_to_get = field.verify(data_size); + auto var_type = field.transformed_storage(); + auto ioss_type = field.get_type(); + int comp_count = var_type->component_count(); + void *rdata = num_to_get > 0 ? data : nullptr; bool is_cell_field = true; if (node_count == num_to_get) { is_cell_field = false; } - double *rdata = num_to_get > 0 ? static_cast(data) : nullptr; + CatalystCGNSMeshBase::ZoneData zoneData; + initZoneDataFromStructuredBlock(zoneData, sb); + zoneData.data_name = field.get_name(); + zoneData.comp_count = comp_count; + zoneData.is_cell_field = is_cell_field; + zoneData.size = num_to_get; - if (role == Ioss::Field::MESH) { - if (field.get_name() == "mesh_model_coordinates_x" || - field.get_name() == "mesh_model_coordinates_y" || - field.get_name() == "mesh_model_coordinates_z") { + if (ioss_type == Ioss::Field::INTEGER) { + zoneData.data_type = zoneData.T_INT; + zoneData.data.p_int = static_cast(data); + } + else if (ioss_type == Ioss::Field::INT64) { + zoneData.data_type = zoneData.T_INT64; + zoneData.data.p_int64 = static_cast(data); + } + else { + zoneData.data_type = zoneData.T_DOUBLE; + zoneData.data.p_double = static_cast(data); + } - this->catCGNSMesh->AddStructuredZoneData( - base, zone, sb->name(), field.get_name(), sb->get_property("ni").get_int(), - sb->get_property("nj").get_int(), sb->get_property("nk").get_int(), comp_count, - is_cell_field, field_suffix_separator, rdata, num_to_get); - } - else if (field.get_name() == "mesh_model_coordinates") { - int phys_dimension = get_region()->get_property("spatial_dimension").get_int(); - - std::vector coord(num_to_get); - - // ======================================================================== - // Repetitive code for each coordinate direction; use a lambda to consolidate... - auto coord_lambda = [=, &coord](const char *ordinate, int ordinal) { - // Data required by upper classes store x0, y0, z0, ... xn, - // yn, zn. Data stored in cgns file is x0, ..., xn, y0, - // ..., yn, z0, ..., zn so we have to allocate some scratch - // memory to read in the data and then map into supplied - // 'data' - // Map to global coordinate position... - for (size_t i = 0; i < num_to_get; i++) { - coord[i] = rdata[phys_dimension * i + ordinal]; - } - - this->catCGNSMesh->AddStructuredZoneData( - base, zone, sb->name(), ordinate, sb->get_property("ni").get_int(), - sb->get_property("nj").get_int(), sb->get_property("nk").get_int(), comp_count, - is_cell_field, field_suffix_separator, coord.data(), num_to_get); - }; - // ======================================================================== - - coord_lambda("mesh_model_coordinates_x", 0); - - if (phys_dimension >= 2) { - coord_lambda("mesh_model_coordinates_y", 1); + if (field.get_name() == "mesh_model_coordinates") { + int phys_dimension = get_region()->get_property("spatial_dimension").get_int(); + + std::vector coord(num_to_get); + + // ======================================================================== + // Repetitive code for each coordinate direction; use a lambda to consolidate... + auto coord_lambda = [=, &zoneData, &coord](const char *ordinate, int ordinal) { + // Data required by upper classes store x0, y0, z0, ... xn, + // yn, zn. Data stored in cgns file is x0, ..., xn, y0, + // ..., yn, z0, ..., zn so we have to allocate some scratch + // memory to read in the data and then map into supplied + // 'data' + // Map to global coordinate position... + for (size_t i = 0; i < num_to_get; i++) { + coord[i] = static_cast(rdata)[phys_dimension * i + ordinal]; } - if (phys_dimension == 3) { - coord_lambda("mesh_model_coordinates_z", 2); - } + zoneData.data_name = ordinate; + zoneData.data.p_double = coord.data(); + this->catCGNSMesh->AddStructuredZoneData(zoneData); + }; + // ======================================================================== + + coord_lambda("mesh_model_coordinates_x", 0); + + if (phys_dimension >= 2) { + coord_lambda("mesh_model_coordinates_y", 1); + } + + if (phys_dimension == 3) { + coord_lambda("mesh_model_coordinates_z", 2); } } - else if (role == Ioss::Field::TRANSIENT) { - this->catCGNSMesh->AddStructuredZoneData( - base, zone, sb->name(), field.get_name(), sb->get_property("ni").get_int(), - sb->get_property("nj").get_int(), sb->get_property("nk").get_int(), comp_count, - is_cell_field, field_suffix_separator, rdata, num_to_get); + else { + this->catCGNSMesh->AddStructuredZoneData(zoneData); } return num_to_get; } - int64_t DatabaseIO::put_field_internal(const Ioss::ElementBlock *, const Ioss::Field &field, - void *, size_t data_size) const - { - - size_t num_to_get = field.verify(data_size); - return num_to_get; - } - } // namespace Iovs_cgns diff --git a/packages/seacas/libraries/ioss/src/visualization/cgns/Iovs_cgns_DatabaseIO.h b/packages/seacas/libraries/ioss/src/visualization/cgns/Iovs_cgns_DatabaseIO.h index 636f69ef76..aabfff466a 100644 --- a/packages/seacas/libraries/ioss/src/visualization/cgns/Iovs_cgns_DatabaseIO.h +++ b/packages/seacas/libraries/ioss/src/visualization/cgns/Iovs_cgns_DatabaseIO.h @@ -1,4 +1,4 @@ -// Copyright(C) 1999-2022 National Technology & Engineering Solutions +// Copyright(C) 1999-2021 National Technology & Engineering Solutions // of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with // NTESS, the U.S. Government retains certain rights in this software. // @@ -7,14 +7,12 @@ #ifndef Iovs_cgns_DatabaseIO_h #define Iovs_cgns_DatabaseIO_h -#include "iovs_export.h" - #include +#include namespace Iovs_cgns { - class CatalystCGNSMeshBase; - class IOVS_EXPORT DatabaseIO : public Ioss::DatabaseIO + class DatabaseIO : public Ioss::DatabaseIO { public: DatabaseIO(Ioss::Region *region, const std::string &filename, Ioss::DatabaseUsage db_usage, @@ -38,41 +36,162 @@ namespace Iovs_cgns { void read_meta_data__() override; - IOSS_NOOP_GFI(Ioss::Region) - IOSS_NOOP_GFI(Ioss::NodeBlock) - IOSS_NOOP_GFI(Ioss::EdgeBlock) - IOSS_NOOP_GFI(Ioss::FaceBlock) - IOSS_NOOP_GFI(Ioss::ElementBlock) - IOSS_NOOP_GFI(Ioss::StructuredBlock) - IOSS_NOOP_GFI(Ioss::SideBlock) - IOSS_NOOP_GFI(Ioss::NodeSet) - IOSS_NOOP_GFI(Ioss::EdgeSet) - IOSS_NOOP_GFI(Ioss::FaceSet) - IOSS_NOOP_GFI(Ioss::ElementSet) - IOSS_NOOP_GFI(Ioss::SideSet) - IOSS_NOOP_GFI(Ioss::CommSet) - IOSS_NOOP_GFI(Ioss::Assembly) - IOSS_NOOP_GFI(Ioss::Blob) - - int64_t put_field_internal(const Ioss::ElementBlock *eb, const Ioss::Field &field, void *data, - size_t data_size) const override; + int64_t get_field_internal(const Ioss::Region * /*reg*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::NodeBlock * /*nb*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::EdgeBlock * /*eb*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::FaceBlock * /*fb*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::ElementBlock * /*eb*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::SideBlock * /*sb*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::NodeSet * /*ns*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::EdgeSet * /*es*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::FaceSet * /*fs*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::ElementSet * /*es*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::SideSet * /*ss*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::CommSet * /*cs*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::StructuredBlock * /*sb*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::Assembly * /*as*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t get_field_internal(const Ioss::Blob * /*bl*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + + int64_t put_field_internal(const Ioss::Region * /*reg*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::NodeBlock * /*nb*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::EdgeBlock * /*eb*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::FaceBlock * /*fb*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::ElementBlock * /*eb*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::SideBlock * /*sb*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::NodeSet * /*ns*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::EdgeSet * /*es*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::FaceSet * /*fs*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::ElementSet * /*es*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::SideSet * /*ss*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::CommSet * /*cs*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } int64_t put_field_internal(const Ioss::StructuredBlock *sb, const Ioss::Field &field, void *data, size_t data_size) const override; - IOSS_NOOP_PFI(Ioss::Region) - IOSS_NOOP_PFI(Ioss::NodeBlock) - IOSS_NOOP_PFI(Ioss::EdgeBlock) - IOSS_NOOP_PFI(Ioss::FaceBlock) - IOSS_NOOP_PFI(Ioss::SideBlock) - IOSS_NOOP_PFI(Ioss::NodeSet) - IOSS_NOOP_PFI(Ioss::EdgeSet) - IOSS_NOOP_PFI(Ioss::FaceSet) - IOSS_NOOP_PFI(Ioss::ElementSet) - IOSS_NOOP_PFI(Ioss::SideSet) - IOSS_NOOP_PFI(Ioss::CommSet) - IOSS_NOOP_PFI(Ioss::Assembly) - IOSS_NOOP_PFI(Ioss::Blob) + int64_t put_field_internal(const Ioss::Assembly * /*as*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::Blob * /*bl*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } std::unique_ptr catCGNSMesh; + bool isIdOutputCreated; + void initZoneDataFromStructuredBlock(CatalystCGNSMeshBase::ZoneData &zoneData, + const Ioss::StructuredBlock *sb) const; + void createIdOutput(); + void outputId(const std::string idName, std::vector &ids, bool isCellField, + const Ioss::StructuredBlock *sb); }; } // namespace Iovs_cgns diff --git a/packages/seacas/libraries/ioss/src/visualization/exodus/CatalystExodusMeshBase.h b/packages/seacas/libraries/ioss/src/visualization/exodus/CatalystExodusMeshBase.h index 1a31aa8f0b..4236cb9b0e 100644 --- a/packages/seacas/libraries/ioss/src/visualization/exodus/CatalystExodusMeshBase.h +++ b/packages/seacas/libraries/ioss/src/visualization/exodus/CatalystExodusMeshBase.h @@ -7,7 +7,11 @@ #ifndef __CATALYST_EXODUS_MESH_BASE_H #define __CATALYST_EXODUS_MESH_BASE_H +#ifndef __CATALYST_PLUGIN_BUILD #include "iovs_export.h" +#else +#define IOVS_EXPORT +#endif #include #include @@ -24,7 +28,7 @@ namespace Iovs_exodus { // Description: // Calls the ParaView Catalyst pipeline to run co-processing // for this time iteration. - virtual void PerformCoProcessing(std::vector & error_and_warning_codes, + virtual void PerformCoProcessing(std::vector &error_and_warning_codes, std::vector &error_and_warning_messages) = 0; // Description: @@ -33,11 +37,6 @@ namespace Iovs_exodus { // the current time iteration count. virtual void SetTimeData(double currentTime, int timeStep) = 0; - // Description: - // Clears all nodal and element variables from the vtkMultiBlockDataSet. - // Clears the global vtkPoints. - virtual void ReleaseMemory() = 0; - // Description: // Collects memory usage information from all processors and // writes the min, max, and mean to the log file. Also writes the @@ -45,32 +44,44 @@ namespace Iovs_exodus { // last called. virtual void logMemoryUsageAndTakeTimerReading() = 0; + // Description: + // Clears memory buffers used in mesh construction and field data + // for the current time-step. Clears the global vtkPoints. + virtual void ReleaseMemory() = 0; + virtual void Delete() = 0; // Description: - // Creates a global variable on the vtkExodusIIMultiBlockDataSet. + // Creates a global variable + // Creates the global variable on all element blocks. + virtual void CreateGlobalVariable(const std::string &variable_name, int num_comps, + const double *data) = 0; + + // Description: + // Creates a global variable // Creates the global variable on all element blocks. - virtual void CreateGlobalVariable(std::vector &component_names, - const double * data) = 0; + virtual void CreateGlobalVariable(const std::string &variable_name, int num_comps, + const int *data) = 0; // Description: - // Creates a global variable on the vtkExodusIIMultiBlockDataSet. + // Creates a global variable // Creates the global variable on all element blocks. - virtual void CreateGlobalVariable(std::vector &component_names, - const int * data) = 0; + virtual void CreateGlobalVariable(const std::string &variable_name, int num_comps, + const int64_t *data) = 0; // Description: - // Initializes the vtkMultiBlockDataSet with a global array of points + // Initializes the global array of points // defined by num_points, dimension (2,3), and data. Clears any existing data. virtual void InitializeGlobalPoints(int num_points, int dimension, const double *data) = 0; // Description: - // Initializes the element blocks to NULL data sets with ids in element_block_id_list. + // Initializes the element blocks to NULL data sets with ids and names in elemBlkIdNameList. // This method must be called first. - virtual void InitializeElementBlocks(const std::vector &element_block_id_list) = 0; + using ElementBlockIdNameList = std::vector>; + virtual void InitializeElementBlocks(const ElementBlockIdNameList &elemBlkIdNameList) = 0; // Description: - // Creates a vtkUnstructuredGrid on the vtkExodusIIMultiBlockDataSet + // Creates a vtkUnstructuredGrid // that represents and element block in the Exodus II data. The global_points // array contains all of the points in the Exodus II file. virtual void CreateElementBlock(const char *elem_block_name, int elem_block_id, @@ -78,7 +89,7 @@ namespace Iovs_exodus { const int64_t *global_elem_ids, int *connectivity) = 0; // Description: - // Creates a vtkUnstructuredGrid on the vtkExodusIIMultiBlockDataSet + // Creates a vtkUnstructuredGrid // that represents and element block in the Exodus II data. The global_points // array contains all of the points in the Exodus II file. virtual void CreateElementBlock(const char *elem_block_name, int elem_block_id, @@ -86,58 +97,34 @@ namespace Iovs_exodus { const int64_t *global_elem_ids, int64_t *connectivity) = 0; // Description: - // Creates a vtkUnstructuredGrid representing the node set in the Exodus II - // data. Node sets are arbitrary lists of mesh point ids. - virtual void CreateNodeSet(const char *node_set_name, int node_set_id, int num_ids, - const int *data) = 0; - - // Description: - // Creates a vtkUnstructuredGrid representing the node set in the Exodus II - // data. Node sets are arbitrary lists of mesh point ids. - virtual void CreateNodeSet(const char *node_set_name, int node_set_id, int num_ids, - const int64_t *data) = 0; - - // Description: - // Creates a vtkUnstructuredGrid representing the side set (also Side Block) in - // the Exodus II data. Side sets are collections of element faces and edges. - virtual void CreateSideSet(const char *ss_owner_name, int side_set_id, int num_ids, - const int *element_ids, const int *face_ids) = 0; - - // Description: - // Creates a vtkUnstructuredGrid representing the side set (also Side Block) in - // the Exodus II data. Side sets are collections of element faces and edges. - virtual void CreateSideSet(const char *ss_owner_name, int side_set_id, int num_ids, - const int64_t *element_ids, const int64_t *face_ids) = 0; - - // Description: - // Creates an element variable the vtkExodusIIMultiBlockDataSet. - virtual void CreateElementVariable(std::vector &component_names, int elem_block_id, - const double *data) = 0; + // Creates an element variable + virtual void CreateElementVariable(const std::string &variable_name, int num_comps, + int elem_block_id, const double *data) = 0; // Description: - // Creates an element variable the vtkExodusIIMultiBlockDataSet. - virtual void CreateElementVariable(std::vector &component_names, int elem_block_id, - const int *data) = 0; + // Creates an element variable + virtual void CreateElementVariable(const std::string &variable_name, int num_comps, + int elem_block_id, const int *data) = 0; // Description: - // Creates an element variable the vtkExodusIIMultiBlockDataSet. - virtual void CreateElementVariable(std::vector &component_names, int elem_block_id, - const int64_t *data) = 0; + // Creates an element variable + virtual void CreateElementVariable(const std::string &variable_name, int num_comps, + int elem_block_id, const int64_t *data) = 0; // Description: - // Creates a nodal variable the vtkExodusIIMultiBlockDataSet. - virtual void CreateNodalVariable(std::vector &component_names, - const double * data) = 0; + // Creates a nodal variable + virtual void CreateNodalVariable(const std::string &variable_name, int num_comps, + const double *data) = 0; // Description: - // Creates a nodal variable the vtkExodusIIMultiBlockDataSet. - virtual void CreateNodalVariable(std::vector &component_names, - const int * data) = 0; + // Creates a nodal variable + virtual void CreateNodalVariable(const std::string &variable_name, int num_comps, + const int *data) = 0; // Description: - // Creates a nodal variable the vtkExodusIIMultiBlockDataSet. - virtual void CreateNodalVariable(std::vector &component_names, - const int64_t * data) = 0; + // Creates a nodal variable + virtual void CreateNodalVariable(const std::string &variable_name, int num_comps, + const int64_t *data) = 0; }; } // namespace Iovs_exodus diff --git a/packages/seacas/libraries/ioss/src/visualization/exodus/Iovs_exodus_DatabaseIO.C b/packages/seacas/libraries/ioss/src/visualization/exodus/Iovs_exodus_DatabaseIO.C index 98fa35b16b..611b8f975a 100644 --- a/packages/seacas/libraries/ioss/src/visualization/exodus/Iovs_exodus_DatabaseIO.C +++ b/packages/seacas/libraries/ioss/src/visualization/exodus/Iovs_exodus_DatabaseIO.C @@ -23,7 +23,6 @@ #include namespace { // Internal helper functions - enum class entity_type { NODAL, ELEM_BLOCK, NODE_SET, SIDE_SET }; int64_t get_id(const Ioss::GroupingEntity *entity, Iovs_exodus::EntityIdSet *idset); bool set_id(const Ioss::GroupingEntity *entity, Iovs_exodus::EntityIdSet *idset); int64_t extract_id(const std::string &name_id); @@ -39,8 +38,8 @@ namespace Iovs_exodus { : Ioss::DatabaseIO(region, Iovs::Utils::getInstance().getDatabaseOutputFilePath(filename, props), db_usage, communicator, props), - isInput(false), singleProcOnly(false), doLogging(false), createSideSets(false), - createNodeSets(false), nodeBlockCount(0), elementBlockCount(0) + isInput(false), singleProcOnly(false), doLogging(false), + nodeBlockCount(0), elementBlockCount(0) { Iovs::Utils::DatabaseInfo dbinfo; @@ -55,14 +54,6 @@ namespace Iovs_exodus { Iovs::Utils::getInstance().writeToCatalystLogFile(dbinfo, props); this->catExoMesh = Iovs::Utils::getInstance().createCatalystExodusMesh(dbinfo, props); - - if (props.exists("CATALYST_CREATE_NODE_SETS")) { - this->createNodeSets = props.get("CATALYST_CREATE_NODE_SETS").get_int(); - } - - if (props.exists("CATALYST_CREATE_SIDE_SETS")) { - this->createSideSets = props.get("CATALYST_CREATE_SIDE_SETS").get_int(); - } } DatabaseIO::~DatabaseIO() { this->catExoMesh->Delete(); } @@ -73,12 +64,12 @@ namespace Iovs_exodus { Ioss::Region *region = this->get_region(); if (state == Ioss::STATE_MODEL) { - std::vector element_block_id_list; + CatalystExodusMeshBase::ElementBlockIdNameList ebinList; Ioss::ElementBlockContainer const &ebc = region->get_element_blocks(); for (auto i : ebc) { - element_block_id_list.push_back(get_id(i, &ids_)); + ebinList.emplace_back(get_id(i, &ids_), i->name()); } - this->catExoMesh->InitializeElementBlocks(element_block_id_list); + this->catExoMesh->InitializeElementBlocks(ebinList); } return true; } @@ -106,7 +97,6 @@ namespace Iovs_exodus { bool DatabaseIO::begin_state__(int state, double time) { Ioss::SerializeIO serializeIO__(this); - this->catExoMesh->ReleaseMemory(); if (!this->globalNodeAndElementIDsCreated) { this->create_global_node_and_element_ids(); @@ -127,6 +117,7 @@ namespace Iovs_exodus { this->catExoMesh->logMemoryUsageAndTakeTimerReading(); Iovs::Utils::getInstance().reportCatalystErrorMessages(error_codes, error_messages, this->parallel_rank()); + this->catExoMesh->ReleaseMemory(); return true; } @@ -137,18 +128,16 @@ namespace Iovs_exodus { { const Ioss::ElementBlockContainer &element_blocks = this->get_region()->get_element_blocks(); Ioss::ElementBlockContainer::const_iterator I; - std::vector component_names; - component_names.emplace_back("GlobalElementId"); for (I = element_blocks.begin(); I != element_blocks.end(); ++I) { int bid = get_id((*I), &ids_); int64_t eb_offset = (*I)->get_offset(); - this->catExoMesh->CreateElementVariable(component_names, bid, + this->catExoMesh->CreateElementVariable("ids", 1, bid, &this->elemMap.map()[eb_offset + 1]); + std::vector object_id((*I)->entity_count(), bid); + this->catExoMesh->CreateElementVariable("object_id", 1, bid, + object_id.data()); } - - component_names.clear(); - component_names.emplace_back("GlobalNodeId"); - this->catExoMesh->CreateNodalVariable(component_names, &this->nodeMap.map()[1]); + this->catExoMesh->CreateNodalVariable("ids", 1, &this->nodeMap.map()[1]); this->globalNodeAndElementIDsCreated = true; } @@ -167,42 +156,23 @@ namespace Iovs_exodus { size_t num_to_get = field.verify(data_size); Ioss::Field::RoleType role = field.get_role(); if ((role == Ioss::Field::TRANSIENT || role == Ioss::Field::REDUCTION) && num_to_get == 1) { - const char *complex_suffix[] = {".re", ".im"}; - Ioss::Field::BasicType ioss_type = field.get_type(); - auto *rvar = static_cast(data); - int *ivar = static_cast(data); - auto *ivar64 = static_cast(data); - - int comp_count = field.get_component_count(Ioss::Field::InOut::OUTPUT); + Ioss::Field::BasicType ioss_type = field.get_type(); + std::string field_name = field.get_name(); + int comp_count = field.get_component_count(Ioss::Field::InOut::OUTPUT); - int re_im = 1; - if (field.get_type() == Ioss::Field::COMPLEX) { - re_im = 2; + if (ioss_type == Ioss::Field::COMPLEX) { + comp_count *= 2; } - for (int complex_comp = 0; complex_comp < re_im; complex_comp++) { - std::string field_name = field.get_name(); - if (re_im == 2) { - field_name += complex_suffix[complex_comp]; - } - - std::vector component_names; - std::vector globalValues; - for (int i = 0; i < comp_count; i++) { - std::string var_name = get_component_name(field, Ioss::Field::InOut::OUTPUT, i + 1); - component_names.push_back(var_name); - // Transfer from 'variables' array. - if (ioss_type == Ioss::Field::REAL || ioss_type == Ioss::Field::COMPLEX) { - globalValues.push_back(rvar[i]); - } - else if (ioss_type == Ioss::Field::INTEGER) { - globalValues.push_back(ivar[i]); - } - else if (ioss_type == Ioss::Field::INT64) { - globalValues.push_back(ivar64[i]); - } - } - this->catExoMesh->CreateGlobalVariable(component_names, globalValues.data()); + if (ioss_type == Ioss::Field::REAL || ioss_type == Ioss::Field::COMPLEX) { + this->catExoMesh->CreateGlobalVariable(field_name, comp_count, static_cast(data)); + } + else if (ioss_type == Ioss::Field::INTEGER) { + this->catExoMesh->CreateGlobalVariable(field_name, comp_count, static_cast(data)); + } + else if (ioss_type == Ioss::Field::INT64) { + this->catExoMesh->CreateGlobalVariable(field_name, comp_count, + static_cast(data)); } } else if (num_to_get != 1) { @@ -256,47 +226,24 @@ namespace Iovs_exodus { } } else if (role == Ioss::Field::TRANSIENT) { - const char *complex_suffix[] = {".re", ".im"}; - Ioss::Field::BasicType ioss_type = field.get_type(); - std::vector temp(num_to_get); - int comp_count = field.get_component_count(Ioss::Field::InOut::OUTPUT); - int re_im = 1; + Ioss::Field::BasicType ioss_type = field.get_type(); + int comp_count = field.get_component_count(Ioss::Field::InOut::OUTPUT); + std::string field_name = field.get_name(); + if (ioss_type == Ioss::Field::COMPLEX) { - re_im = 2; + comp_count *= 2; } - for (int complex_comp = 0; complex_comp < re_im; complex_comp++) { - std::string field_name = field.get_name(); - if (re_im == 2) { - field_name += complex_suffix[complex_comp]; - } - - std::vector interleaved_data(num_to_get * comp_count); - std::vector component_names; - for (int i = 0; i < comp_count; i++) { - std::string var_name = get_component_name(field, Ioss::Field::InOut::OUTPUT, i + 1); - component_names.push_back(var_name); - size_t begin_offset = (re_im * i) + complex_comp; - size_t stride = re_im * comp_count; - - if (ioss_type == Ioss::Field::REAL || ioss_type == Ioss::Field::COMPLEX) { - this->nodeMap.map_field_to_db_scalar_order(static_cast(data), temp, - begin_offset, num_to_get, stride, 0); - } - else if (ioss_type == Ioss::Field::INTEGER) { - this->nodeMap.map_field_to_db_scalar_order(static_cast(data), temp, - begin_offset, num_to_get, stride, 0); - } - else if (ioss_type == Ioss::Field::INT64) { - this->nodeMap.map_field_to_db_scalar_order(static_cast(data), temp, - begin_offset, num_to_get, stride, 0); - } - - for (unsigned int j = 0; j < num_to_get; j++) { - interleaved_data[j * comp_count + i] = temp[j]; - } - } - this->catExoMesh->CreateNodalVariable(component_names, interleaved_data.data()); + if (ioss_type == Ioss::Field::REAL || ioss_type == Ioss::Field::COMPLEX) { + this->catExoMesh->CreateNodalVariable(field_name, comp_count, + static_cast(data)); + } + else if (ioss_type == Ioss::Field::INTEGER) { + this->catExoMesh->CreateNodalVariable(field_name, comp_count, static_cast(data)); + } + else if (ioss_type == Ioss::Field::INT64) { + this->catExoMesh->CreateNodalVariable(field_name, comp_count, + static_cast(data)); } } else if (role == Ioss::Field::REDUCTION) { @@ -365,49 +312,26 @@ namespace Iovs_exodus { /* TODO */ } else if (role == Ioss::Field::TRANSIENT) { - const char *complex_suffix[] = {".re", ".im"}; - Ioss::Field::BasicType ioss_type = field.get_type(); - std::vector temp(num_to_get); - int64_t eb_offset = eb->get_offset(); - int comp_count = field.get_component_count(Ioss::Field::InOut::OUTPUT); - int bid = get_id(eb, &ids_); - - int re_im = 1; + Ioss::Field::BasicType ioss_type = field.get_type(); + int comp_count = field.get_component_count(Ioss::Field::InOut::OUTPUT); + int bid = get_id(eb, &ids_); + std::string field_name = field.get_name(); + if (ioss_type == Ioss::Field::COMPLEX) { - re_im = 2; + comp_count *= 2; } - for (int complex_comp = 0; complex_comp < re_im; complex_comp++) { - std::string field_name = field.get_name(); - if (re_im == 2) { - field_name += complex_suffix[complex_comp]; - } - std::vector interleaved_data(num_to_get * comp_count); - std::vector component_names; - for (int i = 0; i < comp_count; i++) { - std::string var_name = get_component_name(field, Ioss::Field::InOut::OUTPUT, i + 1); - component_names.push_back(var_name); - - int64_t begin_offset = (re_im * i) + complex_comp; - int64_t stride = re_im * comp_count; - - if (ioss_type == Ioss::Field::REAL || ioss_type == Ioss::Field::COMPLEX) { - this->elemMap.map_field_to_db_scalar_order( - static_cast(data), temp, begin_offset, num_to_get, stride, eb_offset); - } - else if (ioss_type == Ioss::Field::INTEGER) { - this->elemMap.map_field_to_db_scalar_order( - static_cast(data), temp, begin_offset, num_to_get, stride, eb_offset); - } - else if (ioss_type == Ioss::Field::INT64) { - this->elemMap.map_field_to_db_scalar_order( - static_cast(data), temp, begin_offset, num_to_get, stride, eb_offset); - } - for (unsigned int j = 0; j < num_to_get; j++) { - interleaved_data[j * comp_count + i] = temp[j]; - } - } - this->catExoMesh->CreateElementVariable(component_names, bid, interleaved_data.data()); + if (ioss_type == Ioss::Field::REAL || ioss_type == Ioss::Field::COMPLEX) { + this->catExoMesh->CreateElementVariable(field_name, comp_count, bid, + static_cast(data)); + } + else if (ioss_type == Ioss::Field::INTEGER) { + this->catExoMesh->CreateElementVariable(field_name, comp_count, bid, + static_cast(data)); + } + else if (ioss_type == Ioss::Field::INT64) { + this->catExoMesh->CreateElementVariable(field_name, comp_count, bid, + static_cast(data)); } } else if (role == Ioss::Field::REDUCTION) { @@ -643,143 +567,6 @@ namespace Iovs_exodus { << field.get_name() << "'"; return -4; } - - int64_t DatabaseIO::put_field_internal(const Ioss::NodeSet * /* ns */, const Ioss::Field &field, - void *data, size_t data_size) const - { - int64_t num_to_get = field.verify(data_size); - int64_t cns_save_num_to_get = 0; - - if (num_to_get > 0 && (field.get_name() == "ids" || field.get_name() == "ids_raw")) { - - // int id = get_id(ns, &this->ids_); - - if (!this->createNodeSets) { - cns_save_num_to_get = num_to_get; - num_to_get = 0; - } - - if (field.get_type() == Ioss::Field::INTEGER) { - this->nodeMap.reverse_map_data(data, field, num_to_get); - // this->catExoMesh->CreateNodeSet(ns->name().c_str(), id, num_to_get, - // static_cast(data)); - } - else if (field.get_type() == Ioss::Field::INT64) { - this->nodeMap.reverse_map_data(data, field, num_to_get); - // this->catExoMesh->CreateNodeSet(ns->name().c_str(), id, num_to_get, - // static_cast(data)); - } - - if (!this->createNodeSets) { - num_to_get = cns_save_num_to_get; - } - } - return num_to_get; - } - - int64_t DatabaseIO::put_field_internal(const Ioss::SideSet *fs, const Ioss::Field &field, - void * /*data*/, size_t data_size) const - { - size_t num_to_get = field.verify(data_size); - if (field.get_name() == "ids") { - // Do nothing, just handles an idiosyncrasy of the GroupingEntity - } - else { - num_to_get = Ioss::Utils::field_warning(fs, field, "output"); - } - return num_to_get; - } - - int64_t DatabaseIO::put_field_internal(const Ioss::SideBlock *eb, const Ioss::Field &field, - void *data, size_t data_size) const - { - int64_t num_to_get = field.verify(data_size); - int64_t css_save_num_to_get = 0; - - if ((field.get_name() == "element_side") || (field.get_name() == "element_side_raw")) { - size_t side_offset = Ioss::Utils::get_side_offset(eb); - - // int id = get_id(eb, &this->ids_); - - size_t index = 0; - - if (field.get_type() == Ioss::Field::INTEGER) { - Ioss::IntVector element(num_to_get); - Ioss::IntVector side(num_to_get); - int *el_side = static_cast(data); - - for (unsigned int i = 0; i < num_to_get; i++) { - element[i] = el_side[index++]; - side[i] = el_side[index++] + side_offset; - } - - if (!this->createSideSets) { - css_save_num_to_get = num_to_get; - num_to_get = 0; - } - - // const Ioss::SideSet *ebowner = eb->owner(); - /*NOTE: Jeff Mauldin JAM 2015Oct8 - CreateSideSet is called once for each block which the sideset - spans, and the eb->name() for the side set is the ebowner->name() - with additional characters to indicate which block we are doing. - The current implementation of the sierra/catalyst sideset - construction creates a single independent sideset and collects all - the nodes and elements from the side set from each block spanned - by the sideset into that single sideset. It needs to have the - ebowner->name(), not the eb->name(), because that is the name - in the input deck for the sideset for reference for things like - extractblock. It may become necessary at a later date to - pass in both ebowner->name() AND eb->name(), but for now we - are just passing in ebowner->name() to give us correct - functionality while not changing the function interface*/ - // this->catExoMesh->CreateSideSet(ebowner->name().c_str(), id, num_to_get, - // &element[0], &side[0]); - - if (!this->createSideSets) { - num_to_get = css_save_num_to_get; - } - } - else { - Ioss::Int64Vector element(num_to_get); - Ioss::Int64Vector side(num_to_get); - auto *el_side = static_cast(data); - - for (unsigned int i = 0; i < num_to_get; i++) { - element[i] = el_side[index++]; - side[i] = el_side[index++] + side_offset; - } - - if (!this->createSideSets) { - css_save_num_to_get = num_to_get; - num_to_get = 0; - } - - // const Ioss::SideSet *ebowner = eb->owner(); - /*NOTE: Jeff Mauldin JAM 2015Oct8 - CreateSideSet is called once for each block which the sideset - spans, and the eb->name() for the side set is the ebowner->name() - with additional characters to indicate which block we are doing. - The current implementation of the sierra/catalyst sideset - construction creates a single independent sideset and collects all - the nodes and elements from the side set from each block spanned - by the sideset into that single sideset. It needs to have the - ebowner->name(), not the eb->name(), because that is the name - in the input deck for the sideset for reference for things like - extractblock. It may become necessary at a later date to - pass in both ebowner->name() AND eb->name(), but for now we - are just passing in ebowner->name() to give us correct - functionality while not changing the function interface*/ - // this->catExoMesh->CreateSideSet(ebowner->name().c_str(), id, - // num_to_get, &element[0], &side[0]); - - if (!this->createSideSets) { - num_to_get = css_save_num_to_get; - } - } - } - return num_to_get; - } } // namespace Iovs_exodus namespace { diff --git a/packages/seacas/libraries/ioss/src/visualization/exodus/Iovs_exodus_DatabaseIO.h b/packages/seacas/libraries/ioss/src/visualization/exodus/Iovs_exodus_DatabaseIO.h index 8d20fedbe8..0f405fe105 100644 --- a/packages/seacas/libraries/ioss/src/visualization/exodus/Iovs_exodus_DatabaseIO.h +++ b/packages/seacas/libraries/ioss/src/visualization/exodus/Iovs_exodus_DatabaseIO.h @@ -49,7 +49,7 @@ namespace Iovs_exodus { // database supports that type (e.g. return_value & Ioss::FACESET) unsigned entity_field_support() const override { - return Ioss::NODEBLOCK | Ioss::ELEMENTBLOCK | Ioss::NODESET | Ioss::SIDESET | Ioss::SIDEBLOCK; + return Ioss::NODEBLOCK | Ioss::ELEMENTBLOCK; } // static int parseCatalystFile(const std::string &filepath, std::string &json_result); @@ -76,12 +76,12 @@ namespace Iovs_exodus { { return 0; } - int64_t get_field_internal(const Ioss::EdgeBlock * /*nb*/, const Ioss::Field & /*field*/, + int64_t get_field_internal(const Ioss::EdgeBlock * /*eb*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { return 0; } - int64_t get_field_internal(const Ioss::FaceBlock * /*nb*/, const Ioss::Field & /*field*/, + int64_t get_field_internal(const Ioss::FaceBlock * /*fb*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { return 0; @@ -91,7 +91,7 @@ namespace Iovs_exodus { { return 0; } - int64_t get_field_internal(const Ioss::SideBlock * /*fb*/, const Ioss::Field & /*field*/, + int64_t get_field_internal(const Ioss::SideBlock * /*sb*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { return 0; @@ -101,22 +101,22 @@ namespace Iovs_exodus { { return 0; } - int64_t get_field_internal(const Ioss::EdgeSet * /*ns*/, const Ioss::Field & /*field*/, + int64_t get_field_internal(const Ioss::EdgeSet * /*es*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { return 0; } - int64_t get_field_internal(const Ioss::FaceSet * /*ns*/, const Ioss::Field & /*field*/, + int64_t get_field_internal(const Ioss::FaceSet * /*fs*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { return 0; } - int64_t get_field_internal(const Ioss::ElementSet * /*ns*/, const Ioss::Field & /*field*/, + int64_t get_field_internal(const Ioss::ElementSet * /*es*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { return 0; } - int64_t get_field_internal(const Ioss::SideSet * /*fs*/, const Ioss::Field & /*field*/, + int64_t get_field_internal(const Ioss::SideSet * /*ss*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { return 0; @@ -133,13 +133,13 @@ namespace Iovs_exodus { return 0; } - int64_t get_field_internal(const Ioss::Assembly * /*sb*/, const Ioss::Field & /*field*/, + int64_t get_field_internal(const Ioss::Assembly * /*as*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /*data_size*/) const override { return 0; } - int64_t get_field_internal(const Ioss::Blob * /*sb*/, const Ioss::Field & /*field*/, + int64_t get_field_internal(const Ioss::Blob * /*bl*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /*data_size*/) const override { return 0; @@ -148,42 +148,50 @@ namespace Iovs_exodus { int64_t put_field_internal(const Ioss::Region *reg, const Ioss::Field &field, void *data, size_t data_size) const override; - int64_t put_field_internal(const Ioss::NodeBlock *nb, const Ioss::Field &field, void *data, - size_t data_size) const override; - int64_t put_field_internal(const Ioss::EdgeBlock * /*nb*/, const Ioss::Field & /*field*/, + int64_t put_field_internal(const Ioss::NodeBlock * nb, const Ioss::Field & field, + void * data, size_t data_size) const override; + int64_t put_field_internal(const Ioss::EdgeBlock * /*eb*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { return 0; } - int64_t put_field_internal(const Ioss::FaceBlock * /*nb*/, const Ioss::Field & /*field*/, + int64_t put_field_internal(const Ioss::FaceBlock * /*fb*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { return 0; } int64_t put_field_internal(const Ioss::ElementBlock *eb, const Ioss::Field &field, void *data, size_t data_size) const override; - int64_t put_field_internal(const Ioss::SideBlock *eb, const Ioss::Field &field, void *data, - size_t data_size) const override; - - int64_t put_field_internal(const Ioss::NodeSet *ns, const Ioss::Field &field, void *data, - size_t data_size) const override; - int64_t put_field_internal(const Ioss::EdgeSet * /*ns*/, const Ioss::Field & /*field*/, + int64_t put_field_internal(const Ioss::SideBlock * /*sb*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::NodeSet * /*ns*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } + int64_t put_field_internal(const Ioss::EdgeSet * /*es*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { return 0; } - int64_t put_field_internal(const Ioss::FaceSet * /*ns*/, const Ioss::Field & /*field*/, + int64_t put_field_internal(const Ioss::FaceSet * /*fs*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { return 0; } - int64_t put_field_internal(const Ioss::ElementSet * /*ns*/, const Ioss::Field & /*field*/, + int64_t put_field_internal(const Ioss::ElementSet * /*es*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { return 0; } - int64_t put_field_internal(const Ioss::SideSet *fs, const Ioss::Field &field, void *data, - size_t data_size) const override; + int64_t put_field_internal(const Ioss::SideSet * /*ss*/, const Ioss::Field & /*field*/, + void * /*data*/, size_t /*data_size*/) const override + { + return 0; + } int64_t put_field_internal(const Ioss::CommSet * /*cs*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /* data_size */) const override { @@ -194,13 +202,13 @@ namespace Iovs_exodus { { return 0; } - int64_t put_field_internal(const Ioss::Assembly * /*sb*/, const Ioss::Field & /*field*/, + int64_t put_field_internal(const Ioss::Assembly * /*as*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /*data_size*/) const override { return 0; } - int64_t put_field_internal(const Ioss::Blob * /*sb*/, const Ioss::Field & /*field*/, + int64_t put_field_internal(const Ioss::Blob * /*bl*/, const Ioss::Field & /*field*/, void * /*data*/, size_t /*data_size*/) const override { return 0; @@ -221,8 +229,6 @@ namespace Iovs_exodus { bool isInput; bool singleProcOnly; // True if history or heartbeat which is only written from proc 0... bool doLogging; // True if logging field input/output - bool createSideSets; - bool createNodeSets; int nodeBlockCount; int elementBlockCount; diff --git a/packages/seacas/libraries/ioss/src/visualization/utils/CatalystManagerBase.h b/packages/seacas/libraries/ioss/src/visualization/utils/CatalystManagerBase.h index 3c3a03c2be..ebe4529dce 100644 --- a/packages/seacas/libraries/ioss/src/visualization/utils/CatalystManagerBase.h +++ b/packages/seacas/libraries/ioss/src/visualization/utils/CatalystManagerBase.h @@ -7,7 +7,11 @@ #ifndef __CATALYST_MANAGER_BASE_H #define __CATALYST_MANAGER_BASE_H +#ifndef __CATALYST_PLUGIN_BUILD #include "iovs_export.h" +#else +#define IOVS_EXPORT +#endif #include "visualization/cgns/CatalystCGNSMeshBase.h" #include "visualization/exodus/CatalystExodusMeshBase.h" @@ -36,6 +40,8 @@ namespace Iovs { virtual int getCatalystOutputIDNumber() = 0; + virtual std::string getCatalystPluginVersion() = 0; + // Parameters: // cataystPythonFilename - Python file with instructions for Catalyst. // restartTag - if not empty, contains the current restart iteration string, ie s0001 diff --git a/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_CatalystVersion.C b/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_CatalystVersion.C new file mode 100644 index 0000000000..fba75c4303 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_CatalystVersion.C @@ -0,0 +1,43 @@ +#include +#include +#include +#include + +namespace Iovs { + + std::string CatalystVersion::getIOSSCatalystInterfaceVersion() + { + return iossCatalystInterfaceVersion; + } + + bool CatalystVersion::isInterfaceCompatibleWithPlugin(const std::string &interface_version, + const std::string &plugin_version) + { + bool retVal = false; + std::istringstream interface_version_parser(interface_version); + std::istringstream plugin_version_parser(plugin_version); + std::vector iver(SEMANTIC_VERSION_LENGTH, 0); + std::vector pver(SEMANTIC_VERSION_LENGTH, 0); + + for (int i = 0; i < SEMANTIC_VERSION_LENGTH; i++) { + interface_version_parser >> iver[i]; + plugin_version_parser >> pver[i]; + interface_version_parser.get(); + plugin_version_parser.get(); + } + + if (iver[MAJOR_INDEX] == pver[MAJOR_INDEX]) { + if (iver[MINOR_INDEX] < pver[MINOR_INDEX]) { + retVal = true; + } + else if (iver[MINOR_INDEX] == pver[MINOR_INDEX]) { + if (iver[PATCH_INDEX] <= pver[PATCH_INDEX]) { + retVal = true; + } + } + } + + return retVal; + } + +} // namespace Iovs \ No newline at end of file diff --git a/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_CatalystVersion.h b/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_CatalystVersion.h new file mode 100644 index 0000000000..0448729330 --- /dev/null +++ b/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_CatalystVersion.h @@ -0,0 +1,52 @@ +// Copyright(C) 1999-2021 National Technology & Engineering Solutions +// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with +// NTESS, the U.S. Government retains certain rights in this software. +// +// See packages/seacas/LICENSE for details + +#ifndef IOSS_IOVS_CATALYST_VERSION_H +#define IOSS_IOVS_CATALYST_VERSION_H + +#ifndef __CATALYST_PLUGIN_BUILD +#include "iovs_export.h" +#else +#define IOVS_EXPORT +#endif + +#include + +namespace Iovs { + + class IOVS_EXPORT CatalystVersion + { + public: + const std::string iossCatalystInterfaceVersion = "2.0.0"; + std::string getIOSSCatalystInterfaceVersion(); + + // The IOSS interface and IOSS Catalyst plugin are versioned + // using semantic versioning: MAJOR.MINOR.PATCH + // + // The interface and plugin versions are incompatible if: + // + // The MAJOR versions are not equal. + // (or) + // The MAJOR versions are equal, and the interface MINOR version + // is greater than the plugin MINOR version. + // (or) + // The MAJOR versions are equal, the MINOR versions are equal, + // and the interface PATCH version is greater than the plugin PATCH + // version. + + bool isInterfaceCompatibleWithPlugin(const std::string &interface_version, + const std::string &plugin_version); + + private: + const unsigned int SEMANTIC_VERSION_LENGTH = 3; + const unsigned int MAJOR_INDEX = 0; + const unsigned int MINOR_INDEX = 1; + const unsigned int PATCH_INDEX = 2; + }; + +} // namespace Iovs + +#endif \ No newline at end of file diff --git a/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_Utils.C b/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_Utils.C index 8b3d82379e..f82200592f 100644 --- a/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_Utils.C +++ b/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_Utils.C @@ -11,6 +11,7 @@ #include #include #include +#include #include #if defined(__IOSS_WINDOWS__) @@ -58,6 +59,7 @@ namespace Iovs { { if (this->catalystManager == nullptr) { this->catalystManager = this->createCatalystManagerInstance(); + this->checkCatalystInterfaceAndPluginVersions(); } return *this->catalystManager; } @@ -88,6 +90,17 @@ namespace Iovs { #endif } + void Utils::checkCatalystInterfaceAndPluginVersions() + { + CatalystVersion cv; + std::string iVer = cv.getIOSSCatalystInterfaceVersion(); + std::string pVer = this->catalystManager->getCatalystPluginVersion(); + if (!cv.isInterfaceCompatibleWithPlugin(iVer, pVer)) { + throw std::runtime_error("IOSS Catalyst interface version: " + iVer + + ", is not compatible with IOSS Catalyst plugin version: " + pVer); + } + } + std::unique_ptr Utils::createCatalystExodusMesh(const DatabaseInfo &dbinfo, const Ioss::PropertyManager &props) { diff --git a/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_Utils.h b/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_Utils.h index 2b8a69e3ff..e82ecfce46 100644 --- a/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_Utils.h +++ b/packages/seacas/libraries/ioss/src/visualization/utils/Iovs_Utils.h @@ -67,6 +67,7 @@ namespace Iovs { CatalystManagerBase *catalystManager = nullptr; CatalystManagerBase *createCatalystManagerInstance(); + void checkCatalystInterfaceAndPluginVersions(); void initMeshFromIOSSProps(CatalystManagerBase::CatalystMeshInit &cmInit, const DatabaseInfo &dbinfo, const Ioss::PropertyManager &props);