[程式] 使用sas做西格瑪計算
------------------------------------------------------------------------
[軟體程式類別]:
sas
[程式問題]:
想將每檔基金內的各個持有的股票權重減去半年前那個時點的該股票權重
並且取絕對值
再將這些這些各個股票相減的權重作西格瑪加總再除以2
然後會有很多不同基金
note:在這當中我有設一個虛擬變數D 我想將若虛擬變數為1的基金資料
減去半年前的資料
[軟體熟悉度]:
低(1~3個月)
[問題敘述]:
各位前輩我想將資料作上述的運算
我的資料格式例如
基金編號 持有金額 caldt_time 股票代號 權重 D
a ... 20050101 1203 ... 0
a ... 20050101 3241 ... 0
a ... 20050101 9321 ... 0
a ... 20050201 1203 ... 0
a ... 20050201 3241 ... 0
a ... 20050201 9321 ... 0
.
.
a ... 20050701 1203 ... 1
a ... 20050701 3241 ... 1
a ... 20050701 0321 ... 1
b ... ... .. ... .
b ... ... .. ... .
b ... ... .. ... .
由上面舉例就是在20050701時虛擬變數為1 所以我要用這個時點
的a資料中各個股票(使用股票代碼)的權重減去半年前的各個股票權重
再來麻煩看到20050701的第三行的股票0321跟原本9321不一樣
所以0321的權重要減去0 然後0減去9321的權重 都要各自取絕對值
最後西格瑪相加再除以2
然後每檔基金(我用基金編號當id)各自回圈去做
這邊我煩惱很久 好像不能用lag跟dif去做
希望有前輩能夠解答 或是提點我需要熟悉那些語法
謝謝大家!!
這邊我想補充一下 其中caldt_time我已經用mdy函數轉成sas內建時間函數
為了方便閱讀所以我把它打成日期
-----------------------------------------------------------------------------
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 118.160.173.252
※ 編輯: mono1023 來自: 118.160.173.252 (05/08 11:44)
推
05/08 12:36, , 1F
05/08 12:36, 1F
→
05/08 12:36, , 2F
05/08 12:36, 2F
→
05/08 12:37, , 3F
05/08 12:37, 3F
→
05/08 12:39, , 4F
05/08 12:39, 4F
→
05/08 12:39, , 5F
05/08 12:39, 5F
→
05/08 12:40, , 6F
05/08 12:40, 6F
→
05/08 12:40, , 7F
05/08 12:40, 7F
→
05/08 13:49, , 8F
05/08 13:49, 8F