Main Content


Add atmosphere model object to radar scenario



atmos = atmosphere(scenario,model) creates an atmosphere object atmos that belongs to a radar scenario object. The atmosphere is defined by the atmospheric refraction model. To enable this object method, set the IsEarthCentered property of the radarScenario object scenario to true. Use this object only in a scenario that uses a radarTransceiver object.

After creating the atmosphere, you can use the effearthradius object function to compute the effective earth radius and the effective earth radius factor.


atmos = atmosphere(___,Name,Value) sets the atmosphere object with additional properties specified by one or more name-value arguments.


collapse all

Create an atmosphere using the effective earth radius model. Assume the effective earth radius is 4/3 of the actual earth radius. Using the model requires that the IsEarthCentered property of radarScenario be true.

scenario  = radarScenario('IsEarthCentered',true);
atmos = atmosphere(scenario,'EffectiveEarth')
atmos = 
  AtmosphereEffectiveEarth with properties:

             InputFormat: 'Radius'
    EffectiveEarthRadius: 8.4774e+06

Compare the effective Earth factors calculated from the CRPL and 4/3 Earth models. Assume the slant range is 100 km, the antenna heights range from 1 to 10 km, and the target altitude is at the surface.

 SR = 100e3;
 ha = linspace(1,10,50).*1e3;
 ht = 0;

Create a radar scenario and a CRPL atmosphere.

scenario = radarScenario('IsEarthCentered',true);
atmos = atmosphere(scenario,'CRPL');
[~,kCRPL] = effearthradius(atmos,SR,ha,ht);

Plot the computed k-factor and a vertical 4/3 line.

hold on
xlim([0.99 1.37])
grid on
legend('CRPL','4/3 Earth','True Earth')
xlabel('Effective Earth Radius Factor k')
ylabel('Altitude (km)')
hold off

Figure contains an axes object. The axes object contains 3 objects of type line, constantline. These objects represent CRPL, 4/3 Earth, True Earth.

Input Arguments

collapse all

Radar scenario, specified as a radarScenario object.

Atmospheric model, specified as 'FreeSpace', 'EffectiveEarth', 'RefractivityGradient', or 'CRPL'.

Data Types: char | string

Name-Value Arguments

Specify optional pairs of arguments as Name1=Value1,...,NameN=ValueN, where Name is the argument name and Value is the corresponding value. Name-value arguments must appear after other arguments, but the order of the pairs does not matter.

Example: InputFormat='k Factor'

No additional name-value pairs are required when the model argument is set to FreeSpace.

EffectiveEarth model

collapse all

Input format, specified as 'Radius' or 'k Factor'. Setting the InputFormat property to 'Radius' enables the EffectiveEarthRadius property. Setting the InputFormat property to 'k Factor' enables the EffectiveEarthK property.


Data Types: char | string

Effective earth radius, specified as a positive scalar. The default earth radius of 4/3 Re is equivalent to a refractivity gradient of -39e-9. Re is the radius of the earth and is obtained from physconst('EarthRadius'). Units are in meters.


Example: 11/7 Re


To enable this property, set the model argument to 'EffectiveEarth' and set the InputFormat property to 'Radius'.

Data Types: double

Effective earth k-factor, specified as a nonnegative scalar. The effective Earth radius Re in this case is calculated as: Re = k*Rearth, where Rearth is the Earth radius as output by physconst('EarthRadius').

Example: 11/7


To enable this property, set the model argument to 'EffectiveEarth' and set the InputFormat property to 'k Factor'.

Data Types: double

RefractivityGradient model

collapse all

Refractivity gradient, specified as a scalar. The refractivity gradient is used to calculate the effective Earth radius.


To enable this property, set the model argument to 'RefractivityGradient'.

Data Types: double


collapse all

Surface refractivity, specified as a non-negative scalar. Units are N-units.


To enable this property, set the model argument to 'CRPL'.

Data Types: double

Refraction exponent factor for the CRPL exponential reference atmosphere model, specified as a non-negative scalar. Units are 1/km.


To enable this property, set the model argument to 'CRPL'.

Data Types: double

Maximum number of iterations for the CRPL method, specified as a non-negative, scalar integer. This input acts as a safeguard to prevent endless iterative calculations.

Example: 20


To enable this property, set the model argument to 'CRPL'.

Data Types: double

Specifies the absolute tolerance for the CRPL method, specified as a positive scalar. This is the tolerance which the iterative process is terminated.

Example: 0.1


To enable this property, set the model argument to 'CRPL'.

Data Types: double

Output Arguments

collapse all

Atmosphere, returned as an Atmosphere object.

More About

collapse all

Curved Earth Model

