如何解决在表上递归运行函数
每次调用函数 fx
都会根据表 x
中的一些数据以及整数 t
和 p
将新列左连接到 q
。
我在下面的 p
和 q
值上显示了所需的迭代,但不知道如何使用 KDB+ 迭代器正确执行此操作。
示例数据和解决方案:
x:([]date:(2013.07.01+til 10);ords:til 10); /Some random table with date (key column)
t:p:([]date:(2013.07.01+1000#til 200);px:1000?10e); /Some random table.
fx:{[x;t;p;q]
/Do something with t;p;q and left-join output column to x on date;
t:([]date:(2013.07.01+til 10);ords:10?10000);
col_names:(`date;`$""sv(string(`P);string(p);string(`Q);string(q)));
t: x lj 1!col_names xcol t;
:t
};
/Run simulation for p=1 to 2 and q=3 to 4 as follows:
fx[ fx[ fx[ fx[x;t;1;3]; t;2;3]; t;1;4]; t;2;4] /How to do this iteration properly?
最后一条语句在 p
和 q
上有两个 for 循环,分别来自 1to2 和 3to4。我确信有一种更好的方法可以使用扫描/覆盖来实现这一点,但我无法弄清楚。有人可以帮忙吗。
解决方法
我们可以将 t
作为投影传递,因为它在每次迭代中保持不变,然后对其他变量使用扫描迭代
fx[;t;;]/[x;1 2 1 2;3 3 4 4]
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。