欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

P2P利息计算工具

程序员文章站 2022-07-01 10:54:10
...
/**
 * 计算器。
 *
 * <p>
 *     用于计算投资相关的积分,本金利息等。
 * </p>
 *
 * 
 */
public final class Calculator {

    /**
     * 计算一次性还款按天计息的利息。
     *
     * <p>
     *     OOBD=ONCE_OFF_BY_DAY,参照{@link RepaymentType#ONCE_OFF_BY_DAY}。
     * </p>
     *
     * @param amount        投资金额。
     * @param rateOfDay    项目(天)利率。
     * @param days          项目期限(天数)。
     * @return 利息值。
     */
    public static BigDecimal calculateInterestWithOOBDBy(BigDecimal amount, BigDecimal rateOfDay, int days) {
        return amount.multiply(rateOfDay).multiply(new BigDecimal(days)).divide(new BigDecimal("100"), 2, BigDecimal.ROUND_HALF_EVEN);
    }

    /**
     * 计算按月还款的分期利息。
     *
     * @param amount        投资金额。
     * @param rateOfYear    项目年利率。
     * @param term          项目期限。
     * @param sequence      当前期数。
     * @return 利息值。
     */
    public static BigDecimal calculateInterestForMonthBy(BigDecimal amount, BigDecimal rateOfYear, int term, int sequence) {
        BigDecimal monthRate = getRateOfMonth(rateOfYear);
        BigDecimal pow1 = BigDecimal.valueOf(Math.pow(BigDecimal.ONE.add(monthRate).doubleValue(), term));
        BigDecimal pow2 = BigDecimal.valueOf(Math.pow(BigDecimal.ONE.add(monthRate).doubleValue(), sequence - 1));

        return amount.multiply(monthRate).multiply(pow1.subtract(pow2)).divide(pow1.subtract(BigDecimal.ONE), 2, BigDecimal.ROUND_HALF_EVEN);
    }

    /**
     * 计算按月还款的分期本金。
     *
     * @param amount        投资金额。
     * @param rateOfYear    项目年利率。
     * @param term          项目期限。
     * @return 利息值。
     */
    public static BigDecimal calculateCapitalForMonthBy(BigDecimal amount, BigDecimal rateOfYear, int term) {
        BigDecimal monthRate = getRateOfMonth(rateOfYear);
        BigDecimal pow = BigDecimal.valueOf(Math.pow(BigDecimal.ONE.add(monthRate).doubleValue(), term));

        return amount.multiply(monthRate).multiply(pow).divide(pow.subtract(BigDecimal.ONE), 2, BigDecimal.ROUND_HALF_EVEN);
    }

    /**
     * 计算借款手续费。
     *
     * @param repaymentType 还款方式。
     * @param limitCategory 额度类型。
     * @param subjectAmount 项目金额。
     * @param term          项目期限。
     * @return 借款手续费。
     */
    public static BigDecimal calculateCommissionChargeBy(int repaymentType, int limitCategory, BigDecimal subjectAmount, int term) {
        BigDecimal poundageAmount = BigDecimal.ZERO;
        if (repaymentType == RepaymentType.ONCE_OFF_BY_DAY.getType()) { //天标借款天数不足5天按5天计算。
            poundageAmount = subjectAmount.multiply(new BigDecimal(term <= 5 ? 5 : term)).divide(new BigDecimal("10000"), 2, BigDecimal.ROUND_HALF_EVEN);
        } else {
            BigDecimal loanRate = new BigDecimal("0.005");
            if (limitCategory == LimitCategory.NET_VALUE.getType()) {   //净值。
                loanRate = new BigDecimal("0.00175");
            } else if (limitCategory == LimitCategory.ASSETS_LIMIT.getType()) { // 资产标
                loanRate = new BigDecimal("0.0025");
            }

            poundageAmount = subjectAmount.multiply(new BigDecimal(term)).multiply(loanRate).setScale(2, BigDecimal.ROUND_HALF_EVEN);
        }
        return poundageAmount;
    }

    /**
     * 根据年化利率(百分比)获取月化利率,保留7位小数位。
     *
     * @param rateOfYear 年化利率(百分比)。
     * @return 月化利率。
     */
    public static BigDecimal getRateOfMonth(BigDecimal rateOfYear) {
        return rateOfYear.multiply(new BigDecimal("0.01")).divide(new BigDecimal("12"), 7, BigDecimal.ROUND_HALF_EVEN);
    }

    /**
     * 根据年化利率(百分比)获取月化利率,保留7位小数位。
     *
     * @param rateOfYear 年化利率(百分比)。
     * @return 月化利率。
     */
    public static BigDecimal getRateOfDay(BigDecimal rateOfYear) {
        return rateOfYear.multiply(new BigDecimal("0.01")).divide(new BigDecimal("365"), 7, BigDecimal.ROUND_HALF_EVEN);
    }
}

 

相关标签: 利息