Распространение радиоволн ВЧ/Реализация/radiation set t: различия между версиями
Строка 1: | Строка 1: | ||
{{DISPLAYTITLE:Распространение радиоволн ВЧ/Реализация/radiation_set_t}} | {{DISPLAYTITLE:Распространение радиоволн ВЧ/Реализация/radiation_set_t}} | ||
{{class|Распространение радиоволн ВЧ/Реализация/radiation_set_t}} | {{class|Распространение радиоволн ВЧ/Реализация/radiation_set_t}} | ||
Тип реализует двемерную коллекцию направлений излучения, которая создается для заданного [[Распространение радиоволн ВЧ/Реализация/Source|источника поля]] и зависит от частоты излучения, номера итерации, а также от позиций [[Распространение радиоволн ВЧ/Реализация/ReflectingObject|отражающих поверхностей]] и [[Распространение радиоволн ВЧ/Реализация/ControlPointSet|контрольных точек]] относительно источника. | |||
[[File:radio_hf_src_angles.svg|thumb|В первом измерении перечисляются углы <math>\varphi</math> (зенита), а во втором - <math>\theta</math> (азимута) относительно некоторого центрального направления <math>\vec{v}</math>. В случае отсутствия оптимизации по локальности отражающих поверхностей и контрольных точек <math>\vec{v}</math> совпадает с главной осью источника. Если же используется оптимизация, вектор <math>\vec{v}</math> совпадает с вектором, возвращаемым методом [[Распространение радиоволн ВЧ/Реализация/encompassing_aperture_t::central_point|encompassing_aperture_t::central_point]] над объектом, в свою очередь возвращенным методом [[Распространение радиоволн ВЧ/Реализация/Source::EncompassingAperture|Source::EncompassingAperture]] источника.]] | |||
Измерения индексируются от нуля. Первое, внешнее, измерение реализуется классами [[Распространение радиоволн ВЧ/Реализация/dyn_radiation_set_dim_1_collection|dyn_radiation_set_dim_1_collection]] и [[Распространение радиоволн ВЧ/Реализация/dyn_radiation_set_dim_1_enumerator|dyn_radiation_set_dim_1_enumerator]], первый из которых реализует коллекцию направлений в этом измерении, а второй - перечисление коллекций нулевого измерения, для каждого элемента коллекции в первом измерении. | |||
Нулевое измерение реализуется классами [[Распространение радиоволн ВЧ/Реализация/dyn_radiation_set_dim_0_collection|dyn_radiation_set_dim_0_collection]] и [[Распространение радиоволн ВЧ/Реализация/dyn_radiation_set_dim_0_enumerator|dyn_radiation_set_dim_0_enumerator]] соответственно. Элементами коллекции в нулевом измерении являются пары угловых значений "азимут-зенит", реализуемые структурой [[Распространение радиоволн ВЧ/Реализация/angle_pair|angle_pair]]. | |||
При формировании коллекции направлений излучения используется минимизация элементов коллекции двумя способами. Первый - это зависимость ангулярного шага от значения функции характеристики направленности в текущей ангулярной позиции, как это описано для [[Распространение_радиоволн_ВЧ/Рей-трейсинг#.D0.A3.D0.B3.D0.BB.D0.BE.D0.B2.D0.BE.D0.B9_.D1.88.D0.B0.D0.B3_.D0.B4.D0.B8.D1.81.D0.BA.D1.80.D0.B5.D1.82.D0.B8.D0.B7.D0.B0.D1.86.D0.B8.D0.B8_.D0.BA.D0.B0.D0.BA_.D1.84.D1.83.D0.BD.D0.BA.D1.86.D0.B8.D1.8F_.D0.A5.D0.9D|итерационного рей-трейсинга]]. Второй способ представляет собой ограничение сферы вокруг источника так, чтобы полученный сектор охватывал все отражающие поверхности и контрольные точки входной геометрической модели, и исключение из множества направлений тех из них, которые не принадлежат этому сектору. См. описание класса [[Распространение радиоволн ВЧ/Реализация/encompassing_aperture_t|encompassing_aperture_t]], который описывает такой сектор с помощью вектора направления на центральную точку сектора и ангулярного радиуса вокруг этого вектора. | |||
Пусть <math>\Delta_{0, \textrm{min}}</math> - управляющее значение, возвращенное методом [[Распространение_радиоволн_ВЧ/Config::AngularSamplingRateMin|Config::AngularSamplingRateMin]], <math>\Delta_{0, \textrm{max}}</math> - управляющее значение, возвращенное методом [[Распространение_радиоволн_ВЧ/Config::AngularSamplingRateMax|Config::AngularSamplingRateMin]], <math>R\left(\omega,\theta,\varphi\right)</math> - функция характеристики направленности источника, <math>i\ge 0</math> - номер текущей итерации, <math>\delta\left(S, \theta, \varphi\right)</math> - функция перехода от азимута <math>\theta</math> и зенита <math>\varphi</math>, выраженных относительно вектора <math>\vec{v}</math> источника <math>S</math> (см. рисунок), к азимуту и зениту, выраженным относительно главной оси источника, <math>\begin{pmatrix}\theta_s & \varphi_s \end{pmatrix} = \delta\left(\vec{v}, \theta, \varphi\right)</math>. Тогда ангулярный шаг в нулевом измерении расчитывается как функция | |||
:<math>\Delta_\theta\left(\omega,\theta,\varphi\right) = \frac{\Delta_{0, \textrm{min}} + \left(\Delta_{0, \textrm{max}} - \Delta_{0, \textrm{min}}\right)R\left(\omega,\theta_s,\varphi_s\right)}{2^i}</math>. | |||
Зенит перечисляется в первом измерении с шагом <math>\Delta_\varphi\left(\omega,\varphi\right)=\Delta_\theta\left(\omega,0,\varphi\right)</math>. | |||
Функция <math>\delta\left(S, \theta, \varphi\right)</math> преобразования ангулярных координат относительно <math>\vec{v}</math> источника <math>S</math> к базису <math>S</math>реализуется поворотом <math>\vec{v}</math> так, чтобы он совпал с направлением главной оси источника (которая в свою очередь совпадает с аппликатой базиса источника). То есть используется матрица поворота | |||
:<math>T\left(\vec{v}\right)=\begin{bmatrix} | |||
\textrm{cos}\varphi_v & 0 & \textrm{sin}\varphi_v \\ | |||
0 & 1 & 0 \\ | |||
-\textrm{sin}\varphi_v & 0 & \textrm{cos}\varphi_v | |||
\end{bmatrix}\begin{bmatrix} | |||
\textrm{cos}\theta_v & -\textrm{sin}\theta_v & 0 \\ | |||
\textrm{sin}\theta_v & \textrm{cos}\theta_v & 0 \\ | |||
0 & 0 & 1 | |||
\end{bmatrix}</math>, | |||
:в которой пара значений <math>\begin{pmatrix}\theta_v & \varphi_v\end{pmatrix}</math> возвращается вызванным над <math>\vec{v}</math> методом [[Распространение радиоволн ВЧ/Реализация/Antenna::ToSpherical|Antenna::ToSpherical]] антенны источника (см. [[Распространение радиоволн ВЧ/Реализация/Source::Antenna|Source::Antenna]]). | |||
Тогда направление, заданное углами <math>\left(\theta,\varphi\right)</math> относительно <math>\vec{v}</math>, в базисе источника будет иметь представление | |||
:<math>P\left(\vec{v}, \theta,\varphi\right)=T\left(\vec{v}\right)\begin{bmatrix} | |||
\textrm{sin}\varphi\textrm{cos}\theta \\ | |||
\textrm{sin}\varphi\textrm{sin}\theta \\ | |||
\textrm{cos}\varphi | |||
\end{bmatrix}</math> | |||
Поэтому результирующая пара углов вычисляется следующим образом | |||
:<math>\begin{pmatrix}\theta & \varphi\end{pmatrix} = | |||
\left[ | |||
\begin{matrix} | |||
\begin{pmatrix}0 & 1\end{pmatrix} \Leftrightarrow P_x^2 + P_y^2 \equiv 0 \\ | |||
\begin{pmatrix}\textrm{sign}\left(P_y\right)\cdot\textrm{acos}\frac{P_x}{P_x^2+P_y^2} & \textrm{acos}\frac{P_z}{\left|P\right|}\end{pmatrix} \Leftrightarrow P_x^2 + P_y^2 \ne 0 \\ | |||
\end{matrix} | |||
\right.</math> |
Версия 20:21, 28 ноября 2018
Реализует перечисление направлений излучения источником элементов волнового поля при использовании итерационного алгоритма рей-трейсинга.
template <class RadiationPatternType>
using radiation_set_t = dyn_radiation_set_dim_1_collection<RadiationPatternType>;
RadiationPatternType | Тип характеристики направленности, для которой осуществляется перечисление. |
Тип реализует двемерную коллекцию направлений излучения, которая создается для заданного источника поля и зависит от частоты излучения, номера итерации, а также от позиций отражающих поверхностей и контрольных точек относительно источника.

Измерения индексируются от нуля. Первое, внешнее, измерение реализуется классами dyn_radiation_set_dim_1_collection и dyn_radiation_set_dim_1_enumerator, первый из которых реализует коллекцию направлений в этом измерении, а второй - перечисление коллекций нулевого измерения, для каждого элемента коллекции в первом измерении.
Нулевое измерение реализуется классами dyn_radiation_set_dim_0_collection и dyn_radiation_set_dim_0_enumerator соответственно. Элементами коллекции в нулевом измерении являются пары угловых значений "азимут-зенит", реализуемые структурой angle_pair.
При формировании коллекции направлений излучения используется минимизация элементов коллекции двумя способами. Первый - это зависимость ангулярного шага от значения функции характеристики направленности в текущей ангулярной позиции, как это описано для итерационного рей-трейсинга. Второй способ представляет собой ограничение сферы вокруг источника так, чтобы полученный сектор охватывал все отражающие поверхности и контрольные точки входной геометрической модели, и исключение из множества направлений тех из них, которые не принадлежат этому сектору. См. описание класса encompassing_aperture_t, который описывает такой сектор с помощью вектора направления на центральную точку сектора и ангулярного радиуса вокруг этого вектора.
Пусть Config::AngularSamplingRateMin, - управляющее значение, возвращенное методом Config::AngularSamplingRateMin, - функция характеристики направленности источника, - номер текущей итерации, - функция перехода от азимута и зенита , выраженных относительно вектора источника (см. рисунок), к азимуту и зениту, выраженным относительно главной оси источника, . Тогда ангулярный шаг в нулевом измерении расчитывается как функция
- управляющее значение, возвращенное методом- .
Зенит перечисляется в первом измерении с шагом
.Функция
преобразования ангулярных координат относительно источника к базису реализуется поворотом так, чтобы он совпал с направлением главной оси источника (которая в свою очередь совпадает с аппликатой базиса источника). То есть используется матрица поворота- ,
- в которой пара значений Antenna::ToSpherical антенны источника (см. Source::Antenna). возвращается вызванным над методом
Тогда направление, заданное углами
относительно , в базисе источника будет иметь представлениеПоэтому результирующая пара углов вычисляется следующим образом