我在kdb数据库上学习q.我担心q中没有循环这一事实.我需要编写一个算法,我会在像C这样的详细程序中用几个嵌套的for循环编写.但是在q中我被不能循环的事实所困扰.
只是给出一个具体的例子(其中一个),我有这个简单的向量(列表):
q)closures
price
-----
18.54
18.53
18.53
18.52
18.57
18.9
18.9
18.77
18.59
18.51
18.37
Run Code Online (Sandbox Code Playgroud)
我需要一个向3by3这些条目组合的向量,具有叠加,如(使用R语法):闭包[0:2],闭包[1:3],闭包[2:4],闭包[3:5] ......我能怎么做?
一般来说,我如何改变自己的心态,正确编程?
非常感谢您对Marco的建议
我正在定义一个函数,其中包含另一个函数:
find_badTicks:{ [tab;sec] // dummy function, for debug..
Ndays: 10i ;
dates: select distinct date from tab where sym = sec ;
closures: select last price by date from tab where sym = sec ;
returns: 1 _ select ( (price)-(prev price) )%(prev price) from closures ;
stdevs: {[x;y] sd[ (Ndays-1)#y _ x ] } [ (returns)[;`price] ] each til ( (1 - (Ndays-1)) + count (returns)[;`price] ) ;
:tab
}
Run Code Online (Sandbox Code Playgroud)
如果我编译该函数,它将起作用。如果我一行一行地运行,那行得通。但是,如果尝试调用该函数,则会出现错误:
q)testTab: find_badTicks [testTab ; `ENI.IM.Equity] ;
'Ndays
Run Code Online (Sandbox Code Playgroud)
如果我在嵌套函数中删除Ndays,显式编写为10,则它可以工作。是的,我想这是嵌套函数内部的局部变量可见性的问题,在函数执行中:即嵌套函数看不到Ndays,这是函数find_badTicks的局部变量。您知道如何在内部函数中使Ndays可见吗?谢谢马可
kdb ×2