welcome to xlongwei.com

欢迎大家一起学习、交流、分享


QQ群:162333776 邮箱:admin@xlongwei.com

利用“计算器”和公式做房贷计算


分类 Java   关键字 分享   标签 java   发布 hongwei  1541767215959
注意 转载须保留原文链接,译文链接,作者译者等信息。  

等额本息公式还是挺复杂的,忽然想起以前写了一个“计算器”,因而就想顺手把房贷利息计算给做了,还加上了提供月供计算利率的功能。


下图就是计算器的界面,支持:进制转换、四则运算、常用函数

image


下图就是房贷公式


有了以上两个工具,等额本息就比较简单了,等额本金则更为简单。

变量定义:A借款本金,B月利率,M期数,X月供;

月供计算:使用了临时变量T=(1+B)^M,然后再计算月供X=A*(B*T)/(T-1)

利息计算:由于难以反推B月利率的计算公式,因此使用了直观的反复试错法,即多次计算月供直到结果与提供的月供极为接近,此时的B月利率就非常接近真实值

String T; // (1+B)^M
if(StringUtil.hasLength(B)) {
	T = NumberUtil.parseExp("(1+"+B+")^"+M);
	X = NumberUtil.parseExp(A+"*("+B+"*"+T+")/("+T+"-1)");
}else {
	double BL = 0.000001, BH = 0.999999, BT = 0.0, XT = Double.parseDouble(X), XI = 0.0;
	if(XT*Integer.parseInt(M) < Double.parseDouble(A)) return null; //不够本金,何谈利息
	do {
		BT = (BL+BH)/2.0; //寻找B月利率
		T = NumberUtil.parseExp("(1+"+BT+")^"+M);
		XI = Double.parseDouble(NumberUtil.parseExp(A+"*("+BT+"*"+T+")/("+T+"-1)"));
		if(Math.abs(XI-XT)<0.1) break;  //1毛以内即可接受结果
		if(XI>XT) BH = BT;
		else BL = BT;
	}while(true);
}


房贷计算接口