Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ntia/p2108
U.S. reference implementation of Recommendation ITU-R P.2108 on the prediction of clutter loss for terrestrial and airborne paths.
https://github.com/ntia/p2108
cpp csharp itu propagation
Last synced: about 2 months ago
JSON representation
U.S. reference implementation of Recommendation ITU-R P.2108 on the prediction of clutter loss for terrestrial and airborne paths.
- Host: GitHub
- URL: https://github.com/ntia/p2108
- Owner: NTIA
- License: other
- Created: 2021-07-08T23:05:12.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-10-23T22:18:56.000Z (2 months ago)
- Last Synced: 2024-10-24T11:19:49.347Z (2 months ago)
- Topics: cpp, csharp, itu, propagation
- Language: C#
- Homepage:
- Size: 263 KB
- Stars: 4
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
- Citation: CITATION.cff
Awesome Lists containing this project
README
# Recommendation ITU-R P.2108-1 - U.S. Reference Implementation #
Persistent Identifier: [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.7114033.svg)](https://doi.org/10.5281/zenodo.7114033)
This code repository contains the U.S. Reference Software Implementation of
Recommendation ITU-R P.2108. This Recommendation contains three methods for the
prediction of clutter loss: [Height Gain Terminal Correction Model](README.md#height-gain-terminal-correction-model),
[Terrestrial Statistical Model](README.md#terrestrial-statistical-model),
[Aeronautical Statistical Model](README.md#aeronautical-statistical-model).
The software implements Section 3 of Annex 1 of the Recommendation.## Height Gain Terminal Correction Model ##
The height gain terminal correction model is described in Section 3.1.
This end-point clutter method gives the median loss due to different terminal
surroundings for terrestrial paths for frequencies between 0.3 to 3 GHz. This
model can be applied to both transmitting and receiving ends of the path.### Inputs (Height Gain Terminal Correction Model) ###
| Variable | Type | Units | Limits | Description |
|----------------|--------|-------|----------------------|-------------------------------|
| `f__ghz` | double | GHz | 0.3 <= `f__ghz` <= 3 | Frequency |
| `h__meter` | double | meter | 0 <= `h__meter` | Antenna height |
| `w_s__meter` | double | meter | 0 < `w_s__meter` | Street width |
| `R__meter` | double | meter | 0 < `R__meter` | Representative clutter height |
| `clutter_type` | int | | | Clutter type
- 1 = Water/sea
- 2 = Open/rural
- 3 = Suburban
- 4 = Urban
- 5 = Trees/forest
- 6 = Dense urban
Where site-specific values for the representative clutter height are not available,
the following default values are recommended.
| Clutter Type | `R__meter` |
|--------------|:----------:|
| Water/sea | 10 |
| Open/rural | 10 |
| Suburban | 10 |
| Urban | 15 |
| Trees/forest | 15 |
| Dense urban | 20 |
### Outputs (Height Gain Terminal Correction Model) ###
| Variable | Type | Units | Description |
|------------|--------|-------|-------------|
| `A_h__db` | double | dB | Additional loss (clutter loss) |
### Return Codes (Height Gain Terminal Correction Model) ###
Possible return codes, including the corresponding defined constant name as
defined in [`Errors.h`](include/Errors.h):
| Value | Const Name | Description |
|-------|---------------------------|----------------------------------------------------|
| 0 | `SUCCESS` | Successful execution |
| 3100 | `ERROR31__FREQUENCY` | Frequency must be between 0.3 and 3 GHz, inclusive |
| 3101 | `ERROR31__ANTENNA_HEIGHT` | Antenna height must be >= 0 meters |
| 3102 | `ERROR31__STREET_WIDTH` | Street width must be > 0 meters |
| 3103 | `ERROR31__CLUTTER_HEIGHT` | Representative clutter height must be > 0 meters |
| 3104 | `ERROR31__CLUTTER_TYPE` | Invalid value for clutter type |
## Terrestrial Statistical Model ##
The statistical clutter loss model for terrestrial paths as described in Section
3.2. This model is valid for urban and suburban clutter environments. For paths
between 0.25 and 1 km, this model can only be applied to one end of the path.
For paths greater than 1 km, the model can be applied to both terminals, if desired.
### Inputs (Terrestrial Statistical Model) ###
| Variable | Type | Units | Limits | Description |
|----------|--------|-------|---------------------|---------------|
| `f__ghz` | double | GHz | 2 <= `f__ghz` <= 67 | Frequency |
| `d__km` | double | km | 0.25 <= `d__km` | Path distance |
| `p` | double | % | 0 < `p` < 100 | Percentage of locations clutter loss not exceeded |
### Outputs (Terrestrial Statistical Model) ###
| Variable | Type | Units | Description |
|------------|--------|-------|-------------|
| `L_ctt__db` | double | dB | Clutter loss |
### Return Codes (Terrestrial Statistical Model) ###
Possible return codes, including the corresponding defined constant name as
defined in [`Errors.h`](include/Errors.h):
| Value | Const Name | Description |
|-------|-----------------------|---------------------------------------------------|
| 0 | `SUCCESS` | Successful execution |
| 3200 | `ERROR32__FREQUENCY` | Frequency must be between 2 and 67 GHz, inclusive |
| 3201 | `ERROR32__DISTANCE` | Path distance must be >= 0.25 km |
| 3202 | `ERROR32__PERCENTAGE` | Percentage must be between 0 and 100 |
## Aeronautical Statistical Model ##
The Earth-space and aeronautical statistical clutter loss model as described in
Section 3.3. This model is applicable when one end of the path is within man-made
clutter and the other end is a satellite, aeroplane, or other platform above the
Earth. This model is valid for urban and suburban clutter environments.
### Inputs (Aeronautical Statistical Model) ###
| Variable | Type | Units | Limits | Description |
|--------------|--------|-------|-------------------------|-----------------|
| `f__ghz` | double | GHz | 10 <= `f__ghz` <= 100 | Frequency |
| `theta__deg` | double | deg | 0 <= `theta__deg` <= 90 | Elevation angle |
| `p` | double | % | 0 < `p` < 100 | Percentage of locations clutter loss not exceeded |
### Outputs (Aeronautical Statistical Model) ###
| Variable | Type | Units | Description |
|------------|--------|-------|-------------|
| `L_ces__db` | double | dB | Clutter loss |
### Return Codes (Aeronautical Statistical Model) ###
Possible return codes, including the corresponding defined constant name as defined
in [`Errors.h`](include/Errors.h):
| Value | Const Name | Description |
|-------|-----------------------|----------------------------------------------------------|
| 0 | `SUCCESS` | Successful execution |
| 3300 | `ERROR33__FREQUENCY` | Frequency must be between 10 and 100 GHz, inclusive |
| 3301 | `ERROR33__THETA` | Elevation angle must be between 0 and 100 GHz, inclusive |
| 3302 | `ERROR33__PERCENTAGE` | Percentage must be between 0 and 100, inclusive |
## Example Values ##
The [Study Group Clutter Excel Workbook](https://www.itu.int/en/ITU-R/study-groups/rsg3/ionotropospheric/Clutter%20and%20BEL%20workbook_V2.xlsx)
contains an extensive set of validation example values.
## Notes on Code Style ##
* In general, variables follow the naming convention in which a single underscore
denotes a subscript (pseudo-LaTeX format), where a double underscore is followed
by the units, i.e. `h_1__meter`.
* Variables are named to match their corresponding mathematical variables in the
underlying Recommendation text.
* Wherever possible, equation numbers are provided. It is assumed that a user
reviewing this source code would have a copy of the Recommendation's text available
as a primary reference.
## Configure and Build ##
### C++ Software ###
The software is designed to be built into a DLL (or corresponding library for
non-Windows systems). The source code can be built for any OS that supports the
standard C++ libraries. A Visual Studio 2019 project file is provided for Windows
users to support the build process and configuration.
### C#/.NET Wrapper Software ###
The .NET support of P.2108 consists of a simple pass-through wrapper around the
native DLL. It is compiled to target .NET Framework 4.8.1. Distribution and updates
are provided through the published [NuGet package](https://github.com/NTIA/p2108/packages).
## References ##
* [Recommendation ITU-R P.2108](https://www.itu.int/rec/R-REC-P.2108/en)
* [Report ITU-R P.2402](https://www.itu.int/pub/R-REP-P.2402)
## Contact ##
For questions, contact Billy Kozma,