From 402389dd64c7f05356d26b5720fcdb5634350ad3 Mon Sep 17 00:00:00 2001 From: Adam Theisen Date: Fri, 17 Nov 2023 16:39:23 -0600 Subject: [PATCH] ENH: Fix to resolve #750 for older ARM qc convention in files (#755) * ENH: Fix to resolve #750 for older ARM qc convention in files * ENH: Adding in tesets * ENH: Streamlining code --- act/qc/clean.py | 31 +++++++++++++++++- act/tests/__init__.py | 1 + .../data/sgp30ecorE6.b1.20040705.000000.cdf | Bin 0 -> 41984 bytes act/tests/sample_files.py | 1 + act/tests/test_qc.py | 11 ++++++- 5 files changed, 42 insertions(+), 2 deletions(-) create mode 100644 act/tests/data/sgp30ecorE6.b1.20040705.000000.cdf diff --git a/act/qc/clean.py b/act/qc/clean.py index e1a7813e58..90f574305b 100644 --- a/act/qc/clean.py +++ b/act/qc/clean.py @@ -425,6 +425,36 @@ def get_attr_info(self, variable=None, flag=False): # If nothing to return set to None return_dict = None + # If no QC is found but there's a Mentor_QC_Field_Information global attribute, + # hard code the information. This is for older ARM files that had QC information + # in this global attribute. For these cases, this should hold 100% + if return_dict is None and 'Mentor_QC_Field_Information' in self._ds.attrs: + qc_att = self._ds.attrs['Mentor_QC_Field_Information'] + if 'Basic mentor QC checks' in qc_att: + if len(qc_att) == 920 or len(qc_att) == 1562: + return_dict = dict() + return_dict['flag_meanings'] = [ + 'Value is equal to missing_value.', + 'Value is less than the valid_min.', + 'Value is greater than the valid_max.', + 'Difference between current and previous values exceeds valid_delta.' + ] + return_dict['flag_tests'] = [1, 2, 3, 4] + return_dict['flag_masks'] = [1, 2, 4, 8] + return_dict['flag_assessments'] = ['Bad', 'Bad', 'Bad', 'Indeterminate'] + return_dict['flag_values'] = [] + return_dict['flag_comments'] = [] + return_dict['arm_attributes'] = [ + 'bit_1_description', + 'bit_1_assessment', + 'bit_2_description', + 'bit_2_assessment', + 'bit_3_description', + 'bit_3_assessment', + 'bit_4_description', + 'bit_4_assessment' + ] + return return_dict def clean_arm_state_variables( @@ -643,7 +673,6 @@ def clean_arm_qc( 'flag_values', 'flag_comments', ]: - if qc_attributes is not None and len(qc_attributes[attr]) > 0: # Only add if attribute does not exists if attr in self._ds[qc_var].attrs.keys() is False: diff --git a/act/tests/__init__.py b/act/tests/__init__.py index 8cd9154ec4..9ae16bd6a3 100644 --- a/act/tests/__init__.py +++ b/act/tests/__init__.py @@ -60,6 +60,7 @@ 'EXAMPLE_SEBS', 'EXAMPLE_ENA_MET', 'EXAMPLE_CCN', + 'EXAMPLE_OLD_QC', ] }, ) diff --git a/act/tests/data/sgp30ecorE6.b1.20040705.000000.cdf b/act/tests/data/sgp30ecorE6.b1.20040705.000000.cdf new file mode 100644 index 0000000000000000000000000000000000000000..45c9a9285bb69c9db6e5aa7c0ec5de81881d151e GIT binary patch literal 41984 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 literal 0 HcmV?d00001 diff --git a/act/tests/sample_files.py b/act/tests/sample_files.py index 2193c416f6..3bdb501410 100644 --- a/act/tests/sample_files.py +++ b/act/tests/sample_files.py @@ -70,3 +70,4 @@ EXAMPLE_MFAS_SODAR = os.path.join(DATA_PATH, 'sodar.20230404.mnd') EXAMPLE_ENA_MET = os.path.join(DATA_PATH, 'enametC1.b1.20221109.000000.cdf') EXAMPLE_CCN = os.path.join(DATA_PATH, 'sgpaosccn2colaE13.b1.20170903.000000.nc') +EXAMPLE_OLD_QC = os.path.join(DATA_PATH, 'sgp30ecorE6.b1.20040705.000000.cdf') diff --git a/act/tests/test_qc.py b/act/tests/test_qc.py index bfeaaab667..4d505ddce2 100644 --- a/act/tests/test_qc.py +++ b/act/tests/test_qc.py @@ -21,7 +21,8 @@ EXAMPLE_IRT25m20s, EXAMPLE_BRS, EXAMPLE_MET_YAML, - EXAMPLE_ENA_MET + EXAMPLE_ENA_MET, + EXAMPLE_OLD_QC ) from act.qc.bsrn_tests import _calculate_solar_parameters from act.qc.add_supplemental_qc import read_yaml_supplemental_qc, apply_supplemental_qc @@ -1474,3 +1475,11 @@ def test_scalar_dqr(): assert np.size(ds['qc_lat'].values) == 1 assert np.size(ds['qc_alt'].values) == 1 assert np.size(ds['base_time'].values) == 1 + + +def test_get_attr_info(): + ds = read_netcdf(EXAMPLE_OLD_QC, cleanup_qc=True) + assert 'flag_assessments' in ds['qc_lv'].attrs + assert 'fail_min' in ds['qc_lv'].attrs + assert ds['qc_lv'].attrs['flag_assessments'][0] == 'Bad' + assert ds['qc_lv'].attrs['flag_masks'][-1] == 4