57 std::string filename = dir + fileName;
58 std::ifstream wakeFile, testFile;
60 char firstChar =
'/', secondChar =
'*';
62 if (fileExistTest(filename,
W.
getInfo(),
true, {
"txt",
"TXT" }))
64 testFile.open(filename);
65 testFile >> firstChar;
66 testFile >> secondChar;
74 if (firstChar ==
'/' && secondChar ==
'*')
76 if (fileExistTest(filename,
W.
getInfo(),
true, {
"txt",
"TXT" }))
83 wakeParser.
get(
"vtx",
vtx);
89 if (fileExistTest(filename,
W.
getInfo(),
true, {
"txt",
"TXT" }))
91 wakeFile.open(filename);
95 for (
int i = 0; i < nnn; ++i)
98 wakeFile >> v.
r()[0] >> v.
r()[1] >> v.
g();
115 std::ofstream outfile;
116 size_t numberNonZero = 0;
119 numberNonZero +=
vtx.size();
130 outfile <<
"# vtk DataFile Version 2.0" << std::endl;
132 outfile <<
"ASCII" << std::endl;
133 outfile <<
"DATASET UNSTRUCTURED_GRID" << std::endl;
134 outfile <<
"POINTS " << numberNonZero <<
" float" << std::endl;
141 outfile << r[0] <<
" " << r[1] <<
" " <<
"0.0" << std::endl;
148 outfile << r[0] <<
" " << r[1] <<
" " <<
"0.0" << std::endl;
151 outfile <<
"CELLS " << numberNonZero <<
" " << 2 * numberNonZero << std::endl;
152 for (
size_t i = 0; i < numberNonZero; ++i)
153 outfile <<
"1 " << i << std::endl;
155 outfile <<
"CELL_TYPES " << numberNonZero << std::endl;
156 for (
size_t i = 0; i < numberNonZero; ++i)
157 outfile <<
"1" << std::endl;
159 outfile << std::endl;
160 outfile <<
"POINT_DATA " << numberNonZero << std::endl;
161 outfile <<
"SCALARS Gamma float 1" << std::endl;
162 outfile <<
"LOOKUP_TABLE default" << std::endl;
166 outfile << v.g() << std::endl;
170 outfile <<
"0.0" << std::endl;
178 bool littleEndian = (*((uint8_t*)&x));
179 const char eolnBIN[] =
"\n";
182 outfile.open(
W.
getPassport().
dir +
"snapshots/" + fname, std::ios::out | std::ios::binary);
184 outfile <<
"# vtk DataFile Version 3.0" <<
"\r\n" <<
"VM2D VTK result: " << (
W.
getPassport().
dir +
"snapshots/" + fname).c_str() <<
" saved " <<
VMlib::CurrentDataTime() << eolnBIN;
185 outfile <<
"BINARY" << eolnBIN;
186 outfile <<
"DATASET UNSTRUCTURED_GRID" << eolnBIN <<
"POINTS " << numberNonZero <<
" " <<
"float" << eolnBIN;
190 Eigen::VectorXf rData = Eigen::VectorXf::Zero(
vtx.size() * 3);
191 for (
size_t i = 0; i <
vtx.size(); ++i)
193 rData(3 * i) = (float)(
vtx[i].r())[0];
194 rData(3 * i + 1) = (float)(
vtx[i].r())[1];
198 for (
int i = 0; i <
vtx.size() * 3; ++i)
200 outfile.write(
reinterpret_cast<char*
>(rData.data()),
vtx.size() * 3 *
sizeof(float));
206 for (
size_t s = 0; s <
W.
getAirfoil(q).getNumberOfPanels(); ++s)
219 std::vector<int> cells(2 * numberNonZero);
220 for (
size_t i = 0; i < numberNonZero; ++i)
223 cells[2 * i + 1] = (int)i;
226 std::vector<int> cellsTypes;
227 cellsTypes.resize(numberNonZero, 1);
231 for (
int i = 0; i < numberNonZero * 2; ++i)
234 for (
int i = 0; i < numberNonZero; ++i)
238 outfile << eolnBIN <<
"CELLS " << numberNonZero <<
" " << numberNonZero * 2 << eolnBIN;
239 outfile.write(
reinterpret_cast<char*
>(cells.data()), numberNonZero * 2 *
sizeof(int));
240 outfile << eolnBIN <<
"CELL_TYPES " << numberNonZero << eolnBIN;
241 outfile.write(
reinterpret_cast<char*
>(cellsTypes.data()), numberNonZero *
sizeof(
int));
244 outfile << eolnBIN <<
"POINT_DATA " << numberNonZero << eolnBIN;
245 outfile << eolnBIN <<
"SCALARS Gamma " <<
"float" <<
" 1" << eolnBIN;
246 outfile <<
"LOOKUP_TABLE default" << eolnBIN;
250 Eigen::VectorXf pData = Eigen::VectorXf::Zero(numberNonZero);
251 for (
int s = 0; s <
vtx.size(); ++s)
252 pData(s) = (float)
vtx[s].g();
255 for (
int i = 0; i <
vtx.size(); ++i)
257 outfile.write(
reinterpret_cast<char*
>(pData.data()),
vtx.size() *
sizeof(float));
263 for (
int s = 0; s <
W.
getAirfoil(q).getNumberOfPanels(); ++s)
267 for (
int i = 0; i <
W.
getAirfoil(q).getNumberOfPanels(); ++i)
280 outfile <<
"point,x,y,G " << std::endl;
286 outfile << counter++ <<
"," << v.r()[0] <<
"," << v.r()[1] <<
"," << v.g() << std::endl;
292 outfile << counter++ <<
"," << r[0] <<
"," << r[1] <<
"," <<
"0.0" << std::endl;
Заголовочный файл с описанием класса Airfoil.
Заголовочный файл с описанием класса Boundary.
Заголовочный файл с описанием класса MeasureVP.
Заголовочный файл с описанием класса Mechanics.
Заголовочный файл с описанием класса Preprocessor.
Заголовочный файл с описанием класса StreamParser.
Заголовочный файл с описанием класса Velocity.
Заголовочный файл с описанием класса Wake.
Заголовочный файл с описанием класса WakeDataBase.
Заголовочный файл с описанием класса World2D.
const Point2D & getR(size_t q) const
Возврат константной ссылки на вершину профиля
size_t getNumberOfPanels() const
Возврат количества панелей на профиле
std::vector< Vortex2D > vtx
Список вихревых элементов
void ReadFromFile(const std::string &dir, const std::string &fileName)
Считывание вихревого следа из файла
const World2D & W
Константная ссылка на решаемую задачу
void SaveKadrVtk(const std::string &filePrefix="Kadr") const
Сохранение вихревого следа в файл .vtk.
size_t getNumberOfAirfoil() const
Возврат количества профилей в задаче
const Airfoil & getAirfoil(size_t i) const
Возврат константной ссылки на объект профиля
VMlib::TimersGen & getTimers() const
Возврат ссылки на временную статистику выполнения шага расчета по времени
const Passport & getPassport() const
Возврат константной ссылки на паспорт
bool ifDivisible(int val) const
Класс, определяющий работу с потоком логов
TimeDiscretizationProperties timeDiscretizationProperties
Структура с параметрами процесса интегрирования по времени
std::string dir
Рабочий каталог задачи
Класс, позволяющий выполнять предварительную обработку файлов
Класс, позволяющий выполнять разбор файлов и строк с настройками и параметрами
bool get(const std::string &name, std::vector< Point2D > &res, const std::vector< Point2D > *defValue=nullptr, bool echoDefault=true) const
Считывание вектора из двумерных точек из базы данных
void stop(const std::string &timerLabel)
Останов счетчика
void start(const std::string &timerLabel)
Запуск счетчика
Класс, опеделяющий двумерный вихревой элемент
HD Point2D & r()
Функция для доступа к радиус-вектору вихря
HD double & g()
Функция для доступа к циркуляции вихря
VMlib::LogStream & getInfo() const
Возврат ссылки на объект LogStream Используется в техничеcких целях для организации вывода
size_t getCurrentStep() const
Возврат константной ссылки на параметры распараллеливания по MPI.
std::string fileNameStep(const std::string &name, int length, size_t number, const std::string &ext)
Формирование имени файла
void CreateDirectory(const std::string &dir, const std::string &name)
Создание каталога
std::string CurrentDataTime()
Формирование строки с текущем временем и датой
void SwapEnd(T &var)
Вспомогательная функция перестановки байт местами (нужно для сохранения бинарных VTK)
std::pair< std::string, int > fileTypeVtx
Тип файлов для сохранения скорости и давления
int saveVtxStep
Шаг сохранения кадров в бинарные файлы
int nameLength
Число разрядов в имени файла