rotpat
Rotate radiation pattern
Description
also specifies an extrapolated value to be used when rpat
= rotpat(pat
,az
,el
,rotax
,expval
)az
and
el
do not cover the entire 3-D space.
Tip
You can use this function to rotate real and complex scalar radiation patterns as well as the orthogonal components of polarized fields. To rotate polarized fields, rotate the horizontal and vertical polarization components separately.
Examples
Rotate Pattern of Short-Dipole Antenna
Use a short-dipole antenna to create a polarized radiation pattern. Rotate the pattern and use the rotated pattern as the radiation pattern of a custom antenna.
Create a phased.ShortDipoleAntennaElement
antenna object with default properties. The short-dipole antenna radiates polarized radiation. Obtain and display the radiation for all directions.
antenna1 = phased.ShortDipoleAntennaElement; el = -90:90; az = -180:180; pat_h = zeros(numel(el),numel(az),'like',1+1i); pat_v = pat_h; fc = 3e8; for m = 1:numel(el) temp = antenna1(fc,[az;el(m)*ones(1,numel(az))]); pat_h(m,:) = temp.H; pat_v(m,:) = temp.V; end pattern(antenna1,fc,'Type','Power')
Rotate the antenna pattern around the y-axis by 135 degrees followed by a rotation around the x-axis by 65 degrees.
newax = rotx(65)*roty(135); pat2_h = rotpat(pat_h,az,el,newax); pat2_v = rotpat(pat_v,az,el,newax);
Insert the rotated pattern into a phased.CustomAntennaElement
object. Set the antenna polarization properties so that the element radiates horizontal and vertical polarized fields. Then display the rotated pattern in three dimensions.
antenna2 = phased.CustomAntennaElement( ... 'SpecifyPolarizationPattern',true, ... 'HorizontalMagnitudePattern',mag2db(abs(pat2_h)), ... 'HorizontalPhasePattern',rad2deg(angle(pat2_h)), ... 'VerticalMagnitudePattern',mag2db(abs(pat2_v)), ... 'VerticalPhasePattern',rad2deg(angle(pat2_v))); pattern(antenna2,fc,'Type','Power')
Rotate Pattern of Cosine Antenna
Create a radiation pattern for a cosine antenna using a phased.CosineAntennaElement
object. Rotate the pattern to use in a phased.CustomAntennaElement
antenna object.
First obtain the radiation pattern for a phased.CosineAntennaElement
object over a limited range of directions. The field is not polarized.
antenna1 = phased.CosineAntennaElement('CosinePower',[5,5]); az = -60:65; el = -60:60; pat = zeros(numel(el),numel(az),'like',1); fc = 300e6; for m = 1:numel(el) temp = antenna1(fc,[az;el(m)*ones(1,numel(az))]); pat(m,:) = temp; end
Display the original pattern.
imagesc(az,el,abs(pat)) axis xy axis equal axis tight xlabel('Azimuth (deg)') ylabel('Elevation (deg)') title('Original Radiation Pattern') colorbar
Rotate the antenna pattern by 20 degrees around the z-axis and 50 degrees around the x-axis. Then display the rotated pattern.
newax = rotx(50)*rotz(20); rpat = rotpat(pat,az,el,newax); imagesc(az,el,abs(rpat)) axis xy axis equal axis tight xlabel('Azimuth (deg)') ylabel('Elevation (deg)') title('Rotated Radiation Pattern') colorbar
Use the rotated pattern in a custom antenna element and display the pattern in 3-D.
antenna2 = phased.CustomAntennaElement( ... 'AzimuthAngles',az,'ElevationAngles',el,'SpecifyPolarizationPattern',false, ... 'MagnitudePattern',mag2db(abs(rpat)), ... 'PhasePattern',zeros(size(rpat))); pattern(antenna2,fc,'Type','Power')
Input Arguments
pat
— Radiation pattern
complex-valued N-by-M matrix | complex-valued N-by-M-by-L
array
Radiation pattern, specified as a complex-valued
N-by-M matrix or complex-valued
N-by-M-by-L array.
N is the length of the el
vector and
M is the length of the az
vector. Each column
corresponds to one of the azimuth angles specified in the az
argument. Each row corresponds to one of the elevation angles specified in the
el
argument. You can specify multiple radiation patterns using
L pages. For example, you can use pages to specify radiation
patterns at different frequencies. The main lobe of each pattern is assumed to point
along the x-axis. Units are in meters-squared.
Data Types: double
Complex Number Support: Yes
az
— Azimuth angles
-180:180
(default) | 1-by-M real-valued row vector
Azimuth angles for computing 3-D radiation pattern, specified as a
1-by-M real-valued row vector where M is the
number of azimuth angles. Each entry corresponds to one of the columns of the matrix
specified in the pat
argument. Angle units are in degrees. Azimuth
angles must lie between –180° and 180°, inclusive.
The azimuth angle is the angle between the x-axis and the projection of the direction vector onto the xy-plane. The azimuth angle is positive when measured from the x-axis toward the y-axis.
Example: -45:2:45
Data Types: double
el
— Elevation angles
-90:90
(default) | 1-by-N real-valued row vector
Elevation angles for computing directivity and pattern, specified as a
1-by-N real-valued row vector where N is the
number of elevation angles. Each entry corresponds to one of the rows of the matrix
specified in the pat
argument. Angle units are in degrees.
Elevation angles must lie between –90° and 90°, inclusive.
The elevation angle is the angle between the direction vector and xy-plane. The elevation angle is positive when measured toward the z-axis.
Example: -75:1:70
Data Types: double
rotax
— Rotation matrix
real-valued orthonormal 3-by-3 matrix | real-valued orthonormal 3-by-3-by-P array of orthonormal
matrices
Rotation matrix, specified as a real-valued orthonormal 3-by-3 matrix or a real-valued 3-by-3-by-P array. The columns represent the x, y, and z directions of the rotated coordinate system with respect to the original coordinate system. The P pages specify different rotation matrices.
This table describes how dimensions of the output pattern rpat
depend on the dimensions of the pat
and rotax
arguments.
Dimensions of rpat
Dimensions of pat | Dimensions of
rotax | |
---|---|---|
3-by-3 | 3-by-3-by-P | |
M-by-N | Rotate a single pattern by a single rotation matrix. Output dimensions of
rpat are
M-by-N. | Rotate a single pattern by P different rotation
matrices. Output dimensions of rpat are
M-by-N-by-P. |
M-by-N-by-L | Rotate L patterns by the same rotation matrix. Output
dimensions of rpat are
M-by-N-by-L. | In this case, P must equal L and
the function rotates each pattern by the corresponding rotation matrix. Output
dimensions of rpat are
M-by-N-by-L. |
Example: rotx(45)*roty(30)
Data Types: double
expval
— Extrapolation value
0
(default) | scalar
Extrapolation value, specified as a scalar. This scalar is the extrapolated value
when the rotated patterns do not fill the entire 3-D space specified by
az
and el
. In general, consider setting
expval
to 0 if the pattern is specified in a linear scale or
-inf
if the pattern is specified in a dB scale.
Example: -inf
Data Types: double
Output Arguments
rpat
— Rotated radiation pattern
complex-valued N-by-M matrix | complex-valued N-by-M-by-P
array
Rotated radiation pattern, returned as a complex-valued
N-by-M matrix or complex-valued
N-by-M-by-P array.
N is the length of the el
vector.
M is the length of the az
vector. The
dimensionality of pat
and rotax
determine the
value of P as discussed in the rotax
input
argument. Units are in meters-squared.
Data Types: double
Complex Number Support: Yes
Extended Capabilities
C/C++ Code Generation
Generate C and C++ code using MATLAB® Coder™.
Version History
Introduced in R2019a
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: United States.
You can also select a web site from the following list
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)
Asia Pacific
- Australia (English)
- India (English)
- New Zealand (English)
- 中国
- 日本Japanese (日本語)
- 한국Korean (한국어)