From 2c3af01a74ddc51d0c14391b2530d79b7aed1297 Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Tue, 5 Nov 2024 18:53:22 -0800 Subject: [PATCH 01/15] getting there creating first draft of ground based TEC decoder not functional at this time --- src/gnssro/gnss_tec_ground_based.py | 444 ++++++++++++++++++++++++++++ 1 file changed, 444 insertions(+) create mode 100755 src/gnssro/gnss_tec_ground_based.py diff --git a/src/gnssro/gnss_tec_ground_based.py b/src/gnssro/gnss_tec_ground_based.py new file mode 100755 index 00000000..81a4978b --- /dev/null +++ b/src/gnssro/gnss_tec_ground_based.py @@ -0,0 +1,444 @@ +#!/usr/bin/env python3 + +# +# (C) Copyright 2019-2024 UCAR +# +# This software is licensed under the terms of the Apache Licence Version 2.0 +# which can be obtained at http://www.apache.org/licenses/LICENSE-2.0. +# + +# +# decode TENET formatted ground-based GNSS Total Electron Content (TEC) +# + +import sys +import os +import time +from datetime import datetime, timezone +import numpy as np +import logging + +# These modules need the path to lib-python modules +import pyiodaconv.ioda_conv_engines as iconv +from pyiodaconv.orddicts import DefaultOrderedDict +from pyiodaconv.def_jedi_utils import iso8601_string, epoch + +os.environ["TZ"] = "UTC" + +# these are the unique values in the raw input file +varDict = { 'vertical total electron content': ['verticalTEC', "float", 'fractional percent'], + 'slant total electron content': ['slantTEC', "float", "m"], +} + +# these are the MetaData common to each input +locationKeyList = [ + ('latitude', 'float', 'degrees_north'), + ('longitude', 'float', 'degrees_east'), + ('pseudoRandomNoiseCode', 'integer'), + ('elevationAngle', 'float', 'GNSS transmitter satellite elevation angle in degrees'), + ('azimuthAngle', 'float', 'aziumuth angle viewing GNSS transmitter in degrees west'), + ('height', 'float'), + ('xECEFPosition', 'float', 'receiving station Earth Centered Earth Fixed X-coordinate in meters'), + ('yECEFPosition', 'float', 'receiving station Earth Centered Earth Fixed Y-coordinate in meters'), + ('zECEFPosition', 'float', 'receiving station Earth Centered Earth Fixed Z-coordinate in meters'), + ('xECEFPositionGNSS', 'float', 'GNSS transmitting satellite Earth Centered Earth Fixed X-coordinate in meters'), + ('yECEFPositionGNSS', 'float', 'GNSS transmitting satellite Earth Centered Earth Fixed Y-coordinate in meters'), + ('zECEFPositionGNSS', 'float', 'GNSS transmitting satellite Earth Centered Earth Fixed Z-coordinate in meters'), + ('dateTime', 'long', 'seconds from epoch 01Jan1970') + ('WMOstationIdentifier', 'integer', 'WMO assigned number for the site'), + ('stationIdentifier', 'string', 'GNSS ground-based receiving station name'), +] + +meta_keys = [m_item[0] for m_item in locationKeyList] + +GlobalAttrs = { + 'converter': os.path.basename(__file__), + 'ioda_version': 3, + 'description': 'Ground-based Total Electron Content', + 'source': 'TENET Network', +} + +metaDataName = iconv.MetaDataName() +obsValName = iconv.OvalName() +obsErrName = iconv.OerrName() +qcName = iconv.OqcName() + +float_missing_value = iconv.get_default_fill_val(np.float32) +int_missing_value = iconv.get_default_fill_val(np.int32) +long_missing_value = iconv.get_default_fill_val(np.int64) +string_missing_value = '_' + +missing_vals = {'string': string_missing_value, + 'integer': int_missing_value, + 'long': long_missing_value, + 'float': float_missing_value} +dtypes = {'string': object, + 'integer': np.int32, + 'long': np.int64, + 'float': np.float32} + + +def main(args): + + file_names = args.input + output_file = args.output + + start_time = time.time() + + data = None + any_data = False + for fname in file_names: + logging.info(f"Reading file: {fname}") + file_data, any_data = read_file(fname, any_data, qc_strict=args.qc_strict) + # if there is data do something + if file_data: + # first successful read + if not data: + data = file_data + # subsequent successful read + else: + for key in set(varDict.keys()).union(meta_keys): + # data[key] = np.concatenate(data[key], file_data[key]) # why not and gotta be much better way + data[key] = np.append(data[key], file_data[key]) + + # if all files have no data + if not any_data: + logging.error("No data to write, stopping execution.") + sys.exit() + + dtg = datetime.fromtimestamp(data['dateTime'][0]) + datetimeRef = dtg.isoformat() + "Z" + + # prepare global attributes we want to output in the file, + # in addition to the ones already loaded in from the input file + GlobalAttrs = { + 'sourceFiles': ", ".join(file_names), + 'datetimeReference': datetimeRef + } + + nlocs = len(data['height']) + logging.info(f" found a total of {nlocs} observations") + DimDict = {'Location': nlocs} + + varDims = {} + for key in varDict.keys(): + variable = varDict[key][0] + varDims[variable] = ['Location'] + + varAttrs = DefaultOrderedDict(lambda: DefaultOrderedDict(dict)) + + # Set units of the MetaData variables and all _FillValues. + for key in meta_keys: + dtype = locationKeyList[meta_keys.index(key)][1] + if locationKeyList[meta_keys.index(key)][2]: + varAttrs[(key, metaDataName)]['units'] = locationKeyList[meta_keys.index(key)][2] + varAttrs[(key, metaDataName)]['_FillValue'] = missing_vals[dtype] + for key in varDict.keys(): + if 'electronDensity' in key: + continue + dtype = varDict[key][1] + units = varDict[key][2] + if units: + varAttrs[(key, metaDataName)]['units'] = units + varAttrs[(key, metaDataName)]['_FillValue'] = missing_vals[dtype] + + # Set units and FillValue attributes for groups associated with observed variable. + for key in ['electronDensity', 'criticalFrequency']: + variable = varDict[key][0] + dtype = varDict[key][1] + units = varDict[key][2] + unitsErr = varDict[key+'Confidence'][2] + varAttrs[(variable, obsValName)]['units'] = units + varAttrs[(variable, obsErrName)]['units'] = unitsErr + varAttrs[(variable, obsValName)]['coordinates'] = 'longitude latitude' + varAttrs[(variable, obsErrName)]['coordinates'] = 'longitude latitude' + varAttrs[(variable, qcName)]['coordinates'] = 'longitude latitude' + varAttrs[(variable, obsValName)]['_FillValue'] = missing_vals[dtype] + varAttrs[(variable, obsErrName)]['_FillValue'] = missing_vals[dtype] + varAttrs[(variable, qcName)]['_FillValue'] = int_missing_value + + # Fill the final IODA data: MetaData then ObsValues, ObsErrors, and QC + ioda_data = {} + +# should populate ioda_data directly rather than creating another copy + for key in meta_keys: + dtype = locationKeyList[meta_keys.index(key)][1] + ioda_data[(key, metaDataName)] = np.array(data[key], dtype=dtypes[dtype]) + for key in varDict.keys(): + variable = varDict[key][0] + dtype = varDict[key][1] + if 'electronDensity' not in key and 'criticalFrequency' not in key: + logging.info(f" the variable: {variable} will be placed into MetaData of ioda_data") + # these MetaData are arrays nlocs long already + ioda_data[(key, metaDataName)] = np.array(data[variable], dtype=dtypes[dtype]) + elif 'Confidence' not in key: + # (electronDensityConfidence) is used as the ObsError + variable = varDict[key][0] + logging.info(f" the variable: {variable} will be placed into ObsValue of ioda_data") + ioda_data[(variable, obsValName)] = np.array(data[variable], dtype=np.float32) + ioda_data[(variable, obsErrName)] = np.array(data[variable+'Confidence'], dtype=np.float32) + qc_array_hack = apply_gross_quality_control(data, qc_strict=args.qc_strict) + ioda_data[(variable, qcName)] = np.array(qc_array_hack, dtype=np.int32) # how to interpret AQI ? + + logging.debug("Writing file: " + output_file) + + # setup the IODA writer and write everything out. + writer = iconv.IodaWriter(output_file, locationKeyList, DimDict) + writer.BuildIoda(ioda_data, varDims, varAttrs, GlobalAttrs) + + logging.info("--- {:9.4g} total seconds ---".format(time.time() - start_time)) + + +def read_file(file_name, any_data, qc_strict=True): + + local_data = init_data_dict() + + # Open the file + with open(file_name, 'r') as file: + # Create an iterator from the file object + file_iterator = iter(file) + + local_data, header_read = get_header(file_iterator, local_data) + logging.debug(f'header was read w/o error: {header_read}') + + while header_read and True: + try: + # Get the next line from the iterator + line = next(file_iterator) + local_data = populate_obsValue(line, local_data) + except StopIteration: + # If StopIteration is raised, break from the loop + break + + # has any data been read at any point + any_data = any_data or header_read + + # repeat all the metaData values + if header_read: + nlocs = len(local_data['height']) + for key in meta_keys: + dtype = locationKeyList[meta_keys.index(key)][1] + local_data[key] = np.full(nlocs, local_data[key], dtype=dtypes[dtype]) + + # if the header was not sucessfully read return nothing + if not header_read: + local_data = None + + return local_data, any_data + + +def get_header(file_iterator, local_data): + ##################################################### + # get header (3 lines) + ##################################################### + + # Line #1: HIUS1 KJPL 080213 + # This line is standard in all TENET files the only thing that changes is the numeric value 080213 + # This value indicates the Coordinated Universal Time (UTC) JPL produces the TENET file + # The format is: DDHHMM (where DD = day, HH = UTC hour, and MM = minutes) + + # Line #2: TENET + # This line is standard in all TENET files and never changes. It indicates the nature of the file – TENET + + # Line #3: 23074 0694/ 271608 NRIL 000064539804 002253881156 005946178085 + # WMO number, latitude (N), longitude (W), station name, ECEF station coordinates + + # for all ECEF coordinates 0 in front indicates positive, and 1 indicates negative. + + header_read = False + while True: + # read first line + try: + _, _, report_time = line.split() + except ValueError: + break + + # read second line + line = next(file_iterator) + if 'TENET' not in line: + break # not necessarily needed + + # read third line + line = next(file_iterator) + try: + WMOid, latitude, longitude, stationName, xECEFPosition, yECEFPosition, zECEFPosition = line.split() + except ValueError: + break + + xECEFPosition = convert_ECEF_string(xECEFPosition) + yECEFPosition = convert_ECEF_string(yECEFPosition) + zECEFPosition = convert_ECEF_string(zECEFPosition) + + except ValueError: + break + + local_data['latitude'] = np.append(local_data['latitude'], lat) + local_data['longitude'] = np.append(local_data['longitude'], lon) + local_data['stationIdentifier'] = np.append(local_data['stationIdentifier'], stationID) + local_data['hmF2'] = np.append(local_data['hmF2'], hmf2) + local_data['foF2'] = np.append(local_data['foF2'], fof2) + local_data['nmF2'] = np.append(local_data['nmF2'], nmf2) + local_data['foF2Uncertainty'] = np.append(local_data['foF2Uncertainty'], conf_fof2) + local_data['nmF2Uncertainty'] = np.append(local_data['nmF2Uncertainty'], conf_nmf2) + local_data['sequenceNumber'] = np.append(local_data['sequenceNumber'], recordNumber) + # populate the first row of ObsValues + local_data = populate_obsValue(line, local_data) + + header_read = True + except StopIteration: + # If StopIteration is raised, break from the loop + break + + return local_data, header_read + + +def populate_obsValue(line, local_data): + + # get the electron density retrieved from GNSS transmitter + # if can correctly parse all fields populate local_data otherwise do nothing + + # ObsValue data row (example) + # Line #4: 11111 180208 021000 280771 26911 2165166150 4210322950 0233/ 3558/ 102029725204 114864753823 022550194624 + # unknown, YYMMDD, HHMMSS, PRN/Latitude, Longitude, VOBS, SOBS, satelite elevation angle, azimuth angle, GNSS ECEF coordinates + + # for all ECEF coordinates 0 in front indicates positive, and 1 indicates negative. + + + # read data lines beginning at fourth line + try: + _, yymmdd, hhmmss, PRNlatitude, longitude, vobs, sobs, elevationAngle, azimuthAngle, \ + xECEFPositionGNSS, yECEFPositionGNSS, zECEFPositionGNSS = line.split() + except ValueError: + break + + dateTime = convert_string_to_dateTime(yymmdd, hhmmss) + PRN, latitude = parse_station_and_latitude(PRNlatitude) + + xECEFPositionGNSS = convert_ECEF_string(xECEFPositionGNSS) + yECEFPositionGNSS = convert_ECEF_string(yECEFPositionGNSS) + zECEFPositionGNSS = convert_ECEF_string(zECEFPositionGNSS) + + local_data['dateTime'] = np.append(local_data['dateTime'], dateTime) + local_data['pseudoRandomNoiseCode'] = np.append(local_data['longitude'], PRN) + local_data['latitude'] = np.append(local_data['latitude'], latitude) + local_data['longitude'] = np.append(local_data['longitude'], longitude) + local_data['elevationAngle'] = np.append(local_data['elevationAngle'], elevationAngle) + local_data['azimuthAngle'] = np.append(local_data['azimuthAngle'], azimuthAngle) + local_data['verticalElectronDensity'] = np.append(local_data['verticalElectronDensity'], vobs) + local_data['slantElectronDensity'] = np.append(local_data['slantElectronDensity'], sobs) + + return local_data + + +def convert_ECEF_string(c): + # for all ECEF coordinates 0 in front indicates positive, and 1 indicates negative. + try: + # Attempt the conversion logic + result = -int(c[1:]) if c[0] == '1' else int(c[1:]) if c[0] == '0' else int(c) + return result + except (IndexError, ValueError) as e: + # Raise an exception with a descriptive message + raise ValueError(f"Invalid input string '{c}': {e}") + + +def convert_string_to_dateTime(yymmdd, hhmmss): + + # convert strings of time into python dateTime object + try: + # Combine and parse the string as a datetime object + dtg = datetime.strptime(f"{yymmdd}{hhmmss}", '%y%m%d%H%M%S') + # Set timezone to UTC + dtg = dtg.replace(tzinfo=timezone.utc) + # Convert to Unix time in seconds since epoch + dateTime = np.int64(round((dtg - epoch).total_seconds())) + + return dateTime + + except ValueError as e: + # Raise an informative error if parsing fails + raise ValueError(f"Invalid date or time format in inputs '{yymmdd}' and '{hhmmss}': {e}") + + +def parse_station_and_latitude(code): + try: + # Extract the station code (first two digits) + station_code = int(code[:2]) + + # Determine latitude sign based on the third digit + latitude_sign = 1 if code[2] == '0' else -1 if code[2] == '1' else None + if latitude_sign is None: + raise ValueError(f"Invalid latitude sign indicator '{code[2]}'; expected '0' for positive or '1' for negative.") + + # Extract the latitude (remaining digits) and apply sign and scale + latitude = latitude_sign * int(code[3:]) / 10.0 + + return station_code, latitude + + except ValueError as e: + raise ValueError(f"Invalid input '{code}': {e}") + + +def apply_gross_quality_control(data, qc_strict=False): + # if strict quality-control is requested + # apply using simple physical reality check on variables + + # initialize returned variable + qc_array_hack = np.zeros_like(data['electronDensity'], dtype=np.int32) + # is requested apply check + if qc_strict: + qc_array_hack = np.where( + (data['electronDensity'].astype(float) < 0) + | (data['height'].astype(float) < 0) + | (data['criticalFrequency'].astype(float) < 0), + 1, + 0) + return qc_array_hack + + +def init_data_dict(): + local_data = {} # Before assigning the output types into the above. + for key in set(varDict.keys()).union(meta_keys): + local_data[key] = [] + return local_data + + +if __name__ == "__main__": + + from argparse import ArgumentParser + + parser = ArgumentParser( + description=('Read a satwind AMV ascii/csv file from SSEC' + ' and convert into IODA output file') + ) + + required = parser.add_argument_group(title='required arguments') + required.add_argument('-i', '--input', nargs='+', + action='store', default=None, required=True, + help='input files') + required.add_argument('-o', '--output', + action='store', default=None, required=True, + help='output file') + + optional = parser.add_argument_group(title='optional arguments') + optional.add_argument('--debug', action='store_true', default=False, + help='enable debug messages') + optional.add_argument('--quality-control', action='store_true', + default=False, dest='qc_strict', + help='add PreQC values') + optional.add_argument('--verbose', action='store_true', default=False, + help='enable verbose debug messages') + + args = parser.parse_args() + + if args.debug: + logging.basicConfig(level=logging.INFO) + elif args.verbose: + logging.basicConfig(level=logging.DEBUG) + else: + logging.basicConfig(level=logging.ERROR) + + for file_name in args.input: + if not os.path.isfile(file_name): + parser.error('Input (-i option) file: ', file_name, ' does not exist') + + main(args) From 2bef6b7a8053bfa662e1d13a80d36729ed051a2f Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Tue, 5 Nov 2024 19:41:41 -0800 Subject: [PATCH 02/15] add most of the data extraction now need to loop over records in file --- src/gnssro/gnss_tec_ground_based.py | 150 ++++++++++++++++------------ 1 file changed, 88 insertions(+), 62 deletions(-) diff --git a/src/gnssro/gnss_tec_ground_based.py b/src/gnssro/gnss_tec_ground_based.py index 81a4978b..0def8350 100755 --- a/src/gnssro/gnss_tec_ground_based.py +++ b/src/gnssro/gnss_tec_ground_based.py @@ -26,8 +26,8 @@ os.environ["TZ"] = "UTC" # these are the unique values in the raw input file -varDict = { 'vertical total electron content': ['verticalTEC', "float", 'fractional percent'], - 'slant total electron content': ['slantTEC', "float", "m"], +varDict = { 'total electron content vertical': ['totalElectronContentVertical', "integer", 'TECU'], + 'total electron content slant': ['totalElectronContentSlant', "integer", "TECU"], } # these are the MetaData common to each input @@ -35,7 +35,7 @@ ('latitude', 'float', 'degrees_north'), ('longitude', 'float', 'degrees_east'), ('pseudoRandomNoiseCode', 'integer'), - ('elevationAngle', 'float', 'GNSS transmitter satellite elevation angle in degrees'), + ('elevationAngleGNSS', 'float', 'GNSS transmitter satellite elevation angle in degrees'), ('azimuthAngle', 'float', 'aziumuth angle viewing GNSS transmitter in degrees west'), ('height', 'float'), ('xECEFPosition', 'float', 'receiving station Earth Centered Earth Fixed X-coordinate in meters'), @@ -44,6 +44,8 @@ ('xECEFPositionGNSS', 'float', 'GNSS transmitting satellite Earth Centered Earth Fixed X-coordinate in meters'), ('yECEFPositionGNSS', 'float', 'GNSS transmitting satellite Earth Centered Earth Fixed Y-coordinate in meters'), ('zECEFPositionGNSS', 'float', 'GNSS transmitting satellite Earth Centered Earth Fixed Z-coordinate in meters'), + ('latitudeIPP', 'float', 'latitude of Ionospheric Pierce Point in degrees_north'), + ('longitudeIPP', 'float', 'longitude of Ionospheric Pierce Point in degrees_east'), ('dateTime', 'long', 'seconds from epoch 01Jan1970') ('WMOstationIdentifier', 'integer', 'WMO assigned number for the site'), ('stationIdentifier', 'string', 'GNSS ground-based receiving station name'), @@ -205,11 +207,16 @@ def read_file(file_name, any_data, qc_strict=True): try: # Get the next line from the iterator line = next(file_iterator) - local_data = populate_obsValue(line, local_data) + local_data, endReport = populate_obsValue(line, local_data) + if endReport: + break + except StopIteration: # If StopIteration is raised, break from the loop break + # header read for first record now reset and read another header + # has any data been read at any point any_data = any_data or header_read @@ -243,91 +250,94 @@ def get_header(file_iterator, local_data): # Line #3: 23074 0694/ 271608 NRIL 000064539804 002253881156 005946178085 # WMO number, latitude (N), longitude (W), station name, ECEF station coordinates - # for all ECEF coordinates 0 in front indicates positive, and 1 indicates negative. - header_read = False - while True: - # read first line - try: - _, _, report_time = line.split() - except ValueError: - break - - # read second line - line = next(file_iterator) - if 'TENET' not in line: - break # not necessarily needed - - # read third line - line = next(file_iterator) - try: - WMOid, latitude, longitude, stationName, xECEFPosition, yECEFPosition, zECEFPosition = line.split() - except ValueError: - break - - xECEFPosition = convert_ECEF_string(xECEFPosition) - yECEFPosition = convert_ECEF_string(yECEFPosition) - zECEFPosition = convert_ECEF_string(zECEFPosition) - - except ValueError: - break - - local_data['latitude'] = np.append(local_data['latitude'], lat) - local_data['longitude'] = np.append(local_data['longitude'], lon) - local_data['stationIdentifier'] = np.append(local_data['stationIdentifier'], stationID) - local_data['hmF2'] = np.append(local_data['hmF2'], hmf2) - local_data['foF2'] = np.append(local_data['foF2'], fof2) - local_data['nmF2'] = np.append(local_data['nmF2'], nmf2) - local_data['foF2Uncertainty'] = np.append(local_data['foF2Uncertainty'], conf_fof2) - local_data['nmF2Uncertainty'] = np.append(local_data['nmF2Uncertainty'], conf_nmf2) - local_data['sequenceNumber'] = np.append(local_data['sequenceNumber'], recordNumber) - # populate the first row of ObsValues - local_data = populate_obsValue(line, local_data) - - header_read = True - except StopIteration: - # If StopIteration is raised, break from the loop - break + # read first line + try: + _, _, report_time = line.split() + except ValueError: + return local_data, header_read + + # read second line + line = next(file_iterator) + if 'TENET' not in line: + return local_data, header_read # not necessarily needed could try to continue + + # read third line + line = next(file_iterator) + try: + WMOid, lat, lon, stationName, xECEFPosition, yECEFPosition, zECEFPosition = line.split() + except ValueError: + return local_data, header_read + + xECEFPosition = convert_ECEF_string(xECEFPosition) + yECEFPosition = convert_ECEF_string(yECEFPosition) + zECEFPosition = convert_ECEF_string(zECEFPosition) + + lat = parse_latitude(lat) + + try: + local_data['latitude'] = np.append(local_data['latitude'], float(lat)) + local_data['longitude'] = np.append(local_data['longitude'], float(lon)) + local_data['stationIdentifier'] = np.append(local_data['stationIdentifier'], stationName) + local_data['xECEFPosition'] = np.append(local_data['xECEFPosition'], xECEFPosition) + local_data['yECEFPosition'] = np.append(local_data['yECEFPosition'], yECEFPosition) + local_data['zECEFPosition'] = np.append(local_data['zECEFPosition'], zECEFPosition) + except ValueError: + return local_data, header_read + + header_read = True return local_data, header_read def populate_obsValue(line, local_data): - # get the electron density retrieved from GNSS transmitter + # get the electron content retrieved from GNSS transmitter # if can correctly parse all fields populate local_data otherwise do nothing # ObsValue data row (example) # Line #4: 11111 180208 021000 280771 26911 2165166150 4210322950 0233/ 3558/ 102029725204 114864753823 022550194624 - # unknown, YYMMDD, HHMMSS, PRN/Latitude, Longitude, VOBS, SOBS, satelite elevation angle, azimuth angle, GNSS ECEF coordinates + # unknown, YYMMDD, HHMMSS, PRN/LatitudeIPP, LongitudeIPP, VOBS, SOBS, satelite elevation angle, azimuth angle, GNSS ECEF coordinates # for all ECEF coordinates 0 in front indicates positive, and 1 indicates negative. + # IPP = Ionospheric Pierce Point + endReport = False + if '99999' in line[0:5]: + # reset for next record + endReport = True + return local_data, endReport # read data lines beginning at fourth line try: - _, yymmdd, hhmmss, PRNlatitude, longitude, vobs, sobs, elevationAngle, azimuthAngle, \ + _, yymmdd, hhmmss, PRNlatitudeIPP, longitudeIPP, vobs, sobs, elevationAngle, azimuthAngle, \ xECEFPositionGNSS, yECEFPositionGNSS, zECEFPositionGNSS = line.split() except ValueError: - break + return local_data, endReport dateTime = convert_string_to_dateTime(yymmdd, hhmmss) - PRN, latitude = parse_station_and_latitude(PRNlatitude) + PRN, IPPlatitude = parse_station_and_latitude(PRNlatitude) xECEFPositionGNSS = convert_ECEF_string(xECEFPositionGNSS) yECEFPositionGNSS = convert_ECEF_string(yECEFPositionGNSS) zECEFPositionGNSS = convert_ECEF_string(zECEFPositionGNSS) - local_data['dateTime'] = np.append(local_data['dateTime'], dateTime) - local_data['pseudoRandomNoiseCode'] = np.append(local_data['longitude'], PRN) - local_data['latitude'] = np.append(local_data['latitude'], latitude) - local_data['longitude'] = np.append(local_data['longitude'], longitude) - local_data['elevationAngle'] = np.append(local_data['elevationAngle'], elevationAngle) - local_data['azimuthAngle'] = np.append(local_data['azimuthAngle'], azimuthAngle) - local_data['verticalElectronDensity'] = np.append(local_data['verticalElectronDensity'], vobs) - local_data['slantElectronDensity'] = np.append(local_data['slantElectronDensity'], sobs) + try: + local_data['dateTime'] = np.append(local_data['dateTime'], dateTime) + local_data['pseudoRandomNoiseCode'] = np.append(local_data['pseudoRandomNoiseCode'], PRN) + local_data['latitudeIPP'] = np.append(local_data['latitudeIPP'], latitudeIPP) + local_data['longitudeIPP'] = np.append(local_data['longitudeIPP'], float(longitudeIPP)/100.) + local_data['elevationAngleGNSS'] = np.append(local_data['elevationAngleGNSS'], float(elevationAngle.rstrip('/'))/10.) + local_data['azimuthAngle'] = np.append(local_data['azimuthAngle'], float(azimuthAngle.rstrip('/'))/10.) + local_data['totalElectronContentVertical'] = np.append(local_data['totalElectronContentVertical'], int(vobs.lstrip('/'))) + local_data['totalElectronContentSlant'] = np.append(local_data['totalElectronContentSlant'], int(sobs.lstrip('/'))) + local_data['xECEFPositionGNSS'] = np.append(local_data['xECEFPositionGNSS'], xECEFPositionGNSS) + local_data['xECEFPositionGNSS'] = np.append(local_data['xECEFPositionGNSS'], xECEFPositionGNSS) + local_data['xECEFPositionGNSS'] = np.append(local_data['xECEFPositionGNSS'], xECEFPositionGNSS) + except ValueError: + return local_data, endReport - return local_data + return local_data, endReport def convert_ECEF_string(c): @@ -378,6 +388,22 @@ def parse_station_and_latitude(code): raise ValueError(f"Invalid input '{code}': {e}") +def parse_latitude(lat_str): + try: + # Determine the latitude sign based on the first digit + latitude_sign = 1 if lat_str[0] == '0' else -1 if lat_str[0] == '1' else None + if latitude_sign is None: + raise ValueError(f"Invalid latitude sign indicator '{lat_str[0]}'; expected '0' for positive or '1' for negative.") + + # Convert the remaining digits to latitude, apply the sign, and divide by 10 + latitude = latitude_sign * int(lat_str[1:]) / 10.0 + + return latitude + + except ValueError as e: + raise ValueError(f"Invalid latitude input '{lat_str}': {e}") + + def apply_gross_quality_control(data, qc_strict=False): # if strict quality-control is requested # apply using simple physical reality check on variables From 806cfbdd50d778f76cd0f77838ffdcee061b6bce Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Wed, 6 Nov 2024 18:43:56 -0800 Subject: [PATCH 03/15] first working version for single record fix PEP8 almost --- src/gnssro/gnss_tec_ground_based.py | 63 +++++++++++++++-------------- 1 file changed, 32 insertions(+), 31 deletions(-) diff --git a/src/gnssro/gnss_tec_ground_based.py b/src/gnssro/gnss_tec_ground_based.py index 0def8350..75204630 100755 --- a/src/gnssro/gnss_tec_ground_based.py +++ b/src/gnssro/gnss_tec_ground_based.py @@ -26,18 +26,17 @@ os.environ["TZ"] = "UTC" # these are the unique values in the raw input file -varDict = { 'total electron content vertical': ['totalElectronContentVertical', "integer", 'TECU'], - 'total electron content slant': ['totalElectronContentSlant', "integer", "TECU"], +varDict = {'totalElectronContentVertical': ['totalElectronContentVertical', "integer", 'TECU'], + 'totalElectronContentSlant': ['totalElectronContentSlant', "integer", "TECU"], } # these are the MetaData common to each input locationKeyList = [ ('latitude', 'float', 'degrees_north'), ('longitude', 'float', 'degrees_east'), - ('pseudoRandomNoiseCode', 'integer'), + ('pseudoRandomNoiseCode', 'integer', 'GNSS transmitter pseudoRandomNoise PRN code'), ('elevationAngleGNSS', 'float', 'GNSS transmitter satellite elevation angle in degrees'), ('azimuthAngle', 'float', 'aziumuth angle viewing GNSS transmitter in degrees west'), - ('height', 'float'), ('xECEFPosition', 'float', 'receiving station Earth Centered Earth Fixed X-coordinate in meters'), ('yECEFPosition', 'float', 'receiving station Earth Centered Earth Fixed Y-coordinate in meters'), ('zECEFPosition', 'float', 'receiving station Earth Centered Earth Fixed Z-coordinate in meters'), @@ -46,8 +45,8 @@ ('zECEFPositionGNSS', 'float', 'GNSS transmitting satellite Earth Centered Earth Fixed Z-coordinate in meters'), ('latitudeIPP', 'float', 'latitude of Ionospheric Pierce Point in degrees_north'), ('longitudeIPP', 'float', 'longitude of Ionospheric Pierce Point in degrees_east'), - ('dateTime', 'long', 'seconds from epoch 01Jan1970') - ('WMOstationIdentifier', 'integer', 'WMO assigned number for the site'), + ('dateTime', 'long', 'seconds from epoch 01Jan1970'), + ('stationIdentifierWMO', 'integer', 'WMO assigned number for the site'), ('stationIdentifier', 'string', 'GNSS ground-based receiving station name'), ] @@ -118,7 +117,7 @@ def main(args): 'datetimeReference': datetimeRef } - nlocs = len(data['height']) + nlocs = len(data['dateTime']) logging.info(f" found a total of {nlocs} observations") DimDict = {'Location': nlocs} @@ -145,13 +144,12 @@ def main(args): varAttrs[(key, metaDataName)]['_FillValue'] = missing_vals[dtype] # Set units and FillValue attributes for groups associated with observed variable. - for key in ['electronDensity', 'criticalFrequency']: + for key in ['totalElectronContentSlant', 'totalElectronContentVertical']: variable = varDict[key][0] dtype = varDict[key][1] units = varDict[key][2] - unitsErr = varDict[key+'Confidence'][2] varAttrs[(variable, obsValName)]['units'] = units - varAttrs[(variable, obsErrName)]['units'] = unitsErr + varAttrs[(variable, obsErrName)]['units'] = units varAttrs[(variable, obsValName)]['coordinates'] = 'longitude latitude' varAttrs[(variable, obsErrName)]['coordinates'] = 'longitude latitude' varAttrs[(variable, qcName)]['coordinates'] = 'longitude latitude' @@ -210,7 +208,7 @@ def read_file(file_name, any_data, qc_strict=True): local_data, endReport = populate_obsValue(line, local_data) if endReport: break - + except StopIteration: # If StopIteration is raised, break from the loop break @@ -222,7 +220,7 @@ def read_file(file_name, any_data, qc_strict=True): # repeat all the metaData values if header_read: - nlocs = len(local_data['height']) + nlocs = len(local_data['dateTime']) for key in meta_keys: dtype = locationKeyList[meta_keys.index(key)][1] local_data[key] = np.full(nlocs, local_data[key], dtype=dtypes[dtype]) @@ -252,6 +250,7 @@ def get_header(file_iterator, local_data): header_read = False # read first line + line = next(file_iterator) try: _, _, report_time = line.split() except ValueError: @@ -260,7 +259,7 @@ def get_header(file_iterator, local_data): # read second line line = next(file_iterator) if 'TENET' not in line: - return local_data, header_read # not necessarily needed could try to continue + return local_data, header_read # not necessarily needed could try to continue # read third line line = next(file_iterator) @@ -277,8 +276,9 @@ def get_header(file_iterator, local_data): try: local_data['latitude'] = np.append(local_data['latitude'], float(lat)) - local_data['longitude'] = np.append(local_data['longitude'], float(lon)) + local_data['longitude'] = np.append(local_data['longitude'], float(lon)/1000.) local_data['stationIdentifier'] = np.append(local_data['stationIdentifier'], stationName) + local_data['stationIdentifierWMO'] = np.append(local_data['stationIdentifierWMO'], int(WMOid)) local_data['xECEFPosition'] = np.append(local_data['xECEFPosition'], xECEFPosition) local_data['yECEFPosition'] = np.append(local_data['yECEFPosition'], yECEFPosition) local_data['zECEFPosition'] = np.append(local_data['zECEFPosition'], zECEFPosition) @@ -311,12 +311,12 @@ def populate_obsValue(line, local_data): # read data lines beginning at fourth line try: _, yymmdd, hhmmss, PRNlatitudeIPP, longitudeIPP, vobs, sobs, elevationAngle, azimuthAngle, \ - xECEFPositionGNSS, yECEFPositionGNSS, zECEFPositionGNSS = line.split() + xECEFPositionGNSS, yECEFPositionGNSS, zECEFPositionGNSS = line.split() except ValueError: return local_data, endReport dateTime = convert_string_to_dateTime(yymmdd, hhmmss) - PRN, IPPlatitude = parse_station_and_latitude(PRNlatitude) + PRN, latitudeIPP = parse_station_and_latitude(PRNlatitudeIPP) xECEFPositionGNSS = convert_ECEF_string(xECEFPositionGNSS) yECEFPositionGNSS = convert_ECEF_string(yECEFPositionGNSS) @@ -332,8 +332,8 @@ def populate_obsValue(line, local_data): local_data['totalElectronContentVertical'] = np.append(local_data['totalElectronContentVertical'], int(vobs.lstrip('/'))) local_data['totalElectronContentSlant'] = np.append(local_data['totalElectronContentSlant'], int(sobs.lstrip('/'))) local_data['xECEFPositionGNSS'] = np.append(local_data['xECEFPositionGNSS'], xECEFPositionGNSS) - local_data['xECEFPositionGNSS'] = np.append(local_data['xECEFPositionGNSS'], xECEFPositionGNSS) - local_data['xECEFPositionGNSS'] = np.append(local_data['xECEFPositionGNSS'], xECEFPositionGNSS) + local_data['yECEFPositionGNSS'] = np.append(local_data['yECEFPositionGNSS'], yECEFPositionGNSS) + local_data['zECEFPositionGNSS'] = np.append(local_data['zECEFPositionGNSS'], zECEFPositionGNSS) except ValueError: return local_data, endReport @@ -361,9 +361,9 @@ def convert_string_to_dateTime(yymmdd, hhmmss): dtg = dtg.replace(tzinfo=timezone.utc) # Convert to Unix time in seconds since epoch dateTime = np.int64(round((dtg - epoch).total_seconds())) - + return dateTime - + except ValueError as e: # Raise an informative error if parsing fails raise ValueError(f"Invalid date or time format in inputs '{yymmdd}' and '{hhmmss}': {e}") @@ -373,17 +373,17 @@ def parse_station_and_latitude(code): try: # Extract the station code (first two digits) station_code = int(code[:2]) - + # Determine latitude sign based on the third digit latitude_sign = 1 if code[2] == '0' else -1 if code[2] == '1' else None if latitude_sign is None: raise ValueError(f"Invalid latitude sign indicator '{code[2]}'; expected '0' for positive or '1' for negative.") - + # Extract the latitude (remaining digits) and apply sign and scale latitude = latitude_sign * int(code[3:]) / 10.0 - + return station_code, latitude - + except ValueError as e: raise ValueError(f"Invalid input '{code}': {e}") @@ -394,12 +394,12 @@ def parse_latitude(lat_str): latitude_sign = 1 if lat_str[0] == '0' else -1 if lat_str[0] == '1' else None if latitude_sign is None: raise ValueError(f"Invalid latitude sign indicator '{lat_str[0]}'; expected '0' for positive or '1' for negative.") - + # Convert the remaining digits to latitude, apply the sign, and divide by 10 - latitude = latitude_sign * int(lat_str[1:]) / 10.0 - + latitude = latitude_sign * float(lat_str[1:-1]) / 10.0 + return latitude - + except ValueError as e: raise ValueError(f"Invalid latitude input '{lat_str}': {e}") @@ -413,9 +413,10 @@ def apply_gross_quality_control(data, qc_strict=False): # is requested apply check if qc_strict: qc_array_hack = np.where( - (data['electronDensity'].astype(float) < 0) - | (data['height'].astype(float) < 0) - | (data['criticalFrequency'].astype(float) < 0), + (data['totalElectronContentSlant'].astype(float) < 0) + | (data['latitude'].astype(float) > 90) + | (data['longitude'].astype(float) > 360) + | (data['elevationAngleGNSS'].astype(float) < 0), 1, 0) return qc_array_hack From 7ebb16c0599f95723d3b903cb67d24413ce1a8e7 Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Fri, 8 Nov 2024 13:07:17 -0800 Subject: [PATCH 04/15] fix the looping over the multiple station reports --- src/gnssro/gnss_tec_ground_based.py | 34 +++++++++++++++-------------- 1 file changed, 18 insertions(+), 16 deletions(-) diff --git a/src/gnssro/gnss_tec_ground_based.py b/src/gnssro/gnss_tec_ground_based.py index 75204630..fd075eac 100755 --- a/src/gnssro/gnss_tec_ground_based.py +++ b/src/gnssro/gnss_tec_ground_based.py @@ -198,35 +198,37 @@ def read_file(file_name, any_data, qc_strict=True): # Create an iterator from the file object file_iterator = iter(file) - local_data, header_read = get_header(file_iterator, local_data) - logging.debug(f'header was read w/o error: {header_read}') - - while header_read and True: + while True: try: - # Get the next line from the iterator - line = next(file_iterator) - local_data, endReport = populate_obsValue(line, local_data) - if endReport: - break + + local_data, header_read = get_header(file_iterator, local_data) + logging.debug(f'header was read w/o error: {header_read}') + + while header_read: + # Get the next line from the iterator + line = next(file_iterator) + local_data, endReport = populate_obsValue(line, local_data) + if endReport: + header_read = False + break except StopIteration: # If StopIteration is raised, break from the loop break - # header read for first record now reset and read another header - + import pdb + pdb.set_trace() # has any data been read at any point any_data = any_data or header_read # repeat all the metaData values - if header_read: - nlocs = len(local_data['dateTime']) + nlocs = len(local_data['dateTime']) + if nlocs > 0: for key in meta_keys: dtype = locationKeyList[meta_keys.index(key)][1] local_data[key] = np.full(nlocs, local_data[key], dtype=dtypes[dtype]) - - # if the header was not sucessfully read return nothing - if not header_read: + else: + # if the header was not sucessfully read return nothing local_data = None return local_data, any_data From 692cda04360099533fe887638a9eb6d80fa9939b Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Fri, 8 Nov 2024 13:39:12 -0800 Subject: [PATCH 05/15] first commit of hopefully working converter for multiple stations --- src/gnssro/gnss_tec_ground_based.py | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-) diff --git a/src/gnssro/gnss_tec_ground_based.py b/src/gnssro/gnss_tec_ground_based.py index fd075eac..7d2dc9c0 100755 --- a/src/gnssro/gnss_tec_ground_based.py +++ b/src/gnssro/gnss_tec_ground_based.py @@ -216,21 +216,12 @@ def read_file(file_name, any_data, qc_strict=True): # If StopIteration is raised, break from the loop break - import pdb - pdb.set_trace() - # has any data been read at any point - any_data = any_data or header_read - + any_data = True # repeat all the metaData values nlocs = len(local_data['dateTime']) - if nlocs > 0: - for key in meta_keys: - dtype = locationKeyList[meta_keys.index(key)][1] - local_data[key] = np.full(nlocs, local_data[key], dtype=dtypes[dtype]) - else: + if nlocs == 0: # if the header was not sucessfully read return nothing local_data = None - return local_data, any_data @@ -339,6 +330,11 @@ def populate_obsValue(line, local_data): except ValueError: return local_data, endReport + # repeat the metaData + if len(local_data['latitude']) < len(local_data['latitudeIPP']): + for key in ['latitude', 'longitude', 'stationIdentifier', 'stationIdentifierWMO', 'xECEFPosition', 'yECEFPosition', 'zECEFPosition']: + local_data[key] = np.append(local_data[key], local_data[key][-1]) + return local_data, endReport From c4d57e672e9041a3c40dcc8e23b8e90c20cd8178 Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Tue, 19 Nov 2024 10:41:01 -0800 Subject: [PATCH 06/15] update converter to only save slant path and add a ctest for converter --- test/CMakeLists.txt | 11 + .../tec_groundBased_TENET_20201001T00Z.tec | 683 ++++++++++++++++++ ....20201001T000000Z_PT1M_tec_groundbased.nc4 | 3 + 3 files changed, 697 insertions(+) create mode 100644 test/testinput/tec_groundBased_TENET_20201001T00Z.tec create mode 100644 test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index f90341f5..63884341 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -2158,6 +2158,17 @@ if( iodaconv_bufr_query_ENABLED ) endif() + ecbuild_add_test( TARGET test_${PROJECT_NAME}_tec_groundbased + TYPE SCRIPT + ENVIRONMENT "PYTHONPATH=${IODACONV_PYTHONPATH}" + COMMAND bash + ARGS ${CMAKE_BINARY_DIR}/bin/iodaconv_comp.sh + netcdf + "${Python3_EXECUTABLE} ${CMAKE_BINARY_DIR}/bin/gnss_tec_ground_based.py + -i testinput/tec_groundBased_TENET_20201001T00Z.tec + -o testrun/obs.20201001T000000Z_PT1M_tec_groundbased.nc4" + obs.20201001T000000Z_PT1M_tec_groundbased.nc4 ${IODA_CONV_COMP_TOL}) + #============================================================================== # PrepBUFR and BUFR tests #============================================================================== diff --git a/test/testinput/tec_groundBased_TENET_20201001T00Z.tec b/test/testinput/tec_groundBased_TENET_20201001T00Z.tec new file mode 100644 index 00000000..ef59a7e7 --- /dev/null +++ b/test/testinput/tec_groundBased_TENET_20201001T00Z.tec @@ -0,0 +1,683 @@ +HIUS1 KJPL 010002 +TENET +00000 1210/ 242907 KARR 102713875465 005304018101 102269379877 +11111 201001 000000 131265 24771 4714133950 8820250550 0252/ 1435/ 007025345077 013882442942 121666885863 +11111 201001 000000 281205 24271 6769134750 6810135550 0833/ 3350/ 112447865917 022145344610 107435220803 +11111 201001 000000 071260 23611 5985061550 1200012360 0219/ 2294/ 118798737186 000534235495 118615910088 +11111 201001 000000 051216 24641 7272119950 9350154150 0477/ 1038/ 003590034578 023803544329 111165607124 +11111 201001 000000 171119 23961 8554141450 1884031160 0175/ 3400/ 116353457832 014638871711 015357454224 +11111 201001 000000 301245 24141 ////124460 ////169260 0435/ 2011/ 111727010619 010455564137 121367744783 +11111 201001 000000 091182 23631 8336068450 1512012460 0267/ 2916/ 125427069453 007618409242 001104167821 +99999 +HIUS1 KJPL 010002 +TENET +08512 0377/ 025704 PDEL 004551708955 102186947293 003883216988 +11111 201001 000000 310402 03121 3590060650 5530093350 0355/ 0567/ 001707173343 117587766017 019632680518 +11111 201001 000000 290347 02331 6674063050 8640081550 0472/ 2134/ 026052853499 103562016877 003888966888 +11111 201001 000000 120412 02031 4414042450 7080068150 0332/ 3125/ 012271346259 009418316979 021377484549 +11111 201001 000000 250389 02491 4882062050 5190065950 0687/ 3351/ 015684634010 104098219502 020750406448 +99999 +HIUS1 KJPL 010002 +TENET +80222 0046/ 074106 BOGT 001744418322 106116105149 000512699203 +11111 201001 000000 210002 08111 1535009060 3138018560 0210/ 1216/ 113641769971 120173542274 110268527561 +11111 201001 000000 201035 06961 1421004360 3084009460 0182/ 2090/ 014773321850 111768769617 118653400940 +11111 201001 000000 310097 07501 6909066450 1088010560 0342/ 0099/ 001707173343 117587766017 019632680518 +11111 201001 000000 160008 07621 1229011460 1777016560 0393/ 1510/ 102040196236 122868631251 113164181820 +11111 201001 000000 260042 07461 1248011260 1264011460 0802/ 1305/ 004704464206 126007823203 100105659075 +11111 201001 000000 100020 07291 1201008360 1459010160 0526/ 2044/ 011642585231 121599160673 109747247442 +99999 +HIUS1 KJPL 010002 +TENET +91158 0221/ 159710 KOKB 105543927810 102054619417 002387670269 +11111 201001 000000 040225 16091 3999008660 4195009160 0711/ 0663/ 123536485470 102255894137 012144304217 +11111 201001 000000 210153 15401 4839003860 1007000870 0201/ 2199/ 113641769971 120173542274 110268527561 +11111 201001 000000 110176 15861 4765005360 6948007860 0388/ 1932/ 122082213466 112371474293 107895730388 +11111 201001 000000 220246 15721 3213006460 4151008260 0473/ 3193/ 112129062380 114736339377 018727403320 +11111 201001 000000 310299 14981 1932004860 4722011760 0123/ 3140/ 001707173343 117587766017 019632680518 +11111 201001 000000 170256 16751 3314008760 6624017560 0220/ 0619/ 116353457832 014638871711 015357454224 +11111 201001 000000 190300 17031 2495013860 6220034460 0113/ 0476/ 110120088925 015058516557 019083243385 +11111 201001 000000 010214 15851 4236009660 4429010160 0718/ 2404/ 121668459115 113982458807 006801961534 +11111 201001 000000 090201 16421 4422009260 6519013660 0381/ 1135/ 125427069453 007618409242 001104167821 +11111 201001 000000 030253 15931 2898006660 3717008460 0479/ 3545/ 113829829155 106584240923 021626827524 +99999 +HIUS1 KJPL 010002 +TENET +74612 0354/ 116908 GOLD 102353669498 104641493803 003676787457 +11111 201001 000000 040358 12471 1020014860 1782025960 0286/ 0826/ 123536485470 102255894137 012144304217 +11111 201001 000000 210260 11831 1373003960 2984008460 0181/ 1723/ 113641769971 120173542274 110268527561 +11111 201001 000000 110265 12411 1418003760 3299008660 0148/ 1428/ 122082213466 112371474293 107895730388 +11111 201001 000000 220361 11791 1018013560 1060014060 0727/ 0428/ 112129062380 114736339377 018727403320 +11111 201001 000000 310368 11431 9375069950 1110008360 0550/ 3079/ 001707173343 117587766017 019632680518 +11111 201001 000000 010335 12061 1167008860 1524011560 0465/ 1195/ 121668459115 113982458807 006801961534 +11111 201001 000000 030377 11961 8949170150 1138021660 0486/ 0414/ 113829829155 106584240923 021626827524 +11111 201001 000000 260311 11091 1289016060 2277028360 0281/ 2324/ 004704464206 126007823203 100105659075 +99999 +HIUS1 KJPL 010002 +TENET +91218 0136/ 215106 GUAM 105071378263 003568409744 001488812296 +11111 201001 000000 040154 21101 2784007860 4045011360 0391/ 2963/ 123536485470 102255894137 012144304217 +11111 201001 000000 280103 21801 2435007960 3470011260 0403/ 1390/ 112447865917 022145344610 107435220803 +11111 201001 000000 170155 21571 2477011360 2774012660 0612/ 0146/ 116353457832 014638871711 015357454224 +11111 201001 000000 190172 21681 2153011260 2974015460 0424/ 0240/ 110120088925 015058516557 019083243385 +11111 201001 000000 060194 21931 1937012260 3626022860 0252/ 0338/ 102839608687 016297527606 020822345043 +11111 201001 000000 090125 21341 2972011160 3302012360 0622/ 2401/ 125427069453 007618409242 001104167821 +99999 +HIUS1 KJPL 010002 +TENET +94120 1128/ 228908 DARW 104091411421 004684666073 101408492050 +11111 201001 000000 041047 21861 2142004860 5445012160 0102/ 3078/ 123536485470 102255894137 012144304217 +11111 201001 000000 281131 22991 8922138750 9220143450 0743/ 1084/ 112447865917 022145344610 107435220803 +11111 201001 000000 071178 22411 8913072650 1629013360 0263/ 2220/ 118798737186 000534235495 118615910088 +11111 201001 000000 051150 23471 6548174450 1121029960 0297/ 1120/ 003590034578 023803544329 111165607124 +11111 201001 000000 171068 22811 1294016260 2209027660 0298/ 3523/ 116353457832 014638871711 015357454224 +11111 201001 000000 191031 22981 1446020760 3218046160 0170/ 0058/ 110120088925 015058516557 019083243385 +11111 201001 000000 301174 22831 7432092850 1101013760 0378/ 1864/ 111727010619 010455564137 121367744783 +11111 201001 000000 091113 22541 1267009860 1692013160 0448/ 2932/ 125427069453 007618409242 001104167821 +99999 +HIUS1 KJPL 010002 +TENET +91285 0198/ 155508 MKEA 105464188047 102495203502 002148163493 +11111 201001 000000 040204 15711 4319008260 4692008960 0653/ 0634/ 123536485470 102255894137 012144304217 +11111 201001 000000 210139 15101 4265006460 8040012060 0248/ 2172/ 113641769971 120173542274 110268527561 +11111 201001 000000 110157 15491 5074006760 7011009260 0424/ 1874/ 122082213466 112371474293 107895730388 +11111 201001 000000 220224 15341 3488006760 4467008660 0480/ 3247/ 112129062380 114736339377 018727403320 +11111 201001 000000 310273 14651 1909004860 4554011460 0136/ 3147/ 001707173343 117587766017 019632680518 +11111 201001 000000 010193 15471 4583014060 4676014260 0777/ 2390/ 121668459115 113982458807 006801961534 +11111 201001 000000 090180 16061 4485008560 6992013260 0348/ 1081/ 125427069453 007618409242 001104167821 +11111 201001 000000 030233 15541 3301009260 4376012360 0453/ 3591/ 113829829155 106584240923 021626827524 +99999 +HIUS1 KJPL 010002 +TENET +88890 1517/ 057906 FALK 002106882675 103355284264 104981582347 +11111 201001 000000 201510 05591 5122085250 5380089550 0709/ 2910/ 014773321850 111768769617 118653400940 +11111 201001 000000 181522 05241 2504189150 3220243150 0477/ 2557/ 017746357803 101862900273 119701646745 +11111 201001 000000 161499 06321 5435061250 7220081350 0452/ 0661/ 102040196236 122868631251 113164181820 +11111 201001 000000 271528 06201 3313101750 4000122850 0531/ 1183/ 104337225045 114264643571 122123828195 +11111 201001 000000 261443 06301 5822037850 1152007560 0225/ 0272/ 004704464206 126007823203 100105659075 +11111 201001 000000 101485 05841 4872090550 6010111650 0512/ 0071/ 011642585231 121599160673 109747247442 +99999 +HIUS1 KJPL 010002 +TENET +72403 0390/ 076806 GODE 001130802605 104831377452 003994004176 +11111 201001 000000 220406 08191 7882068950 1118009860 0406/ 0644/ 112129062380 114736339377 018727403320 +11111 201001 000000 310397 07741 1142006360 1172006460 0761/ 0289/ 001707173343 117587766017 019632680518 +11111 201001 000000 250420 07131 9942040450 1558006360 0345/ 3084/ 015684634010 104098219502 020750406448 +11111 201001 000000 030438 08401 7747107950 1457020360 0249/ 0454/ 113829829155 106584240923 021626827524 +11111 201001 000000 260345 07731 1240009160 1773013060 0401/ 1754/ 004704464206 126007823203 100105659075 +11111 201001 000000 100282 07341 1005002460 2371005760 0142/ 1959/ 011642585231 121599160673 109747247442 +99999 +HIUS1 KJPL 010002 +TENET +91938 1176/ 149608 THTI 105246490766 103077303462 101913726111 +11111 201001 000000 041116 15291 4227007660 7659013760 0268/ 0289/ 123536485470 102255894137 012144304217 +11111 201001 000000 111175 14971 2334013760 2335013760 0886/ 0784/ 122082213466 112371474293 107895730388 +11111 201001 000000 071207 15231 1465012160 2051016960 0415/ 1424/ 118798737186 000534235495 118615910088 +11111 201001 000000 161202 14301 1632007360 2964013360 0266/ 2455/ 102040196236 122868631251 113164181820 +11111 201001 000000 011142 14931 3013012560 3838015960 0485/ 3556/ 121668459115 113982458807 006801961534 +11111 201001 000000 271231 14611 1351007560 2402013360 0277/ 2096/ 104337225045 114264643571 122123828195 +11111 201001 000000 091153 15611 3369008460 6054015160 0272/ 0715/ 125427069453 007618409242 001104167821 +11111 201001 000000 081203 14981 1508011260 1830013560 0527/ 1764/ 116215657216 108570148590 119295081535 +99999 +HIUS1 KJPL 010002 +TENET +68265 1259/ 332306 HRAO 005085443815 002668443949 102768574142 +11111 201001 000000 131293 32971 5082067050 7160094450 0410/ 2129/ 007025345077 013882442942 121666885863 +11111 201001 000000 051268 32561 2973049550 5080084550 0298/ 2588/ 003590034578 023803544329 111165607124 +11111 201001 000000 201306 33981 1834194150 3710392650 0215/ 1279/ 014773321850 111768769617 118653400940 +11111 201001 000000 181284 33501 0366212750 0480279150 0461/ 1387/ 017746357803 101862900273 119701646745 +11111 201001 000000 151274 33271 3891087250 4210094350 0659/ 1679/ 017922004811 007367765425 118657795205 +11111 201001 000000 241224 33161 8275114950 1067014860 0475/ 3489/ 022067881927 014762014731 003189261196 +99999 +HIUS1 KJPL 010002 +TENET +24959 0620/ 230308 YAKT 101915075753 002308333806 005610030407 +11111 201001 000000 040592 21761 5972099250 1069017860 0274/ 2529/ 123536485470 102255894137 012144304217 +11111 201001 000000 220655 21261 3775032750 7730067050 0209/ 3026/ 112129062380 114736339377 018727403320 +11111 201001 000000 170592 22891 5539052150 6590062050 0545/ 1952/ 116353457832 014638871711 015357454224 +11111 201001 000000 120646 24111 5170085850 8290137650 0332/ 0557/ 012271346259 009418316979 021377484549 +11111 201001 000000 190604 23111 2934060650 3110064250 0692/ 1653/ 110120088925 015058516557 019083243385 +11111 201001 000000 020603 24651 3494088450 6850173350 0229/ 0940/ 011250546456 020616801792 013074719828 +11111 201001 000000 060612 23391 4256084850 4630092350 0651/ 1094/ 102839608687 016297527606 020822345043 +11111 201001 000000 030634 22171 4486049450 6270069150 0416/ 2947/ 113829829155 106584240923 021626827524 +99999 +HIUS1 KJPL 010002 +TENET +94293 1193/ 212909 TOW2 105054658660 003275553095 102091413607 +11111 201001 000000 041117 20671 2176003760 4815008160 0172/ 3201/ 123536485470 102255894137 012144304217 +11111 201001 000000 281191 21561 1386008460 1630009960 0557/ 0881/ 112447865917 022145344610 107435220803 +11111 201001 000000 111204 20311 1450007160 3157015560 0180/ 2609/ 122082213466 112371474293 107895730388 +11111 201001 000000 071222 21031 1065006260 1446008560 0436/ 2185/ 118798737186 000534235495 118615910088 +11111 201001 000000 051220 22331 1039009760 2352021960 0161/ 1084/ 003590034578 023803544329 111165607124 +11111 201001 000000 171114 21421 2040008960 4047017660 0224/ 0089/ 116353457832 014638871711 015357454224 +11111 201001 000000 301228 21361 9421074450 1252009960 0452/ 1710/ 111727010619 010455564137 121367744783 +11111 201001 000000 091171 21131 1740007360 2056008760 0552/ 3218/ 125427069453 007618409242 001104167821 +11111 201001 000000 081248 20631 1041004960 2132010060 0209/ 2264/ 116215657216 108570148590 119295081535 +99999 +HIUS1 KJPL 010002 +TENET +00000 0493/ 124106 NANO 102335802374 103451719852 004811805521 +11111 201001 000000 040478 13191 8665149950 1362023660 0343/ 1008/ 123536485470 102255894137 012144304217 +11111 201001 000000 220487 12461 7596086750 7660087450 0821/ 1405/ 112129062380 114736339377 018727403320 +11111 201001 000000 310496 12031 4067068150 4750079650 0564/ 2826/ 001707173343 117587766017 019632680518 +11111 201001 000000 250569 11051 4985052550 1178012460 0141/ 3191/ 015684634010 104098219502 020750406448 +11111 201001 000000 010455 12781 6991058150 9980082950 0402/ 1432/ 121668459115 113982458807 006801961534 +11111 201001 000000 030499 12661 6549130650 7140142450 0648/ 0621/ 113829829155 106584240923 021626827524 +99999 +HIUS1 KJPL 010002 +TENET +08450 0365/ 006207 SFER 005326750052 101719859612 003051875153 +11111 201001 000000 310334 02491 3096050250 6010097550 0234/ 0495/ 001707173343 117587766017 019632680518 +11111 201001 000000 290267 01681 7989078450 8970088050 0609/ 2071/ 026052853499 103562016877 003888966888 +11111 201001 000000 120329 01331 5052050050 8430083450 0310/ 3188/ 012271346259 009418316979 021377484549 +11111 201001 000000 250308 01771 5250068850 5960078050 0596/ 3550/ 015684634010 104098219502 020750406448 +11111 201001 000000 240266 00981 5586041050 1069007860 0241/ 2562/ 022067881927 014762014731 003189261196 +11111 201001 000000 260247 03151 6516047750 1644012060 0106/ 1046/ 004704464206 126007823203 100105659075 +11111 201001 000000 100192 02741 6431035150 1625008960 0105/ 1351/ 011642585231 121599160673 109747247442 +99999 +HIUS1 KJPL 010002 +TENET +72362 0343/ 108107 PIE1 101640954260 105014894994 003575260909 +11111 201001 000000 040355 11841 8523252150 1760052160 0205/ 0777/ 123536485470 102255894137 012144304217 +11111 201001 000000 110248 11801 1388004960 3495012360 0107/ 1348/ 122082213466 112371474293 107895730388 +11111 201001 000000 220352 10981 9355211550 1019023060 0649/ 0518/ 112129062380 114736339377 018727403320 +11111 201001 000000 310356 10631 7341069150 8240077650 0609/ 3151/ 001707173343 117587766017 019632680518 +11111 201001 000000 010326 11311 1035009060 1501013160 0392/ 1092/ 121668459115 113982458807 006801961534 +11111 201001 000000 030371 11161 6919120450 9650167950 0417/ 0429/ 113829829155 106584240923 021626827524 +11111 201001 000000 260304 10401 1164008860 1806013660 0351/ 2236/ 004704464206 126007823203 100105659075 +99999 +HIUS1 KJPL 010002 +TENET +94970 1428/ 212609 HOB2 103950182949 002522486156 104311436313 +11111 201001 000000 131476 22071 5761167750 1108032260 0239/ 1338/ 007025345077 013882442942 121666885863 +11111 201001 000000 281402 21641 7405194850 9940261550 0444/ 0508/ 112447865917 022145344610 107435220803 +11111 201001 000000 111410 20051 7212140150 1534029860 0191/ 2759/ 122082213466 112371474293 107895730388 +11111 201001 000000 071432 20981 7088226250 7950253750 0610/ 2543/ 118798737186 000534235495 118615910088 +11111 201001 000000 051426 22411 6149130850 1260026860 0209/ 0941/ 003590034578 023803544329 111165607124 +11111 201001 000000 301436 21321 7612247950 7890257050 0736/ 1541/ 111727010619 010455564137 121367744783 +11111 201001 000000 271513 20151 6173108650 1475026060 0135/ 2171/ 104337225045 114264643571 122123828195 +11111 201001 000000 091371 20981 1088015160 1825025460 0307/ 3382/ 125427069453 007618409242 001104167821 +11111 201001 000000 081447 20641 5768172250 8680259150 0369/ 2433/ 116215657216 108570148590 119295081535 +99999 +HIUS1 KJPL 010002 +TENET +87593 1349/ 057906 LPGS 002780167128 104437521353 103629216738 +11111 201001 000000 201358 05641 1184010760 1273011560 0668/ 2308/ 014773321850 111768769617 118653400940 +11111 201001 000000 181373 05331 7129177250 1036025760 0390/ 2349/ 017746357803 101862900273 119701646745 +11111 201001 000000 161348 06181 1044009460 1315011860 0494/ 0914/ 102040196236 122868631251 113164181820 +11111 201001 000000 271379 06161 9492108050 1352015460 0403/ 1382/ 104337225045 114264643571 122123828195 +11111 201001 000000 261310 06101 1297007960 1885011460 0390/ 0352/ 004704464206 126007823203 100105659075 +11111 201001 000000 101335 05831 1567012360 1635012960 0722/ 0149/ 011642585231 121599160673 109747247442 +99999 +HIUS1 KJPL 010002 +TENET +45007 0223/ 245808 HKPT 103686057487 005146187896 000779984935 +11111 201001 000000 040115 22551 2261005460 5064012060 0167/ 2974/ 123536485470 102255894137 012144304217 +11111 201001 000000 280048 23501 1870004260 2140004860 0586/ 1652/ 112447865917 022145344610 107435220803 +11111 201001 000000 170098 23331 1883008360 2322010360 0512/ 3393/ 116353457832 014638871711 015357454224 +11111 201001 000000 190114 23451 1801010560 2583015060 0399/ 0019/ 110120088925 015058516557 019083243385 +11111 201001 000000 020126 24491 1413015360 3441037260 0125/ 0610/ 011250546456 020616801792 013074719828 +11111 201001 000000 301034 23281 1585003760 3683008660 0149/ 1885/ 111727010619 010455564137 121367744783 +11111 201001 000000 060129 23671 1546005360 2703009360 0286/ 0209/ 102839608687 016297527606 020822345043 +11111 201001 000000 090066 23031 2225004960 3098006960 0418/ 2648/ 125427069453 007618409242 001104167821 +99999 +HIUS1 KJPL 010002 +TENET +40634 0341/ 316607 IZAD 004396047061 003080774289 003433316242 +11111 201001 000000 290303 33111 6707089550 1102014760 0318/ 1118/ 026052853499 103562016877 003888966888 +11111 201001 000000 120346 32481 7049064450 7840071650 0621/ 3560/ 012271346259 009418316979 021377484549 +11111 201001 000000 190407 31181 3501015450 8920039350 0100/ 3112/ 110120088925 015058516557 019083243385 +11111 201001 000000 020325 32241 6781043850 7640049450 0605/ 2679/ 011250546456 020616801792 013074719828 +11111 201001 000000 250357 32901 6717073950 9810107950 0387/ 0464/ 015684634010 104098219502 020750406448 +11111 201001 000000 240301 32511 7791044650 9090052050 0565/ 1772/ 022067881927 014762014731 003189261196 +11111 201001 000000 060369 31901 5443034350 9620060750 0280/ 3125/ 102839608687 016297527606 020822345043 +99999 +HIUS1 KJPL 010002 +TENET +00000 1319/ 226207 CEDU 103753552714 003912824174 103347780797 +11111 201001 000000 131371 23271 1006120150 1940231750 0237/ 1369/ 007025345077 013882442942 121666885863 +11111 201001 000000 281303 22771 0545121250 0600133350 0635/ 0437/ 112447865917 022145344610 107435220803 +11111 201001 000000 071338 22221 0929041950 1270057350 0431/ 2364/ 118798737186 000534235495 118615910088 +11111 201001 000000 051320 23291 1003057650 1640094350 0321/ 0952/ 003590034578 023803544329 111165607124 +11111 201001 000000 301338 22591 ////062450 ////069950 0613/ 1871/ 111727010619 010455564137 121367744783 +11111 201001 000000 091279 22201 5827039050 9150061350 0344/ 3151/ 125427069453 007618409242 001104167821 +11111 201001 000000 081368 21751 4342049050 9080102550 0199/ 2321/ 116215657216 108570148590 119295081535 +99999 +HIUS1 KJPL 010002 +TENET +47620 0361/ 221606 USUD 103855355160 003427513862 003740829757 +11111 201001 000000 040359 21601 1019007860 1493011560 0385/ 2711/ 123536485470 102255894137 012144304217 +11111 201001 000000 280284 22521 1389004060 2799008160 0216/ 1577/ 112447865917 022145344610 107435220803 +11111 201001 000000 170359 22171 1125009860 1125009860 0885/ 1718/ 116353457832 014638871711 015357454224 +11111 201001 000000 190370 22281 1081010260 1138010760 0704/ 0418/ 110120088925 015058516557 019083243385 +11111 201001 000000 060380 22461 9101095150 1140011960 0499/ 0482/ 102839608687 016297527606 020822345043 +11111 201001 000000 030402 21591 8412043750 1447007560 0294/ 3147/ 113829829155 106584240923 021626827524 +99999 +HIUS1 KJPL 010002 +TENET +08221 0404/ 004206 MADR 004849330981 100360338355 004114714847 +11111 201001 000000 310448 01361 5500199250 1107040160 0217/ 0532/ 001707173343 117587766017 019632680518 +11111 201001 000000 290370 00471 5068218450 6430277250 0488/ 1734/ 026052853499 103562016877 003888966888 +11111 201001 000000 120422 00101 4954079450 6180099050 0502/ 3105/ 012271346259 009418316979 021377484549 +11111 201001 000000 020411 35421 3848127050 7440245550 0236/ 2798/ 011250546456 020616801792 013074719828 +11111 201001 000000 250413 00501 6667113850 6960118850 0721/ 0281/ 015684634010 104098219502 020750406448 +11111 201001 000000 240367 35811 5602053850 9450090750 0304/ 2358/ 022067881927 014762014731 003189261196 +99999 +HIUS1 KJPL 010002 +TENET +61967 1073/ 287607 DGAR 001916291022 006030046814 100801668859 +11111 201001 000000 131131 28841 2136091050 3600153450 0305/ 1727/ 007025345077 013882442942 121666885863 +11111 201001 000000 281087 28201 3572104250 5920172750 0314/ 2544/ 112447865917 022145344610 107435220803 +11111 201001 000000 051089 28691 2846145050 3110158550 0644/ 2051/ 003590034578 023803544329 111165607124 +11111 201001 000000 151136 29341 1645085350 3410176850 0203/ 1388/ 017922004811 007367765425 118657795205 +11111 201001 000000 021033 28871 2360107050 3280148850 0420/ 0158/ 011250546456 020616801792 013074719828 +11111 201001 000000 241057 29201 1318118550 1940174550 0382/ 0708/ 022067881927 014762014731 003189261196 +11111 201001 000000 060036 28401 1433063550 3450152850 0131/ 3412/ 102839608687 016297527606 020822345043 +99999 +HIUS1 KJPL 010002 +TENET +84752 1165/ 071508 AREQ 001942853159 105804150787 101796784779 +11111 201001 000000 211181 07801 2240007160 3959012660 0280/ 1063/ 113641769971 120173542274 110268527561 +11111 201001 000000 201198 06871 1606006160 2303008860 0399/ 2175/ 014773321850 111768769617 118653400940 +11111 201001 000000 311040 07361 1739003760 4373009260 0108/ 0095/ 001707173343 117587766017 019632680518 +11111 201001 000000 181238 06351 8738107850 2022024960 0151/ 2240/ 017746357803 101862900273 119701646745 +11111 201001 000000 161178 07351 1990008760 2310010160 0571/ 1260/ 102040196236 122868631251 113164181820 +11111 201001 000000 271217 07431 1723007760 2915013160 0303/ 1541/ 104337225045 114264643571 122123828195 +11111 201001 000000 261149 07231 2247008760 2424009460 0663/ 0275/ 004704464206 126007823203 100105659075 +11111 201001 000000 101168 07071 2137009860 2194010060 0760/ 2391/ 011642585231 121599160673 109747247442 +99999 +HIUS1 KJPL 010002 +TENET +30710 0522/ 255707 IRKM 100968365730 003794555088 005017963978 +11111 201001 000000 040528 23631 6322160450 1528038860 0129/ 2811/ 123536485470 102255894137 012144304217 +11111 201001 000000 170508 25131 7009055150 8560067350 0521/ 2479/ 116353457832 014638871711 015357454224 +11111 201001 000000 120541 26201 3931072650 5550102550 0409/ 0597/ 012271346259 009418316979 021377484549 +11111 201001 000000 190517 25371 4694062350 4910065150 0717/ 2535/ 110120088925 015058516557 019083243385 +11111 201001 000000 020504 26211 5532099550 7850141350 0406/ 1092/ 011250546456 020616801792 013074719828 +11111 201001 000000 060520 25611 5590073550 5600073750 0863/ 1014/ 102839608687 016297527606 020822345043 +11111 201001 000000 030575 24521 3774060150 7490119350 0224/ 3161/ 113829829155 106584240923 021626827524 +99999 +HIUS1 KJPL 010002 +TENET +17060 0411/ 331007 ISTA 004359516831 002874183935 003650589757 +11111 201001 000000 290324 33271 6112078550 9980128250 0322/ 1153/ 026052853499 103562016877 003888966888 +11111 201001 000000 120367 32631 6087042450 6630046150 0649/ 3527/ 012271346259 009418316979 021377484549 +11111 201001 000000 190428 31331 4192014550 1058003760 0106/ 3109/ 110120088925 015058516557 019083243385 +11111 201001 000000 020347 32381 7491049450 8580056650 0585/ 2637/ 011250546456 020616801792 013074719828 +11111 201001 000000 250377 33051 4586051850 6390072250 0418/ 0483/ 015684634010 104098219502 020750406448 +11111 201001 000000 240322 32661 5936035750 7130042950 0536/ 1808/ 022067881927 014762014731 003189261196 +11111 201001 000000 060390 32041 5977034450 1043006060 0287/ 3111/ 102839608687 016297527606 020822345043 +99999 +HIUS1 KJPL 010002 +TENET +87344 1315/ 064507 CORD 002345553254 104910946275 103316187117 +11111 201001 000000 211319 07321 1038014960 1982028460 0242/ 0963/ 113641769971 120173542274 110268527561 +11111 201001 000000 201328 06241 8247075250 9430086050 0587/ 2296/ 014773321850 111768769617 118653400940 +11111 201001 000000 181348 05891 6776149650 1119024760 0316/ 2319/ 017746357803 101862900273 119701646745 +11111 201001 000000 161315 06741 9451101650 1109011960 0559/ 0944/ 102040196236 122868631251 113164181820 +11111 201001 000000 271346 06761 8611126250 1207017760 0414/ 1425/ 104337225045 114264643571 122123828195 +11111 201001 000000 261282 06641 1156006960 1521009060 0459/ 0278/ 004704464206 126007823203 100105659075 +11111 201001 000000 101305 06421 1045010960 1070011160 0767/ 3451/ 011642585231 121599160673 109747247442 +99999 +HIUS1 KJPL 010002 +TENET +63799 1030/ 319806 MALI 004913710635 003945969260 000995320733 +11111 201001 000000 150014 32321 1485085850 2950170550 0223/ 1656/ 017922004811 007367765425 118657795205 +11111 201001 000000 120143 32131 1392126150 2230201950 0332/ 0010/ 012271346259 009418316979 021377484549 +11111 201001 000000 020110 31921 0724106950 0880130050 0525/ 3165/ 011250546456 020616801792 013074719828 +11111 201001 000000 250174 32731 5030338550 1152077560 0156/ 0344/ 015684634010 104098219502 020750406448 +11111 201001 000000 240088 32171 ////191350 ////192650 0829/ 1134/ 022067881927 014762014731 003189261196 +11111 201001 000000 060188 31341 3578071850 8930179150 0112/ 3231/ 102839608687 016297527606 020822345043 +99999 +HIUS1 KJPL 010002 +TENET +71828 0548/ 066806 SCH2 001448688502 103385364981 005190844886 +11111 201001 000000 220554 07481 1422065950 2070095950 0389/ 0779/ 112129062380 114736339377 018727403320 +11111 201001 000000 310542 06871 2743089750 2850093250 0731/ 1145/ 001707173343 117587766017 019632680518 +11111 201001 000000 120600 05551 2686042650 5320084450 0225/ 3159/ 012271346259 009418316979 021377484549 +11111 201001 000000 250554 06161 2474073750 3070091450 0507/ 2867/ 015684634010 104098219502 020750406448 +11111 201001 000000 030580 07581 2468094050 4120156950 0310/ 0520/ 113829829155 106584240923 021626827524 +11111 201001 000000 260464 07011 5482137250 1121028160 0210/ 1644/ 004704464206 126007823203 100105659075 +99999 +HIUS1 KJPL 010002 +TENET +32540 0530/ 201307 PETS 103580952621 001399746724 005071981709 +11111 201001 000000 040505 19741 ////168850 ////215650 0483/ 2282/ 123536485470 102255894137 012144304217 +11111 201001 000000 220544 19211 ////062050 ////101150 0322/ 2898/ 112129062380 114736339377 018727403320 +11111 201001 000000 170513 20391 ////082850 ////093650 0601/ 1330/ 116353457832 014638871711 015357454224 +11111 201001 000000 190527 20501 ////108150 ////122450 0599/ 0923/ 110120088925 015058516557 019083243385 +11111 201001 000000 060541 20731 ////177550 ////235350 0453/ 0681/ 102839608687 016297527606 020822345043 +11111 201001 000000 090460 20031 ////259050 ////468050 0269/ 1860/ 125427069453 007618409242 001104167821 +11111 201001 000000 030538 19711 ////064650 ////076550 0549/ 2926/ 113829829155 106584240923 021626827524 +99999 +HIUS1 KJPL 010002 +TENET +70261 0650/ 147510 FAIR 102281716628 101453656320 005756770407 +11111 201001 000000 040609 15361 4991108250 7420160850 0376/ 1424/ 123536485470 102255894137 012144304217 +11111 201001 000000 220630 14471 4234070750 4770079750 0605/ 2148/ 112129062380 114736339377 018727403320 +11111 201001 000000 310648 13801 4438087650 6060119750 0432/ 2739/ 001707173343 117587766017 019632680518 +11111 201001 000000 170642 16451 4925050950 9170094750 0254/ 0869/ 116353457832 014638871711 015357454224 +11111 201001 000000 120754 15001 6190093350 1414021360 0157/ 0034/ 012271346259 009418316979 021377484549 +11111 201001 000000 190666 16241 5107073250 8780125850 0294/ 0670/ 110120088925 015058516557 019083243385 +11111 201001 000000 250720 13151 5882098050 1246020860 0193/ 3277/ 015684634010 104098219502 020750406448 +11111 201001 000000 010581 14741 5304045950 9450081850 0276/ 1804/ 121668459115 113982458807 006801961534 +11111 201001 000000 060693 16291 4907122350 9230230150 0249/ 0463/ 102839608687 016297527606 020822345043 +11111 201001 000000 030639 14831 3962094450 4070097050 0758/ 1578/ 113829829155 106584240923 021626827524 +99999 +HIUS1 KJPL 010002 +TENET +93110 1366/ 185210 AUCK 105105804514 000461575144 103781989578 +11111 201001 000000 041245 18281 1492003760 3678009260 0119/ 3495/ 123536485470 102255894137 012144304217 +11111 201001 000000 281352 19421 8864125350 1682023860 0245/ 0829/ 112447865917 022145344610 107435220803 +11111 201001 000000 211365 17561 8774154650 1707030160 0233/ 2667/ 113641769971 120173542274 110268527561 +11111 201001 000000 111349 18091 7890100850 1063013660 0442/ 2931/ 122082213466 112371474293 107895730388 +11111 201001 000000 071372 18491 6656106350 6770108150 0787/ 1971/ 118798737186 000534235495 118615910088 +11111 201001 000000 011279 17681 1319012960 3122030560 0140/ 3179/ 121668459115 113982458807 006801961534 +11111 201001 000000 301386 18791 6121114850 7580142250 0508/ 1359/ 111727010619 010455564137 121367744783 +11111 201001 000000 271420 17811 7322049650 1429009760 0232/ 2224/ 104337225045 114264643571 122123828195 +11111 201001 000000 091321 18681 9769062650 1424009160 0388/ 0179/ 125427069453 007618409242 001104167821 +11111 201001 000000 081378 18241 8280079450 9720093250 0559/ 2376/ 116215657216 108570148590 119295081535 +99999 +HIUS1 KJPL 010002 +TENET +61902 1080/ 014407 ASC1 006104900762 100605836232 101740632445 +11111 201001 000000 131254 35761 3571021650 8840053550 0117/ 2169/ 007025345077 013882442942 121666885863 +11111 201001 000000 201193 00851 4224045250 6100065350 0394/ 1430/ 014773321850 111768769617 118653400940 +11111 201001 000000 181191 00571 2238192950 2830244050 0490/ 1796/ 017746357803 101862900273 119701646745 +11111 201001 000000 151190 00331 2240041550 3050056550 0434/ 2145/ 017922004811 007367765425 118657795205 +11111 201001 000000 291136 00591 4811042150 5520048350 0583/ 0051/ 026052853499 103562016877 003888966888 +11111 201001 000000 241133 00081 4336054950 6940087850 0333/ 2973/ 022067881927 014762014731 003189261196 +11111 201001 000000 101177 01311 4798056750 9160108250 0242/ 1054/ 011642585231 121599160673 109747247442 +99999 +HIUS1 KJPL 010002 +TENET +64500 0004/ 350308 NKLG 006287454158 001071586392 000039130580 +11111 201001 000000 201082 35681 2942075750 6880177150 0146/ 1431/ 014773321850 111768769617 118653400940 +11111 201001 000000 181060 35191 3409210150 6070374050 0277/ 1663/ 017746357803 101862900273 119701646745 +11111 201001 000000 151050 34911 3593075050 5800121150 0328/ 1928/ 017922004811 007367765425 118657795205 +11111 201001 000000 290011 35191 5081122650 5530133450 0650/ 0647/ 026052853499 103562016877 003888966888 +11111 201001 000000 120091 34731 4390055150 9500119250 0183/ 3413/ 012271346259 009418316979 021377484549 +11111 201001 000000 020053 34331 5462056450 1137011760 0201/ 3052/ 011250546456 020616801792 013074719828 +11111 201001 000000 250081 35291 4199063650 8500128650 0214/ 0179/ 015684634010 104098219502 020750406448 +11111 201001 000000 240010 34811 3339108550 3850125150 0578/ 2857/ 022067881927 014762014731 003189261196 +99999 +HIUS1 KJPL 010002 +TENET +60030 0278/ 015606 MAS1 004221639422 102549308389 004031201371 +11111 201001 000000 310414 03601 2942050450 4160071250 0408/ 0591/ 001707173343 117587766017 019632680518 +11111 201001 000000 290361 02791 6982052150 9640071950 0424/ 2202/ 026052853499 103562016877 003888966888 +11111 201001 000000 120431 02511 4248030850 7110051550 0309/ 3120/ 012271346259 009418316979 021377484549 +11111 201001 000000 250405 02991 4584049650 4900053150 0678/ 3233/ 015684634010 104098219502 020750406448 +11111 201001 000000 240356 01511 5036017650 1282004560 0101/ 2590/ 022067881927 014762014731 003189261196 +11111 201001 000000 260340 04141 6550046550 1450010360 0172/ 1194/ 004704464206 126007823203 100105659075 +99999 +HIUS1 KJPL 010002 +TENET +89664 1778/ 193309 MCM4 101311764219 000310829384 106213080036 +11111 201001 000000 131792 21541 6234132950 9020192350 0393/ 1183/ 007025345077 013882442942 121666885863 +11111 201001 000000 071743 18991 4210124250 5450160750 0472/ 3448/ 118798737186 000534235495 118615910088 +11111 201001 000000 051727 24021 5821093250 1439023060 0117/ 0910/ 003590034578 023803544329 111165607124 +11111 201001 000000 201849 15481 3854143950 7960297250 0205/ 2013/ 014773321850 111768769617 118653400940 +11111 201001 000000 181857 20451 3766151450 7370296350 0230/ 1739/ 017746357803 101862900273 119701646745 +11111 201001 000000 151836 23601 5437105550 1112021660 0209/ 1497/ 017922004811 007367765425 118657795205 +11111 201001 000000 161756 14291 6489116450 1538027660 0139/ 2552/ 102040196236 122868631251 113164181820 +11111 201001 000000 271781 17521 6047122250 8030162250 0452/ 2558/ 104337225045 114264643571 122123828195 +11111 201001 000000 081751 18161 3711127950 4930169950 0452/ 3080/ 116215657216 108570148590 119295081535 +99999 +HIUS1 KJPL 010002 +TENET +89000 1663/ 249509 CAS1 100901814196 002409484954 105816559002 +11111 201001 000000 131658 25561 ////066050 ////076750 0571/ 0854/ 007025345077 013882442942 121666885863 +11111 201001 000000 281595 24691 ////054950 ////098350 0274/ 3490/ 112447865917 022145344610 107435220803 +11111 201001 000000 071660 23761 ////049350 ////073050 0378/ 2667/ 118798737186 000534235495 118615910088 +11111 201001 000000 051616 25681 ////047850 ////076550 0332/ 0384/ 003590034578 023803544329 111165607124 +11111 201001 000000 181711 26901 ////130850 ////267050 0210/ 1336/ 017746357803 101862900273 119701646745 +11111 201001 000000 151676 26611 ////057350 ////101250 0281/ 1098/ 017922004811 007367765425 118657795205 +11111 201001 000000 301653 24591 ////068850 ////074450 0659/ 2994/ 111727010619 010455564137 121367744783 +11111 201001 000000 271732 23781 ////059550 ////117050 0228/ 2046/ 104337225045 114264643571 122123828195 +11111 201001 000000 081687 23231 ////085650 ////155750 0266/ 2414/ 116215657216 108570148590 119295081535 +99999 +HIUS1 KJPL 010002 +TENET +60135 0340/ 006905 RABT 005143450907 101563446555 003421010138 +11111 201001 000000 310367 02391 3465051950 6450096650 0254/ 0517/ 001707173343 117587766017 019632680518 +11111 201001 000000 290302 01591 7667078250 8920090950 0568/ 2013/ 026052853499 103562016877 003888966888 +11111 201001 000000 120361 01251 5504044250 8550068750 0350/ 3163/ 012271346259 009418316979 021377484549 +11111 201001 000000 020360 00211 4511088550 1133022260 0109/ 2902/ 011250546456 020616801792 013074719828 +11111 201001 000000 240300 00861 5283031550 1016006160 0239/ 2528/ 022067881927 014762014731 003189261196 +99999 +HIUS1 KJPL 010002 +TENET +61998 1494/ 289706 KERG 001406382712 003918287826 104815962987 +11111 201001 000000 131496 29031 3168084150 3200084950 0813/ 1416/ 007025345077 013882442942 121666885863 +11111 201001 000000 281461 28031 1386077950 2550143250 0260/ 2920/ 112447865917 022145344610 107435220803 +11111 201001 000000 051468 28831 1970061450 2300071750 0564/ 3363/ 003590034578 023803544329 111165607124 +11111 201001 000000 181519 29861 0211148650 0360253950 0298/ 1191/ 017746357803 101862900273 119701646745 +11111 201001 000000 151496 29491 1634070150 2090089650 0481/ 0992/ 017922004811 007367765425 118657795205 +11111 201001 000000 301516 28341 1704050650 2510074650 0382/ 2370/ 111727010619 010455564137 121367744783 +99999 +HIUS1 KJPL 010002 +TENET +89564 1676/ 297108 MAW1 001111334784 002169004068 105874305798 +11111 201001 000000 131663 29711 4274084050 4450087450 0727/ 3593/ 007025345077 013882442942 121666885863 +11111 201001 000000 071721 27371 4089036250 8690077050 0191/ 2293/ 118798737186 000534235495 118615910088 +11111 201001 000000 051625 29231 3759044150 5900069250 0344/ 3355/ 003590034578 023803544329 111165607124 +11111 201001 000000 201702 31731 2827151650 5430291250 0239/ 1197/ 014773321850 111768769617 118653400940 +11111 201001 000000 181675 30861 4982183650 7070260650 0406/ 0954/ 017746357803 101862900273 119701646745 +11111 201001 000000 151658 30431 3873090550 4880114150 0494/ 0627/ 017922004811 007367765425 118657795205 +11111 201001 000000 301683 28661 4521056250 6170076750 0432/ 2535/ 111727010619 010455564137 121367744783 +11111 201001 000000 271760 30141 3827103350 7820211150 0210/ 1731/ 104337225045 114264643571 122123828195 +99999 +HIUS1 KJPL 010002 +TENET +96996 1122/ 263207 COCO 101696365034 006039663115 101149203378 +11111 201001 000000 131174 25831 3670123750 7350247750 0219/ 1513/ 007025345077 013882442942 121666885863 +11111 201001 000000 281109 25311 4172173150 4380181850 0710/ 2446/ 112447865917 022145344610 107435220803 +11111 201001 000000 051119 25651 4098164450 4860194950 0549/ 1253/ 003590034578 023803544329 111165607124 +11111 201001 000000 171037 25011 6976118450 1382023460 0225/ 3274/ 116353457832 014638871711 015357454224 +11111 201001 000000 191012 25191 6011143850 1324031760 0175/ 3455/ 110120088925 015058516557 019083243385 +11111 201001 000000 021040 26081 5830089050 1248019160 0188/ 0459/ 011250546456 020616801792 013074719828 +11111 201001 000000 301164 25151 5061100050 9090179650 0272/ 2044/ 111727010619 010455564137 121367744783 +99999 +HIUS1 KJPL 010002 +TENET +71562 0506/ 128109 HOLB 102503123684 103188339080 004908497224 +11111 201001 000000 040489 13531 4488056450 6750084950 0369/ 1059/ 123536485470 102255894137 012144304217 +11111 201001 000000 220499 12831 0565046450 0570046850 0819/ 1712/ 112129062380 114736339377 018727403320 +11111 201001 000000 310510 12381 ////060550 ////072750 0536/ 2820/ 001707173343 117587766017 019632680518 +11111 201001 000000 170546 14851 3596031050 9060078250 0107/ 0636/ 116353457832 014638871711 015357454224 +11111 201001 000000 190580 14541 3028038850 7520096350 0115/ 0464/ 110120088925 015058516557 019083243385 +11111 201001 000000 250587 11401 2371060850 5680145750 0134/ 3207/ 015684634010 104098219502 020750406448 +11111 201001 000000 010467 13131 2156049450 3060070150 0406/ 1499/ 121668459115 113982458807 006801961534 +11111 201001 000000 030511 13031 ////048850 ////051950 0685/ 0653/ 113829829155 106584240923 021626827524 +11111 201001 000000 260423 11401 5701090450 1427022660 0110/ 2354/ 004704464206 126007823203 100105659075 +99999 +HIUS1 KJPL 010002 +TENET +38353 0427/ 285306 POL2 001240005835 004530916961 004302377629 +11111 201001 000000 170436 27681 4250056450 7350097650 0291/ 2834/ 116353457832 014638871711 015357454224 +11111 201001 000000 120441 28821 4157089450 4910105750 0553/ 0517/ 012271346259 009418316979 021377484549 +11111 201001 000000 190439 28061 3449072750 4560096150 0455/ 2937/ 110120088925 015058516557 019083243385 +11111 201001 000000 020413 28671 4932111450 5280119250 0675/ 1373/ 011250546456 020616801792 013074719828 +11111 201001 000000 240386 29261 5144057050 9280102850 0270/ 1229/ 022067881927 014762014731 003189261196 +11111 201001 000000 060435 28331 4217097950 4590106650 0650/ 3064/ 102839608687 016297527606 020822345043 +99999 +HIUS1 KJPL 010002 +TENET +00000 0391/ 218910 MIZU 103857269681 003108773030 004003843864 +11111 201001 000000 040385 21351 1001007060 1411009860 0410/ 2657/ 123536485470 102255894137 012144304217 +11111 201001 000000 280302 22341 1195002660 2620005860 0177/ 1554/ 112447865917 022145344610 107435220803 +11111 201001 000000 220452 20571 9407024750 2262005960 0132/ 3071/ 112129062380 114736339377 018727403320 +11111 201001 000000 170386 21911 9799075150 9850075550 0838/ 1491/ 116353457832 014638871711 015357454224 +11111 201001 000000 120487 23141 6994095950 1780024460 0101/ 0385/ 012271346259 009418316979 021377484549 +11111 201001 000000 190397 22031 8949073650 9400077450 0709/ 0541/ 110120088925 015058516557 019083243385 +11111 201001 000000 020417 23451 8340153650 2055037960 0119/ 0720/ 011250546456 020616801792 013074719828 +11111 201001 000000 060408 22221 7336075350 9160094150 0501/ 0527/ 102839608687 016297527606 020822345043 +11111 201001 000000 090349 21551 1204008860 1806013260 0371/ 2144/ 125427069453 007618409242 001104167821 +11111 201001 000000 030425 21341 7994033750 1272005460 0336/ 3124/ 113829829155 106584240923 021626827524 +99999 +HIUS1 KJPL 010002 +TENET +94998 1545/ 201110 MAC1 103464162118 001334220604 105169021494 +11111 201001 000000 131586 21111 6647083950 1211015360 0265/ 1319/ 007025345077 013882442942 121666885863 +11111 201001 000000 281503 20921 5824099950 1009017360 0290/ 0544/ 112447865917 022145344610 107435220803 +11111 201001 000000 211533 18051 6333083650 1549020460 0123/ 2663/ 113641769971 120173542274 110268527561 +11111 201001 000000 111507 19001 6126082850 1176015960 0240/ 2937/ 122082213466 112371474293 107895730388 +11111 201001 000000 071536 19891 4106092350 4350097850 0693/ 3000/ 118798737186 000534235495 118615910088 +11111 201001 000000 051538 22061 6430045750 1531010960 0137/ 0955/ 003590034578 023803544329 111165607124 +11111 201001 000000 301544 20301 5356093050 5540096250 0741/ 0948/ 111727010619 010455564137 121367744783 +11111 201001 000000 271584 19191 5717047150 1000008260 0286/ 2273/ 104337225045 114264643571 122123828195 +11111 201001 000000 091456 19991 7875033850 1643007060 0200/ 3548/ 125427069453 007618409242 001104167821 +11111 201001 000000 081545 19551 5764065050 7240081750 0496/ 2642/ 116215657216 108570148590 119295081535 +99999 +HIUS1 KJPL 010002 +TENET +89571 1686/ 282008 DAV1 000486875640 002285198046 105914769227 +11111 201001 000000 131672 28411 2238086050 2370091150 0694/ 0332/ 007025345077 013882442942 121666885863 +11111 201001 000000 281613 26731 3711083350 8000179750 0185/ 3118/ 112447865917 022145344610 107435220803 +11111 201001 000000 071709 26151 4043036150 7620068050 0248/ 2417/ 118798737186 000534235495 118615910088 +11111 201001 000000 051632 28111 3217042550 5000066150 0350/ 3555/ 003590034578 023803544329 111165607124 +11111 201001 000000 201730 30631 2745104550 5790220450 0195/ 1310/ 014773321850 111768769617 118653400940 +11111 201001 000000 301684 27331 4767066750 5950083250 0502/ 2676/ 111727010619 010455564137 121367744783 +11111 201001 000000 271768 27991 4093072150 8210144550 0219/ 1833/ 104337225045 114264643571 122123828195 +11111 201001 000000 081750 25821 5343083350 1170018260 0177/ 2180/ 116215657216 108570148590 119295081535 +99999 +HIUS1 KJPL 010002 +TENET +43279 0130/ 282407 IISC 001337953151 006070394614 001427788562 +11111 201001 000000 280091 27681 2925065650 5280118450 0270/ 2358/ 112447865917 022145344610 107435220803 +11111 201001 000000 050089 28201 1945137550 2720192350 0416/ 1857/ 003590034578 023803544329 111165607124 +11111 201001 000000 120190 28601 1642170150 3040315050 0257/ 0287/ 012271346259 009418316979 021377484549 +11111 201001 000000 190182 27781 2748068350 5030125050 0263/ 3203/ 110120088925 015058516557 019083243385 +11111 201001 000000 020145 28381 1790117250 2000130950 0615/ 0405/ 011250546456 020616801792 013074719828 +11111 201001 000000 240126 28761 0647104850 1000162050 0353/ 0937/ 022067881927 014762014731 003189261196 +11111 201001 000000 060175 28061 1251081950 1900124450 0363/ 3396/ 102839608687 016297527606 020822345043 +99999 +HIUS1 KJPL 010002 +TENET +71587 0476/ 052707 STJO 002612712457 103426913975 004686553728 +11111 201001 000000 220502 06241 3439062750 6260114150 0265/ 0631/ 112129062380 114736339377 018727403320 +11111 201001 000000 310478 05561 7049074150 7820082250 0624/ 0769/ 001707173343 117587766017 019632680518 +11111 201001 000000 290429 04341 4485090750 8830178650 0227/ 2391/ 026052853499 103562016877 003888966888 +11111 201001 000000 120523 04351 3569045150 6860086750 0239/ 3131/ 012271346259 009418316979 021377484549 +11111 201001 000000 250484 04941 6472054550 7450062850 0580/ 2947/ 015684634010 104098219502 020750406448 +11111 201001 000000 030540 06341 1853119550 4010258550 0183/ 0415/ 113829829155 106584240923 021626827524 +11111 201001 000000 260410 05841 8896146950 1706028260 0240/ 1454/ 004704464206 126007823203 100105659075 +99999 +HIUS1 KJPL 010002 +TENET +11418 0499/ 345207 GOPE 004075711665 000931883963 004801363832 +11111 201001 000000 310546 00041 ////072650 ////161250 0171/ 0503/ 001707173343 117587766017 019632680518 +11111 201001 000000 290443 35081 2643084750 4150133050 0344/ 1500/ 026052853499 103562016877 003888966888 +11111 201001 000000 120496 34511 ////082050 ////087050 0691/ 2976/ 012271346259 009418316979 021377484549 +11111 201001 000000 020479 34011 2550076250 3800113550 0375/ 2597/ 011250546456 020616801792 013074719828 +11111 201001 000000 250495 34951 ////102950 ////110650 0670/ 0700/ 015684634010 104098219502 020750406448 +11111 201001 000000 240440 34331 3100035250 5020057050 0326/ 2096/ 022067881927 014762014731 003189261196 +11111 201001 000000 060531 33761 1040033250 1940061950 0253/ 3082/ 102839608687 016297527606 020822345043 +99999 +HIUS1 KJPL 010002 +TENET +78547 0178/ 064606 CRO1 002607808673 105488155295 001932651077 +11111 201001 000000 220240 07261 3837081150 8540180550 0170/ 0483/ 112129062380 114736339377 018727403320 +11111 201001 000000 310209 06611 5449056650 7160074450 0460/ 0238/ 001707173343 117587766017 019632680518 +11111 201001 000000 290172 05591 6946111450 1414022760 0212/ 2682/ 026052853499 103562016877 003888966888 +11111 201001 000000 250233 06001 7257037250 1349006960 0255/ 3232/ 015684634010 104098219502 020750406448 +11111 201001 000000 260160 06611 8852073150 1004008360 0597/ 1387/ 004704464206 126007823203 100105659075 +11111 201001 000000 100133 06431 8023051150 1152007360 0398/ 1843/ 011642585231 121599160673 109747247442 +99999 +HIUS1 KJPL 010002 +TENET +98431 0146/ 238906 PIMO 103186335916 005286694402 001601059844 +11111 201001 000000 280115 23911 1480007860 1847009760 0501/ 1768/ 112447865917 022145344610 107435220803 +11111 201001 000000 170166 23751 1323008660 1536009960 0571/ 3260/ 116353457832 014638871711 015357454224 +11111 201001 000000 190178 23871 1200008660 1520010960 0489/ 3563/ 110120088925 015058516557 019083243385 +11111 201001 000000 020181 24701 9218105650 1904021860 0205/ 0645/ 011250546456 020616801792 013074719828 +11111 201001 000000 060188 24061 1082007560 1585011060 0386/ 0202/ 102839608687 016297527606 020822345043 +11111 201001 000000 090134 23391 1752008660 2709013360 0353/ 2577/ 125427069453 007618409242 001104167821 +99999 +HIUS1 KJPL 010002 +TENET +67109 1190/ 312807 ABPO 004097277338 004429184768 102065647454 +11111 201001 000000 131228 31161 2885059650 3980082250 0425/ 1953/ 007025345077 013882442942 121666885863 +11111 201001 000000 051198 30951 3291054650 4180069350 0487/ 2532/ 003590034578 023803544329 111165607124 +11111 201001 000000 181239 31801 ////172250 ////317250 0260/ 1367/ 017746357803 101862900273 119701646745 +11111 201001 000000 151216 31481 2969071650 3780091150 0485/ 1456/ 017922004811 007367765425 118657795205 +11111 201001 000000 291149 32251 2769051250 6300116550 0159/ 0683/ 026052853499 103562016877 003888966888 +11111 201001 000000 021127 31091 3014039250 5340069450 0279/ 3438/ 011250546456 020616801792 013074719828 +11111 201001 000000 241164 31421 4786188050 5810228350 0526/ 0284/ 022067881927 014762014731 003189261196 +99999 +HIUS1 KJPL 010002 +TENET +14474 0427/ 341906 DUBR 004642073253 001393082763 004133088824 +11111 201001 000000 290372 34681 3952154150 5600218450 0407/ 1392/ 026052853499 103562016877 003888966888 +11111 201001 000000 120419 34181 3622172450 3950188150 0647/ 3212/ 012271346259 009418316979 021377484549 +11111 201001 000000 020401 33791 4792138250 6670192450 0419/ 2668/ 011250546456 020616801792 013074719828 +11111 201001 000000 250419 34571 0218169050 0250193650 0585/ 0513/ 015684634010 104098219502 020750406448 +11111 201001 000000 240370 34091 2531137250 3470188150 0429/ 2090/ 022067881927 014762014731 003189261196 +11111 201001 000000 060456 33441 2246096550 4530194650 0216/ 3115/ 102839608687 016297527606 020822345043 +99999 +HIUS1 KJPL 010002 +TENET +72971 0460/ 078107 ALGO 000918156901 104346202267 004561774229 +11111 201001 000000 220467 08341 4364141550 5840189450 0446/ 0733/ 112129062380 114736339377 018727403320 +11111 201001 000000 310460 07861 3262171950 3280172950 0836/ 0619/ 001707173343 117587766017 019632680518 +11111 201001 000000 120559 06441 0150086150 0380218550 0102/ 3247/ 012271346259 009418316979 021377484549 +11111 201001 000000 250481 07221 2470119450 3630175550 0383/ 3025/ 015684634010 104098219502 020750406448 +11111 201001 000000 010435 09531 5355093350 1329023260 0115/ 0944/ 121668459115 113982458807 006801961534 +11111 201001 000000 030494 08511 3283153850 5480256850 0310/ 0500/ 113829829155 106584240923 021626827524 +11111 201001 000000 260401 07841 5888154650 9640253150 0320/ 1777/ 004704464206 126007823203 100105659075 +99999 +HIUS1 KJPL 010002 +TENET +72789 0481/ 119707 BREW 102112073912 103705468736 004726622758 +11111 201001 000000 040470 12831 5983102850 9950170950 0312/ 0959/ 123536485470 102255894137 012144304217 +11111 201001 000000 220477 12061 6315078450 6400079550 0800/ 1146/ 112129062380 114736339377 018727403320 +11111 201001 000000 310484 11641 5546072150 6290081850 0597/ 2831/ 001707173343 117587766017 019632680518 +11111 201001 000000 250552 10691 4461073350 1030016960 0152/ 3174/ 015684634010 104098219502 020750406448 +11111 201001 000000 010446 12411 7079056050 1029008160 0390/ 1364/ 121668459115 113982458807 006801961534 +11111 201001 000000 030490 12251 4887087350 5490098050 0608/ 0598/ 113829829155 106584240923 021626827524 +11111 201001 000000 260410 11001 9344158750 2065035160 0173/ 2283/ 004704464206 126007823203 100105659075 +99999 +HIUS1 KJPL 010002 +TENET +71913 0588/ 094106 CHUR 100236448060 103307743146 005429850467 +11111 201001 000000 220577 09861 4897079750 5700092750 0568/ 1079/ 112129062380 114736339377 018727403320 +11111 201001 000000 310577 09301 3267082750 3380085550 0741/ 2122/ 001707173343 117587766017 019632680518 +11111 201001 000000 120671 08051 4534037050 1030008460 0160/ 3298/ 012271346259 009418316979 021377484549 +11111 201001 000000 250606 08481 2120058550 3250089750 0358/ 2974/ 015684634010 104098219502 020750406448 +11111 201001 000000 010536 10871 6151050450 1334010960 0182/ 1152/ 121668459115 113982458807 006801961534 +11111 201001 000000 030596 10041 4026097050 5120123450 0486/ 0703/ 113829829155 106584240923 021626827524 +99999 +HIUS1 KJPL 010002 +TENET +71936 0625/ 114508 YELL 101224502130 102689324414 005633443740 +11111 201001 000000 040598 12891 6078108850 1139020460 0251/ 1033/ 123536485470 102255894137 012144304217 +11111 201001 000000 220607 11661 5120074750 5610081850 0641/ 1473/ 112129062380 114736339377 018727403320 +11111 201001 000000 310613 11051 7151078850 8000088150 0613/ 2431/ 001707173343 117587766017 019632680518 +11111 201001 000000 120723 10331 6546047150 1512010960 0152/ 3417/ 012271346259 009418316979 021377484549 +11111 201001 000000 190693 13541 4801060750 1115014160 0149/ 0418/ 110120088925 015058516557 019083243385 +11111 201001 000000 250658 10151 5572067750 9800119150 0283/ 3071/ 015684634010 104098219502 020750406448 +11111 201001 000000 010563 12331 7610047750 1444009160 0245/ 1391/ 121668459115 113982458807 006801961534 +11111 201001 000000 030622 11901 6396088150 7140098350 0616/ 0923/ 113829829155 106584240923 021626827524 +99999 +HIUS1 KJPL 010002 +TENET +72289 0342/ 118208 JPLM 102493361145 104655320430 003565311685 +11111 201001 000000 040346 12561 9565058950 1639010160 0296/ 0822/ 123536485470 102255894137 012144304217 +11111 201001 000000 210253 11931 1385002560 2919005260 0195/ 1735/ 113641769971 120173542274 110268527561 +11111 201001 000000 110258 12471 1386002460 3112005560 0166/ 1436/ 122082213466 112371474293 107895730388 +11111 201001 000000 220350 11911 9411060150 9810062750 0724/ 0368/ 112129062380 114736339377 018727403320 +11111 201001 000000 310358 11551 7870055150 9510066650 0531/ 3092/ 001707173343 117587766017 019632680518 +11111 201001 000000 010324 12161 1063005860 1356007560 0483/ 1194/ 121668459115 113982458807 006801961534 +11111 201001 000000 030366 12081 7201058250 9190074350 0483/ 0396/ 113829829155 106584240923 021626827524 +11111 201001 000000 260301 11201 1237007760 2191013760 0279/ 2345/ 004704464206 126007823203 100105659075 +99999 +HIUS1 KJPL 010002 +TENET +00000 0489/ 125505 UCLU 102440747397 103416546655 004784932427 +11111 201001 000000 040475 13301 1019014860 1569022860 0355/ 1017/ 123536485470 102255894137 012144304217 +11111 201001 000000 220484 12591 7931098650 7980099250 0832/ 1473/ 112129062380 114736339377 018727403320 +11111 201001 000000 310493 12161 6495075750 7680089550 0552/ 2839/ 001707173343 117587766017 019632680518 +11111 201001 000000 010452 12901 6879056250 9670079150 0412/ 1450/ 121668459115 113982458807 006801961534 +11111 201001 000000 030496 12791 6302089450 6830096950 0656/ 0609/ 113829829155 106584240923 021626827524 +99999 diff --git a/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 b/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 new file mode 100644 index 00000000..57c6eb7b --- /dev/null +++ b/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:9da2f6483c88c371eb9aaba3ac6185aa3c4cbc4326de597141c1bf50c2b42664 +size 48635 From e8614b43f2fd8b306662827fbaeb0b7b6c11743b Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Tue, 19 Nov 2024 10:44:08 -0800 Subject: [PATCH 07/15] add the changes to converter keeping only slant and using generic epoch definition --- src/gnssro/gnss_tec_ground_based.py | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/src/gnssro/gnss_tec_ground_based.py b/src/gnssro/gnss_tec_ground_based.py index 7d2dc9c0..9c03db53 100755 --- a/src/gnssro/gnss_tec_ground_based.py +++ b/src/gnssro/gnss_tec_ground_based.py @@ -26,8 +26,7 @@ os.environ["TZ"] = "UTC" # these are the unique values in the raw input file -varDict = {'totalElectronContentVertical': ['totalElectronContentVertical', "integer", 'TECU'], - 'totalElectronContentSlant': ['totalElectronContentSlant', "integer", "TECU"], +varDict = {'totalElectronContent': ['totalElectronContent', "integer", 'TECU'], } # these are the MetaData common to each input @@ -45,7 +44,7 @@ ('zECEFPositionGNSS', 'float', 'GNSS transmitting satellite Earth Centered Earth Fixed Z-coordinate in meters'), ('latitudeIPP', 'float', 'latitude of Ionospheric Pierce Point in degrees_north'), ('longitudeIPP', 'float', 'longitude of Ionospheric Pierce Point in degrees_east'), - ('dateTime', 'long', 'seconds from epoch 01Jan1970'), + ('dateTime', 'long', iso8601_string), ('stationIdentifierWMO', 'integer', 'WMO assigned number for the site'), ('stationIdentifier', 'string', 'GNSS ground-based receiving station name'), ] @@ -144,7 +143,7 @@ def main(args): varAttrs[(key, metaDataName)]['_FillValue'] = missing_vals[dtype] # Set units and FillValue attributes for groups associated with observed variable. - for key in ['totalElectronContentSlant', 'totalElectronContentVertical']: + for key in varDict.keys(): variable = varDict[key][0] dtype = varDict[key][1] units = varDict[key][2] @@ -322,8 +321,7 @@ def populate_obsValue(line, local_data): local_data['longitudeIPP'] = np.append(local_data['longitudeIPP'], float(longitudeIPP)/100.) local_data['elevationAngleGNSS'] = np.append(local_data['elevationAngleGNSS'], float(elevationAngle.rstrip('/'))/10.) local_data['azimuthAngle'] = np.append(local_data['azimuthAngle'], float(azimuthAngle.rstrip('/'))/10.) - local_data['totalElectronContentVertical'] = np.append(local_data['totalElectronContentVertical'], int(vobs.lstrip('/'))) - local_data['totalElectronContentSlant'] = np.append(local_data['totalElectronContentSlant'], int(sobs.lstrip('/'))) + local_data['totalElectronContent'] = np.append(local_data['totalElectronContent'], int(sobs.lstrip('/'))) local_data['xECEFPositionGNSS'] = np.append(local_data['xECEFPositionGNSS'], xECEFPositionGNSS) local_data['yECEFPositionGNSS'] = np.append(local_data['yECEFPositionGNSS'], yECEFPositionGNSS) local_data['zECEFPositionGNSS'] = np.append(local_data['zECEFPositionGNSS'], zECEFPositionGNSS) From d5db5178d5c6131b1724f576850c381502630b41 Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Tue, 19 Nov 2024 13:38:49 -0800 Subject: [PATCH 08/15] add ground based decoder script to list in CMakeLists --- src/gnssro/CMakeLists.txt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/gnssro/CMakeLists.txt b/src/gnssro/CMakeLists.txt index 77dda978..899fcfd5 100644 --- a/src/gnssro/CMakeLists.txt +++ b/src/gnssro/CMakeLists.txt @@ -14,9 +14,10 @@ ecbuild_add_executable( TARGET gnssro_gsidiag2ioda # config for scripts list(APPEND scripts - gnssro_bufr2ioda.py + gnss_tec_ground_based.py gnssaro_netcdf2ioda.py gnssro_AWSopendataNetcdf2ioda.py + gnssro_bufr2ioda.py ) file( RELATIVE_PATH SCRIPT_LIB_PATH ${CMAKE_BINARY_DIR}/bin ${PYIODACONV_BUILD_LIBDIR} ) From 841f298781416178ca45fcab3a2c4f9c6a8374bb Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Tue, 19 Nov 2024 15:06:18 -0800 Subject: [PATCH 09/15] add input and output to lists in CMakeLists --- test/CMakeLists.txt | 2 ++ 1 file changed, 2 insertions(+) diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index 63884341..fe229a11 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -99,6 +99,7 @@ list( APPEND test_input testinput/madis_2021010100.nc testinput/gpm_dpr_20240401-S105223-E122536.sample.hdf5 testinput/Pandora57s1_BoulderCO_L2_rnvs3p1-8.txt + testinput/tec_groundBased_TENET_20201001T00Z.tec ) list( APPEND test_output @@ -191,6 +192,7 @@ list( APPEND test_output testoutput/madis_snod_2021010100.nc testoutput/20240401T105230_PT1M_dpr_gpm.nc testoutput/Pandora57s1_BoulderCO_L2_rnvs3p1-8.nc + testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 ) if( iodaconv_gnssro_ENABLED ) From 9be98a9c21641629d3287cc60bc0e0133ce17054 Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Tue, 19 Nov 2024 16:07:46 -0800 Subject: [PATCH 10/15] fix coding norm issue --- src/gnssro/gnss_tec_ground_based.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/gnssro/gnss_tec_ground_based.py b/src/gnssro/gnss_tec_ground_based.py index 9c03db53..4ffac09b 100755 --- a/src/gnssro/gnss_tec_ground_based.py +++ b/src/gnssro/gnss_tec_ground_based.py @@ -26,7 +26,8 @@ os.environ["TZ"] = "UTC" # these are the unique values in the raw input file -varDict = {'totalElectronContent': ['totalElectronContent', "integer", 'TECU'], +varDict = { + 'totalElectronContent': ['totalElectronContent', "integer", 'TECU'], } # these are the MetaData common to each input From 8c97c48db193567775d51ba1b74485dd68cf638e Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Tue, 19 Nov 2024 16:10:58 -0800 Subject: [PATCH 11/15] update sourceFiles attribute for testoutput --- test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 b/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 index 57c6eb7b..c871b5c6 100644 --- a/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 +++ b/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:9da2f6483c88c371eb9aaba3ac6185aa3c4cbc4326de597141c1bf50c2b42664 +oid sha256:6fe7c277b7623df9a2710c0a4bb066d79d3b27e13030566d110749e9920eff49 size 48635 From cbb0088acbb67eac7a7ba6f1842f1e56b4e59231 Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Mon, 2 Dec 2024 15:53:15 -0800 Subject: [PATCH 12/15] update metaData names to IODA conventions --- src/gnssro/gnss_tec_ground_based.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/gnssro/gnss_tec_ground_based.py b/src/gnssro/gnss_tec_ground_based.py index 4ffac09b..a9843076 100755 --- a/src/gnssro/gnss_tec_ground_based.py +++ b/src/gnssro/gnss_tec_ground_based.py @@ -34,9 +34,9 @@ locationKeyList = [ ('latitude', 'float', 'degrees_north'), ('longitude', 'float', 'degrees_east'), - ('pseudoRandomNoiseCode', 'integer', 'GNSS transmitter pseudoRandomNoise PRN code'), + ('satelliteTransmitterId', 'integer', 'GNSS transmitter ID constellation pseudoRandomNoise PRN code'), ('elevationAngleGNSS', 'float', 'GNSS transmitter satellite elevation angle in degrees'), - ('azimuthAngle', 'float', 'aziumuth angle viewing GNSS transmitter in degrees west'), + ('sensorAzimuthAngle', 'float', 'aziumuth angle viewing GNSS transmitter in degrees west'), ('xECEFPosition', 'float', 'receiving station Earth Centered Earth Fixed X-coordinate in meters'), ('yECEFPosition', 'float', 'receiving station Earth Centered Earth Fixed Y-coordinate in meters'), ('zECEFPosition', 'float', 'receiving station Earth Centered Earth Fixed Z-coordinate in meters'), @@ -317,11 +317,11 @@ def populate_obsValue(line, local_data): try: local_data['dateTime'] = np.append(local_data['dateTime'], dateTime) - local_data['pseudoRandomNoiseCode'] = np.append(local_data['pseudoRandomNoiseCode'], PRN) + local_data['satelliteTransmitterId'] = np.append(local_data['satelliteTransmitterId'], PRN) local_data['latitudeIPP'] = np.append(local_data['latitudeIPP'], latitudeIPP) local_data['longitudeIPP'] = np.append(local_data['longitudeIPP'], float(longitudeIPP)/100.) local_data['elevationAngleGNSS'] = np.append(local_data['elevationAngleGNSS'], float(elevationAngle.rstrip('/'))/10.) - local_data['azimuthAngle'] = np.append(local_data['azimuthAngle'], float(azimuthAngle.rstrip('/'))/10.) + local_data['sensorAzimuthAngle'] = np.append(local_data['sensorAzimuthAngle'], float(azimuthAngle.rstrip('/'))/10.) local_data['totalElectronContent'] = np.append(local_data['totalElectronContent'], int(sobs.lstrip('/'))) local_data['xECEFPositionGNSS'] = np.append(local_data['xECEFPositionGNSS'], xECEFPositionGNSS) local_data['yECEFPositionGNSS'] = np.append(local_data['yECEFPositionGNSS'], yECEFPositionGNSS) From e34e69488ca82fa7537b84fa61d5dd9917f516be Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Mon, 2 Dec 2024 16:00:08 -0800 Subject: [PATCH 13/15] update the testoutput with new metaData names --- test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 b/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 index c871b5c6..e5e1bbf6 100644 --- a/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 +++ b/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:6fe7c277b7623df9a2710c0a4bb066d79d3b27e13030566d110749e9920eff49 +oid sha256:d3f9698dbb29dcfe52ebb22f7b3bae0a668e090068b3babf74031dab0c498d7c size 48635 From 64b8179c55d5c3d095d1c78fc950fc0dcf2df2a4 Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Fri, 6 Dec 2024 17:42:28 -0800 Subject: [PATCH 14/15] trigger CI From 7b0569e84569787c5e94d36b950cd3ac688a9f58 Mon Sep 17 00:00:00 2001 From: BenjaminRuston Date: Tue, 10 Dec 2024 09:06:52 -0800 Subject: [PATCH 15/15] add observation to ObsValue and out of MetaData add an error estimate --- src/gnssro/gnss_tec_ground_based.py | 13 +++++++------ .../obs.20201001T000000Z_PT1M_tec_groundbased.nc4 | 4 ++-- 2 files changed, 9 insertions(+), 8 deletions(-) diff --git a/src/gnssro/gnss_tec_ground_based.py b/src/gnssro/gnss_tec_ground_based.py index a9843076..9d2c18d8 100755 --- a/src/gnssro/gnss_tec_ground_based.py +++ b/src/gnssro/gnss_tec_ground_based.py @@ -135,7 +135,7 @@ def main(args): varAttrs[(key, metaDataName)]['units'] = locationKeyList[meta_keys.index(key)][2] varAttrs[(key, metaDataName)]['_FillValue'] = missing_vals[dtype] for key in varDict.keys(): - if 'electronDensity' in key: + if 'totalElectronContent' in key: continue dtype = varDict[key][1] units = varDict[key][2] @@ -167,16 +167,17 @@ def main(args): for key in varDict.keys(): variable = varDict[key][0] dtype = varDict[key][1] - if 'electronDensity' not in key and 'criticalFrequency' not in key: + if 'totalElectronContent' not in key: logging.info(f" the variable: {variable} will be placed into MetaData of ioda_data") # these MetaData are arrays nlocs long already ioda_data[(key, metaDataName)] = np.array(data[variable], dtype=dtypes[dtype]) - elif 'Confidence' not in key: - # (electronDensityConfidence) is used as the ObsError + else: + # what should be used as ObsError (10% or a fixed value) variable = varDict[key][0] logging.info(f" the variable: {variable} will be placed into ObsValue of ioda_data") ioda_data[(variable, obsValName)] = np.array(data[variable], dtype=np.float32) - ioda_data[(variable, obsErrName)] = np.array(data[variable+'Confidence'], dtype=np.float32) + ioda_data[(variable, obsErrName)] = np.array(data[variable]*0.1, dtype=np.float32) + # ioda_data[(variable, obsErrName)] = np.full((nlocs), errValue, dtype=np.float32) qc_array_hack = apply_gross_quality_control(data, qc_strict=args.qc_strict) ioda_data[(variable, qcName)] = np.array(qc_array_hack, dtype=np.int32) # how to interpret AQI ? @@ -406,7 +407,7 @@ def apply_gross_quality_control(data, qc_strict=False): # apply using simple physical reality check on variables # initialize returned variable - qc_array_hack = np.zeros_like(data['electronDensity'], dtype=np.int32) + qc_array_hack = np.zeros_like(data['totalElectronContent'], dtype=np.int32) # is requested apply check if qc_strict: qc_array_hack = np.where( diff --git a/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 b/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 index e5e1bbf6..39e66013 100644 --- a/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 +++ b/test/testoutput/obs.20201001T000000Z_PT1M_tec_groundbased.nc4 @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:d3f9698dbb29dcfe52ebb22f7b3bae0a668e090068b3babf74031dab0c498d7c -size 48635 +oid sha256:8be87e5341cc584449f55623ba1a9f9baf1ec065fb8ed3562fcd9104fba6169b +size 53299