All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.ab0oo.aprs.parser.Utilities Maven / Gradle / Ivy

Go to download

A complete encoder/decoder library for on-air packets used with the Amateur Packet Reporting System, a tactical command and control system used by Amateur Radio operators

There is a newer version: 3.0.6
Show newest version
/*
 * AVRS - http://avrs.sourceforge.net/
 *
 * Copyright (C) 2011 John Gorkos, AB0OO
 *
 * AVRS is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published
 * by the Free Software Foundation; either version 2 of the License,
 * or (at your option) any later version.
 *
 * AVRS is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with AVRS; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
 * USA
 */
package net.ab0oo.aprs.parser;

/**
 * @author johng
 * 
 */
public class Utilities {
	
	/** 
	 * @param args
	 */
	public static void main(String[] args) {
		if (args.length == 0) {
			System.out.println("Usage:  AprsPass ");
			System.exit(1);
		}
	}

	
	/** 
	 * @param callSign
	 * @return int
	 */
	public static int doHash(String callSign) {
		short kKey = 0x73e2; // Straight from Steme Dimse himself
		if (callSign.indexOf('-') > 0) {
			callSign = callSign.substring(0, callSign.indexOf('-'));
		}
		callSign = callSign.toUpperCase();
		short i = 0;
		int hash = kKey;
		int len = callSign.length();
		while (i < len) {
			hash ^= callSign.charAt(i) << 8;
			if (i + 1 < len) {
				hash ^= callSign.charAt(i + 1);
			}
			i += 2;
		}
		int code = hash & 0x7FFF;
		return code;
	}
	
	
	/** 
	 * @param knots
	 * @return int
	 */
	public static int ktsToMph(int knots) {
		return (int)Math.round(knots * 1.15077945);
	}
	
	
	/** 
	 * @param knots
	 * @return int
	 */
	public static int kntsToKmh(int knots) {
		return (int)Math.round(knots*1.852);
	}
	
	
	/** 
	 * @param meters
	 * @return double
	 */
	public static double metersToMiles(double meters) {
		return meters * 0.000621371192;
	}
	
	
	/** 
	 * @param meters
	 * @return double
	 */
	public static double metersToKilometers(double meters) {
		return meters / 1000.0;
	}
	
	
	/** 
	 * @param degrees
	 * @return String
	 */
	public static String degressToCardinal(double degrees) {
		if ( degrees >= 11.25 && degrees < 33.75 ) return "NNE";
		if ( degrees >= 33.75 && degrees < 56.25 ) return "NE";
		if ( degrees >= 56.25 && degrees < 78.25 ) return "ENE";
		if ( degrees >= 78.25 && degrees < 101.25 ) return "E";
		if ( degrees >= 101.25 && degrees < 123.75 ) return "ESE";
		if ( degrees >= 123.75 && degrees < 146.25 ) return "SE";
		if ( degrees >= 146.25 && degrees < 168.75 ) return "SSE";
		if ( degrees >= 168.75 && degrees < 191.25 ) return "S";
		if ( degrees >= 191.25 && degrees < 213.75 ) return "SSW";
		if ( degrees >= 213.75 && degrees < 236.25 ) return "SW";
		if ( degrees >= 236.25 && degrees < 258.75 ) return "WSW";
		if ( degrees >= 258.75 && degrees < 281.25 ) return "W";
		if ( degrees >= 281.25 && degrees < 303.75 ) return "WNW";
		if ( degrees >= 303.75 && degrees < 326.25 ) return "NW";
		if ( degrees >= 326.25 && degrees < 348.75 ) return "NNW";
		return "N";
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy