Распространение радиоволн ВЧ/Реализация/radiation set t: различия между версиями
(Угловой шаг) |
|||
Строка 17: | Строка 17: | ||
Пусть <math>\Delta_{0, \textrm{min}}</math> - управляющее значение, возвращенное методом [[Распространение_радиоволн_ВЧ/Config::AngularSamplingRateMin|Config::AngularSamplingRateMin]], <math>\Delta_{0, \textrm{max}}</math> - управляющее значение, возвращенное методом [[Распространение_радиоволн_ВЧ/Config::AngularSamplingRateMax|Config::AngularSamplingRateMax]], <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{c_p}</math> источника <math>S</math> (см. рисунок), к азимуту и зениту, выраженным относительно главной оси источника, <math>\begin{pmatrix}\theta_s & \varphi_s \end{pmatrix} = \delta\left(S, \theta, \varphi\right)</math>. Тогда ангулярный шаг в нулевом измерении расчитывается как функция | Пусть <math>\Delta_{0, \textrm{min}}</math> - управляющее значение, возвращенное методом [[Распространение_радиоволн_ВЧ/Config::AngularSamplingRateMin|Config::AngularSamplingRateMin]], <math>\Delta_{0, \textrm{max}}</math> - управляющее значение, возвращенное методом [[Распространение_радиоволн_ВЧ/Config::AngularSamplingRateMax|Config::AngularSamplingRateMax]], <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{c_p}</math> источника <math>S</math> (см. рисунок), к азимуту и зениту, выраженным относительно главной оси источника, <math>\begin{pmatrix}\theta_s & \varphi_s \end{pmatrix} = \delta\left(S, \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_\theta\left(\omega,\theta,\varphi\right) = \frac{\Delta_{0, \textrm{min}} + \left(\Delta_{0, \textrm{max}} - \Delta_{0, \textrm{min}}\right)\left(1 - R\left(\omega,\theta_s,\varphi_s\right)\right)}{2^i}</math>. | ||
Зенит перечисляется в первом измерении с шагом <math>\Delta_\varphi\left(\omega,\varphi\right)=\Delta_\theta\left(\omega,0,\varphi\right)</math>. | Зенит перечисляется в первом измерении с шагом <math>\Delta_\varphi\left(\omega,\varphi\right)=\Delta_\theta\left(\omega,0,\varphi\right)</math>. |
Версия 16:54, 29 ноября 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::AngularSamplingRateMax, - функция характеристики направленности источника, - номер текущей итерации, - функция перехода от азимута и зенита , выраженных относительно вектора источника (см. рисунок), к азимуту и зениту, выраженным относительно главной оси источника, . Тогда ангулярный шаг в нулевом измерении расчитывается как функция
- управляющее значение, возвращенное методом- .
Зенит перечисляется в первом измерении с шагом
.Функция
преобразования ангулярных координат относительно источника к базису реализуется поворотом вектора так, чтобы он совпал с направлением главной оси источника (которая в свою очередь совпадает с аппликатой базиса источника). То есть используется матрица поворота- ,
в которой пара значений Antenna::ToSpherical антенны источника (см. Source::Antenna).
возвращается вызванным над методомТогда направление, заданное углами
относительно , в базисе источника будет иметь представлениеПоэтому результирующая пара углов вычисляется следующим образом
Область определения функции encompassing_aperture_t::radius, сектора сферы вокруг источника, так что все отражающие объекты и контрольные точки геометрической модели при отображении на сферу оказываются внутри сектора. При этом вектор , возвращаемый методом encompassing_aperture_t::central_point, направлен на центр такого сектора.
: , , где - максимально возможный зенит - ангулярный радиус, значение которого возвращается методом