Ở đây có 4 file, chúng ta sẽ mở lần lượt từng file một để ghi thông tin vào
chúng. Những thông tin chúng ta ghi sẽ được hiển thị ở phần help của package và
các hàm của nó sau khi package được xây dựng xong. Click vào tên của file và phần
nội dung của nó sẽ được hiển thị trong cửa sổ phía trên bên trái.
Các phần cơ bản:
title: tiêu đề
description: dòng miêu tả ngắn
details: nguồn gốc
author: tác giả
references: tài liệu tham khảo
keyword: từ khóa
seealso: tương tự, tạo liên kết với các hàm có công dụng tương tự
example: ví dụ
arguments: các phần tử của hàm
details: chi tiết
value: giá trị đầu ra của hàm
note: ghi chú
source: nguồn số liệu
Chúng ta xóa đi phần chữ có dấu “~~” phía trước và nhập nội dung vào đấy,
các nội dung nhập vào phải nằm gọn trong cặp ngoặc nhọn { } có sẵn. Đối với
keyword chúng ta sẽ nhập tên file vào đó (nếu có hai dòng keyword, chúng ta sẽ
xóa đi dòng 2, chỉ giữ lại một dòng thôi). Ví dụ, bên dưới là cửa sổ của file
chinhhop
252 trang |
Chia sẻ: tienthan23 | Lượt xem: 2077 | Lượt tải: 1
Bạn đang xem trước 20 trang tài liệu Luận văn Phân tích số liệu thống kê với ngôn ngữ R, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
models$p<-models$p[-xoa]
models$d<-models$d[-xoa]
models$q<-models$q[-xoa]
aic<-aic[-xoa]
#xep loai
xl<-1:length(aic)
aicxl<-sort(aic)
for(k in 1:length(aic)){
for(l in 1:length(aic)){
if(aic[k]==aicxl[l]){
if(l<10){xl[k]<-paste("..........",l); break;}
else
if(l<100){xl[k]<-paste(".........",l); break;}
}}}
#tim chi so mo hinh toi uu
for(t in 1:length(aic)) if(aic[t]==min(aic)) break;
id.best<-t
#hop nhat mo hinh
mohinh<-1:length(aic)
giatri.AIC<-1:length(aic)
for(i in 1:length(mohinh)){
mohinh[i]<-paste("ARIMA(", models$p[i],",",
models$d[i],",", models$q[i], ")",sep="")
giatri.AIC[i]<-paste("...AIC =",round(aic[i],2))
}
#xu ly ket qua xuat
kq1<-data.frame(mohinh,giatri.AIC,xl)
namescot1<-paste("Mo","hinh",sep=" ")
namescot2<-paste("Gia","tri","AIC",sep=" ")
namescot3<-paste("Xep","loai",sep=" ")
colnames(kq1)<-c(namescot1,namescot2,namescot3)
stt<-1:length(mohinh)
for(j in 1:length(mohinh)) stt[j]<-paste("mo hinh",j)
dimnames(kq1)[[1]]<-stt
kq2<-data.frame("the.best.model"=paste(mohinh[id.best],
giatri.AIC[id.best]))
colnames(kq2)<-c(paste("Mo","hinh","toi","uu",sep=" "))
dimnames(kq2)[[1]]<-" "
print<-list(mohinh=kq1,best=kq2)
}#finish ARIMA
if(type=="SARIMA"){
if (missing(order) || is.null(order) || !is.numeric(order) ||
length(order) != 3L || any(order < 0))
stop("'order' cau mo hinh SARIMA phai la mot vector so
khong am va co chieu dai la 3!")
if (is.null(seas) || !is.list(seas))stop("'seas' phai la mot danh
sach gom hai thanh phan 'order' va 'frequency'!")
if (is.null(seas$order) || !is.numeric(seas$order) ||
length(seas$order) != 3 || any(seas$order < 0))
stop("'seas$order' phai la mot vector so khong am va co
chieu dai la 3!")
if (is.null(seas$frequency) || is.na(seas$frequency) ||
seas$frequency[1] < 0 )
stop("'seas$frequency' phai la mot so nguyen khong am!")
#Ghi nhan cac he so
p<-order[1]
d<-order[2]
q<-order[3]
P<-seas$order[1]
D<-seas$order[2]
Q<-seas$order[3]
s<-seas$frequency[1]
#Kiem he so mot lan nua
if (is.na(p)||!is.numeric(p) || p < 0 || !is.wholenumber(p))
stop("p phai la nguyen duong")
if (is.na(d)||!is.numeric(d) || d < 0 || !is.wholenumber(d))
stop("d phai la nguyen duong")
if (is.na(q)||!is.numeric(q) || q < 0 || !is.wholenumber(q))
stop("p phai la nguyen duong")
if (is.na(P)||!is.numeric(P) || P < 0 || !is.wholenumber(P))
stop("P phai la nguyen duong")
if (is.na(D)||!is.numeric(D) || D < 0 || !is.wholenumber(D))
stop("D phai la nguyen duong")
if (is.na(Q)||!is.numeric(Q) || Q < 0 || !is.wholenumber(Q))
stop("Q phai la nguyen duong")
if (is.na(s)||!is.numeric(s) || s < 0 || !is.wholenumber(s))
stop("s phai la nguyen duong")
#To hop mo hinh, tinh aic
anser<-gl(1,1,length=(p+1)*(q+1)*(P+1)*(Q+1),labels=c("aic
= ","aic ="))
models<-
list(p=1:((p+1)*(q+1)*(P+1)*(Q+1)),d=1:((p+1)*(q+1)*(P+1)*(Q+
1)),
q=1:((p+1)*(q+1)*(P+1)*(Q+1)),P=1:((p+1)*(q+1)*(P+1)*(Q+1)),
D=1:((p+1)*(q+1)*(P+1)*(Q+1)),Q=1:((p+1)*(q+1)*(P+1)*(Q+1)),
s=1:((p+1)*(q+1)*(P+1)*(Q+1)))
aic<-1:((p+1)*(q+1)*(P+1)*(Q+1))
index=0
for(i1 in 0:p){
for(i2 in 0:q){
for(j1 in 0:P){
for(j2 in 0:Q){
index=index+1
models$p[index]<-i1
models$d[index]<-d
models$q[index]<-i2
models$P[index]<-j1
models$D[index]<-D
models$Q[index]<-j2
models$s[index]<-s
aic[index]<-
AIC(arima(DataTimeSeries,order=c(i1,d,i2),seasonal=list(order=c
(j1,D,j2),s)))
}}}}
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
240
#Xoa bo cac mo hinh 0 co y nghia
xoa<-0
for(i in 1:length(aic)) if(models$p[i]==0 & models$q[i]==0)
xoa<-cbind(xoa,i)
for(i in 1:length(aic)) if(models$P[i]==0 & models$Q[i]==0)
xoa<-cbind(xoa,i)
xoa<-unique(as.numeric(xoa[-1]))
models$p<-models$p[-xoa]
models$d<-models$d[-xoa]
models$q<-models$q[-xoa]
models$P<-models$P[-xoa]
models$D<-models$D[-xoa]
models$Q<-models$Q[-xoa]
models$s<-models$s[-xoa]
aic<-aic[-xoa]
#xep loai
xl<-1:length(aic)
aicxl<-sort(aic)
#do tim va cap so
for(k in 1:length(aic)){
for(l in 1:length(aic)){
if(aic[k]==aicxl[l]){
if(l<10){xl[k]<-paste("..........",l); break;}
else
if(l<100){xl[k]<-paste(".........",l); break;}
}}}
#tim chi so mo hinh toi uu
for(t in 1:length(aic)) if(aic[t]==min(aic)) break;
id.best<-t
#hop nhat mo hinh
mohinh<-1:length(aic)
giatri.AIC<-1:length(aic)
for(i in 1:length(mohinh)){
mohinh[i]<-
paste("SARIMA(",models$p[i],",",models$d[i],",",models$q[i],
")*(",models$P[i],",",models$D[i],",",models$Q[i],
"),s=", models$s[i],sep="")
giatri.AIC[i]<-paste("...AIC =",round(aic[i],2))}
#xu ly ket qua in ra
kq1<-data.frame(mohinh,giatri.AIC,xl)
namescot1<-paste("Mo","hinh",sep=" ")
namescot2<-paste("Gia","tri","AIC",sep=" ")
namescot3<-paste("Xep","loai",sep=" ")
colnames(kq1)<-c(namescot1,namescot2,namescot3)
stt<-1:length(mohinh)
for(j in 1:length(mohinh)) stt[j]<-paste("mo hinh",j)
dimnames(kq1)[[1]]<-stt
kq2<-data.frame("the.best.model"=paste(mohinh[id.best],
giatri.AIC[id.best]))
colnames(kq2)<-c(paste("Mo","hinh","toi","uu",sep=" "))
dimnames(kq2)[[1]]<-" "
print<-list(mohinh=kq1,best=kq2)
}#finish SARIMA
if(type=="ARMAX"){
if(is.null(xreg))stop("Phai khai bao xreg cho mo hinh!")
if(is.vector(xreg))
if(length(xreg)!=length(DataTimeSeries))stop("Chieu dai chuoi
quan sat va xreg khac nhau!")
if(is.data.frame(xreg))
if(dim(xreg)[1]!=length(DataTimeSeries))stop("Chieu dai chuoi
quan sat va xreg khac nhau!"
if(!is.null(seas$order)||!is.null(seas$frequency))stop("Mo
hinh khong phu hop!")
if (missing(order) ||is.null(order) || !is.numeric(order) ||
length(order) != 2L || any(order < 0)) stop("Loi o bac cua mo
hinh!")
#Ghi nhan cac he so
p<-order[1]
d<-0
q<-order[2]
#Kiem he so mot lan nua
if (is.na(p)||!is.numeric(p) || p < 0 || !is.wholenumber(p))
stop("Loi o bac cua mo hinh!")
if (is.na(q)||!is.numeric(q) || q < 0 || !is.wholenumber(q))
stop("Loi o bac cua mo hinh!")
#To hop mo hinh, tinh aic
anser<-gl(1,1,length=(p+1)*(q+1),labels=c("aic = ","aic ="))
models<-
list(p=1:((p+1)*(q+1)),d=1:((p+1)*(q+1)),q=1:((p+1)*(q+1)))
aic<-1:((p+1)*(q+1))
index=0
for(i1 in 0:p){
for(i2 in 0:q){
index=index+1
models$p[index]<-i1
models$d[index]<-d
models$q[index]<-i2
aic[index]<-
AIC(arimax(DataTimeSeries,order=c(i1,d,i2),xreg=xreg))
}}
#Xoa bo cac mo hinh 0 co y nghia
xoa<-0
for(i in 1:length(aic))
if(models$p[i]==0 & models$q[i]==0) xoa<-cbind(xoa,i)
models$p<-models$p[-xoa]
models$d<-models$d[-xoa]
models$q<-models$q[-xoa]
aic<-aic[-xoa]
#xep loai
xl<-1:length(aic)
aicxl<-sort(aic)
for(k in 1:length(aic)){
for(l in 1:length(aic)){
if(aic[k]==aicxl[l]){
if(l<10){xl[k]<-paste("..........",l); break;}
else
if(l<100){xl[k]<-paste(".........",l); break;}
}}}
#tim chi so mo hinh toi uu
for(t in 1:length(aic)) if(aic[t]==min(aic)) break;
id.best<-t
#hop nhat mo hinh
mohinh<-1:length(aic)
giatri.AIC<-1:length(aic)
for(i in 1:length(mohinh)){
mohinh[i]<-paste("ARMAX(", models$p[i],",", models$q[i],
")",sep="")
giatri.AIC[i]<-paste("...AIC =",round(aic[i],2))
}
#xu ly ket qua xuat
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
241
kq1<-data.frame(mohinh,giatri.AIC,xl)
namescot1<-paste("Mo","hinh",sep=" ")
namescot2<-paste("Gia","tri","AIC",sep=" ")
namescot3<-paste("Xep","loai",sep=" ")
colnames(kq1)<-c(namescot1,namescot2,namescot3)
stt<-1:length(mohinh)
for(j in 1:length(mohinh)) stt[j]<-paste("mo hinh",j)
dimnames(kq1)[[1]]<-stt
kq2<-data.frame("the.best.model"=paste(mohinh[id.best],
giatri.AIC[id.best]))
colnames(kq2)<-c(paste("Mo","hinh","toi","uu",sep=" "))
dimnames(kq2)[[1]]<-" "
print<-list(mohinh=kq1,best=kq2)
}#finish ARMAX
if(type=="ARIMAX"){
if(is.null(xreg))stop("Phai khai bao xreg cho mo hinh!")
if(is.vector(xreg))
if(length(xreg)!=length(DataTimeSeries))stop("Chieu dai chuoi
quan sat va xreg khac nhau!")
if(is.data.frame(xreg))
if(dim(xreg)[1]!=length(DataTimeSeries))stop("Chieu dai chuoi
quan sat va xreg khac nhau!")
if(!is.null(seas$order)||!is.null(seas$frequency))stop("Mo
hinh khong phu hop!")
if (missing(order) ||is.null(order) || !is.numeric(order) ||
length(order) != 3L || any(order < 0))
stop("Loi o bac cua mo hinh!")
#Ghi nhan cac he so
p<-order[1]
d<-order[2]
q<-order[3]
#Kiem he so mot lan nua
if (is.na(p)||!is.numeric(p) || p < 0 || !is.wholenumber(p))
stop("Loi o bac cua mo hinh!")
if (is.na(d)||!is.numeric(d) || d < 0 || !is.wholenumber(d))
stop("Loi o bac cua mo hinh!")
if (is.na(q)||!is.numeric(q) || q < 0 || !is.wholenumber(q))
stop("Loi o bac cua mo hinh!")
#To hop mo hinh, tinh aic
anser<-gl(1,1,length=(p+1)*(q+1),labels=c("aic = ","aic ="))
models<-
list(p=1:((p+1)*(q+1)),d=1:((p+1)*(q+1)),q=1:((p+1)*(q+1)))
aic<-1:((p+1)*(q+1))
index=0
for(i1 in 0:p){
for(i2 in 0:q){
index=index+1
models$p[index]<-i1
models$d[index]<-d
models$q[index]<-i2
aic[index]<-
AIC(arimax(DataTimeSeries,order=c(i1,d,i2),xreg=xreg))
}}
#Xoa bo cac mo hinh 0 co y nghia
xoa<-0
for(i in 1:length(aic))
if(models$p[i]==0 & models$q[i]==0) xoa<-cbind(xoa,i)
models$p<-models$p[-xoa]
models$d<-models$d[-xoa]
models$q<-models$q[-xoa]
aic<-aic[-xoa]
#xep loai
xl<-1:length(aic)
aicxl<-sort(aic)
for(k in 1:length(aic)){
for(l in 1:length(aic)){
if(aic[k]==aicxl[l]){
if(l<10){xl[k]<-paste("..........",l); break;}
else
if(l<100){xl[k]<-paste(".........",l); break;}
}}}
#tim chi so mo hinh toi uu
for(t in 1:length(aic)) if(aic[t]==min(aic)) break;
id.best<-t
#hop nhat mo hinh
mohinh<-1:length(aic)
giatri.AIC<-1:length(aic)
for(i in 1:length(mohinh)){
mohinh[i]<-paste("ARIMAX(", models$p[i],",",
models$d[i],",", models$q[i], ")",sep="")
giatri.AIC[i]<-paste("...AIC =",round(aic[i],2))
}
#xu ly ket qua xuat
kq1<-data.frame(mohinh,giatri.AIC,xl)
namescot1<-paste("Mo","hinh",sep=" ")
namescot2<-paste("Gia","tri","AIC",sep=" ")
namescot3<-paste("Xep","loai",sep=" ")
colnames(kq1)<-c(namescot1,namescot2,namescot3)
stt<-1:length(mohinh)
for(j in 1:length(mohinh)) stt[j]<-paste("mo hinh",j)
dimnames(kq1)[[1]]<-stt
kq2<-data.frame("the.best.model"=paste(mohinh[id.best],
giatri.AIC[id.best]))
colnames(kq2)<-c(paste("Mo","hinh","toi","uu",sep=" "))
dimnames(kq2)[[1]]<-" "
print<-list(mohinh=kq1,best=kq2)
}#finish ARIMAX
if(type=="SARIMAX"){
if(is.null(xreg))stop("Phai khai bao xreg cho mo hinh!")
if(is.vector(xreg))
if(length(xreg)!=length(DataTimeSeries))stop("Chieu dai chuoi
quan sat va xreg khac nhau!")
if(is.data.frame(xreg))
if(dim(xreg)[1]!=length(DataTimeSeries))stop("Chieu dai chuoi
quan sat va xreg khac nhau!")
if (missing(order) || is.null(order) || !is.numeric(order) ||
length(order) != 3L || any(order < 0))
stop("'order' cau mo hinh SARIMA phai la mot vector so
khong am va co chieu dai la 3!")
if (is.null(seas) || !is.list(seas))stop("'seas' phai la mot danh
sach gom hai thanh phan 'order' va 'frequency'!")
if (is.null(seas$order) || !is.numeric(seas$order) ||
length(seas$order) != 3 || any(seas$order < 0))
stop("'seas$order' phai la mot vector so khong am va co
chieu dai la 3!")
if (is.null(seas$frequency) || is.na(seas$frequency) ||
seas$frequency[1] < 0 )
stop("'seas$frequency' phai la mot so nguyen khong am!")
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
242
#Ghi nhan cac he so
p<-order[1]
d<-order[2]
q<-order[3]
P<-seas$order[1]
D<-seas$order[2]
Q<-seas$order[3]
s<-seas$frequency[1]
#Kiem he so mot lan nua
if (is.na(p)||!is.numeric(p) || p < 0 || !is.wholenumber(p))
stop("p phai la nguyen duong")
if (is.na(d)||!is.numeric(d) || d < 0 || !is.wholenumber(d))
stop("d phai la nguyen duong")
if (is.na(q)||!is.numeric(q) || q < 0 || !is.wholenumber(q))
stop("p phai la nguyen duong")
if (is.na(P)||!is.numeric(P) || P < 0 || !is.wholenumber(P))
stop("P phai la nguyen duong")
if (is.na(D)||!is.numeric(D) || D < 0 || !is.wholenumber(D))
stop("D phai la nguyen duong")
if (is.na(Q)||!is.numeric(Q) || Q < 0 || !is.wholenumber(Q))
stop("Q phai la nguyen duong")
if (is.na(s)||!is.numeric(s) || s < 0 || !is.wholenumber(s))
stop("s phai la nguyen duong")
#To hop mo hinh, tinh aic
anser<-gl(1,1,length=(p+1)*(q+1)*(P+1)*(Q+1),labels=c("aic
= ","aic ="))
models<-
list(p=1:((p+1)*(q+1)*(P+1)*(Q+1)),d=1:((p+1)*(q+1)*(P+1)*(Q+
1)),
q=1:((p+1)*(q+1)*(P+1)*(Q+1)),P=1:((p+1)*(q+1)*(P+1)*(Q+1)),
D=1:((p+1)*(q+1)*(P+1)*(Q+1)),Q=1:((p+1)*(q+1)*(P+1)*(Q+1)),
s=1:((p+1)*(q+1)*(P+1)*(Q+1)))
aic<-1:((p+1)*(q+1)*(P+1)*(Q+1))
index=0
for(i1 in 0:p){
for(i2 in 0:q){
for(j1 in 0:P){
for(j2 in 0:Q){
index=index+1
models$p[index]<-i1
models$d[index]<-d
models$q[index]<-i2
models$P[index]<-j1
models$D[index]<-D
models$Q[index]<-j2
models$s[index]<-s
aic[index]<-
AIC(arimax(DataTimeSeries,order=c(i1,d,i2),seasonal=list(order=
c(j1,D,j2),s),xreg=xreg))
}}}}
#Xoa bo cac mo hinh 0 co y nghia
xoa<-0
for(i in 1:length(aic)) if(models$p[i]==0 & models$q[i]==0)
xoa<-cbind(xoa,i)
for(i in 1:length(aic)) if(models$P[i]==0 & models$Q[i]==0)
xoa<-cbind(xoa,i)
xoa<-unique(as.numeric(xoa[-1]))
models$p<-models$p[-xoa]
models$d<-models$d[-xoa]
models$q<-models$q[-xoa]
models$P<-models$P[-xoa]
models$D<-models$D[-xoa]
models$Q<-models$Q[-xoa]
models$s<-models$s[-xoa]
aic<-aic[-xoa]
#xep loai
xl<-1:length(aic)
aicxl<-sort(aic)
#do tim va cap so
for(k in 1:length(aic)){
for(l in 1:length(aic)){
if(aic[k]==aicxl[l]){
if(l<10){xl[k]<-paste("..........",l); break;}
else
if(l<100){xl[k]<-paste(".........",l); break;}
}}}
#tim chi so mo hinh toi uu
for(t in 1:length(aic)) if(aic[t]==min(aic)) break;
id.best<-t
#hop nhat mo hinh
mohinh<-1:length(aic)
giatri.AIC<-1:length(aic)
for(i in 1:length(mohinh)){
mohinh[i]<-
paste("SARIMAX(",models$p[i],",",models$d[i],",",models$q[i],
")*(",models$P[i],",",models$D[i],",",models$Q[i],
"),s=", models$s[i],sep="")
giatri.AIC[i]<-paste("...AIC =",round(aic[i],2))}
#xu ly ket qua in ra
kq1<-data.frame(mohinh,giatri.AIC,xl)
namescot1<-paste("Mo","hinh",sep=" ")
namescot2<-paste("Gia","tri","AIC",sep=" ")
namescot3<-paste("Xep","loai",sep=" ")
colnames(kq1)<-c(namescot1,namescot2,namescot3)
stt<-1:length(mohinh)
for(j in 1:length(mohinh)) stt[j]<-paste("mo hinh",j)
dimnames(kq1)[[1]]<-stt
kq2<-data.frame("the.best.model"=paste(mohinh[id.best],
giatri.AIC[id.best]))
colnames(kq2)<-c(paste("Mo","hinh","toi","uu",sep=" "))
dimnames(kq2)[[1]]<-" "
print<-list(mohinh=kq1,best=kq2)
}#finish SARIMAX
if(type=="ARCH"){
if(!is.null(seas$order)||!is.null(seas$frequency))stop("Mo
hinh khong phu hop!")
if (missing(order) || is.null(order) ||!is.numeric(order) ||
length(order) != 1L || any(order < 0))
stop("'order' cua mo hinh ARCH phai la mot so nguyen
duong")
#Ghi nhan cac he so
p<-0
q<-order[1]
if (is.na(q)||!is.numeric(q) || q < 0 || !is.wholenumber(q))
stop("q phai la nguyen duong")
#To hop mo hinh, tinh aic
anser<-gl(1,1,length=(p+1)*(q+1),labels=c("aic = ","aic ="))
models<-list(p=1:((p+1)*(q+1)),q=1:((p+1)*(q+1)))
aic<-1:((p+1)*(q+1))
index=0
for(i1 in 0:p){
for(i2 in 0:q){
index=index+1
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
243
models$p[index]<-i1
models$q[index]<-i2
if(index!=1)aic[index]<-
AIC(garch(DataTimeSeries,order=c(i1,i2),trace=FALSE))
}}
aic<-aic[-1]
models$p<-models$p[-1]
models$q<-models$q[-1]
#xep loai
xl<-1:length(aic)
aicxl<-sort(aic)
for(k in 1:length(aic)){
for(l in 1:length(aic)){
if(aic[k]==aicxl[l]){
if(l<10){xl[k]<-paste("..........",l); break;}
else
if(l<100){xl[k]<-paste(".........",l); break;}
}}}
#tim chi so mo hinh toi uu
for(t in 1:length(aic)) if(aic[t]==min(aic)) break;
id.best<-t
#Suat ket qua
#hop nhat mo hinh
mohinh<-1:length(aic)
giatri.AIC<-1:length(aic)
for(i in 1:length(aic)){
mohinh[i]<-paste("ARCH(",models$q[i], ")",sep="")
giatri.AIC[i]<-paste("...AIC =",round(aic[i],2))
}
#xu ly ket qua xuat
kq1<-data.frame("Cac mo hinh ARCH.." = mohinh,"...Gia tri
AIC.." = giatri.AIC,"....xep loai"=xl)
namescot1<-paste("Mo","hinh",sep=" ")
namescot2<-paste("Gia","tri","AIC",sep=" ")
namescot3<-paste("Xep","loai",sep=" ")
colnames(kq1)<-c(namescot1,namescot2,namescot3)
stt<-1:length(mohinh)
for(j in 1:length(mohinh)) stt[j]<-paste("mo hinh",j)
dimnames(kq1)[[1]]<-stt
kq2<-data.frame("the.best.model"=paste(mohinh[id.best],
giatri.AIC[id.best]))
colnames(kq2)<-c(paste("Mo","hinh","toi","uu",sep=" "))
dimnames(kq2)[[1]]<-" "
print<-list(mohinh=kq1,best=kq2)
}#finish ARCH
if(type=="GARCH"){
if(!is.null(seas$order)||!is.null(seas$frequency))stop("Mo
hinh khong phu hop!")
if (missing(order) || is.null(order) ||!is.numeric(order) ||
length(order) != 2L || any(order < 0))
stop("'order' cua mo hinh GARCH phai la mot vector gom
hai so nguyen duong")
#Ghi nhan cac he so
p<-order[1]
q<-order[2]
if (is.na(p)||!is.numeric(p) || p < 0 || !is.wholenumber(p))
stop("p phai la nguyen duong")
if (is.na(q)||!is.numeric(q) || q < 0 || !is.wholenumber(q))
stop("q phai la nguyen duong")
#To hop mo hinh, tinh aic
anser<-gl(1,1,length=(p+1)*(q+1),labels=c("aic = ","aic ="))
models<-list(p=1:((p+1)*(q+1)),q=1:((p+1)*(q+1)))
aic<-1:((p+1)*(q+1))
index=0
for(i1 in 0:p){
for(i2 in 0:q){
index=index+1
models$p[index]<-i1
models$q[index]<-i2
if(i1!=0)aic[index]<-
AIC(garch(DataTimeSeries,order=c(i1,i2),trace=FALSE))
}}
aic<-aic[-c(1:(q+1))]
models$p<-models$p[-c(1:(q+1))]
models$q<-models$q[-c(1:(q+1))]
#xep loai
xl<-1:length(aic)
aicxl<-sort(aic)
for(k in 1:length(aic)){
for(l in 1:length(aic)){
if(aic[k]==aicxl[l]){
if(l<10){xl[k]<-paste("..........",l); break;}
else
if(l<100){xl[k]<-paste(".........",l); break;}
}}}
#tim chi so mo hinh toi uu
for(t in 1:length(aic)) if(aic[t]==min(aic)) break;
id.best<-t
#Suat ket qua
#hop nhat mo hinh
mohinh<-1:length(aic)
giatri.AIC<-1:length(aic)
for(i in 1:length(aic)){
mohinh[i]<-paste("GARCH(",models$p[i],",",models$q[i],
")",sep="")
giatri.AIC[i]<-paste("...AIC =",round(aic[i],2))
}
#xu ly ket qua xuat
kq1<-data.frame("Cac mo hinh GARCH.." = mohinh,"...Gia tri
AIC.." = giatri.AIC,"....xep loai"=xl)
namescot1<-paste("Mo","hinh",sep=" ")
namescot2<-paste("Gia","tri","AIC",sep=" ")
namescot3<-paste("Xep","loai",sep=" ")
colnames(kq1)<-c(namescot1,namescot2,namescot3)
stt<-1:length(mohinh)
for(j in 1:length(mohinh)) stt[j]<-paste("mo hinh",j)
dimnames(kq1)[[1]]<-stt
kq2<-data.frame("the.best.model"=paste(mohinh[id.best],
giatri.AIC[id.best]))
colnames(kq2)<-c(paste("Mo","hinh","toi","uu",sep=" "))
dimnames(kq2)[[1]]<-" "
print<-list(mohinh=kq1,best=kq2)
}#finsh GARCH
print
}
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
244
Hàm fuzzy.ts1( )
fuzzy.ts1 <-
function(ts,n=5,D1=0,D2=0,type=c("Chen","Singh","Heuristic","
Chen-Hsu"),bin=NULL,trace=FALSE,divide=NULL,plot=FALSE){
#--ham con---
is.wholenumber <-function(x, tol = .Machine$double.eps^0.5)
abs(x - round(x)) < tol
matdo<-function(x,g){
method <- 1
x.unique <- sort(unique(x))
min.dif <- min(diff(x.unique),na.rm=TRUE)/2
min.dif.factor <- 1
nnm <- sum(!is.na(x))
n <- table(x)
xx <- as.double(names(n))
cum <- cumsum(n)
m <- length(xx)
y <- as.integer(ifelse(is.na(x), NA, 1))
cuts <- approx(cum,xx,xout=(1:g)*nnm/g,method="constant",
rule=2,f=1)$y
cuts[length(cuts)] <- max(xx)
lower <- xx[1]
upper <- 1e+45
up <- low <- double(g)
i <- 0
for (j in 1:g) {
cj <- if (method == 1 || j == 1) cuts[j]
else {
s <- if (is.na(lower))
FALSE
else xx >= lower
cum.used <- if (all(s)) 0
else max(cum[!s])
if (j == m) max(xx)
else if (sum(s) < 2) max(xx)
else approx(cum[s] - cum.used, xx[s], xout = (nnm -
cum.used)/(g - j + 1), method = "constant", rule = 2, f = 1)$y
}
if (cj == upper) next
i <- i + 1
upper <- cj
y[x >= (lower - min.dif.factor * min.dif)] <- i
low[i] <- lower
lower <- if (j == g) upper
else min(xx[xx > upper],na.rm=TRUE)
if (is.na(lower)) lower <- upper
up[i] <- lower
}
low <- low[1:i]
up <- up[1:i]
kq=c(low,up[length(up)])
v=rep(0,length(kq))
for(i in 1:length(kq))
{tt=length(x[x==kq[i]])
if(tt!=0)v[i]=i}
v[v==0]<-NA
v<-na.omit(v)
for(i in 1:length(v))
kq[v[i]]=kq[v[i]]-10^(-3)
kq
}
rule1<-function(x2,x1,A3,D){
#trich thong tin
tapmo<-as.character(D[,1])
low<-D[,2]
up<-D[,3]
bw<-D[,4]
for(i in 1:length(tapmo)) #dinh vi tri A3
if(A3==tapmo[i]) {vt=i;break}
s<-(up[vt]-low[vt])/4 #tinh khoang chia
different<-abs(x2-x1)/2
distant=abs(up[vt]-low[vt])/2
if(different > distant) x=low[vt]+3*s
else
if(different == distant) x=low[vt]+2*s
else
if(different < distant) x=low[vt]+1*s
x
}
rule2<-function(x3,x2,x1,A4,D){
#trich thong tin
tapmo<-as.character(D[,1])
low<-D[,2]
up<-D[,3]
bw<-D[,4]
for(i in 1:length(tapmo)) #dinh vi tri A2
if(A4==tapmo[i]) {vt=i;break}
s<-(up[vt]-low[vt])/4 #tinh khoang chia
different1a<- abs((x3-x2)-(x2-x1))*2+x3
different1b<- x3-abs((x3-x2)-(x2-x1))*2
different2a<- abs((x3-x2)-(x2-x1))/2+x3
different2b<- x3-abs((x3-x2)-(x2-x1))/2
if(low[vt]<=different1a & different1a<=up[vt]) x=low[vt]+3*s
else
if(low[vt]<=different1b & different1b<=up[vt]) x=low[vt]+3*s
else
if(low[vt]<=different2a & different2a<=up[vt]) x=low[vt]+1*s
else
if(low[vt]<=different2b & different2b<=up[vt]) x=low[vt]+1*s
else
x=low[vt]+2*s
x
}
rule3<-function(x3,x2,x1,A4,D){
#trich thong tin
tapmo<-as.character(D[,1])
low<-D[,2]
up<-D[,3]
bw<-D[,4]
for(i in 1:length(tapmo)) #dinh vi tri A2
if(A4==tapmo[i]) {vt=i;break}
s<-(up[vt]-low[vt])/4 #tinh khoang chia
different1a<- abs((x3-x2)-(x2-x1))*2+x3
different1b<- x3-abs((x3-x2)-(x2-x1))*2
different2a<- abs((x3-x2)-(x2-x1))/2+x3
different2b<- x3-abs((x3-x2)-(x2-x1))/2
if(low[vt]<=different2a & different2a<=up[vt]) x=low[vt]+1*s
else
if(low[vt]<=different2b & different2b<=up[vt]) x=low[vt]+1*s
else
if(low[vt]<=different1a & different1a<=up[vt]) x=low[vt]+3*s
else
if(low[vt]<=different1b & different1b<=up[vt]) x=low[vt]+3*s
else
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
245
x=low[vt]+2*s
x
}
namthang<-function(data.ts){
batdau<-start(data.ts)
tanso<-frequency(data.ts)
nam1<-batdau[1]
thang1<-batdau[2]
ketthuc<-end(data.ts)
nam2<-ketthuc[1]
thang2<-ketthuc[2]
namkq<-1:length(data.ts)
thangkq<-1:length(data.ts)
index=0;
for(nam in nam1:nam2)
for(thang in 1:tanso)
if(nam!=nam1 || thang>=thang1){
index=index+1
namkq[index]<-nam
thangkq[index]<-thang
if(nam==nam2 & thang==thang2) break;
}
if(tanso==4)
{thangkq[thangkq==1]<-"Q1";thangkq[thangkq==2]<-"Q1";
thangkq[thangkq==3]<-"Q1";thangkq[thangkq==4]<-"Q1";
print<-paste(namkq,thangkq,sep=" ")}
else
if(tanso==12)
{thangkq[thangkq==1]<-"Jan";thangkq[thangkq==2]<-"Feb";
thangkq[thangkq==3]<-"Mar";thangkq[thangkq==4]<-"Apr";
thangkq[thangkq==5]<-"May";thangkq[thangkq==6]<-"Jun";
thangkq[thangkq==7]<-"Jul";thangkq[thangkq==8]<-"Aug";
thangkq[thangkq==9]<-"Sep";thangkq[thangkq==10]<-"Oct";
thangkq[thangkq==11]<-"Nov";thangkq[thangkq==12]<-"Dec";
print<-paste(namkq,thangkq,sep=" ")}
else
if(tanso==7)
{thangkq[thangkq==1]<-"Mon";thangkq[thangkq==2]<-"Tue";
thangkq[thangkq==3]<-"Wed";thangkq[thangkq==4]<-"Thu";
thangkq[thangkq==5]<-"Fri";thangkq[thangkq==6]<-"Sat";
thangkq[thangkq==7]<-"Sun";
print<-paste(namkq,thangkq,sep=" ")}
else
if(tanso!=1)
print<-paste("(",namkq,",",thangkq,")",sep="")
else
print<-namkq
print
}
divide.distance<-function(tsi,f,min.tsi,max.tsi){
min.x=min(tsi,min.tsi)
max.x=max(tsi,max.tsi)
h=(max.x-min.x)/f
k<-1:(f+1);
for(i in 1:(f+1)){
if(i==1)k[i]=min.x
else
k[i]=min.x+(i-1)*h
}
k
}
quanhe<-function(ts,type){
qh<-1:length(ts)
if(type=="Chen") for(i in 1:length(ts))if(i>1)qh[i]<-c("<--")
if(type=="Singh") for(i in 1:length(ts))if(i>1)qh[i]<-c("<--")
if(type=="Heuristic") for(i in 1:length(ts))if(i>1)qh[i]<-c("<--")
if(type=="Chen-Hsu") for(i in 1:length(ts))if(i>1)qh[i]<-c("<--")
qh[qh!="<--"]<-"-x-"
qh}
#--ham con---
#---kiem tra input---
#Kiem tra so lieu
if (!is.numeric(ts)) stop("Error in 'ts'!")
if(!is.ts(ts)) stop("Error in 'ts'!") else
if(!is.null(dim(ts)))stop("Error in 'ts'!")
kt<-0
for(i in 1:length(ts))if(is.na(ts[i]))kt=kt+1
if(kt>0)stop("Trong chuoi co gia tri NA!")
if (is.na(D1)||!is.numeric(D1)) stop("Error in 'D1'!")
if (is.na(D2)||!is.numeric(D2)) stop("Error in 'D2'!")
if (is.na(n)||!is.numeric(n) || n < 1 || !is.wholenumber(n))
stop("Error in 'n'!")
type<-match.arg(type)
if(type!="Chen" & type!="Singh" & type!="Heuristic" &
type!="Chen-Hsu") stop("Error in 'type'!")
if(type!="Chen-Hsu")if(!is.null(bin))stop("'bin' just for Chen-Hsu
model!")
if(!is.null(divide))if(type!="Chen-Hsu") stop("'divide' just for
Chen-Hsu model!")
if(type=="Chen-Hsu")if(is.null(divide))divide<-c("distance") else
if(divide!="distance" & divide!="density")stop("'divide' must be
'distance' or 'density'!")
#---kiem tra input---
#---tinh toan ban dau---
d1=D1
d2=D2
thoidiem<-namthang(ts)
quanhemo<-quanhe(ts,type)
#Buoc 1: Xay dung va chia tap nen
min.x=min(ts)-d1
max.x=max(ts)+d2
h=(max.x-min.x)/n
k<-1:(n+1);U<-1:n
for(i in 1:(n+1)){
if(i==1)k[i]=min.x
else
{k[i]=min.x+(i-1)*h
U[i-1]=paste("A",i-1,sep="")}
}
D<-data.frame(U,low=k[1:n],up=k[2:(n+1)])
D$Bw<-(1/2)*(D$low+D$up)
#Buoc 2: Xac dinh cac tap mo
loai<-1:length(ts)
for(i in 1:length(ts)){
for(j in 1:n){
if (D$low[j]<=ts[i] & ts[i]<=D$up[j])
{loai[i]=paste("A",j,sep=""); break;}
}}
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
246
#Buoc 3: Xac dinh moi quan he mo
loai.old<-1:length(loai)
for(i in 1:length(loai)){
if(i==1)loai.old[i]=NA
else
loai.old[i]=loai[i-1]
}
quanhemokq<-paste(loai,quanhemo,loai.old,sep="")
D1<-data.frame(ts,loai,loai.old)
b<-table(D1$loai)
ni<-1:n
for(i in 1:n)
for(j in 1:n){
if(paste("A",i,sep="")==names(b)[j] & j<=length(b))
{ni[i]=b[j];break;}else{
if(j>length(b)) {ni[i]=0; break;}
}
}
D$ni<-ni
#Gom nhom
a<-1:(n*n)
a<-matrix(a,nrow=n)
for(cot in 1:n){
for(i in 2:length(D1$loai.old)){
for(j in 1:n){
if(D1$loai.old[i]==paste("A",cot,sep="") &
a[j,cot]!=paste("A",j,sep="")
& D1$loai[i]==paste("A",j,sep=""))
{a[j,cot]=paste("A",j,sep=""); break;}
}}}
for(cot in 1:n){
for(j in 1:n) if(a[j,cot]!=paste("A",j,sep="")) a[j,cot]<-NA
}
#---tinh toan ban dau---
#---giai mo va du bao---
#type Chen
if(type=="Chen"){
#1.Giai mo
mo<-1:n
for(cot in 1:n){
if(cot>1)a[a==1]<-NA
s<-length(na.omit(a[,cot]))
a[is.na(a)]<-1
if(s==1){
for(j in 1:n) if(a[j,cot]==paste("A",j,sep="")){t=D$Bw[j];break;}
mo[cot]=t
}
else
if(s>1){
t=0
for(j in 1:n) if(a[j,cot]== paste("A",j,sep=""))t=t+D$Bw[j]
mo[cot]=t/s
}
else
if(s==0){
mo[cot]=D$Bw[cot]
}
}
#2.Du bao
db<-1:length(loai.old)
for(i in 1:length(loai.old)){
if(i==1)db[i]=NA
else
for(j in 1:n)if(loai.old[i]==paste("A",j,sep=""))
{db[i]=mo[j];break;}
}
db<-ts(db,start=start(ts),frequency=frequency(ts))
DB1<-data.frame(thoidiem,D1$ts,quanhemokq,db)
}#finish Chen
#type == Singh
if(type=="Singh"){
F<-1:length(ts);Ds<-1:length(ts)
X<-1:length(ts);XX<-1:length(ts)
Y<-1:length(ts);YY<-1:length(ts)
P<-1:length(ts);PP<-1:length(ts)
Q<-1:length(ts);QQ<-1:length(ts)
G<-1:length(ts);GG<-1:length(ts)
H<-1:length(ts);HH<-1:length(ts)
E<-ts;
#Xoa bo level thua: begin
tt=0;v<-1:length(D$ni)
for(t0 in 1:length(D$ni))
if(D$ni[t0]==0){tt=tt+1;v[tt]=t0;}
if(tt==0)(v=NULL) else v=v[1:tt]
if(!is.null(v)){
Dt<-D[-v,]
t1=1;
while(t1<=length(levels(Dt$U))){
test=0;
for(t2 in 1:length(Dt$U))
if(levels(Dt$U)[t1]==Dt$U[t2]){test=1;break;}
if(test==0)levels(Dt$U)[t1]=NA else t1=t1+1;
}}
if(is.null(v))Dt<-D
#Xoa bo level thua: the end
for(i in 0:(length(ts)-1)){
if(i<3)F[i+1]<-NA
else{
R=0;S=0;
Ds[i]=abs(abs(E[i]-E[i-1])-abs(E[i-1]-E[i-2]))
X[i]=E[i]+(Ds[i]/2)
XX[i]=E[i]-(Ds[i]/2)
Y[i]=E[i]+Ds[i]
YY[i]=E[i]-Ds[i]
P[i]=E[i]+(Ds[i]/4)
PP[i]=E[i]-(Ds[i]/4)
Q[i]=E[i]+2*Ds[i]
QQ[i]=E[i]-2*Ds[i]
G[i]=E[i]+(Ds[i]/6)
GG[i]=E[i]-(Ds[i]/6)
H[i]=E[i]+3*Ds[i]
HH[i]=E[i]-3*Ds[i]
Dt.U<-as.character(Dt$U)
D1.loai<-as.character(D1$loai)
for(j in 1:length(Dt.U)) if(D1.loai[i+1]==Dt.U[j]) {l=j;break;}
if(Dt$low[l]<=X[i] & X[i]<=Dt$up[l]) {R=R+X[i];S=S+1;}
if(Dt$low[l]<=XX[i] & XX[i]<=Dt$up[l]) {R=R+XX[i];S=S+1;}
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
247
if(Dt$low[l]<=Y[i] & Y[i]<=Dt$up[l]) {R=R+Y[i];S=S+1;}
if(Dt$low[l]<=YY[i] & YY[i]<=Dt$up[l]) {R=R+YY[i];S=S+1;}
if(Dt$low[l]<=P[i] & P[i]<=Dt$up[l]) {R=R+P[i];S=S+1;}
if(Dt$low[l]<=PP[i] & PP[i]<=Dt$up[l]) {R=R+PP[i];S=S+1;}
if(Dt$low[l]<=Q[i] & Q[i]<=Dt$up[l]) {R=R+Q[i];S=S+1;}
if(Dt$low[l]<=QQ[i] & QQ[i]<=Dt$up[l]) {R=R+QQ[i];S=S+1;}
if(Dt$low[l]<=G[i] & G[i]<=Dt$up[l]) {R=R+G[i];S=S+1;}
if(Dt$low[l]<=GG[i] & GG[i]<=Dt$up[l]) {R=R+GG[i];S=S+1;}
if(Dt$low[l]<=H[i] & H[i]<=Dt$up[l]) {R=R+H[i];S=S+1;}
if(Dt$low[l]<=HH[i] & HH[i]<=Dt$up[l]) {R=R+HH[i];S=S+1;}
F[i+1]=(R + Dt$Bw[l])/(S+1)
}
}
F<-ts(F,start=start(ts),frequency=frequency(ts))
DB2<-
data.frame(thoidiem,sl.goc=D1$ts,quanhemo=quanhemokq,.....
sl.mo=F)
}#finish Singh
#type Heuristic
if(type=="Heuristic"){
#Xac dinh nhom quan he mo Heuristic
tap="begin";t.thai="calm";Bw.h=0
for(cot in 1:n){
locate<-rep(0,n)
for(i in 1:n) if(!is.na(a[i,cot]))locate[i]=i
locate[locate==0]<-NA
locate<-na.omit(locate)
if(length(locate)>0){
#xu huong giam: lon->nho
l=0
locate[length(locate)+1]<-(n+1)
for(i in 1:(length(locate)-1))
if(cot >= locate[i] & cot < locate[i+1])
{l=i;break;}
locate=locate[1:(length(locate)-1)]
if(l!=0){
t=0
for(i in 1:l) t=t+D$Bw[locate[i]]
tb<-t/length(locate[1:l])
tap[length(tap)+1]=paste("A",cot,sep="")
t.thai[length(t.thai)+1]="down"
Bw.h[length(Bw.h)+1]=tb
}
#xu huong tang: nho->lon
l=0
for(i in 1:length(locate)) if(cot <= locate[i]) {l=i;break;}
if(l!=0){
t=0
for(i in l:length(locate)) t=t+D$Bw[locate[i]]
tb<-t/length(locate[l:length(locate)])
tap[length(tap)+1]=paste("A",cot,sep="")
t.thai[length(t.thai)+1]="raise"
Bw.h[length(Bw.h)+1]=tb
}}}
tap<-factor(tap[2:length(tap)])
t.thai<-t.thai[2:length(t.thai)]
Bw.h<-Bw.h[2:length(Bw.h)]
D.h<-data.frame(tap,t.thai,Bw.h)
#Du bao
Heuristic<-1:length(ts)
Heuristic[1]<-NA
for(j in 2:length(ts)){
xj<-ts[j]-ts[j-1]
D1.loai.old<-as.character(D1$loai.old)
D.h.tap<-as.character(D.h$tap)
if(xj>=0){
for(v in 1:dim(D.h)[1])
if(D1.loai.old[j]==D.h.tap[v] & D.h$t.thai[v]=="raise") bt=v
Heuristic[j]=D.h$Bw.h[bt]
}
else
if(xj<0){
for(v in 1:dim(D.h)[1])
if(D1.loai.old[j]==D.h.tap[v] & D.h$t.thai[v]=="down") bt=v
Heuristic[j]=D.h$Bw.h[bt]
}
}
Heuristic<-ts(Heuristic,start=start(ts),frequency=frequency(ts))
DB3<-
data.frame(thoidiem,sl.goc=D1$ts,quanhemo=quanhemokq,.....
sl.mo=Heuristic)
}#finish Heuristic
#type Chen va Hsu
if(type=="Chen-Hsu"){
if(is.null(bin)){ #bin==null
#Phan lai tap mo
b<-D$ni
level=max(round(length(ts)/n-0.5),min(b),2)#tuy theo y nguoi
dung
f<-1:n
for(i in 1:n) {if(b[i]>(level+2))f[i]=round(b[i]/level+0.5) else f[i]=1;
if(f[i]==0) f[i]=1}
n2=sum(f)
U2<-1:n2; k2<-1:(n2+1); t=0; k2[1]<-k[1]
for( i in 1:n){
tsi=ts[ts>=D$low[i]]
tsi=tsi[tsi<=D$up[i]]
if(divide=="density")new=matdo(tsi,f[i])
else
if(divide=="distance")new=divide.distance(tsi,f[i],D$low[i],D$up
[i])
else
stop("divide phai co gia tri la 'distance' hoac 'frequency'!")
new[1]=min(new[1],D$low[i])
new[length(new)]=max(new[length(new)],D$up[i])
for(j in 2:(f[i]+1)){
t=t+1
k2[t+1]=new[j]
U2[t]=paste("A",t,sep="")
}
}
} else{ #bin !=null
if(min(bin)=max.x || length(bin)<1)
stop("gia tri tam bin khong hop le!")
k2<-1:(length(bin)+2);U2<-1:(length(bin)+1)
k2[1]<-min.x;k2[length(k2)]<-max.x
for(t in 2:(length(k2)-1)) k2[t]=bin[t-1]
for(t in 1:(length(bin)+1)) U2[t]=paste("A",t,sep="")
n2<-length(U2)
}
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
248
D.ch<-data.frame(U2,low2=k2[1:n2],up2=k2[2:(n2+1)])
D.ch$Bw2<-(1/2)*(D.ch$low+D.ch$up)
#Xac dinh moi quan he mo moi
loai2<-1:length(ts)
for(i in 1:length(ts)){
for(j in 1:n2){
if (D.ch$low2[j]<=ts[i] & ts[i]<=D.ch$up2[j])
{loai2[i]=paste("A",j,sep=""); break;}
}}
D1.ch<-data.frame(ts,loai2,loai2.old=c(NA,loai2[1:(length(loai2)-
1)]))
b<-table(D1.ch$loai2)
quanhemokq<-
paste(D1.ch$loai2,quanhemo,D1.ch$loai2.old,sep="")
ni<-1:n2
for(i in 1:n2)
for(j in 1:n2){
if(paste("A",i,sep="")==names(b)[j] & j<=length(b))
{ni[i]=b[j]; break;}else{
if(j>length(b)){ni[i]=0;break;}
}
}
D.ch$ni<-ni
#Xoa bo level thua: begin
tt=0;v<-1:length(D.ch$ni)
for(t0 in 1:length(D.ch$ni))
if(D.ch$ni[t0]==0){tt=tt+1;v[tt]=t0;}
if(tt==0)(v=NULL) else v=v[1:tt]
if(!is.null(v)){
Dt<-D.ch[-v,]
t1=1;
while(t1<=length(levels(Dt$U2))){
test=0;
for(t2 in 1:length(Dt$U2))
if(levels(Dt$U2)[t1]==Dt$U2[t2]){test=1;break;}
if(test==0)levels(Dt$U2)[t1]=NA else t1=t1+1;
}}
else
Dt<-D.ch
#Xoa bo level thua: the end
#Giai mo va du bao
X=ts
A<-as.character(D1.ch$loai2)
P<-1:length(X)
tapmochonam2<-as.character(Dt[,1])
for(i in 1:length(tapmochonam2)) #dinh vi tri tap mo cua nam 2
if(A[2]==tapmochonam2[i]) {vt=i;break}
P[1]<-NA;P[2]=Dt[vt,4]
for(t in 2:(length(ts)-1)){
if(t==2) P[t+1]=rule1(X[t],X[t-1],A[t+1],Dt)
else
{
different=(X[t]-X[t-1])-(X[t-1]-X[t-2])
if(A[t+1]>A[t] & different>=0) P[t+1]=rule2(X[t],X[t-1],X[t-
2],A[t+1],Dt)#th1
else
if(A[t+1]>A[t] & different<=0) P[t+1]=rule3(X[t],X[t-1],X[t-
2],A[t+1],Dt)#th2
else
if(A[t+1]=0) P[t+1]=rule2(X[t],X[t-1],X[t-
2],A[t+1],Dt)#th3
else
if(A[t+1]<A[t] & different<=0) P[t+1]=rule3(X[t],X[t-1],X[t-
2],A[t+1],Dt)#th4
else
if(A[t+1]==A[t] & different>=0) P[t+1]=rule2(X[t],X[t-1],X[t-
2],A[t+1],Dt)#th5
else
if(A[t+1]==A[t] & different<=0) P[t+1]=rule3(X[t],X[t-1],X[t-
2],A[t+1],Dt)#th6
}
}
P<-ts(P,start=start(ts),frequency=frequency(ts))
DB4<-
data.frame(thoidiem,sl.goc=D1.ch$ts,quanhemo=quanhemokq,
".....sl.mo"=P)
diem25<-1:length(D.ch[,3])
diem75<-1:length(D.ch[,3])
h<-(D.ch[,3]-D.ch[,2])/4
canduoi<-D.ch[,2]
for(i in 1:length(D.ch[,3])){
diem25[i]<-canduoi[i]+1*h[i]
diem75[i]<-canduoi[i]+3*h[i]}
D.ch<-data.frame(D.ch[,1],D.ch[,2],diem25,D.ch[,4],diem75,
D.ch[,3],D.ch[,5])
namescot1<-"set"
namescot2<-"dow"
namescot3<-"0.25"
namescot4<-"0.50"
namescot5<-"0.75"
namescot6<-"up"
namescot7<-"num"
colnames(D.ch)<-
c(namescot1,namescot2,namescot3,namescot4,namescot5,
namescot6,namescot7)
}#finish chen-hsu
#---giai mo va du bao---
#---tinh toan do chinh xac---
if(type=="Chen") accuracy<-
av.res(Y=data.frame(DB1[,2]),F=data.frame(Chen=DB1[,4]))
if(type=="Singh") accuracy<-
av.res(Y=data.frame(DB2[,2]),F=data.frame(Singh=DB2[,4]))
if(type=="Heuristic") accuracy<-
av.res(Y=data.frame(DB3[,2]),F=data.frame(Heuristic=DB3[,4]))
if(type=="Chen-Hsu") accuracy<-
av.res(Y=data.frame(DB4[,2]),F=data.frame("Chen-
Hsu"=DB4[,4]))
#---tinh toan do chinh xac---
#---xuat ket qua---
if(trace==TRUE){
namescot1<-"set"
namescot2<-"dow"
namescot3<-"up"
namescot4<-"mid"
namescot5<-"num"
colnames(D)<-
c(namescot1,namescot2,namescot3,namescot4,namescot5)
namescot1<-"point"
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
249
namescot2<-"ts"
namescot3<-"relative"
namescot4<-"forecast"
if(type=="Chen")colnames(DB1)<-
c(namescot1,namescot2,namescot3,namescot4)
if(type=="Singh")colnames(DB2)<-
c(namescot1,namescot2,namescot3,namescot4)
if(type=="Heuristic")colnames(DB3)<-
c(namescot1,namescot2,namescot3,namescot4)
if(type=="Chen-Hsu")colnames(DB4)<-
c(namescot1,namescot2,namescot3,namescot4)
if(type=="Chen") MO<-list(type="Chen",table1=D,table2=DB1,
accuracy=accuracy)
if(type=="Singh") MO<-list(type="Singh",table1=D,table2=DB2,
accuracy=accuracy)
if(type=="Heuristic") MO<-list(type="Heuristic",table1=D,
table2=DB3,accuracy=accuracy)
if(type=="Chen-Hsu") {
if(is.null(bin)) MO<-list(type="Chen-Hsu",table1=D,table2=D.ch,
table3=DB4,accuracy=accuracy)
else
if(!is.null(bin)) MO<-list(type="Chen-Hsu",table1=D.ch,
table2=DB4,accuracy=accuracy)
}}
else
if(trace==FALSE){
if(type=="Chen") MO<-DB1[,4]
if(type=="Singh") MO<-DB2[,4]
if(type=="Heuristic") MO<-DB3[,4]
if(type=="Chen-Hsu") MO<-DB4[,4]}
else
MO<-c("trace phai co gia tri 'TRUE' hoac 'FALSE'")
#---xuat ket qua---
#---ve bieu do du bao---
if(plot==TRUE){
if(type=="Chen") {
goc<-DB1[,2]
dubao<-DB1[,4]
if(length(goc)<50){
plot(goc,col="blue",main=paste("Chen",n,"fuzzy set"),type="o",
pch=16,ylim=c(min(c(goc,dubao),na.rm=1),max(c(goc,dubao),
na.rm=1)),xlab="index",ylab="data");
lines(dubao,col="red",type="o",pch=18)
legend("bottomright","(x,y)",c("ts","forecast"),col=c("blue","red
"),lty=c(1,1),pch=c(16,18))
}
if(length(goc)>49){
plot(goc,col="blue",main=paste("Chen",n,"fuzzy set"),type="l",
ylim=c(min(c(goc,dubao),na.rm=1),max(c(goc,dubao),na.rm=1)),
xlab="index",ylab="data");
lines(dubao,col="red",type="l")
legend("bottomright","(x,y)",c("ts","forecast"),col=c("blue","red
"),lty=c(1,1))
}
k.ve<-par()$yaxp
h=(k.ve[2]-k.ve[1])/k.ve[3]
for(i in 0:k.ve[3]) abline(h=k.ve[1]+h*i,lty=3,col="gray")
}
if(type=="Singh"){
goc<-DB2[,2]
dubao<-DB2[,4]
if(length(goc)<50){
plot(goc,col="blue",main=paste("Singh",n,"fuzzy set"),type="o",
pch=16,ylim=c(min(c(goc,dubao),na.rm=1),max(c(goc,dubao),
na.rm=1)),xlab="index",ylab="data");
lines(dubao,col="red",type="o",pch=18)
legend("bottomright","(x,y)",c("ts","forecast"),col=c("blue",
"red"),lty=c(1,1),pch=c(16,18))
}
if(length(goc)>49){
plot(goc,col="blue",main=paste("Singh",n,"fuzzy set"),type="l",
ylim=c(min(c(goc,dubao),na.rm=1),max(c(goc,dubao),na.rm=1)),
xlab="index",ylab="data");
lines(dubao,col="red",type="l")
legend("bottomright","(x,y)",c("ts","forecast"),col=c("blue","red
"),lty=c(1,1))
}
k.ve<-par()$yaxp
h=(k.ve[2]-k.ve[1])/k.ve[3]
for(i in 0:k.ve[3]) abline(h=k.ve[1]+h*i,lty=3,col="gray")
}
if(type=="Heuristic") {
goc<-DB3[,2]
dubao<-DB3[,4]
if(length(goc)<50){
plot(goc,col="blue",main=paste("Heuristic",n,"fuzzy
set"),type="o",pch=16,ylim=c(min(c(goc,dubao),na.rm=1),
max(c(goc,dubao),na.rm=1)),xlab="index",ylab="data");
lines(dubao,col="red",type="o",pch=18)
legend("bottomright","(x,y)",c("ts","forecast"),col=c("blue","red
"),lty=c(1,1),pch=c(16,18))
}
if(length(goc)>49){
plot(goc,col="blue",main=paste("Heuristic",n,"fuzzy set"),
type="l",ylim=c(min(c(goc,dubao),na.rm=1),max(c(goc,dubao),
na.rm=1)),xlab="index",ylab="data");
lines(dubao,col="red",type="l")
legend("bottomright","(x,y)",c("ts","forecast"),col=c("blue",
"red"),lty=c(1,1))
}
k.ve<-par()$yaxp
h=(k.ve[2]-k.ve[1])/k.ve[3]
for(i in 0:k.ve[3]) abline(h=k.ve[1]+h*i,lty=3,col="gray")
}
if(type=="Chen-Hsu") {
goc<-DB4[,2]
dubao<-DB4[,4]
if(length(goc)<50){
plot(goc,col="blue",main=paste("Chen-Hsu",n,
"fuzzy set"),type="o", pch=16,ylim=c(min(c(goc,dubao),
na.rm=1),max(c(goc,dubao),na.rm=1)),xlab="index",
ylab="data");
lines(dubao,col="red",type="o",pch=18)
legend("bottomright","(x,y)",c("ts","forecast"),col=c("blue",
"red"),lty=c(1,1),pch=c(16,18))
}
if(length(goc)>49){
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
250
plot(goc,col="blue",main=paste("Chen-Hsu",n,"fuzzy
set"),type="l",ylim=c(min(c(goc,dubao),na.rm=1),max(c(goc,
dubao),na.rm=1)),xlab="index",ylab="data");
lines(dubao,col="red",type="l")
legend("bottomright","(x,y)",c("ts","forecast"),col=c("blue",
"red"),lty=c(1,1))
}
k.ve<-par()$yaxp
h=(k.ve[2]-k.ve[1])/k.ve[3]
for(i in -2:(k.ve[3]+2)) abline(h=k.ve[1]+h*i,lty=3,col="gray")
}
}
#---ve bieu do du bao---
MO
}
Hàm fuzzy.ts2( )
fuzzy.ts2 <-function(ts,n=5,w=NULL,D1=0,D2=0,C=NULL,r=4,
trace=FALSE,forecast=NULL,plot=FALSE){
#---ham con---
is.wholenumber <-function(x, tol =
.Machine$double.eps^0.5)
abs(x - round(x)) < tol
namthang<-function(data.ts){
batdau<-start(data.ts)
tanso<-frequency(data.ts)
nam1<-batdau[1]
thang1<-batdau[2]
ketthuc<-end(data.ts)
nam2<-ketthuc[1]
thang2<-ketthuc[2]
namkq<-1:length(data.ts)
thangkq<-1:length(data.ts)
index=0;
for(nam in nam1:nam2)
for(thang in 1:tanso)
if(nam!=nam1 || thang>=thang1){
index=index+1
namkq[index]<-nam
thangkq[index]<-thang
if(nam==nam2 & thang==thang2) break;
}
if(tanso==4)
{thangkq[thangkq==1]<-"Q1";thangkq[thangkq==2]<-"Q1";
thangkq[thangkq==3]<-"Q1";thangkq[thangkq==4]<-"Q1";
print<-paste(namkq,thangkq,sep=" ")}
else
if(tanso==12)
{thangkq[thangkq==1]<-"Jan";thangkq[thangkq==2]<-"Feb";
thangkq[thangkq==3]<-"Mar";thangkq[thangkq==4]<-"Apr";
thangkq[thangkq==5]<-"May";thangkq[thangkq==6]<-"Jun";
thangkq[thangkq==7]<-"Jul";thangkq[thangkq==8]<-"Aug";
thangkq[thangkq==9]<-"Sep";thangkq[thangkq==10]<-"Oct";
thangkq[thangkq==11]<-"Nov";thangkq[thangkq==12]<-
"Dec";
print<-paste(namkq,thangkq,sep=" ")}
else
if(tanso==7)
{thangkq[thangkq==1]<-"Mon";thangkq[thangkq==2]<-
"Tue";
thangkq[thangkq==3]<-"Wed";thangkq[thangkq==4]<-"Thu";
thangkq[thangkq==5]<-"Fri";thangkq[thangkq==6]<-"Sat";
thangkq[thangkq==7]<-"Sun";
print<-paste(namkq,thangkq,sep=" ")}
else
if(tanso!=1)
print<-paste("(",namkq,",",thangkq,")",sep="")
else
print<-namkq
print
}
computeVi<-function(M,table,w){
n<-(dim(M)[1] - w)
cot<-dim(M)[2]
Vi<-1:dim(M)[1]
Vi[1:w]<-NA
for(i in 1:n){
O<-M[i:(w-1+(i-1)),]
if(w==2)O<-t(as.matrix(O))
K<-M[w+(i-1),]
R<-O
for (i1 in 1:cot) for (j1 in 1:(w-1)) if (O[j1,i1] > K[i1]) R[j1,i1] <-
K[i1]
F <- 1:cot
for (i2 in 1:cot) F[i2] <- max(R[, i2])
Vi[w+i]<- sum(F * table$Bw)/sum(F)
}
Vi
}
computeVi2<-function(M,table){
cot<-dim(M)[2]
dong<-(dim(M)[1]-1)
O<-M[1:dong,]
if(w==2)O<-t(as.matrix(O))
K<-M[(dong+1),]
R<-O
for (i1 in 1:cot) for (j1 in 1:(w-1)) if (O[j1,i1] > K[i1]) R[j1,i1] <-
K[i1]
F <- 1:cot
for (i2 in 1:cot) F[i2] <- max(R[, i2])
Vi<- sum(F * table$Bw)/sum(F)
Vi
}
#---ham con---
#---kiem tra input---
if (!is.numeric(ts)) stop("Error in 'ts'!")
if(!is.ts(ts)) stop("Error in 'ts'!") else
if(!is.null(dim(ts)))stop("Error in 'ts'!")
kt<-0
for(i in 1:length(ts))if(is.na(ts[i]))kt=kt+1
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
251
if(kt>0)stop("Time series contain NA!")
if (is.na(n)||!is.numeric(n) || n < 1 || !is.wholenumber(n))
stop("Error in 'n'!")
if (is.na(r)||!is.numeric(r) || r < 0 || !is.wholenumber(r))
stop("Error in 'r'!")
if (is.null(w)||is.na(w)||!is.numeric(w) || w < 2 ||
!is.wholenumber(w)) stop("Error in 'w'!")
if (is.null(C)||is.na(C)||!is.numeric(C)) stop("Error in 'C'!")
if (is.na(D1)||!is.numeric(D1)) stop("Error in 'D1'!")
if (is.na(D2)||!is.numeric(D2)) stop("Error in 'D2'!")
if (is.null(forecast)||is.na(forecast)||!is.numeric(forecast) ||
forecast < 1 || !is.wholenumber(forecast)) stop("Error in
'forecast'!")
if(w>=length(ts)) stop("Error in 'w'!")
#---kiem tra input---
#---tap bien doi---
ts1<-as.vector(diff(ts))
min.x=min(ts1)-D1
max.x=max(ts1)+D2
h=(max.x-min.x)/n
k<-1:(n+1);U<-1:n
for(i in 1:(n+1)){
if(i==1)k[i]=min.x
else
{k[i]=min.x+(i-1)*h
U[i-1]=paste("u",i-1,sep="")}}
D<-data.frame(U,low=k[1:n],up=k[2:(n+1)])
D$Bw<-(1/2)*(D$low+D$up)
table1<-D
#---tap bien doi---
#---mo hoa bien doi---
thoidiem <- namthang(ts)
Ai <- 1:length(ts1)
MATRIX <- matrix(1:(length(ts1) * n), ncol = n)
for (i in 1:length(ts1)) {
temp = ""
for (j in 1:n) {
my.At <- 1/(1 + (C * (ts1[i] - D$Bw[j]))^2)
MATRIX[i, j] <- my.At
At.j <- paste("(",round(my.At,r),"/u",j,sep = "", ")")
if (j == 1) temp <- paste(temp, At.j, sep = "")
else temp <- paste(temp, At.j, sep = ",")
}
Ai[i] <- paste("A[",thoidiem[i+1],"]={",temp,"}",sep="")
}
table2<-data.frame(point=thoidiem,ts=ts,diff.ts=c(NA,ts1))
table3<-c(NA,Ai)
#---mo hoa bien doi---
#---noi suy---
V<-computeVi(MATRIX,table1,w)
N<-c(NA,(ts[-length(ts)]+V))
V<-c(NA,V)
table4<-
data.frame(point=thoidiem,interpolate=N,diff.interpolate=V
)
accuracy<-
av.res(Y=data.frame(ts),F=data.frame("Abbasov.Mamedova"
=table4[,2]))
table4<-na.omit(table4)
rownames(table4)<-c(1:dim(table4)[1])
#---noi suy---
#---du bao---
V<-1:forecast
N<-0:forecast
Ai<-1:forecast
N[1]<-table4[dim(table4)[1],2]
MT<-MATRIX[(dim(MATRIX)[1]-w+1):dim(MATRIX)[1],]
temp<-c(as.vector(ts),1:forecast)
temp<-ts(temp,start=start(ts),frequency=frequency(ts))
temp<-namthang(temp)
temp<-temp[(length(ts)+1):length(temp)]
thoidiem<-temp
for(i in 1:forecast){
V[i]<-computeVi2(MT,table1)
N[i+1]<-N[i]+V[i]
for(chuyen in 1:(dim(MT)[1]-1)) MT[chuyen,]<-
MT[(chuyen+1),]
temp = ""
for (j in 1:n) {
my.At <- 1/(1 + (C * (V[i] - D$Bw[j]))^2)
MT[dim(MT)[1], j] <- my.At
At.j <- paste("(",round(my.At,r),"/u",j,sep = "", ")")
if (j == 1) temp <- paste(temp, At.j, sep = "")
else temp <- paste(temp, At.j, sep = ",")
}
Ai[i] <- paste("A[",thoidiem[i],"]={",temp,"}",sep="")
}
N<-N[-1]
table5<-
data.frame(point=thoidiem,forecast=N,diff.forecast=V)
table6<-Ai
#---du bao---
KQ<-list(type="Abbasov-
Manedova",table1=table1,table2=table2,table3=table3,table
4=table4,table5=table5,table6=table6,accuracy=accuracy)
if(trace==TRUE) MO<-KQ else if(trace==FALSE) MO<-table5
else MO<-c("'trace' must be 'TRUE' or 'FALSE'")
if(plot==TRUE) {
tsp<-ts
tsp[1:w]<-NA
tsp<-na.omit(tsp)
goc<-ts(table2[,2],start=start(ts),frequency=frequency(ts))
dubao<-
ts(c(table4[,2],table5[,2]),start=start(tsp),frequency=frequen
cy(tsp))
if(length(goc)<50){
plot(goc,col="blue",main=paste("Abbasov-Mamedova,
C =",C,"w =",w,"n =",n),type="o",pch=16,xlab="index",
ylab="data");
lines(dubao,col="red",type="o",pch=18)
PHÂN TÍCH SỐ LIỆU THỐNG KÊ VỚI NGÔN NGỮ R
252
legend("bottomright","(x,y)",c("ts","forecast"),col=c("blue","
red"),lty=c(1,1),pch=c(16,18))
}
if(length(goc)>49){
plot(goc,col="blue",main=paste("Abbasov-Mamedova, C
=",C,"w =",w,"n =",n),type="l",xlab="index",ylab="data");
lines(dubao,col="red",type="l")
legend("bottomright","(x,y)",c("ts","forecast"),col=c("blue","
red"),lty=c(1,1))
}
k.ve<-par()$yaxp
h=(k.ve[2]-k.ve[1])/k.ve[3]
for(i in -2:(k.ve[3]+2)) abline(h=k.ve[1]+h*i,lty=3,col="gray")
}
MO
}
Các file đính kèm theo tài liệu này:
- luan_van_viet_minh_0504.pdf