Wouldn't be convenient to create circle by passing center latitude and longitude and radius as it they are given in source - in terms of coordinate format and unit of measure?
A humble outlet of my ideas of how to deal with repetitive task based on aeronautical data
Thursday, 29 November 2018
Challenge: QGIS plugin to create circle (based on aviation-like data)
Wouldn't be convenient to create circle by passing center latitude and longitude and radius as it they are given in source - in terms of coordinate format and unit of measure?
Tuesday, 27 November 2018
Coordinates (4): way if you hate regex
If we don't want to use regular expression, we need to change our approach to solve the 'variety of coordinates format' problem.
This time we will
coord_input: input coordinate to be converted (it also might be DD format!)
c_type: coordinate type (latitude, longitude) to make sure that coordinate is within appropriate range
Definition of c_type constants:
First we 'normalize input':
This time we will
- 'normalize' input into more friendly format (e. g. replace all kind of separators (delimiters) with space)
- parse output sequentially - decision what to do next depends on what you get from previous step, e.g if you split intermediate result into list and get 3 items - it means that the first are degrees, second - minutes, third - seconds (to be more precise - we make such assumption) and validate them to check if it make sense
def coord2dd(coord_input, c_type):
coord_input: input coordinate to be converted (it also might be DD format!)
c_type: coordinate type (latitude, longitude) to make sure that coordinate is within appropriate range
Definition of c_type constants:
C_LAT = 'C_LAT' C_LON = 'C_LON'
First we 'normalize input':
coord_norm = coord_input.strip() coord_norm = coord_norm.upper() coord_norm = coord_norm.replace(',', '.')
Monday, 26 November 2018
Challenge: importing FAA digital obstacle file content into PostGIS database
plus bonus: browsing data using QGIS.
What FAA Digital Obstacle File (DOF) is and how to model it using PostGIS database - refer to post
Now, it's time to load some data into our database using Python script.
First we need to populate tables such as ctry_state, hacc, lighting because primary keys of this tables are foreign keys in main table obstruction.
To insert data into hacc (horizontal accuracy) table execute following DML statement:
What FAA Digital Obstacle File (DOF) is and how to model it using PostGIS database - refer to post
Now, it's time to load some data into our database using Python script.
First we need to populate tables such as ctry_state, hacc, lighting because primary keys of this tables are foreign keys in main table obstruction.
To insert data into hacc (horizontal accuracy) table execute following DML statement:
INSERT INTO hacc VALUES ('1', 20, 'FEET'), ('2', 50, 'FEET'), ('3', 100, 'FEET'), ('4', 250, 'FEET'), ('5', 500, 'FEET'), ('6', 1000, 'FEET'), ('7', 0.5, 'NM'), ('8', 1, 'NM'), ('9', -1, 'UNKNOWN'), ('N', -1, 'NO DATA');
Sunday, 25 November 2018
aviation_gis_tools: bearings, magnetic variation
In this post we will discuss another indispensable 'item' when we deal with aviation content: bearings (true and magnetic) and magnetic variations.
Many times in aeronautical publications you will see:
Because bearing and magnetic variation are types of angles (as well as latitude and longitude) and might be given in various formats let's create basic class Angle.
Angle class will cover common tasks as validating input, range and so on.
Class definition will start with constructor:
Many times in aeronautical publications you will see:
- position of points are defined as magnetic bearing from specified point (e. g. aerodrome reference point), and magnetic variation for this point is known, we are interesting in geographic position of obstacle not magnetic
- boundary of airspace (a good example that comes to my mind are airspaces on minimum radar vectoring chart) are defined as arcs and 'strait' lines by points, which are defined by radials and distances against point with specified position and magnetic variation; by definition radial are expressed in magnetic bearing - and again we would like to know geographic position of vertices that create the shape of airspace not magnetic.
Because bearing and magnetic variation are types of angles (as well as latitude and longitude) and might be given in various formats let's create basic class Angle.
Angle class will cover common tasks as validating input, range and so on.
Class definition will start with constructor:
class Angle: def __init__(self, src_value): self.src_value = src_value self._is_valid = None self._dd_value = None self._err_msg = ''
Saturday, 24 November 2018
aviation_gis_tools: calculation on ellipsoid
The common issue in aviation is:
Some point of interest (e. g. location of fixes, obstacles, airspace boundary definition) are not given directly as pair of coordinates but their location is defined as combinations of distance (in various units), direction (true or magnetic) against specified point (waypoint, navigation aid, runway threshold) with defined latitude and longitude.
Some point of interest (e. g. location of fixes, obstacles, airspace boundary definition) are not given directly as pair of coordinates but their location is defined as combinations of distance (in various units), direction (true or magnetic) against specified point (waypoint, navigation aid, runway threshold) with defined latitude and longitude.
Friday, 23 November 2018
Coordinates (3): way of regular expressions (continued)
In second post related to coordinates only one format of DMS has been covered. As I pointed to cover more possible format we have to write more regular expression or write complex regular expression in that way that it will match all combination of coordinate format that we want.
In this post I am going to share how to convert coordinate in various format (DMSH, HDMS) with different separators (space, hyphen, no separator) and get format of coordinate.
Let's start with defining constants to describe various coordinate formats:
In this post I am going to share how to convert coordinate in various format (DMSH, HDMS) with different separators (space, hyphen, no separator) and get format of coordinate.
Let's start with defining constants to describe various coordinate formats:
# Hemisphere prefix degrees, minutes, seconds separated F_HDMS_SEP_HYPHEN = 'F_HDMS_SEP_HYPHEN' # hyphen separator F_HDMS_SEP_SPACE = 'F_HDMS_SEP_SPACE' # space separator F_HDMS_SEP_WORD = 'F_HDMS_SEP_WORD' # word DEG, MIN SEC separator F_HDMS_SEP_LETTER = 'F_HDMS_SEP_LETTER' # letter D, M, S separator # Hemisphere suffix degrees, minutes, seconds separated F_DMSH_SEP_HYPHEN = 'F_DMSH_SEP_HYPHEN' # hyphen separator F_DMSH_SEP_SPACE = 'F_DMSH_SEP_SPACE' # space separator F_DMSH_SEP_WORD = 'F_DMSH_SEP_WORD' # word DEG, MIN SEC separator F_DMSH_SEP_LETTER = 'F_DMSH_SEP_LETTER' # letter D, M, S separator # Degrees, minutes, seconds compacted F_HDMS_COMP = 'F_HDMS_COMP' # Hemisphere prefix DMS compacted F_DMSH_COMP = 'F_DMSH_COMP' # Hemisphere suffix DMS compacted
Thursday, 22 November 2018
Challenge: FAA Digital Obstacle File into CSV format
If we want to visualize or work DOF we need to import it into our GIS application. If we don't have a customized function that import DOF in dat format, probably the easiest way is to convert dat file into CSV file, simultaneously calculating coordinates in DD format.
First, let's define fields in our output CSV file:
Script will read line of input file, parse this line and assign values to appropriate fields of output csv file. So we need to open input file and 'open' output csv file:
First, let's define fields in our output CSV file:
cvs_field_names = ['oas_code', 'obs_number', 'verif_stat', 'country_id', 'state_id', 'city_name', 'lat_dms', 'lon_dms', 'obs_type', 'quantity', 'agl_height', 'ams_height', 'lighting', 'hor_acc', 'vert_acc', 'mar_indicator', 'faa_study_number', 'action', 'jdate', 'lat_dd', 'lon_dd']
Script will read line of input file, parse this line and assign values to appropriate fields of output csv file. So we need to open input file and 'open' output csv file:
with open(in_file, 'r') as dof_file: with open(output_file, 'w', newline='') as csv_file:
Wednesday, 21 November 2018
PostGIS database for storing FAA Digital Obstacle File
FAA - Federal Aviation Administration - United States authority to regulate civil aviation issues DOF (Digital Obstacle File) with obstacles of interest to aviation users in the United States, with limited coverage of selected region and countries.
To get more information about DOF and to download data visit:
FAA Digital Obstacle File web page
To understand format of data refer to:
DOF description
If you download a DOF.dat (main file with all records) you will see that file contains information about 450 000 obstacles. This might be pretty impressive number of records, which will be more efficient to use (select large amount of data) in database. Needless to say each obstacle has information about its location. Using of PostGIS - spatial extension for PostgreSQL will be a good choice to deal with this content.
To get more information about DOF and to download data visit:
FAA Digital Obstacle File web page
To understand format of data refer to:
DOF description
If you download a DOF.dat (main file with all records) you will see that file contains information about 450 000 obstacles. This might be pretty impressive number of records, which will be more efficient to use (select large amount of data) in database. Needless to say each obstacle has information about its location. Using of PostGIS - spatial extension for PostgreSQL will be a good choice to deal with this content.
Monday, 19 November 2018
Coordinates (2): way of regular expressions
In the second part I will show how to check if latitude or longitude is valid using regular expressions.
First, let's look at example of latitude and longitude in DMSH format, space delimited:
52 22 33.47N 015 42 33.44E
We can write is in general form as:
DD MM SS.ss H DDD MM SS.ss H
and the following must be true:
ddsddsdd.ddL dddsddsdd.ddL
where d is digit, s is space and L is hemisphere letter (N, S, E, W).
We will take into account that latitude can be without 'leading zeros' in our further deliberations:
1 1 1.44N instead of 01 01 01.44N
There are two options here:
1. To write quite complex regular expression that will take into account all combinations of deg, min, sec e. g.:
Regular expression to match coordinate in DMSH format, space separated looks like:
First, let's look at example of latitude and longitude in DMSH format, space delimited:
52 22 33.47N 015 42 33.44E
We can write is in general form as:
DD MM SS.ss H DDD MM SS.ss H
and the following must be true:
- DD is between <-90, 90> for latitude and <-180, 180> for longitude
- MM is between <0, 59>
- SS.ss is between equal or grater than 0 and less then 60
ddsddsdd.ddL dddsddsdd.ddL
where d is digit, s is space and L is hemisphere letter (N, S, E, W).
We will take into account that latitude can be without 'leading zeros' in our further deliberations:
1 1 1.44N instead of 01 01 01.44N
There are two options here:
1. To write quite complex regular expression that will take into account all combinations of deg, min, sec e. g.:
- for latitude: if deg is equal 90, min, sec must be equal 0 (90 05 05.55N is not valid latitude)
- for latitude: if deg is between <-90, 90> min might take integer values <0, 59>, sec integer values <0, 59> or float values <0, 60)
Regular expression to match coordinate in DMSH format, space separated looks like:
regex_dmsh = re.compile(r'''(?P<deg>^\d{1,3}) # Degrees (\s) (?P<min>\d{1,2}) # Minutes (\s) (?P<sec>\d{1,2}(\.\d+)?) # Seconds (?P<hem>[NSEW]$) ''', re.VERBOSE)
Thursday, 15 November 2018
Challenge: QGIS Plugin to create polygon from text
This is the first post from series Challenge - where you can find how to automate repetitive task to save time and money.
Let's assume that you have to create vector data based on textual description of polygons, e. g.:
It is not a big problem, when you have to enter into system 1, 2, 5 or even 10 such polygons that are have not too many vertices.
But what if you have many of them and deadline is coming?
We can write plugin for QGIS which will create polygons.
Let's assume that you have to create vector data based on textual description of polygons, e. g.:
585200N0312800E-584700N0312700E-583500N0311700E-583200N0312700E- 583200N0313300E-582900N0313800E-582800N0314400E- 582500N0314500E-585200N0312800E.
It is not a big problem, when you have to enter into system 1, 2, 5 or even 10 such polygons that are have not too many vertices.
But what if you have many of them and deadline is coming?
We can write plugin for QGIS which will create polygons.
Wednesday, 14 November 2018
Coordinates (1): variety of coordinate formats
A glance at variety of coordinate formats which you can find in aeronautical publications (AIP, NOTAMS, other documents) might give you a serious headache:
- Poland: 520932.8N 0205905.6E
- Senegal: 14DEG40'30''N 017DEG25'59''W
- India: 130000N 0781015E
- Australia: 12 25 24S 130 54 23E, S 18 16 31.28 E 143 35 19.30, S24 00.0 E152 12.5
- USA: 30 15 01.00N 088 04 45.00W, lat. 38°38'19"N., long. 104°52'02"W
- Pacific Organised Track System (PACOTS): 41N160E 44N170E
Tuesday, 13 November 2018
QGIS Plugin: DistanceUnitConverter
But, what if you are working on your task and you need to convert distance between two units without searching on the internet? Maybe plugin is a good answer.
Plugin that allows you to convert distance among various units: meters, kilometers, nautical miles, feet and statue miles.
Monday, 12 November 2018
aviation_gis_tools: dealing with distance
Let's start building aviation tools from something which is quite simple and very basic: dealing with distances.
There are many units of measure for distance that are used in aviation industry: meters, feet, nautical miles and statue miles. Definition of unit of measure that will be used in our tools:
There are many units of measure for distance that are used in aviation industry: meters, feet, nautical miles and statue miles. Definition of unit of measure that will be used in our tools:
UOM_M = 'M' # meters UOM_KM = 'KM' # kilometers UOM_NM = 'NM' # nautical miles UOM_FEET = 'FEET' # feet UOM_SM = 'SM' # statue miles
Sunday, 11 November 2018
aviation_gis_tools is upcoming! (and note about reinventing the wheel)
As I wrote in the introductory post, you can learn here how to make your work more efficient, comfortable and even enjoyable while dealing with aviation content. Needless to say, we need some tools to do such things. Luckily, there is a bunch of tools available on the market: plugins and extension for free, open source and proprietary GIS software. Furthermore, some of this applications share their API which allows us to extend their capability by adding specified, problem oriented and highly customized tools. Hence, we are able to build a new functionality using built-in, optimized functions, the same that we use while using user interface.
But, here I am going to write some tools from scratch…
So, you may ask: What is the purpose of creating and likely duplicating existing code?
But, here I am going to write some tools from scratch…
So, you may ask: What is the purpose of creating and likely duplicating existing code?
Thursday, 8 November 2018
Welcome!
Welcome to the Aviation GIS Applications blog. This is a blog about wide range of uses GIS, including a lot of Python scripting, to deal with aviation content, unsurprisingly in aviation industry.
But don’t worry – if you are not particularly interested in aviation and related issues but you are eager to learn, or just need to know how to:
But don’t worry – if you are not particularly interested in aviation and related issues but you are eager to learn, or just need to know how to:
Subscribe to:
Posts (Atom)