Code_TYMPAN  4.4.0
Industrial site acoustic simulation
TYChemin9613Solver2024.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) <2012-2024> <EDF-DTG> <FRANCE>
3  * This file is part of Code_TYMPAN (R).
4  * Code_TYMPAN (R) is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (at your option) any later version.
8  * Code_TYMPAN (R) is distributed in the hope that it will be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
11  * See the GNU General Public License for more details.
12  * You should have received a copy of the GNU General Public License along
13  * with Code_TYMPAN (R). If not, see <https://www.gnu.org/licenses/>.
14  */
15 
16 #ifndef __TY_CHEMIN_9613SOLVER2024__
17 #define __TY_CHEMIN_9613SOLVER2024__
18 
20 
37 {
38 public:
40  double d_SO, double d_OR, double a, double h,
41  const OVector3D& n) const override;
42 
54  void calcCylinderReflectionAttenuation(const OPoint3D& S, const OPoint3D& R, const OPoint3D& P,
55  const OPoint3D& M, double r, const OVector3D& axis) override;
56 
57 protected:
59  const OSpectreOctave& Agr_m, double hs, double hr,
60  double dp) const override;
61 
70  OPoint3D projectOnPlane(const OPoint3D& P, const OVector3D& u1, const OVector3D& u2);
71 };
72 #endif // __TY_CHEMIN_9613SOLVER2024__
Representation of one of the most optimal path between source and receptor: S—>R Specific derivation ...
The 3D point class.
Definition: 3d.h:487
The 3D vector class.
Definition: 3d.h:298
Representation of one of the most optimal path between source and receptor: S—>R. The class TYChemin ...
OSpectreOctave calcTotalGroundAttenuation(const OSpectreOctave &Agr_s, const OSpectreOctave &Agr_r, const OSpectreOctave &Agr_m, double hs, double hr, double dp) const override
Compute total ground attenuation Agr from region ground attenuations and geometric configuration.
void calcCylinderReflectionAttenuation(const OPoint3D &S, const OPoint3D &R, const OPoint3D &P, const OPoint3D &M, double r, const OVector3D &axis) override
Compute attenuation when a reflection occur on a cylinder Implements Eq. 30 of 9613-2:2024 standard.
OSpectreOctave calcMinimalExtensionConditionOneReflection(const OPoint3D &Oprev, const OPoint3D &O, double d_SO, double d_OR, double a, double h, const OVector3D &n) const override
Evaluate minimal extension condition for a specular reflection on a flat surface in function of the w...
OPoint3D projectOnPlane(const OPoint3D &P, const OVector3D &u1, const OVector3D &u2)
Project a point P on the plane spanned by (u1, u2) from (0, 0, 0)
Representation of one of the most optimal path between source and receptor: S—>R. The class TYChemin ...