Распространение радиоволн ВЧ/Реализация/radiation set t: различия между версиями

Материал из CAMaaS preliminary wiki
Перейти к навигации Перейти к поиску
(Угловой шаг)
Строка 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Тип характеристики направленности, для которой осуществляется перечисление.

Тип реализует двумерную коллекцию направлений излучения, которая создается для заданного источника поля и зависит от частоты излучения, номера итерации, а также от позиций отражающих поверхностей и контрольных точек относительно источника.

В первом измерении перечисляются углы (зенита), а во втором - (азимута) относительно некоторого центрального направления . В случае отсутствия оптимизации по локальности отражающих поверхностей и контрольных точек совпадает с главной осью источника. Если же используется оптимизация, вектор совпадает с вектором, возвращаемым методом encompassing_aperture_t::central_point над объектом, в свою очередь возвращенным методом Source::EncompassingAperture источника.
Минимизация количества элементов коллекции radiation_set_t путем локализации контрольных точек и отражающих поверхностей входной модели сектором на сфере, описанной вокруг источника <mathS</math>. Сектор, возвращаемый методом Source::EncompassingAperture источника, представлен центральным направлением и ангулярным радиусом вокруг этого направления. В процессе перечисления направлений излучения азимут пробегает значения диапазона , а зенит - диапазона . Оба угла заданы в базисе , в котором направление совпадает с аппликатой, как показано на рисунке.

Измерения индексируются с нуля. Первое, внешнее, измерение реализуется классами 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, направлен на центр такого сектора.