时间序列分段:Top-Down算法python实现

算法原理:
自顶向下TD算法:时间序列的开始点和结束点是首先选中的分段点。然后,遍历两点之间的所有点,找出和这两点连成的直线距离最大的点,如果这个点到直线的距离“大于”预先给定的阀值,则将它作为第三个分段点。这样我们就有了两个线段,做了最初步的划分。
之后,这个新增点到左边相邻点和右边相邻点构成的两条线段,继续寻找距离最大的点,然后,找到的两个点,谁与相应的线段距离最大,且这个距离“大于”阀值,则该点作为第四个分段点….如此循环,直到再也找不到距离大于R的点,分段完成。
这个阀值,也就是点到线段的距离,可以使用正交距离(原始点和分段线段在该点的值的差的绝对值)、垂直距离(原始点到分段线段的直线的长度)和欧式距离,当然也可以设置其他的特性作为阀值,比如拟合误差、又比如弧度、角度、余弦等,由此可以引申很多种不同的算法。
参考文章:http://www.cnblogs.com/by1990/archive/2011/01/15/1936296.html##

具体代码

#计算点到直线的距离
def calculate_error(st, seq_range):
    x = np.arange(seq_range[0], seq_range[1] + 1)
    y = np.array(st[seq_range[0]:seq_range[1] + 1])
    A = np.ones((len(x), 2), float)
    A[:, 0] = x
    # 返回回归系数、残差平方和、自变量X的秩、X的奇异值
    (p, residuals, ranks, s) = np.linalg.lstsq
  • 7
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
电梯调度算法主要有三种:FCFS(先来先服务)、SSTF(最短寻道时间优先)和SCAN(电梯扫描算法)。以下是用Python实现这三种算法代码示例: 1. FCFS算法 ```python def FCFS(head, requests): seek_sequence = [] current = head for request in requests: seek_sequence.append(abs(request - current)) current = request return seek_sequence ``` 其中,head是电梯的初始位置,requests是待处理的请求序列。该算法实现过程如下: 1. 将电梯当前所在位置加入寻道序列中; 2. 遍历请求序列,计算每个请求与电梯当前位置之间的距离,并将距离加入寻道序列中; 3. 将电梯移动到下一个请求位置,并重复上述步骤; 4. 返回寻道序列。 2. SSTF算法 ```python def SSTF(head, requests): seek_sequence = [] current = head while len(requests) > 0: distances = [abs(request - current) for request in requests] index = distances.index(min(distances)) seek_sequence.append(distances[index]) current = requests.pop(index) return seek_sequence ``` 其中,head是电梯的初始位置,requests是待处理的请求序列。该算法实现过程如下: 1. 将电梯当前所在位置加入寻道序列中; 2. 遍历请求序列,计算每个请求与电梯当前位置之间的距离,找到距离最短的请求,并将距离加入寻道序列中; 3. 将电梯移动到距离最短的请求位置,从请求序列中删除该请求,并重复上述步骤; 4. 返回寻道序列。 3. SCAN算法 ```python def SCAN(head, requests, direction): seek_sequence = [] requests.append(head) requests.sort() index = requests.index(head) if direction == 'up': seek_sequence = requests[index:] + requests[:index][::-1] elif direction == 'down': seek_sequence = requests[:index+1][::-1] + requests[index+1:] return seek_sequence ``` 其中,head是电梯的初始位置,requests是待处理的请求序列,direction是电梯移动的方向(向上或向下)。该算法实现过程如下: 1. 将电梯当前所在位置加入请求序列中,并将请求序列排序; 2. 找到电梯当前所在位置在请求序列中的索引; 3. 根据电梯移动的方向,生成新的请求序列; 4. 返回电梯移动的顺序。 以上是用Python实现电梯调度算法代码示例,可以根据实际需要进行调整和修改。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值