- 浏览: 357839 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (55)
- java基础 (18)
- oracle (13)
- PL/SQL (8)
- Hibernate (3)
- JDBC (1)
- JVM (1)
- Dump (1)
- windows (2)
- struts2 (2)
- SQL (3)
- OGNL (1)
- Web前端 (3)
- 开发工具 (4)
- weblogic (0)
- shell (0)
- linux (1)
- windows,项目实施 (0)
- eclipse (3)
- SVN (1)
- vmware (2)
- 虚拟机 (2)
- hadoop (0)
- Android (0)
- 大数据 (2)
- Jquery (3)
- js (5)
- js,ajax (4)
- CKeditor (1)
- HTML (1)
- mysql (0)
最新评论
-
alangxi:
非常详尽,非常感谢。
BigDecimal 使用方法详解 -
nich002:
内容很详尽。
BigDecimal 使用方法详解 -
nich002:
看着真蛋疼。
BigDecimal 使用方法详解 -
zhangyinhu8680:
jz20110918 写道想问问楼主,sqlserver的 S ...
Oracle SQL中实现indexOf和lastIndexOf功能,substr和instr用法 -
zhangyinhu8680:
数据库我只用过oracle,sqlServer我我没有接触过, ...
Oracle SQL中实现indexOf和lastIndexOf功能,substr和instr用法
/**
* 灰度预测模型
*
* @author Sean Chen
* @version 1.0 2012-12-6
*/
public class GrayModel {
private double a0, a1, a2;
private int size;
private double error;
public GrayModel() {
}
public void build(double[] x0) {
size = x0.length;
double[] x1 = new double[size];
x1[0] = x0[0];
for (int i = 1; i < size; i++) {
x1[i] = x0[i] + x1[i - 1];
}
double[][] b = new double[size - 1][2];
double[][] bt = new double[2][size - 1];
double[][] y = new double[size - 1][1];
for (int i = 0; i < b.length; i++) {
b[i][0] = -(x1[i] + x1[i + 1]) / 2;
b[i][1] = 1;
bt[0][i] = b[i][0];
bt[1][i] = 1;
y[i][0] = x0[i + 1];
}
double[][] t = new double[2][2];
multiply(bt, b, t);
t = inverse(t);
double[][] t1 = new double[2][size - 1];
multiply(t, bt, t1);
double[][] t2 = new double[2][1];
multiply(t1, y, t2);
a0 = t2[0][0];
double u = t2[1][0];
a2 = u / a0;
a1 = x0[0] - a2;
a0 = -a0;
error = 0;
for (int i = 0; i < x0.length; i++) {
double d = (x0[i] - getX0(i));
error += d * d;
}
error /= x0.length;
}
/**
* 误差
*
* @return
*/
public double getError() {
return error;
}
double getX1(int k) {
return a1 * Math.exp(a0 * k) + a2;
}
double getX0(int k) {
// return a0 * a1 * Math.exp(a0 * k);
if (k == 0)
return a1 * Math.exp(a0 * k) + a2;
else
return a1 * (Math.exp(a0 * k) - Math.exp(a0 * (k - 1)));
}
/**
* 预测后续的值
*
* @param index
* @return
*/
public double nextValue(int index) {
if (index < 0)
throw new IndexOutOfBoundsException();
return getX0(size + index);
}
/**
* 预测下一个值
*
* @return
*/
public double nextValue() {
return nextValue(0);
}
static double[][] inverse(double[][] t) {
double[][] a = new double[2][2];
double det = t[0][0] * t[1][1] - t[0][1] * t[1][0];
a[0][0] = t[1][1] / det;
a[0][1] = -t[1][0] / det;
a[1][0] = -t[0][1] / det;
a[1][1] = t[0][0] / det;
return a;
}
static void multiply(double[][] left, double[][] right, double[][] dest) {
int n1 = left.length;
int m1 = left[0].length;
int m2 = right[0].length;
for (int k = 0; k < n1; k++) {
for (int s = 0; s < m2; s++) {
dest[k][s] = 0;
for (int i = 0; i < m1; i++) {
dest[k][s] += left[k][i] * right[i][s];
}
}
}
}
public static void main(String[] args) {
GrayModel gs = new GrayModel();
// 函数 sin+cos
double[] y = new double[10];
double step = 0.001;
double x = 0.001;
for (int i = 0; i < y.length; i++) {
y[i] = Math.sin(x) + Math.cos(x);
x += step;
}
gs.build(y);
for (int i = 0; i < 5; i++) {
// 真实值与预测值的差值
System.out.println(Math.sin(x) + Math.cos(x) - gs.nextValue(i));
x += step;
}
System.out.println(Math.sqrt(gs.getError()));
}
}
文章转自 http://chen-yongkai.iteye.com/blog/1742805
* 灰度预测模型
*
* @author Sean Chen
* @version 1.0 2012-12-6
*/
public class GrayModel {
private double a0, a1, a2;
private int size;
private double error;
public GrayModel() {
}
public void build(double[] x0) {
size = x0.length;
double[] x1 = new double[size];
x1[0] = x0[0];
for (int i = 1; i < size; i++) {
x1[i] = x0[i] + x1[i - 1];
}
double[][] b = new double[size - 1][2];
double[][] bt = new double[2][size - 1];
double[][] y = new double[size - 1][1];
for (int i = 0; i < b.length; i++) {
b[i][0] = -(x1[i] + x1[i + 1]) / 2;
b[i][1] = 1;
bt[0][i] = b[i][0];
bt[1][i] = 1;
y[i][0] = x0[i + 1];
}
double[][] t = new double[2][2];
multiply(bt, b, t);
t = inverse(t);
double[][] t1 = new double[2][size - 1];
multiply(t, bt, t1);
double[][] t2 = new double[2][1];
multiply(t1, y, t2);
a0 = t2[0][0];
double u = t2[1][0];
a2 = u / a0;
a1 = x0[0] - a2;
a0 = -a0;
error = 0;
for (int i = 0; i < x0.length; i++) {
double d = (x0[i] - getX0(i));
error += d * d;
}
error /= x0.length;
}
/**
* 误差
*
* @return
*/
public double getError() {
return error;
}
double getX1(int k) {
return a1 * Math.exp(a0 * k) + a2;
}
double getX0(int k) {
// return a0 * a1 * Math.exp(a0 * k);
if (k == 0)
return a1 * Math.exp(a0 * k) + a2;
else
return a1 * (Math.exp(a0 * k) - Math.exp(a0 * (k - 1)));
}
/**
* 预测后续的值
*
* @param index
* @return
*/
public double nextValue(int index) {
if (index < 0)
throw new IndexOutOfBoundsException();
return getX0(size + index);
}
/**
* 预测下一个值
*
* @return
*/
public double nextValue() {
return nextValue(0);
}
static double[][] inverse(double[][] t) {
double[][] a = new double[2][2];
double det = t[0][0] * t[1][1] - t[0][1] * t[1][0];
a[0][0] = t[1][1] / det;
a[0][1] = -t[1][0] / det;
a[1][0] = -t[0][1] / det;
a[1][1] = t[0][0] / det;
return a;
}
static void multiply(double[][] left, double[][] right, double[][] dest) {
int n1 = left.length;
int m1 = left[0].length;
int m2 = right[0].length;
for (int k = 0; k < n1; k++) {
for (int s = 0; s < m2; s++) {
dest[k][s] = 0;
for (int i = 0; i < m1; i++) {
dest[k][s] += left[k][i] * right[i][s];
}
}
}
}
public static void main(String[] args) {
GrayModel gs = new GrayModel();
// 函数 sin+cos
double[] y = new double[10];
double step = 0.001;
double x = 0.001;
for (int i = 0; i < y.length; i++) {
y[i] = Math.sin(x) + Math.cos(x);
x += step;
}
gs.build(y);
for (int i = 0; i < 5; i++) {
// 真实值与预测值的差值
System.out.println(Math.sin(x) + Math.cos(x) - gs.nextValue(i));
x += step;
}
System.out.println(Math.sqrt(gs.getError()));
}
}
文章转自 http://chen-yongkai.iteye.com/blog/1742805
发表评论
-
Spring的作用域以及RequestContextListener作用
2015-09-28 11:01 0分类: spring 2013-01-28 09:54 114 ... -
如何在spring中获取request对象
2015-08-06 19:11 0如何在spring中获取request对象 2014-04-3 ... -
Oracle的rollup、cube、grouping sets函数
2015-06-17 11:22 4919文章转自 http://blog.csdn.net/huan ... -
Java 反射之私有字段和方法详细介绍
2015-02-16 16:31 1565尽管我们通常认为通过JAVA的反射机制来访问其它类的私有字段和 ... -
deleteCharAt()方法和delete()实例
2014-11-26 09:19 4409以下例子将告诉你如何使用 java.lang.StringBu ... -
Notepad++插件使用技巧,转自各方
2014-10-20 21:16 879http://www.360doc.com/content/1 ... -
JAVA中运用数组的四种排序方法
2014-03-20 10:03 0JAVA中在运用数组进行排序功能时,一般有四种方法:快速排 ... -
Hadoop使用技巧
2013-08-18 21:51 0http://blog.sina.com.cn/s/blog_ ... -
Hadoop 中利用 mapreduce 读写 mysql 数据
2013-08-18 21:34 0Hadoop 中利用 mapreduce 读写 mysql 数 ... -
ArrayUtils使用详解
2013-06-14 16:58 3649ArrayUtils 拥有以下方法: toString 将一 ... -
hibernate通过映射文件生成表结构
2013-05-12 14:38 0文章来自 http://dianziermu. ... -
log4j详解与实战
2013-03-20 13:57 857http://www.iteye.com/topic/3780 ... -
SVN更改用户
2013-01-08 14:39 1650由于在svn的界面中并没 ... -
在eclipse 设置编辑区、控制台、xml等文本文件字体大小
2012-12-30 19:32 9006eclipse 编辑区 设置字体大小: 窗口(Window) ... -
jfreechart
2012-09-06 10:32 0jfreechart -
获取java 处理时间的实现(具体代码)
2012-10-23 11:37 4654资料整合: (一).今天的日期,两天前的日期,三天后的日期 ... -
Eclipse中载入Java(JDK) 源代码 详解(实例说明)
2012-07-11 10:46 6832在Eclipse中,很多朋友遇到过这样的问题:开发过程中会经常 ... -
java中处理时间的系列代码明细
2012-06-23 09:04 1357Java代码 /** 日期类 * @date * ... -
OGNL表达式
2012-10-23 11:25 1768OGNL表达式(2011-12-30 10:50: ... -
Java常用类型转换
2012-05-21 16:20 2067(一)Integer类型 1).定义 Inte ...
相关推荐
本程序使用java实现灰色关联算法,计算灰色关联度,使用者可根据自身需要进行修改
代码 离散灰色预测模型和AR预测模型的组合 预测代码 离散灰色预测模型和AR预测模型的组合 预测代码 离散灰色预测模型和AR预测模型的组合 预测代码 离散灰色预测模型和AR预测模型的组合 预测代码 离散灰色预测模型和...
灰色预测matlab代码
灰色预测具体代码实现,含原始数据。本资源针对湖南省未来人口预测问题,给出了预测结果。
灰色马儿科夫算法的java实现,其中包含残差修正的代码,但是结果中并未使用残差修正,只用了马尔科夫链,使用者可以根据自己需要进行修改
灰色预测模型的原理、建模计算、检验和案例,帮助大家更好理解灰色预测模型建模使用。
灰色预测及其使用matlab实现灰色预测
快来下载吧, 灰色预测及其代码实现
灰色预测matlab实现
灰色预测模型的matlab源代码,可对一些线性变换的数据进行预测
灰色预测模型.ppt 灰色系统理论是研究解决灰色系统分析、建模、预测、决策和控制的理论.灰色预测是对灰色系统所做的预测.目前常用的一些预测方法(如回归分析等),需要较大的样本.若样本较小,常造成较大误差,使...
应用MATLAB软件进行灰色预测,此为相关代码,具有很好的学习价值。
灰色预测模型优秀论文41
灰色预测模型主要用于小样本的时间序列的样本外预测。
灰色预测主要用于样本量较少,具有一定趋势的时间序列数据预测,文件是TXT格式,里面包含了灰色预测G(1,1)R语言代码,有详细代码和解释。
灰色预测的MATLAB代码实现,包含详细注释,并且附带文档描述对灰色预测的一些个人理解,理解起来相对容易些。
是有关于灰色模型的课题,里面讲到了很多关于灰色模型的知识,以及预测方法,可以帮助大家了解和学习
灰色预测算法可用于少量数据的单调线性预测,将matlab代码导出为jar,直接导入Yuce.jar即可使用
其中包含了一个关于利用灰色预测模型进行预测的案例,稍作修改可用于其它问题的预测