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

com.obdobion.algebrain.function.FuncTieredRate Maven / Gradle / Ivy

package com.obdobion.algebrain.function;

import java.text.ParseException;
import java.util.Enumeration;
import java.util.Hashtable;

import com.obdobion.algebrain.Function;
import com.obdobion.algebrain.ValueStack;
import com.obdobion.algebrain.support.EquationSupport;
import com.obdobion.algebrain.token.TokVariable;

/**
 * @author Chris DeGreef
 *
 */
public class FuncTieredRate extends Function
{
    public FuncTieredRate()
    {
        super();
    }

    public FuncTieredRate(final TokVariable var)
    {
        super(var);
    }

    @Override
    public void resolve (final ValueStack values) throws Exception
    {
        if (values.size() < 2)
            throw new Exception("missing operands for " + toString());

        try
        {
            final String tableName = values.popString();
            final Double baseAmount = values.popDouble();

            if (baseAmount.doubleValue() == 0)
            {
                values.push(new Double(0D));
                return;
            }

            final EquationSupport model = getEqu().getSupport();

            final Hashtable rateTable = model.resolveRate(tableName, getEqu().getBaseDate(), baseAmount
                    .doubleValue());
            double blendedRate = 0;
            double previousLimit = 0;
            double previousRate = 0;

            /*
             * only the last key in the table is used for tiered rates
             */
            for (final Enumeration limits = rateTable.keys(); limits.hasMoreElements();)
            {
                final Double limit = limits.nextElement();
                final Double rate = rateTable.get(limit);

                if (previousRate > 0)
                    blendedRate += (previousRate * ((limit.doubleValue() - previousLimit) / baseAmount.doubleValue()));

                previousRate = rate.doubleValue();
                previousLimit = limit.doubleValue();
            }

            if (previousRate > 0)
                blendedRate += (previousRate * ((baseAmount.doubleValue() - previousLimit) / baseAmount.doubleValue()));

            values.push(new Double(blendedRate));
        } catch (final ParseException e)
        {
            e.fillInStackTrace();
            throw new Exception(toString() + "; " + e.getMessage(), e);
        }
    }

    @Override
    public String toString ()
    {
        return "function(tieredrate)";
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy