KDB-从表列创建字典以克服8函数参数限制?

KDB-从表列创建字典以克服8函数参数限制?,kdb,Kdb,当我扩展代码时,我发现自己需要向函数发送越来越多的数据,以便正确处理和计算预测 我现在正处于一个转折点,我需要将多个列值连接为一个大字符串或符号(我很有信心可以这样做,但维护起来很困难),而不是创建一个字典(我知道这是最佳实践)来传递给我的函数 例如,我有一个包含数据的表,该表使用输入作为函数变量来计算和返回数据的时间数组(最终将其解组) 下面的例子使用了一个名为Call_Function的字段,其中包含函数名,我想传递几个其他变量(例如tok9、tok10、tok11等) 我正在考虑创建一个类

当我扩展代码时,我发现自己需要向函数发送越来越多的数据,以便正确处理和计算预测

我现在正处于一个转折点,我需要将多个列值连接为一个大字符串或符号(我很有信心可以这样做,但维护起来很困难),而不是创建一个字典(我知道这是最佳实践)来传递给我的函数

例如,我有一个包含数据的表,该表使用输入作为函数变量来计算和返回数据的时间数组(最终将其解组)

下面的例子使用了一个名为Call_Function的字段,其中包含函数名,我想传递几个其他变量(例如tok9、tok10、tok11等)

我正在考虑创建一个类似于下面的字典

dictArguments: {[t] exec tok1, tok2, tok3, tok4, tok5, tok6, tok7, tok8, tok9, tok10, tok11 from t}; 
applyFcast:{[t] update fcast: first[Call_Function]'[dictArguments] from t where not null dictArguments[tok1], 0= count each fcast};


updateTable: applyFcast dictArguments ::;   //run functions in order
t: updateTable over t;  //converge over table t
t: ungroup t; 

有没有人有一个很好的例子来说明如何创建一个字典,以便根据大量现有的表列传递给函数?

这可能是一个愚蠢的问题,但是您是否尝试过在表中的每个上使用一个函数

表只是字典的列表,当你索引到表中时,你就得到了字典。例如:

q)t: ([] a: 5 ? 10; b: 5 ? 10)
q)t 0
a| 1
b| 4
所以如果我们有一个有九列的表

q)t: ([] c1:5?10; c2:5?10; c3:5?10; c4:5?10; c5:5?10; c6:5?10; c7:5?10; c8:5?10; c9:5?10)
q)t
c1 c2 c3 c4 c5 c6 c7 c8 c9
--------------------------
9  5  9  8  4  3  5  5  8 
7  2  0  5  2  7  6  4  1 
6  3  0  2  8  8  4  2  7 
6  9  0  8  0  2  1  7  2 
4  5  9  6  5  1  3  8  4 
如果要对函数
f
执行操作,只需执行以下操作:

q)f: {(x `c1) + x `c9}
q)f each t
17 8 13 8 8

这对你有用吗,还是我有点误解了这个问题?

这可能是个愚蠢的问题,但是你有没有试过在表上使用一个带有函数的

表只是字典的列表,当你索引到表中时,你就得到了字典。例如:

q)t: ([] a: 5 ? 10; b: 5 ? 10)
q)t 0
a| 1
b| 4
所以如果我们有一个有九列的表

q)t: ([] c1:5?10; c2:5?10; c3:5?10; c4:5?10; c5:5?10; c6:5?10; c7:5?10; c8:5?10; c9:5?10)
q)t
c1 c2 c3 c4 c5 c6 c7 c8 c9
--------------------------
9  5  9  8  4  3  5  5  8 
7  2  0  5  2  7  6  4  1 
6  3  0  2  8  8  4  2  7 
6  9  0  8  0  2  1  7  2 
4  5  9  6  5  1  3  8  4 
如果要对函数
f
执行操作,只需执行以下操作:

q)f: {(x `c1) + x `c9}
q)f each t
17 8 13 8 8

这对你有用吗,或者我对这个问题有点误解了吗?

如果你想使用下表,请根据你在前面问题中使用的示例进行操作

q)show t:flip `id`seg`aa`bb`cc`Uknown`Call_Function!(`AAA`AAA`AAA`BBB`CCC;1 2 3 1 1;1500 0n 400 40 900;0n 200 30 40 0n;0.4 0.25 0n 0n 0.35;`bb`aa`cc`cc`bb;`Solvebb`Solveaa`Solvecc`Solvecc`Solvebb);
id  seg aa   bb  cc   Uknown Call_Function
------------------------------------------
AAA 1   1500     0.4  bb     Solvebb
AAA 2        200 0.25 aa     Solveaa
AAA 3   400  30       cc     Solvecc
BBB 1   40   40       cc     Solvecc
CCC 1   900      0.35 bb     Solvebb
并通过将
aa
bb
cc
变量作为字典切片而不是作为三个单独的参数来应用
Call_函数
,然后您可以将
Call_函数定义为

