说明
处理时隙时容易迷失, 因此在处理前先整理好时隙的关系。
内容
时隙是一个整型序列,内容如下
假设窗口都为10, 向前看(back)
# 给定时隙序列和窗口,进行回看(watch back), 生成回看时隙字典【符合左闭右开】
def watchback_slots(data_slots, window = None, is_added_slot=False):
data_slots1 = sorted(list(data_slots))
# 如果没有添加过当前时隙(下一时隙)
if not is_added_slot:
# 增加一个后续时隙
data_slots1.append( max(data_slots) + 1)
# 2 观察时隙进行回看(watch data)
res_dict = {}
for i,watch in enumerate(data_slots1[window:]):
data_slot_start = data_slots1[i]
res_dict[watch] = data_slot_start, watch
return res_dict
向后看(按照左闭右开的原则,当前时隙不能知道当前时隙的数据,所以也属于未来数据)
def overlook_slots(data_slots, window = None, is_added_slot=False):
data_slots1 = sorted(list(data_slots))
# 如果没有添加过当前时隙(下一时隙)
if not is_added_slot:
# 增加一个后续时隙
data_slots1.append( max(data_slots) + 1)
# 眺望时隙(overlook data)
res_dict = {}
for i , overlook in enumerate(data_slots1[:-window]):
data_slot_end = data_slots1[i + window]
data_slot_start = data_slots1[i]
res_dict[overlook] = data_slot_start, data_slot_end
return res_dict
测试,数据的前11行
数据的后12行
watch_back_dict = fs.watchback_slots(data_slots, window = 10)
overlook_dict = fs.overlook_slots(data_slots, window = 10)
选定某个观察点时,在构造数据学习时,我们需要同时需要“前面的”和“后面的”数据,所以将两个字典的键取交集后就是建模数据的时隙。(X, y)
但是在使用时,则取watch的就可以(X)
Note: 原始数据必须是按照时隙汇聚了的。