基于Matlab科技论文绘图:gif

转载自github:https://github.com/JorgeGT/PlotRTL1090

PlotRTL1090

3D visualization of air traffic through RTL-SDR (dump1090) and MATLAB

Summary

PlotRTL1090 is a simple MATLAB routine to record and visualize air traffic. It makes use of the excellent dump1090, forked by MalcolmRobb from antirez which profits from the ability of a ~$6 USB DTV receptor (RTL-SDR) to relay raw radio data along a wide spectrum, including the 1090 MHz frequency in which aircraft broadcast ADS-B messages indicating their callsign, altitude, speed, position, etc.

The code is provided on a single file for convenience, but the actual use is divided in two phases. The first portion of the code contains a loop that polls a running dump1090 server (or forks!) to read the JSON transcript of decoded ADS-B messages and store them in a .mat file. You can resume this loop at any time to collect additional data (which will be timestamped for your convenience). When enough data is recorded, you can execute the second code cell to render the data into a 3D visualization (which will be also saved as a .gif and .mp4).

Requirements

  • A server running dump1090 to record ADS-B data. For those who don't have (yet!) an RTL-SDR dongle available, two sample datasets are provided to test the code. Those have been used to generate the renders shown on the following section.
  • MATLAB (tested on 2012b and 2014a)

Example results

The file coords contains a recording of air traffic around the Valencia area (LEVC) in Spain. The file coords_nl has been supplied by /u/theodric of /r/RTLSDR using this code near Amsterdam-Schiphol (EHAM) area in The Netherlands. Using these files some sample renderings are shown below.

  • Valencia Airport (LEVC): using the default options of the provided MATLAB script, the following render can be reproduced: Resultado

  • Amsterdam-Schiphol Airport (EHAM): in order to use the data from Schiphol, we must also modify the bullseye center and select which land contours to plot. In this case the most simple option is to select all countries (the render time will be increased):

  • load('coords_nl');
    centerLoc = [52.3147007,4.755935]; 
    countries = shaperead([SHPdir 'ne_10m_admin_0_countries.shp'],'UseGeoCoords', true);

    Resultado

    • Holding, approach and take off patterns (EHAM): just by filtering the plotted data by altitude, we can avoid the very crowded high altitude airways and focus on landing/take off operations. Operations from the small Den Helder airport can also be seen:
    filter = alt < 5000; % feet

    Resultado

    • Airlines: Ryanair (EHAM): the filter can contain more elaborate expressions! For instance, let's use a regular expression to select only flights operated by the blue-and-white irish low cost. As you can see in the following figure, the irish airline appears to avoid using the Schiphol airport, as only high altitude flighs can be seen:
    filter = cellfun(@(x) ~isempty(regexpi(x,'^RYR.*$')),flg);

    Resultado

    Tip: you can concatenate logical expressions in the filter! You could for example select only Ryanair flights operating under 5000 ft by making filter = cellfun(@(x) ~isempty(regexpi(x,'^RYR.*$')),flg) & alt < 6000;. Any combination of altitude, speed, position, callsign, etc. is available!

    Acknowledgements

    • Antirez and MalcolmRobb for dump1090.
    • Christianpanton for the included matlab-json function.
    • Natural Earth for releasing the included shapefiles as public domain.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值