Build Heterogeneous Agent Model (HAM) in R

更新於 2020/05/12閱讀時間約 4 分鐘
rm(list=ls());gc()
library(data.table)
library(ggplot2)
library(doSNOW)
library(foreach)
library(tidyverse)
library(tibbletime)
library(rlang)
#-----Settings---------#
Ft=0
a=1
b=0.05
c=0.02
d=0.95
eta=0.1
lambda=0.45
v_alpha=0.0025
v_beta=0.025
v_gamma=0.0025
N0=100
K0=50
#------read table----------#
Data<-fread("price.txt",data.table = F)
#-------------------------#
colnames(Data)<-c("Code","Name","Date","Turnover","Price")
TW_names<-unique(Data$Name)
Data<-Data %>%
mutate(log_P=log(Price)) %>%
mutate(Demand_F=c*(Ft-log_P)+rnorm(n=nrow(Data),sd=v_gamma)) %>%
mutate(Demand_C=b*(log_P-lag(log_P))+rnorm(n=nrow(Data),sd=v_beta)) %>%
mutate(Attr_F=0,Attr_C=0)
#------building model-----#
Data_append<- foreach(ix = 1:length(TW_names),.combine="rbind")%do%{
test<-Data %>% filter(Name==TW_names[ix])
for(iy in 4:nrow(test)){
test$Attr_C[iy]=(exp(test$log_P[iy])-exp(test$log_P[iy-1]))*test$Demand_C[iy-2]+d*test$Attr_C[iy-1]
test$Attr_F[iy]=(exp(test$log_P[iy])-exp(test$log_P[iy-1]))*test$Demand_F[iy-2]+d*test$Attr_F[iy-1]
}
return(test)
}
Data_append<-Data_append %>% mutate(FtoC=ifelse(Attr_C>Attr_F,0.5+lambda,0.5-lambda),CtoF=ifelse(Attr_F>Attr_C,0.5+lambda,0.5-lambda))
chartist<- foreach(ix = 1:length(TW_names),.combine="rbind")%do%{
test<-Data_append %>% filter(Name==TW_names[ix])
test=test %>%
mutate(N=N0) %>%
mutate(K=K0) %>%
mutate(Deter=runif(nrow(test),min = 0,max=1))
for(iy in 2:nrow(test)){
test$K[iy]=ifelse(test$Deter[iy]<(N0-test$K[iy-1])/N0*(eta+test$FtoC[iy-1]*(test$K[iy-1])/(N0-1)),test$K[iy-1]+1,ifelse(test$Deter[iy]>(1-(test$K[iy-1]/N0*(eta+test$CtoF[iy-1]*(N0-test$K[iy-1])/(N0-1)))),test$K[iy-1]-1,test$K[iy-1]))
}
return(test)
}
C_W=chartist %>% mutate(chartist_weight=K/N0)
    留言0
    查看全部
    avatar-img
    發表第一個留言支持創作者!
    Zhaung Eric的沙龍 的其他內容
    Download Stock Data from WRDS (accounts are required)
    R example of Branching Ratio
    Download Stock Data from WRDS (accounts are required)
    R example of Branching Ratio
    你可能也想看
    Google News 追蹤
    Thumbnail
    *合作聲明與警語: 本文係由國泰世華銀行邀稿。 證券服務係由國泰世華銀行辦理共同行銷證券經紀開戶業務,定期定額(股)服務由國泰綜合證券提供。   剛出社會的時候,很常在各種 Podcast 或 YouTube 甚至是在朋友間聊天,都會聽到各種市場動態、理財話題,像是:聯準會降息或是近期哪些科
    Thumbnail
    完整標題:build 與「築」或「築搭」、「築做」、「築定」、「築造」、「築建」或「身材之練鍛」、「築體」、「美體」等的轉換密碼,兼談「筑」與 piano 的關聯
    Thumbnail
    這部電影的風格十分強烈,而我只能詞窮的說這讓我想用藝術性來形容,而且在對話與畫面中又帶有哲學思想,只是我也無法歸類是屬於哪一個系統(雖然說對於任何一種哲學思想的歸類都是過度簡化的)。 故事的敘述是很瑣碎的以五個事件(incident)以及最後地獄之旅作為整個電影的架構,沒有所謂的主軸
    Thumbnail
    因為發現身邊很多不滿自己工作的人,其實每天都很忙,但這份填飽肚子的工作,卻沒有為他們的生命帶來任何養分。
    Thumbnail
    由《性愛成癮的女人》的導演-拉斯馮提爾所執導,描述了一個在70年代美國華盛頓州犯下多起謀殺案件的殺人魔傑克,以五個章節分段剖析了殺人犯的心理狀態。 電影在今年五月坎城影展上首映,被媒體稱作「有史以來最難受的觀影體驗」,甚至在播放完畢後以「逃出」形容離開放映場的心情。這部電影到底是如何讓這些觀眾崩潰?
    Thumbnail
    *合作聲明與警語: 本文係由國泰世華銀行邀稿。 證券服務係由國泰世華銀行辦理共同行銷證券經紀開戶業務,定期定額(股)服務由國泰綜合證券提供。   剛出社會的時候,很常在各種 Podcast 或 YouTube 甚至是在朋友間聊天,都會聽到各種市場動態、理財話題,像是:聯準會降息或是近期哪些科
    Thumbnail
    完整標題:build 與「築」或「築搭」、「築做」、「築定」、「築造」、「築建」或「身材之練鍛」、「築體」、「美體」等的轉換密碼,兼談「筑」與 piano 的關聯
    Thumbnail
    這部電影的風格十分強烈,而我只能詞窮的說這讓我想用藝術性來形容,而且在對話與畫面中又帶有哲學思想,只是我也無法歸類是屬於哪一個系統(雖然說對於任何一種哲學思想的歸類都是過度簡化的)。 故事的敘述是很瑣碎的以五個事件(incident)以及最後地獄之旅作為整個電影的架構,沒有所謂的主軸
    Thumbnail
    因為發現身邊很多不滿自己工作的人,其實每天都很忙,但這份填飽肚子的工作,卻沒有為他們的生命帶來任何養分。
    Thumbnail
    由《性愛成癮的女人》的導演-拉斯馮提爾所執導,描述了一個在70年代美國華盛頓州犯下多起謀殺案件的殺人魔傑克,以五個章節分段剖析了殺人犯的心理狀態。 電影在今年五月坎城影展上首映,被媒體稱作「有史以來最難受的觀影體驗」,甚至在播放完畢後以「逃出」形容離開放映場的心情。這部電影到底是如何讓這些觀眾崩潰?