q)Solvebb:{[d](d[`aa]%d[`cc])*(1-exp(neg d[`cc]*1+til 5))};
q)Solveaa:{[d](d[`bb]+d[`cc];d[`bb]*d[`cc])};
q)Solvecc:{[d](d[`aa]+d[`bb];d[`aa]*d[`bb])};
然后,您可以在只包含列
aa
bb
cc
的中间表上使用
each
,而不是同时使用这两个(

q)ungroup update result:first[Call_Function] each ([]aa;bb;cc) by Call_Function from t
id  seg aa   bb  cc   Uknown Call_Function result
---------------------------------------------------
AAA 1   1500     0.4  bb     Solvebb       1236.3
AAA 1   1500     0.4  bb     Solvebb       2065.016
AAA 1   1500     0.4  bb     Solvebb       2620.522
AAA 1   1500     0.4  bb     Solvebb       2992.888
AAA 1   1500     0.4  bb     Solvebb       3242.493
AAA 2        200 0.25 aa     Solveaa       200.25
AAA 2        200 0.25 aa     Solveaa       50
AAA 3   400  30       cc     Solvecc       430
AAA 3   400  30       cc     Solvecc       12000
BBB 1   40   40       cc     Solvecc       80
BBB 1   40   40       cc     Solvecc       1600
CCC 1   900      0.35 bb     Solvebb       759.3735
CCC 1   900      0.35 bb     Solvebb       1294.495
CCC 1   900      0.35 bb     Solvebb       1671.589
CCC 1   900      0.35 bb     Solvebb       1937.322
CCC 1   900      0.35 bb     Solvebb       2124.581

若要根据前面问题中使用的示例进行操作,请选择下表

q)show t:flip `id`seg`aa`bb`cc`Uknown`Call_Function!(`AAA`AAA`AAA`BBB`CCC;1 2 3 1 1;1500 0n 400 40 900;0n 200 30 40 0n;0.4 0.25 0n 0n 0.35;`bb`aa`cc`cc`bb;`Solvebb`Solveaa`Solvecc`Solvecc`Solvebb);
id  seg aa   bb  cc   Uknown Call_Function
------------------------------------------
AAA 1   1500     0.4  bb     Solvebb
AAA 2        200 0.25 aa     Solveaa
AAA 3   400  30       cc     Solvecc
BBB 1   40   40       cc     Solvecc
CCC 1   900      0.35 bb     Solvebb
并通过将
aa
bb
cc
变量作为字典切片而不是作为三个单独的参数来应用
Call_函数
,然后您可以将
Call_函数定义为

q)Solvebb:{[d](d[`aa]%d[`cc])*(1-exp(neg d[`cc]*1+til 5))};
q)Solveaa:{[d](d[`bb]+d[`cc];d[`bb]*d[`cc])};
q)Solvecc:{[d](d[`aa]+d[`bb];d[`aa]*d[`bb])};
然后,您可以在只包含列
aa
bb
cc
的中间表上使用
each
,而不是同时使用这两个(

q)ungroup update result:first[Call_Function] each ([]aa;bb;cc) by Call_Function from t
id  seg aa   bb  cc   Uknown Call_Function result
---------------------------------------------------
AAA 1   1500     0.4  bb     Solvebb       1236.3
AAA 1   1500     0.4  bb     Solvebb       2065.016
AAA 1   1500     0.4  bb     Solvebb       2620.522
AAA 1   1500     0.4  bb     Solvebb       2992.888
AAA 1   1500     0.4  bb     Solvebb       3242.493
AAA 2        200 0.25 aa     Solveaa       200.25
AAA 2        200 0.25 aa     Solveaa       50
AAA 3   400  30       cc     Solvecc       430
AAA 3   400  30       cc     Solvecc       12000
BBB 1   40   40       cc     Solvecc       80
BBB 1   40   40       cc     Solvecc       1600
CCC 1   900      0.35 bb     Solvebb       759.3735
CCC 1   900      0.35 bb     Solvebb       1294.495
CCC 1   900      0.35 bb     Solvebb       1671.589
CCC 1   900      0.35 bb     Solvebb       1937.322
CCC 1   900      0.35 bb     Solvebb       2124.581

谢谢你,马特,我对你在这里所做的事感到非常高兴。在上面的文章中,我肯定有很多内容没有分享。实际上,我有很多数字和字符串数据,我相当长的函数通过这些数据进行解析,以确定如何处理该行。基于字符串和数字数据的排列,函数有很多If和Cond。此链接可能是一个有用的参考[link]我稍后还会添加另一条评论。Matthew,我在这里添加了一个图像片段。[链接]以提供示例。实际上,每一行都是用于生成时间序列数据数组的函数的可变输入。注:每行都是一段,取决于上面的结果。实际上,我希望将每一行的列表/字典传递给一个函数,该函数将在`$float列中返回此数组。对更多功能输入的需要是管理(即…直到累积值、特定日期、增量月份等)的终止点。。。。有效地,这些列表将起作用,但我认为作为一个字典,我可以在函数中调用适当的col名称,如果这样做有意义的话。所有数据都是使用{“vs x}从一个空格分隔的字符串中解析出来的,因此我可以将其与这些附加值放在一起,并传递字符串,这是我的下一步。因此,您首先执行
调用[u函数]
,这只是对单个函数求值吗?(甚至只是一个函数名?)没错,表中有一个名为Call\u function的字段,其中包含每行正在调用的函数的名称。这一点现在工作得很好。挑战在于,我需要将其他标准传递到这些函数中,例如上一部分的累积值、日期和累积月份,这些基本上都是约束(直到累积值=XXX,增量时间段=XXX个月,或者直到某个特定日期,然后终止并移动到下一个段。这是一个大量的排列管理。谢谢Matt,我正在围绕你在这里所做的事情绞尽脑汁。在上面我肯定没有分享很多上下文。实际上,我有很多数字nd字符串数据,我相当长的函数解析它以确定如何处理该行。这些函数有很多基于字符串和数字数据排列的If和Cond。此链接可能是一个有用的参考[link]我稍后还会添加另一条注释。Matthew,我在这里添加了一个图像片段。[link]提供一个示例。实际上,每一行都是用于生成时间序列数据数组的函数的变量输入。请注意,每一行都是一个依赖于上面结果的段。实际上,我希望每一行都有一个列表/字典传递给一个函数,该函数将在`$float列中返回此数组。需要更多函数INPUT用于管理产品的终止点