001/* 002 * This file is part of McIDAS-V 003 * 004 * Copyright 2007-2024 005 * Space Science and Engineering Center (SSEC) 006 * University of Wisconsin - Madison 007 * 1225 W. Dayton Street, Madison, WI 53706, USA 008 * https://www.ssec.wisc.edu/mcidas/ 009 * 010 * All Rights Reserved 011 * 012 * McIDAS-V is built on Unidata's IDV and SSEC's VisAD libraries, and 013 * some McIDAS-V source code is based on IDV and VisAD source code. 014 * 015 * McIDAS-V is free software; you can redistribute it and/or modify 016 * it under the terms of the GNU Lesser Public License as published by 017 * the Free Software Foundation; either version 3 of the License, or 018 * (at your option) any later version. 019 * 020 * McIDAS-V is distributed in the hope that it will be useful, 021 * but WITHOUT ANY WARRANTY; without even the implied warranty of 022 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 023 * GNU Lesser Public License for more details. 024 * 025 * You should have received a copy of the GNU Lesser Public License 026 * along with this program. If not, see https://www.gnu.org/licenses/. 027 */ 028 029package edu.wisc.ssec.mcidasv.data.hydra; 030 031import java.util.Map; 032 033public class IASI_RangeProcessor extends RangeProcessor { 034 035 public IASI_RangeProcessor() throws Exception { 036 super(); 037 } 038 039 public float[] processRange(short[] values, Map<String, double[]> subset) { 040 int channelIndex = (int) (subset.get(SpectrumAdapter.channelIndex_name))[0]; 041 042 float[] new_values = IASI_L1C_Utility.getDecodedIASIImage(values, null, channelIndex); 043 double[] track_coords = subset.get(SwathAdapter.track_name); 044 int numLines = ((int) (track_coords[1] - track_coords[0]) + 1); 045 new_values = IASI_L1C_Utility.psuedoScanReorder2(new_values, 60, numLines * 2); 046 047 // - subset here, if necessary 048 return new_values; 049 } 050 051}