The fact that the index of refraction of air depends on height can be treated approximately by using an effective Earth's radius larger than the actual value.

Given the effective Earth's radius R0, the antenna height ha, and the initial elevation angle θ0, the model relates the target height hT and the slant range RT by


so knowing one of those magnitudes enables you to compute the other. In particular,


The actual range R is equal to the slant range. The true elevation angle θT is equal to the initial elevation angle.

To compute the ground range G, use


Curved Earth model geometry

A standard propagation model uses an effective Earth's radius that is 4/3 times the actual value. This model has two major limitations:

  1. The model implies a value for the index of refraction near the Earth's surface that is valid only for certain areas and at certain times of the year. To mitigate this limitation, use an effective Earth's radius based on the near-surface refractivity value.

  2. The model implies a value for the gradient of the index of refraction that is unrealistically low at heights of around 8 km. To partially mitigate this limitation, use an effective Earth's radius based on the platform altitudes.

For more information, see effearthradius.

CRPL Exponential Reference Atmosphere Model

Atmospheric refraction evidences itself as a deviation in an electromagnetic ray from a straight line due to variation in air density as a function of height. The Central Radio Propagation Laboratory (CRPL) exponential reference atmosphere model treats refraction effects by assuming that the index of refraction n(h) and the refractivity N decay exponentially with height. The model defines


where Ns is the atmospheric refractivity value (in units of 10–6) at the surface of the earth, Rexp is the decay constant, and h is the height above the surface in kilometers. Thus


The default value of Ns is 313 N-units and can be modified using the SurfaceRefractivity name-value argument in functions that accept it. The default value of Rexp is 0.143859 km–1 and can be modified using the RefractionExponent name-value argument in functions that accept it.

CRPL Model Geometry

When the refractivity of air is incorporated into the curved Earth model, the ray paths do not follow a straight line but curve downward. (This statement assumes standard atmospheric propagation and nonnegative elevation angles.) The true elevation angle $\theta_T$ is different from the initial $\theta_0$. The actual range $R$, which is the distance along the curved path $R'$, is different from the slant range $R_T$.

Given the Earth's radius $R_0$, the antenna height $h_a$, the initial elevation angle $\theta_0$, and the height-dependent index of refraction $n(h)$ with value $n_0$ at $h=0$, the modified model relates the target height $h_T$ and the actual range $R$ by

$$ R=\int_0^{h_T-h_a}{n(h)\,dh}\,
 \left({{1-\left(\frac{\textstyle n_0\cos\theta_0}{\textstyle
 n(h)\left(1+\frac{\textstyle h}{\textstyle

When Method is specified as "CRPL", the integral is solved using $n(h)$ from CRPL Exponential Reference Atmosphere Model.

To compute the ground range $G$, use

$$ G=\int_0^{h_T-h_a}\frac{dh}{1+\frac{\textstyle h}{\textstyle
R_0+h_a}}\, \left({{\left(\frac{\textstyle n(h)\left(1+\frac{\textstyle


N-units are a convenient way to express the index of refraction. Because the index of refraction is very close to unity, N-units express just the deviation from unity. The refractivity N in N-units is related to the index of refraction n by


For example, an index of refraction of 1.000313 becomes 313 in N-units. N-units are dimensionless.


[1] Bradford R. Bean, G. D. Thayer. CRPL Exponential Reference Atmosphere, U.S. Department of Commerce, National Bureau of Standards, 1959.

[2] Blake, L. V. "A Note on Selection of an Atmospheric Refractivity Model for Radar Range-Height-Angle Charts." NRL Report 5626, Apr. 24, 1961

[3] Blake, L.V. "Ray Height Computation for a Continuous Nonlinear Atmospheric Refractive-Index Profile." RADIO SCIENCE, Vol. 3 (New Series), No. 1, Jan. 1968, pp. 85-92.

[4] Doerry, A. W. "Correcting Radar Range Measurements for Atmospheric Propagation Effects." edited by Kenneth I. Ranney and Armin Doerry, 90771K. Baltimore, Maryland, USA, 2014.

[5] Doerry, A. W. "Earth Curvature and Atmospheric Refraction Effects on Radar Signal Propagation." Sandia National Laboratories, SAND2012-10690, Jan. 2013.

[6] Robertshaw, G. "Effective Earth Radius for Refraction of Radio Waves at Altitudes above 1 Km." IEEE Transactions on Antennas and Propagation 34, no. 9 (September 1986): 1099-1105.

[7] Sweezy, W. B. , and B. R. Bean. "Correction of Atmospheric Refraction Errors In Radio Height Finding." Journal of Research of the National Bureau of Standards, D. Radio Propagation, 67D, no. 2 (March - April 1963).

Version History

Introduced in R2022b