23{
24
26 std::vector<double> scale =
scales;
27
28
29 std::string circFileName = getPassport().dir + "circ";
30
31
32 if (currentStep == 0)
33 {
34 std::ofstream circFile(circFileName.c_str());
35
37
38 std::stringstream ssCirc;
39 ssCirc << "step time scale";
40 for (auto r : rad)
41 ssCirc << " R=" << r;
42
44
45 circFile << std::endl;
46 circFile.close();
47 circFile.clear();
48 }
49
50 for (int c = 0; c < scale.size(); ++c)
51 {
52 std::vector<double> circRad(rad.size(), 0.0);
53
54 int nPts = 50;
55
56 double delta = 6.0;
57
58 double R = 0.0;
59 double L = 0.0;
60 double epsAst = 0.0;
61 double gam = 0.0;
62 double curCirc = 0.0;
63
64 for (size_t i = 0; i < rad.size(); ++i)
65 {
66 R = rad[i];
67 curCirc = 0.0;
68
69#pragma omp parallel for default(none) private(L,gam,epsAst) shared(R,nPts,delta,c,scale) reduction(+:curCirc) schedule(dynamic,100)
70 for (
int j = 0; j < (int)
wake->vtx.size(); ++j)
71 {
72 L =
wake->vtx[j].r().length();
73 gam =
wake->vtx[j].g();
74 epsAst = scale[c] * velocity->wakeVortexesParams.epsastWake[j];
75
76 if (R - L > delta * epsAst)
77 curCirc += gam;
78 else if (R - L > -delta * epsAst)
79 {
80 double h = fabs(R - L);
81 if (h / R > 1e-3)
82 {
83 double phi = atan(h / sqrt(delta * delta * epsAst * epsAst - h * h));
84 double deltaPhi = (
PI - 2.0 * phi) / nPts;
85
86 double addCirc = 0.0;
87
88 auto func = [h, epsAst, delta](double phi) -> double
89 {
90 return (
IDPI / epsAst) * (exp(h / (epsAst * sin(phi))) * (epsAst - h / sin(phi)) - exp(-delta) * (1 + delta));
91 };
92
93 for (int s = 0; s < nPts; ++s)
94 {
95 double valAngle = -phi - deltaPhi * (s + 0.5);
96
97 addCirc += func(valAngle) * deltaPhi;
98 }
99 addCirc *= gam;
100
101 if (L > R)
102 curCirc += addCirc;
103 else
104 curCirc += (gam - addCirc);
105 }
106 else
107 curCirc += 0.5 * gam;
108 }
109 }
110
111 circRad[i] = curCirc;
112 }
113
114
115 std::ofstream circFile(circFileName.c_str(), std::ios::app);
116
117 circFile << currentStep << " " << getCurrentTime() << " " << scale[c];
118
119 for (auto gamma : circRad)
120 circFile << " " << gamma;
121 circFile << std::endl;
122
123
124 circFile.close();
125 circFile.clear();
126
127 }
128
129}
void PrintHeaderToTextFile(std::ofstream &str, const std::string &header)
Формирование подзаголовка в текстовом файле вывода программы VM2D/VM3D.
void PrintLogoToTextFile(std::ofstream &str, const std::string &fileName, const std::string &descr)
Формирование заголовка файла программы VM2D/VM3D.