ASA_IM__BP version 0

ASA_IM__BP_v0

This definition is based on version 4/C of product specification PO-RS-MDA-GS-2009 Vol8

root type

binary record
idfield namedefinition
0mph
ascii record "MPH"size: 1247
1sph
ascii record "SPH_IM"size: 1059
2dsd
ascii array[dim_0]
dim_0: $num_dsd
ascii record "DSD"size: 280
3mds1_sq_ads
binary array[dim_0]
SQ ADSRs

dim_0: $num_dsr[0]
binary record "ADSR_IM_SQ"size: 170
4geolocation_grid_ads
binary array[dim_0]
Geolocation Grid ADSRs

dim_0: $num_dsr[1]
binary record "ADSR_IM_Geolocation_Grid"size: 521
5mds1
binary array[dim_0]
Measurement Data Set 1.

dim_0: $num_dsr[2]
binary record "MDSR_IM_BP"

detection rule

This product definition is applicable if a product matches the following rule:

bytes(/,0,8) == "PRODUCT=" and
bytes(/,9,10) == "ASA_IM__BP"

product variables

namesizeinitialisation
num_samples_per_line$num_samples_per_line = int(/sph/line_length)
num_dsd$num_dsd = int(/mph/num_dsd)
num_ds$num_ds = 3
ds_to_dsd_index[$num_ds]$ds_to_dsd_index[0] = index(/dsd, str(./ds_name) == "MDS1 SQ ADS                 ");
$ds_to_dsd_index[1] = index(/dsd, str(./ds_name) == "GEOLOCATION GRID ADS        ");
$ds_to_dsd_index[2] = index(/dsd, str(./ds_name) == "MDS1                        ")
ds_available[$num_ds]for i = 0 to $num_ds - 1 do
$ds_available[i] = if($ds_to_dsd_index[i] != -1 and !(bytes(/dsd[$ds_to_dsd_index[i]]/filename,8) == "NOT USED"), 1, 0)
ds_offset[$num_ds]for i = 0 to $num_ds - 1 do
$ds_offset[i] = if($ds_available[i] == 1, 8 * int(/dsd[$ds_to_dsd_index[i]]/ds_offset), 0)
num_dsr[$num_ds]for i = 0 to $num_ds - 1 do
$num_dsr[i] = if($ds_available[i] == 1, int(/dsd[$ds_to_dsd_index[i]]/num_dsr), 0)