/**
* Copyright (C) 2008 - 2014 52°North Initiative for Geospatial Open Source
* Software GmbH
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 as published
* by the Free Software Foundation.
*
* If the program is linked with libraries which are licensed under one of
* the following licenses, the combination of the program with the linked
* library is not considered a "derivative work" of the program:
*
* - Apache License, version 2.0
* - Apache Software License, version 1.0
* - GNU Lesser General Public License, version 3
* - Mozilla Public License, versions 1.0, 1.1 and 2.0
* - Common Development and Distribution License (CDDL), version 1.0
*
* Therefore the distribution of the program linked with libraries licensed
* under the aforementioned licenses, is permitted by the copyright holders
* if the distribution is compliant with both the GNU General Public
* icense version 2 and the aforementioned licenses.
*
* This program 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.
*/
package org.n52.ses.api;
import org.n52.oxf.conversion.unit.NumberWithUOM;
import org.n52.oxf.conversion.unit.ucum.UCUMTools.UnitConversionFailedException;
/**
*
* @author Matthes Rieke <m.rieke@uni-muenster.de>
*
*/
public interface IUnitConverter {
/**
* Converts the given value to its base units and returns the new
* ucum-expression (result[0]) and the converted value (result[1]).
* Should be called for each subscription.
*
* @param unitString UCUM code
* @param value numerical value of the property
*
* @return the new ucum-expression (result[0]) and the converted value (result[1])
*
*/
public abstract NumberWithUOM convert(String unitString, double value);
/**
* Used to convert a value from the given unit to the first
* registered compatible unit, using UCUM. returns the new
* ucum-expression (result[0]) and the converted value (result[1]).
* Should be called for every incoming sensor data.
*
* @param unitString UCUM code of the unit
* @param phenomenon the phenomenon
* @param value the numerical value
* @return the new ucum-expression (result[0]) and the converted value (result[1])
* @throws UnitConversionFailedException if there is no valid conversion defined
*/
public abstract NumberWithUOM convert(String unitString, String phenomenon, double value)
throws UnitConversionFailedException;
/**
* Used to register a new Unit with a phenomenon. The unit
* is converted to its base units (SI).
* Should be called for each PublisherRegistration (new sensor) request.
*
* @param unitString the UCUM code
* @param phenomenon the phenomenon
*
* @return false If the phenomenon is already registered and is compatible.
* @throws UnitConversionFailedException if there is no valid conversion defined
*/
public abstract boolean registerNewUnit(String unitString, String phenomenon)
throws UnitConversionFailedException;
/**
* Used to check if the phenomenon is compatible with a possibly registered one.
* Should be called for each subscription.
*
* ATTENTION: Do not use this method to check if two units are compatible! Use isCompatible intead!
*
* @param unitString the UCUM code
* @param phenomenon the phenomenon
*
* @return true if units are compatible or phenomenon was not registered previously
* (subscribing should continue normally). false if units are not compatible.
*/
public abstract boolean isCompatibleWithPhenomenon(String unitString, String phenomenon);
/**
* Checks if two known units are compatible (i.e. rely on the same SI units).
*
* @param unitString1 first UCUM code
* @param unitString2 second UCUM code
* @return <code>true</code> if they are compatible, <code>false</code> else or in error cases
*/
public abstract boolean isCompatible(String unitString1, String unitString2);
}