滑动窗口
滑动窗口算法原理
![滑动窗口算法原理](https://img.taocdn.com/s3/m/359c0f5ec4da50e2524de518964bcf84b8d52d5b.png)
滑动窗口算法原理滑动窗口算法(Sliding Window Algorithm)是一种用于解决字符串(或数组)问题的算法。
它通过使用一个固定长度的窗口,在字符串上滑动并保持窗口的大小不变,来寻找满足特定条件的子串(或子数组)。
滑动窗口算法的基本思想是通过两个指针,一个左指针和一个右指针,在给定字符串上移动这两个指针以定位子串。
右指针用于扩展窗口,而左指针用于收缩窗口。
通过不断的移动左右指针,可以在字符串上依次扫描每个可能的子串。
1. 找到满足特定条件的最小子串(Minimum Window Substring)。
2. 找到满足特定条件的最长子串(Longest Substring Without Repeating Characters)。
3. 找到满足特定条件的数组中的最长子数组(Maximum SumSubarray of Size K)。
下面详细解释滑动窗口算法的原理和步骤:1. 定义两个指针,即左指针(left)和右指针(right)。
初始时,左指针指向子串的起始位置,右指针指向子串的结束位置。
2.向右移动右指针,扩展窗口,直到满足特定条件为止。
在扩展窗口的过程中,可以更新一些数据结构来保存所需的信息,比如字符频率的哈希表。
3.当窗口满足特定条件时,开始收缩窗口,即向右移动左指针。
同时,更新所需的信息。
4.在收缩窗口的过程中,不断更新最优解。
如果当前窗口满足最优条件,可以更新最优解。
5.重复步骤2到步骤4,直到右指针到达字符串的末尾。
举个例子来说明滑动窗口算法的应用:问题:给定一个字符串s和一个目标字符串t,在字符串s中找到包含t所有字符的最短子串。
示例输入:s="ADOBECODEBANC",t="ABC"示例输出:"BANC"首先,我们可以使用一个哈希表来记录目标字符串t中每个字符的频率。
然后使用两个指针left和right来定义一个窗口,初始时left和right都指向字符串s的第一个位置。
什么是滑动窗口滑动窗口的机制
![什么是滑动窗口滑动窗口的机制](https://img.taocdn.com/s3/m/13212634abea998fcc22bcd126fff705cd175c42.png)
什么是滑动窗⼝滑动窗⼝的机制 滑动窗⼝概念不仅存在于数据链路层,也存在于传输层,两者有不同的协议,但基本原理是相近的。
那么你对滑动窗⼝了解多少呢?以下是由店铺整理关于什么是滑动窗⼝的内容,希望⼤家喜欢! 滑动窗⼝的概念 滑动窗⼝(Sliding window)是⼀种流量控制技术。
早期的⽹络通信中,通信双⽅不会考虑⽹络的拥挤情况直接发送数据。
由于⼤家不知道⽹络拥塞状况,同时发送数据,导致中间节点阻塞掉包,谁也发不了数据,所以就有了滑动窗⼝机制来解决此问题。
参见滑动窗⼝如何根据⽹络拥塞发送数据仿真视频。
图⽚是⼀个滑动窗⼝的实例: 滑动窗⼝协议是⽤来改善吞吐量的⼀种技术,即容许发送⽅在接收任何应答之前传送附加的包。
接收⽅告诉发送⽅在某⼀时刻能送多少包(称窗⼝尺⼨)。
TCP中采⽤滑动窗⼝来进⾏传输控制,滑动窗⼝的⼤⼩意味着接收⽅还有多⼤的缓冲区可以⽤于接收数据。
发送⽅可以通过滑动窗⼝的⼤⼩来确定应该发送多少字节的数据。
当滑动窗⼝为0时,发送⽅⼀般不能再发送数据报,但有两种情况除外,⼀种情况是可以发送紧急数据,例如,允许⽤户终⽌在远端机上的运⾏进程。
另⼀种情况是发送⽅可以发送⼀个1字节的数据报来通知接收⽅重新声明它希望接收的下⼀字节及发送⽅的滑动窗⼝⼤⼩。
滑动窗⼝的机制 滑动窗⼝协议的基本原理就是在任意时刻,发送⽅都维持了⼀个连续的允许发送的帧的序号,称为发送窗⼝;同时,接收⽅也维持了⼀个连续的允许接收的帧的序号,称为接收窗⼝。
发送窗⼝和接收窗⼝的序号的上下界不⼀定要⼀样,甚⾄⼤⼩也可以不同。
不同的滑动窗⼝协议窗⼝⼤⼩⼀般不同。
发送⽅窗⼝内的序列号代表了那些已经被发送,但是还没有被确认的帧,或者是那些可以被发送的帧。
下⾯举例说明,假设发送窗⼝尺⼨为2,接收窗⼝尺⼨为1: 分析:①初始态,发送⽅没有帧发出,发送窗⼝前后沿相重合。
接收⽅0号窗⼝打开,等待接收0号帧;②发送⽅打开0号窗⼝,表⽰已发出0帧但尚确认返回信息。
滑动窗口协议书
![滑动窗口协议书](https://img.taocdn.com/s3/m/bace477c2e60ddccda38376baf1ffc4ffe47e2af.png)
滑动窗口协议书甲方(发送方):_____________________乙方(接收方):_____________________鉴于甲方与乙方就数据传输服务达成合作意向,为确保数据传输的准确性、完整性和稳定性,双方同意采用滑动窗口协议来管理数据传输过程。
现就滑动窗口协议的具体条款达成如下协议:第一条协议目的本协议旨在通过滑动窗口机制,确保双方在数据传输过程中能够有效地控制数据流量,避免数据丢失和重复发送,提高传输效率。
第二条协议定义2.1 滑动窗口协议:指在数据传输过程中,发送方在未收到接收方确认信息前,可以连续发送多个数据包,但发送的数据包数量受到窗口大小的限制。
2.2 窗口大小:指在任何时刻,发送方可以发送但尚未收到确认的数据包的最大数量。
第三条窗口大小3.1 双方同意,初始窗口大小设定为N个数据包。
3.2 根据网络状况和接收方的处理能力,乙方有权要求调整窗口大小,但需提前通知甲方,并得到甲方的同意。
第四条数据传输4.1 甲方在发送数据时,应按照滑动窗口协议的规定,控制发送的数据包数量。
4.2 乙方在接收数据后,应及时向甲方发送确认信息,以便甲方更新窗口状态并发送后续数据包。
第五条数据确认5.1 乙方在接收到数据包后,应检查数据的完整性和正确性。
5.2 若数据包无误,乙方应向甲方发送确认信息;若数据包有误,乙方应向甲方发送否定确认信息,并要求重新发送。
第六条超时重传6.1 若甲方在规定时间内未收到乙方的确认信息,应视为数据传输失败,甲方应重新发送该数据包。
6.2 双方应协商确定超时时间,并在协议中明确。
第七条协议变更7.1 任何一方希望变更本协议内容,应提前通知对方,并得到对方的书面同意。
7.2 变更后的协议内容,自双方签字盖章之日起生效。
第八条争议解决8.1 本协议在履行过程中发生的任何争议,双方应通过友好协商解决。
8.2 如协商不成,任何一方均可向甲方所在地人民法院提起诉讼。
第九条其他9.1 本协议自双方签字盖章之日起生效,有效期为一年,除非双方另有书面约定。
tcp滑动窗口机制原理
![tcp滑动窗口机制原理](https://img.taocdn.com/s3/m/86089a8a0d22590102020740be1e650e52eacf00.png)
tcp滑动窗口机制原理TCP滑动窗口机制原理。
TCP(Transmission Control Protocol)是一种面向连接的、可靠的、基于字节流的传输层通信协议,它为应用层提供可靠的数据传输服务。
在TCP协议中,滑动窗口机制是一种重要的流量控制机制,它能够有效地提高网络传输的效率和可靠性。
滑动窗口机制是指发送方和接收方通过动态调整窗口大小来控制数据流量的一种机制。
在TCP连接中,发送方和接收方各自维护一个窗口,用来控制数据的发送和接收。
发送方的窗口大小取决于接收方的窗口大小和网络的拥塞情况,发送方只能发送窗口范围内的数据,而接收方则根据自身处理能力和缓存大小确定窗口大小,控制发送方的发送速度。
滑动窗口机制的原理如下,当发送方发送数据时,如果接收方的窗口大小为0,发送方将停止发送数据;当接收方准备好接收数据时,它会通知发送方它的窗口大小,发送方会根据接收方的窗口大小和网络状况来确定发送数据的大小和速度。
如果网络拥塞,接收方的窗口大小会减小,发送方需要相应地调整发送速度;如果网络畅通,接收方的窗口大小会增大,发送方也会相应地提高发送速度。
这样,通过动态调整窗口大小,滑动窗口机制能够实现网络传输的流量控制,提高网络的利用率和可靠性。
滑动窗口机制的优点在于它能够根据网络状况动态调整数据的发送速度,避免了网络拥塞和数据丢失的问题。
同时,滑动窗口机制还能够充分利用网络带宽,提高网络传输的效率。
另外,滑动窗口机制还能够保证数据的有序传输,确保数据的完整性和可靠性。
总之,TCP滑动窗口机制是一种重要的流量控制机制,它能够有效地提高网络传输的效率和可靠性。
通过动态调整窗口大小,滑动窗口机制能够根据网络状况实现流量控制,避免网络拥塞和数据丢失的问题。
因此,了解和掌握滑动窗口机制的原理对于理解TCP协议和网络通信具有重要意义。
滑动窗口协议
![滑动窗口协议](https://img.taocdn.com/s3/m/e1307d43ba68a98271fe910ef12d2af90342a847.png)
滑动窗口协议引言在计算机网络中,滑动窗口协议是一种常用的数据传输协议,用于确保可靠的数据传输。
本文将介绍滑动窗口协议的基本概念、工作原理以及应用场景等内容。
滑动窗口协议的基本概念滑动窗口协议是一种基于窗口的流量控制协议。
在数据传输过程中,发送方和接收方都维护着一个固定大小的窗口,用于管理待发送的数据和已接收的数据。
滑动窗口协议的工作原理滑动窗口协议的工作原理可以简单地描述为以下几个步骤: 1. 发送方将待发送的数据分割成若干个数据包,并按顺序发送。
2. 接收方接收数据包,并发送确认信息给发送方。
3. 发送方收到确认信息后,将窗口向前滑动一个单位,继续发送下一个数据包。
4. 如果接收方未收到某个数据包,或者数据包有错误,将请求发送方重新发送该数据包。
滑动窗口协议的优势相比于其他传输协议,滑动窗口协议具有以下优势: 1. 可靠性:滑动窗口协议通过确认机制和重传机制,能够确保数据的可靠传输。
2. 流量控制:通过窗口大小的控制,滑动窗口协议可以有效控制数据传输的速率,避免数据的丢失和网络拥塞。
3. 高效性:滑动窗口协议支持并行发送多个数据包,提高了数据传输的效率。
滑动窗口协议的应用场景滑动窗口协议广泛应用于各种数据传输场景,包括但不限于: 1. 文件传输:在文件传输过程中,滑动窗口协议可以确保文件的完整性和正确性。
2. 视频流传输:通过滑动窗口协议,可以实现对视频流的实时传输和播放。
3. 数据库同步:在数据库同步过程中,滑动窗口协议可以确保数据的一致性和可靠性。
总结滑动窗口协议是一种常用的数据传输协议,通过窗口管理机制,实现了数据的可靠传输和流量控制。
它具有可靠性、高效性和流量控制等优势,并在文件传输、视频流传输和数据库同步等场景中得到广泛应用。
熟悉滑动窗口协议的工作原理和应用场景,对于网络通信的设计和优化具有重要意义。
滑动窗口协议的名词解释
![滑动窗口协议的名词解释](https://img.taocdn.com/s3/m/89dda3ae112de2bd960590c69ec3d5bbfc0ada7a.png)
滑动窗口协议的名词解释在计算机网络领域中,滑动窗口协议是一种用于数据传输的通信协议。
它利用了滑动窗口机制,以实现可靠的数据传输和流量控制。
滑动窗口协议的设计理念是基于发送方与接收方之间的通信通道。
一、滑动窗口机制滑动窗口机制是滑动窗口协议的核心概念之一。
它是一种流量控制技术,通过动态调整发送方与接收方之间的传输窗口大小来控制数据传输速率。
发送方和接收方各自维护一个窗口,窗口的大小取决于网络条件和协议设计。
二、发送方窗口发送方窗口是指发送方维护的一个缓冲区,用于存储待发送的数据包。
窗口的大小可以根据网络状况和接收方的接收能力进行动态调整。
发送方每发送一个数据包,窗口向后滑动一格。
如果接收方确认接收到数据包,发送方将滑动窗口继续向后滑动,发送下一个数据包。
三、接收方窗口接收方窗口是指接收方维护的一个缓冲区,用于按序接收发送方发送的数据包。
接收方窗口的大小也可以根据网络状况和接收方的处理能力进行动态调整。
接收方通过发送确认消息告知发送方已接收到哪些数据包,以便发送方进行相应的调整。
四、滑动窗口协议的工作原理滑动窗口协议的工作原理基于两个核心概念:流量控制和可靠传输。
发送方和接收方通过协商和动态调整窗口大小,以实现合理的数据传输速率,并保证数据的可靠性。
1. 流量控制滑动窗口协议通过发送方和接收方之间窗口的大小动态调整,以控制数据传输速率。
发送方根据接收方窗口大小和网络状况来发送数据包,确保不会过载接收方。
一旦接收方窗口满了,发送方将停止发送,直到接收方发送确认消息,表示有更多可接收的空间。
这种流量控制机制可以有效避免网络拥塞和数据丢失。
2. 可靠传输滑动窗口协议通过确认机制和超时重传来实现数据的可靠传输。
发送方在发送数据包后,等待接收方的确认消息。
如果发送方在规定时间内没有收到确认消息,就会认为数据包丢失,将重传该数据包。
接收方在接收到数据包后,发送确认消息给发送方,以表示已经接收到该数据包。
如果接收方在规定时间内未发送确认消息,发送方会重新发送该数据包。
TCP协议中的滑动窗口与拥塞窗口:区别与联系(四)
![TCP协议中的滑动窗口与拥塞窗口:区别与联系(四)](https://img.taocdn.com/s3/m/189fdb5c2379168884868762caaedd3383c4b5dd.png)
TCP协议中的滑动窗口与拥塞窗口:区别与联系引言:在计算机网络中,TCP协议是最常用的传输层协议之一。
而在TCP 协议中,滑动窗口和拥塞窗口是两个重要的概念。
它们分别涉及到网络通信的效率和流量控制问题。
本文将深入探讨滑动窗口和拥塞窗口的区别与联系。
一、滑动窗口滑动窗口是TCP协议中用于实现流量控制和确认机制的一种机制。
通过滑动窗口,发送方和接收方可以有效地处理网络拥塞及数据传输的不确定性。
滑动窗口的原理在TCP协议中,滑动窗口是发送方和接收方之间的一种协调机制。
发送方通过滑动窗口来确定可以发送的数据量,而接收方通过滑动窗口来告知发送方可以接收的数据量。
滑动窗口的大小会随着网络环境和双方处理能力的变化而调整,从而实现流量的控制。
滑动窗口的功能滑动窗口具有以下功能:- 确认机制:接收方通过滑动窗口来告知发送方已经收到的数据,从而确认传输完成。
- 流量控制:发送方通过滑动窗口来设置可以发送的数据量,避免过多数据拥塞网络。
- 重传机制:发送方通过滑动窗口来检测和重传丢失的数据包,保证数据的可靠传输。
二、拥塞窗口拥塞窗口是TCP协议中用于控制网络拥塞程度的一种机制。
通过拥塞窗口,TCP协议可以根据网络拥塞情况来调整数据传输的速率,从而避免网络拥塞。
拥塞窗口的原理拥塞窗口通过动态调整发送方可以发送数据的速率,以避免网络拥塞。
当网络发生拥塞时,拥塞窗口会缩小,降低发送速率;当网络恢复正常时,拥塞窗口会逐渐增大,提高发送速率。
拥塞窗口的功能拥塞窗口具有以下功能:- 控制发送速率:拥塞窗口通过调整发送速率来避免网络拥塞,保证数据能够正常传输。
- 动态适应网络:拥塞窗口能够根据网络拥塞程度的变化,灵活调整发送速率,以适应不同的网络环境和负载。
三、滑动窗口与拥塞窗口的区别尽管滑动窗口和拥塞窗口在TCP协议中都扮演着重要的角色,它们之间存在一些区别。
功能不同滑动窗口主要用于确认机制和流量控制,而拥塞窗口则专注于控制发送速率,避免网络拥塞。
滑动窗口的工作原理
![滑动窗口的工作原理](https://img.taocdn.com/s3/m/aaa8aedd50e79b89680203d8ce2f0066f4336473.png)
滑动窗口的工作原理
滑动窗口是一种常用的算法技巧,用于在数组或字符串上的连续子序列或子字符串中进行操作或查找。
其工作原理是通过使用两个指针来维护一个窗口,窗口的大小可以根据具体问题的要求进行调整。
具体来说,滑动窗口的工作原理如下:
1. 初始化左右指针:首先,将左指针和右指针都初始化为数组或字符串的起始位置。
2. 移动右指针:将右指针向右移动,以扩展窗口,直到满足特定的条件。
3. 更新结果:在每次移动右指针后,根据问题的要求更新结果。
4. 移动左指针:如果满足特定条件,那么将左指针向右移动,以缩小窗口。
在移动左指针后,需要根据问题的要求更新结果。
5. 重复操作:重复步骤2至步骤4,直到右指针到达数组或字
符串的末尾。
通过不断地移动窗口的左右指针,滑动窗口算法可以在固定时间内解决很多有关连续子序列或子字符串的问题。
例如,可以使用滑动窗口来解决最小覆盖子串、最长无重复字符子串、找到字符串中所有字母异位词等问题。
需要注意的是,在不同的问题场景下,窗口的大小可能需要根据具体情况来调整。
有时候,窗口的大小是固定的;有时候,窗口的大小是可变的,可以根据问题要求进行调整。
总之,滑动窗口通过移动左右指针来维护一个窗口,在连续子序列或子字符串上进行操作或查找。
它是一种高效的解决问题的算法技巧。
滑动窗口技术名词解释
![滑动窗口技术名词解释](https://img.taocdn.com/s3/m/c6f3782aa517866fb84ae45c3b3567ec112ddc6c.png)
滑动窗口技术名词解释滑动窗口技术,听上去好像是个高大上的东西,但其实就像是在日常生活中找东西那么简单。
想象一下,你在大街上走,突然发现路边有个小摊,卖着香喷喷的烤串。
你想吃,却又不想停下脚步,怎么办?这时候,你就可以用“滑动窗口”的思路。
就像把眼睛“滑动”过去,快速抓住想要的东西。
这个技术的核心就是在一个固定大小的窗口内,灵活地移动,通过不断地更新数据,找到你真正需要的信息。
无论是在处理数据流,还是分析数组,滑动窗口总能帮你迅速抓住重点,避免了无谓的浪费。
举个简单的例子,假设你正在研究一个数列,想找出某个子数组的和,听起来是不是有点儿复杂?但如果你用滑动窗口的方式,只要固定一个窗口大小,然后在这个范围内来回滑动,就能快速计算出和。
就像在厨房里,做饭的时候不停地试味道,慢慢调整,最终调出最佳的味道。
滑动窗口让你的操作更高效,能在时间上节省不少。
想象一下,如果没有这个技术,你就得一个一个数,简直比上山打猎还累。
这就像是放风筝。
你得抓住风的方向,才能让风筝飞得又高又稳。
滑动窗口的作用就是让你把注意力集中在关键部分,避免在无关紧要的地方浪费时间和精力。
假设你在看电影,总是被旁边的手机和人打扰,结果根本没法好好享受剧情。
用滑动窗口的方法,就像把注意力“聚焦”到屏幕上,慢慢深入剧情,感受每一个情感波动,最终才能体会到电影的魅力。
滑动窗口还可以用在网络流量监控上。
网络数据就像高速公路上的车流,车流量大时,你需要时刻监控每个路口,防止拥堵。
通过滑动窗口技术,你可以在每个时间段内,快速查看流量情况,提前采取措施,避免“堵车”。
想想如果没有这项技术,恐怕数据就像漫天飞舞的雪花,根本无从下手。
滑动窗口的出现就像是给你装上了导航仪,让你在复杂的网络中轻松前行。
滑动窗口也不是万能的,它有自己的局限性。
比如在处理极大数据时,如果窗口大小选择不当,就可能出现效率低下的问题。
这就像我们去逛商场,走太快可能错过好东西,走太慢又容易累。
时序滑动窗口评估方法
![时序滑动窗口评估方法](https://img.taocdn.com/s3/m/632ed57666ec102de2bd960590c69ec3d5bbdbe7.png)
时序滑动窗口评估方法时序滑动窗口评估方法,也被称为滚动交叉验证,是一种用于评估时序数据模型性能的方法。
在时序数据中,每个数据点的观测值与前面的观测值相关联,这种相关性需要在模型评估过程中得到有效处理。
时序滑动窗口评估方法通过模拟真实预测环境,将训练集和测试集划分为连续时间窗口,以便更准确地评估模型的性能。
以下是时序滑动窗口评估方法的基本原理及步骤:1.数据预处理:将原始时序数据按照时间顺序进行排序,并进行必要的数据清洗和特征工程。
确保数据的质量和合理性。
2.定义时间窗口:确定时间窗口的大小和间隔。
时间窗口的大小决定了每个训练和测试集的样本数量,时间窗口的间隔决定了预测的时间跨度。
3.划分训练集和测试集:根据时间窗口的大小和间隔,将数据划分为多个连续的训练集和测试集。
通常情况下,训练集和测试集之间是有重叠的。
4.建立模型:使用训练集来训练模型。
可以选择适合时序数据的模型,例如ARIMA模型、LSTM网络等。
根据实际情况决定模型的复杂度。
5.模型评估:使用测试集来评估模型的性能。
在每个时间窗口中,使用训练集来训练模型,并使用测试集来进行预测。
计算预测结果与真实值之间的误差,例如均方根误差(RMSE)、平均绝对误差(MAE)等。
6.性能指标计算:对于每个时间窗口,可以计算各种性能指标,例如平均误差、方差、相关系数等。
可以将这些指标的平均值作为模型整体性能的评估指标。
7.结果分析:根据评估指标和实际需求,分析模型的性能。
如果模型表现良好,则可以使用该模型进行预测。
如果模型表现不佳,则需要调整模型参数或者尝试其他模型。
在实际应用中,时序滑动窗口评估方法可以用于评估各种时序数据模型,例如股票价格预测、天气预报、销售预测等。
通过合理选择时间窗口的大小和间隔,可以更准确地评估模型的性能,并提供对未来数据的可靠预测。
总之,时序滑动窗口评估方法是一种针对时序数据的有效评估方法。
在实际应用中,根据具体问题的需求,可以灵活调整时间窗口的大小和间隔,并结合合适的模型来评估和预测时序数据的性能。
滑动窗口实验报告
![滑动窗口实验报告](https://img.taocdn.com/s3/m/e44e5892db38376baf1ffc4ffe4733687e21fcdc.png)
实验目的:了解滑动窗口技术的原理和应用,通过实验验证滑动窗口在信号处理、图像处理和文本分析等领域的有效性。
实验环境:操作系统:Windows 10编程语言:Python 3.8库:NumPy、Matplotlib、Pandas实验内容:1. 滑动窗口在信号处理中的应用2. 滑动窗口在图像处理中的应用3. 滑动窗口在文本分析中的应用实验一:滑动窗口在信号处理中的应用1. 实验目的通过实验验证滑动窗口在信号处理中的有效性,对信号进行平滑处理,减少噪声干扰。
2. 实验步骤(1)导入NumPy库,生成一个包含噪声的信号;(2)定义滑动窗口函数,实现信号的平滑处理;(3)绘制原始信号和经过滑动窗口处理后的信号;(4)分析实验结果。
3. 实验代码```pythonimport numpy as npimport matplotlib.pyplot as plt# 生成信号signal = np.sin(np.linspace(0, 10, 100)) + np.random.normal(0, 0.5, 100)# 定义滑动窗口函数def moving_average(data, window_size):weights = np.ones(window_size) / window_sizereturn np.convolve(data, weights, mode='valid')# 处理信号window_size = 5smoothed_signal = moving_average(signal, window_size)# 绘制信号plt.figure(figsize=(10, 5))plt.plot(signal, label='Original Signal')plt.plot(np.arange(window_size // 2, len(signal) - window_size // 2), smoothed_signal, label='Smoothed Signal')plt.legend()plt.show()```4. 实验结果实验结果表明,经过滑动窗口处理后的信号相对于原始信号更加平滑,噪声干扰得到了有效抑制。
滑动窗口工作原理
![滑动窗口工作原理](https://img.taocdn.com/s3/m/304d3069e3bd960590c69ec3d5bbfd0a7956d5b4.png)
滑动窗口工作原理
滑动窗口是一种常用的算法技巧,可以用来解决一些字符串或数组相关的问题。
它的基本思想是在一个固定大小的窗口内,通过滑动窗口的方式来处理数据。
具体的工作原理如下:
1. 初始化滑动窗口的大小,并将窗口应用于数据的初始部分。
窗口通常由一个起始位置和一个结束位置来表示。
2. 分析窗口内的数据,对其进行处理或计算。
可以使用此数据来解决问题或获取所需的结果。
3. 移动窗口,即将窗口向右滑动或向左滑动,以便处理下一个数据部分。
滑动窗口的移动通常是通过调整窗口的起始位置和结束位置来完成的。
4. 重复步骤2和步骤3,直到窗口滑动到数据的末尾。
滑动窗口的关键点是确定窗口的大小和如何移动窗口。
在实际应用中,可以根据具体问题的要求来确定窗口的大小。
窗口的移动步长也可以根据需要进行调整,例如在某些问题中要求窗口连续滑动,而在其他问题中可能需要窗口间隔滑动。
通过滑动窗口,我们可以有效地处理一些需要对数据进行连续或局部计算的问题,例如求解最大值、最小值、平均值,或者在字符串中查找满足某种条件的子串。
它可以将原本需要遍历
整个数据的复杂度优化为线性的复杂度,从而提高算法的效率。
总的来说,滑动窗口是一种高效的算法技巧,可以用于处理字符串或数组相关的问题,在实践中被广泛应用。
滑动窗口获取值的方法
![滑动窗口获取值的方法](https://img.taocdn.com/s3/m/8cf687753069a45177232f60ddccda38366be159.png)
滑动窗口获取值的方法
1. 嘿,你知道吗?滑动窗口获取值就像是在一个宝藏箱里找宝贝!比如说在处理一列数字时,想象窗口像小手一样,从这头滑到那头,抓住我们想要的值。
这多有趣呀!
2. 哇塞,想不想知道滑动窗口获取值怎么玩得转?就像你走在一条路上,用一个小框框去框住路上的风景,框住的就是你要的。
比如分析股票价格变化,那窗口就是你的神奇视界!
3. 嘿呀,滑动窗口获取值其实超简单的啦!好比你拿起一个望远镜头,移动它去看不同的地方,看到的就是你能获取的值呀。
就像监测网络流量时,这个窗口可太关键了呢!
4. 哎呀呀,滑动窗口获取值难道不是很有意思吗?想象一下它像个小机器人帮你抓取数据呢!比如说在统计单词出现频率时,它就好好干活啦。
5. 嘿哟,你可别小瞧了滑动窗口获取值哟!这就好像你在拼图,一块一块找对位置。
像在音频处理中,那窗口就是寻找美妙音符的魔法工具!
6. 哈哈,滑动窗口获取值可是很有魔力的哦!就如同你在挑选美丽花朵,用那个窗口去挑你最喜欢的那几朵。
比如在游戏中统计得分,就是靠它啦!
7. 哇哦,滑动窗口获取值真的超厉害的呢!可以把它想象成一个神奇的筛子,筛出你要的精华。
比如从大量文本中提取关键信息,它可是大功臣呀!我觉得呀,滑动窗口获取值的方法真是神奇又好用,大家一定要好好掌握呀!。
滑动窗口的工作原理
![滑动窗口的工作原理](https://img.taocdn.com/s3/m/86142d7130126edb6f1aff00bed5b9f3f90f720e.png)
滑动窗口的工作原理滑动窗口(Sliding Window)是一种常用的算法技巧,用于解决多种问题,如字符串匹配、子数组/子串等的问题。
它的工作原理是通过维护一个动态大小的窗口,在数据结构中滑动该窗口,以求解问题。
1.初始化窗口:设置两个指针,即左指针l和右指针r,并将它们都指向序列的起始位置。
开始时,窗口的大小是0。
2.扩展窗口:右指针不断向右侧移动,并根据题目要求扩大窗口的大小。
可以是逐个元素地移动右指针,或者跳跃性地移动右指针。
在每次扩展窗口之后,需要检查窗口是否满足题目给定的条件。
3.判断条件:在每次扩展窗口之后,需要判断当前窗口是否满足题目给定的条件。
可以是统计窗口中的元素个数、求和、求平均值等。
如果窗口满足条件,则进入下一步;如果不满足条件,则缩小窗口。
4.缩小窗口:如果窗口不满足条件,需要缩小窗口的大小。
左指针向右侧移动,即缩小窗口的大小。
在缩小窗口的同时,需要更新窗口内的数据和统计值,以保持数据的正确性。
5.更新最优解:如果窗口满足题目给定的条件,需要更新最优解。
最优解可以是最短子串、最长子序列、最大值、最小值等,根据题目具体要求而定。
在更新最优解之后,可以继续扩展窗口或者缩小窗口,以便继续寻找更优的解。
6.终止条件:重复上述步骤,直到右指针移动到序列的末尾,或者满足题目给定的终止条件。
在满足终止条件后,可以返回最终结果或者统计信息。
滑动窗口算法的时间复杂度通常为O(n),其中n为序列的长度。
由于指针只遍历一遍,因此滑动窗口算法的时间复杂度是线性的。
滑动窗口算法的应用场景非常广泛,主要用于解决字符串匹配、子数组/子串等问题。
例如,可以用滑动窗口算法解决的问题包括最小覆盖子串、最长无重复字符子串、字符串排列等。
总的来说,滑动窗口是一种非常实用的算法技巧,通过维护一个动态变化的窗口,可以有效地解决多种问题。
通过合理地选择窗口的扩展和缩小方式,以及对窗口内部数据的处理和更新,可以高效地求解问题,同时保持时间复杂度较低。
TCP协议中的滑动窗口与拥塞窗口:区别与联系(一)
![TCP协议中的滑动窗口与拥塞窗口:区别与联系(一)](https://img.taocdn.com/s3/m/f48892f264ce0508763231126edb6f1afe007167.png)
TCP(Transmission Control Protocol)是互联网上最常用的传输层协议之一,它的设计和实现非常复杂。
其中,滑动窗口和拥塞窗口是TCP协议中的两个重要概念,它们在保证数据可靠传输和网络拥塞控制方面扮演着关键的角色。
本文将就滑动窗口和拥塞窗口进行论述,深入分析它们的区别与联系。
一、滑动窗口滑动窗口是一种流量控制机制,它允许发送方一次性发送多个数据包而不需要等待确认。
发送方和接收方约定一个窗口大小,发送方只能发送从窗口的起始位置开始的连续几个数据包,当接收方确认收到其中一个数据包后,窗口向前滑动,发送方可以发送新的数据包。
这样就能够有效利用网络的带宽,提高传输效率。
滑动窗口的窗口大小可以根据网络的情况进行动态调整。
如果发生丢包或网络延迟较高,发送方就会收到较长的确认延迟时间,此时发送方会减小窗口大小,避免拥塞。
反之,如果网络情况较好,发送方会逐渐增大窗口大小,以充分利用带宽,提高传输速度。
二、拥塞窗口拥塞窗口是一种网络拥塞控制机制,用于防止网络过载。
在TCP 协议中,拥塞窗口大小限制了一次发送的数据量,以防止过多的数据在网络中引起拥塞。
拥塞窗口的大小是根据网络的拥塞程度动态调整的。
当网络拥塞时,接收方发送的确认包会提示发送方减小拥塞窗口大小,以降低数据发送速率。
而当网络负载减轻时,接收方会提示发送方增大拥塞窗口,提高数据发送速率。
拥塞窗口的调整是通过拥塞控制算法来完成的,常见的算法有慢开始和拥塞避免算法。
慢开始算法会在连接刚建立时,发送方以较小的窗口大小发送数据,然后根据网络的状况逐渐增大窗口大小。
拥塞避免算法主要是根据网络延迟和丢包情况进行调整,以避免网络拥塞。
三、滑动窗口与拥塞窗口的区别滑动窗口和拥塞窗口在TCP协议中有着不同的作用。
滑动窗口主要用于流量控制,用于控制发送方的数据发送量,以适应网络的带宽和接收方的接收能力。
而拥塞窗口主要用于网络拥塞控制,防止过多的数据在网络中引起拥塞。
卷积神经网络中的滑动窗口技术应用(六)
![卷积神经网络中的滑动窗口技术应用(六)](https://img.taocdn.com/s3/m/01285ce8dc3383c4bb4cf7ec4afe04a1b071b0c0.png)
卷积神经网络中的滑动窗口技术应用卷积神经网络(Convolutional Neural Network,CNN)是一种深度学习模型,广泛应用于图像识别、语音识别和自然语言处理等领域。
滑动窗口技术(Sliding Window)是CNN模型中的一种重要技术,它能够有效地处理输入数据,并在图像识别任务中取得良好的效果。
滑动窗口技术的基本原理是将输入数据分割为多个小区域,然后对每个小区域进行卷积操作。
在图像识别任务中,滑动窗口技术可以帮助CNN模型有效地捕捉图像中的局部特征,从而提高模型的识别准确度和鲁棒性。
接下来,我们将详细探讨滑动窗口技术在CNN模型中的应用。
首先,滑动窗口技术可以帮助CNN模型捕捉图像中的局部特征。
在图像识别任务中,图像往往包含了大量的信息,而CNN模型需要从中提取出有用的特征来进行识别。
滑动窗口技术可以将图像分割为多个小区域,然后对每个小区域进行卷积操作,从而可以有效地捕捉到图像中的局部特征。
这样一来,CNN模型就可以更准确地识别图像中的物体、场景等内容。
其次,滑动窗口技术可以提高CNN模型的识别准确度和鲁棒性。
由于图像中的物体往往具有不同的尺度、形状和位置,因此单一大小的卷积核往往无法满足对图像中不同特征的有效提取。
滑动窗口技术可以通过改变窗口的大小和位置来适应不同的图像特征,从而提高模型的识别准确度和鲁棒性。
此外,滑动窗口技术还可以通过重叠窗口的方式来提高特征提取的效率,进一步提高模型的性能。
最后,滑动窗口技术在实际应用中具有广泛的应用价值。
在图像识别任务中,滑动窗口技术可以帮助CNN模型有效地处理各种大小和形状的图像,从而适应不同的应用场景。
此外,滑动窗口技术还可以应用于目标检测、图像分割等其他图像处理任务中,为图像处理技术的发展提供了重要的支持。
总之,滑动窗口技术是CNN模型中的重要技术,它可以帮助模型有效地捕捉图像中的局部特征,提高识别准确度和鲁棒性,并在实际应用中具有广泛的应用价值。
滑动窗口流量控制原理
![滑动窗口流量控制原理](https://img.taocdn.com/s3/m/baf91300302b3169a45177232f60ddccda38e6df.png)
滑动窗口流量控制原理滑动窗口流量控制原理,这名字听起来挺高大上的,实际上却跟我们日常生活中的“排队”有点儿像。
想象一下,你在一个人满为患的餐厅外,肚子咕咕叫,眼看着前面的人一个接一个进门,你心里有点小焦急。
不过你知道,要是大家都急匆匆,肯定会乱成一团,所以,餐厅的服务员就会控制进门的速度,确保每个人都有地方坐,不会因为过多的顾客而让整个流程变得一团糟。
这就是流量控制的原理,简单吧!在网络世界里,数据就像餐厅里的顾客,源源不断地涌入。
为了保证网络不至于瘫痪,滑动窗口就像那位体贴的服务员,合理安排数据的发送和接收。
它通过设定一个窗口大小,规定了每次能发送多少数据。
这就像你在餐厅里,每次只能进一组顾客,不能让人挤成一锅粥。
数据包一个个被发送,而接收端则根据它的处理能力,来决定何时接收更多的包。
这样,发送方和接收方都能和谐共处,简直是网络交际的绝佳范本。
我们可以想象一下,滑动窗口就像是一辆快车,开得飞快,但司机却很聪明,知道什么时候刹车,什么时候加速。
这种控制方式不仅能提高效率,还能避免网络拥堵,真是聪明的设计呢!如果没有这个机制,数据就会在网络上打架,互相干扰,结果可想而知,整个网络就像是个失控的派对,谁也无法享受乐趣。
此外,滑动窗口的精妙之处还在于它的动态调整能力。
窗口大小并不是固定的,它可以根据网络的实际状况进行变化。
就好比说,餐厅的服务员看到今天客人特别多,干脆就把进门的速度加快点,让大家尽快就座。
如果有些顾客离开了,服务员就会迅速调整,确保每一位顾客都有座位。
数据在网络中流动也是这个道理,当接收方能够处理更多的数据时,窗口会自动增大,反之亦然。
这样的灵活性,使得网络通信更为高效,避免了资源的浪费,真是一举两得。
很多时候,我们在网上冲浪的时候,可能感觉不到这些技术的存在,但它们就像隐形的守护者,默默确保我们在浏览网页、观看视频时,不会出现卡顿和延迟。
就像在繁忙的城市中,交通灯在指挥着车辆的流动,确保每条街道都能顺畅通行。
滑动窗口算法基本原理
![滑动窗口算法基本原理](https://img.taocdn.com/s3/m/bcce5badf80f76c66137ee06eff9aef8941e4828.png)
滑动窗口算法基本原理滑动窗口算法,这个名字听上去有点高深,其实就像你在超市里推着购物车,一边逛一边把需要的东西放进去,简单得不要不要的。
想象一下,你走进超市,目标是买到一个完整的购物清单。
你在每个货架前停下,看看是不是需要的东西,然后把它们放进车里。
可问题来了,车子装得太满了,推着真是累。
于是你开始思考,如何合理地选择,才能让购物车既不满到倾倒,又能装下你所有想要的东西。
这个时候,你就是在使用滑动窗口算法。
这个算法可不仅仅是在超市里使用,其实它在计算机科学里大显身手,处理数据的时候也能发挥奇效。
比如说,想要找出一个字符串里的所有子串,特别是那些有特殊性质的子串。
通常这种事情挺麻烦,脑袋里得过一遍又一遍,结果很可能让你晕头转向。
可是,滑动窗口算法就像你的好朋友,轻轻一推,让你少走很多弯路。
你只需要不断调整你的“窗口”,在字符串上滑来滑去,轻松就能找到你想要的结果。
说到这里,咱们再来细说一下,什么是“窗口”。
在滑动窗口算法中,窗口其实就是一段范围,比如在字符串中,它可以是一个字符到另一个字符的距离。
你想找的东西就在这个范围内。
想象一下你在看电影,镜头一移动,你就能看到不同的场景。
这个窗口可以大可以小,完全取决于你想要的结果。
你也可以把它当成一扇窗,往外看,只不过窗外的景色是数据。
你从这一边看过去,发现那一边的美好,回过头来,你会觉得这也太神奇了!咱们聊聊这个算法的使用场景。
无论是字符串处理、数组求和,还是更复杂的动态规划问题,滑动窗口都能派上用场。
想象一下,你在处理一串数据,想找出其中的最大值或最小值,脑子里转了无数个圈,结果就是一团糟。
这个时候,滑动窗口就像你的超能力,能够迅速找到那道闪亮的光。
比如,你有一串数字,想找出其中和最大的连续子数组,滑动窗口来帮忙,直接调整窗口的大小,问题就迎刃而解。
使用滑动窗口算法时,也得注意不要用力过猛。
适当的控制窗口大小很重要,不然就容易出现“过犹不及”的情况。
比方说,你把窗口开得太大,结果啥都看不清楚;反之,如果窗口太小,可能就会漏掉一些关键的信息。
滑动窗口课件ppt
![滑动窗口课件ppt](https://img.taocdn.com/s3/m/abd5d623ae1ffc4ffe4733687e21af45b207fe67.png)
提高操作效率
总结词
详细描述
较小的窗口可以减少鼠标移动距离,加快操作速度,提 高用户在课件中的操作效率。
增加窗口数量
总结词
提供更多信息内容
01
总结词
增强交互性
03
总结词
提高组织性
05
02
详细描述
通过增加窗口数量,可以在课件中展示更多 的信息内容,满足用户多样化的学习需求。
04
详细描述
多个窗口可以提供更多的交互选项, 使用户能够更加灵活地与课件进行互 动,提高学习效果。
06
详细描述
通过合理地排列多个窗口,可以提高课件的组 织性,使用户能够更加清晰地理解课件的结构 和内容。
动态调整窗口大小和数量
总结词
自适应学习需求
详细描述
根据用户的学习需求和行为 ,动态调整窗口的大小和数 量,可以提供更加个性化的
学习体验。
总结词
提高响应速度
详细描述
动态调整窗口大小和数量可以加快课件的 响应速度,提高用户体验。
滑动窗口的主要特点是,随着数据流 不断流入,窗口会不断滑动,对新的 数据进行处理。
滑动窗口的基本原理
数据流
数据流是一个无穷的数据集合,每个数据项都有一个时间 戳。滑动窗口对数据流中的数据进行处理,通常是对每个 时间窗口内的数据进行聚合或统计。
窗口大小
滑动窗口的大小是固定的,通常以时间或数据项的数量来 表示。窗口大小的选择要根据具体应用的需求来确定。
基于链表的实现方式
将窗口内的元素存储在链表中,通过链表的节点进行操作。
滑动窗口算法的性能分析
01
02
03
时间复杂度分析
分析算法在处理数据流时 所需的时间,包括窗口的 滑动、元素的添加和删除 等操作的时间复杂度。
滑动窗口和人工特征提取算法
![滑动窗口和人工特征提取算法](https://img.taocdn.com/s3/m/fc65eb45cd1755270722192e453610661ed95a8b.png)
滑动窗口和人工特征提取算法首先,我们来了解一下滑动窗口算法。
滑动窗口算法是一种基于窗口扫描的方法,它将一个固定大小的窗口在输入数据上从左到右滑动,并在每个窗口位置上进行分类或者检测操作。
滑动窗口算法通常用于目标检测、行人检测、物体识别等任务。
其基本思想是将输入数据分割成多个固定大小的子窗口,然后在每个子窗口上运行分类或者检测算法。
通过调整窗口的大小和位置,可以在不同尺度和位置上进行目标检测或者分类。
滑动窗口算法的优点是简单易懂、易于实现。
它可以适应不同尺度的目标,具有一定的稳定性和鲁棒性。
然而,滑动窗口算法也存在一些缺点。
首先,滑动窗口算法需要对输入数据进行多次扫描,计算复杂度较高。
其次,滑动窗口算法只考虑了局部信息,没有利用全局上下文信息。
此外,滑动窗口算法的窗口大小和位置选择有一定的主观性,需要手动调整参数。
接下来,我们来介绍人工特征提取算法。
人工特征提取算法是一种通过设计合适的特征来描述输入数据的方法。
在计算机视觉和模式识别中,人工特征提取算法常用于图像分类、目标识别和图像检索等任务。
通过提取有效的特征,可以减少数据维度、提高分类或者识别准确率。
人工特征提取算法的基本思想是将输入数据映射到一个高维特征空间,然后在特征空间上进行分类或者检测。
常用的人工特征提取算法包括SIFT、HOG和SURF等。
这些算法通过提取图像的局部纹理、形状和颜色等特征来描述图像的内容。
人工特征提取算法的设计需要依据专业知识和经验,并且需要对不同任务进行定制。
人工特征提取算法的优点是可以提取有效的特征来描述输入数据。
这些特征具有一定的可解释性,可以传递对输入数据的理解。
此外,人工特征提取算法的计算复杂度较低,适用于大规模数据处理。
然而,人工特征提取算法也存在一些缺点。
首先,特征的设计和选择需要专业知识和经验,不可避免地带有主观性。
其次,人工特征提取算法很难适应不同的任务和数据集,需要进行针对性的调整和优化。
综上所述,滑动窗口算法和人工特征提取算法是计算机视觉和模式识别领域中常用的两种基本技术。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
滑动窗口
滑动窗口(Sliding window )是一种流量控制技术。
早期的网络通信中,通信双方不会考虑网络的拥挤情况直接发送数据。
由于大家不知道网络拥塞状况,一起发送数据,导致中间结点阻塞掉包,谁也发不了数据。
所以就有了滑动窗口机制来解决此问题。
参见滑动窗口如何根据网络拥塞发送数据仿真视频。
图片是一个滑动窗口的实例:
滑动窗口协议是用来改善吞吐量的一种技术,即容许发送方在接收任何应答之前传送附加的包。
接收方告诉发送方在某一时刻能送多少包(称窗口尺寸)。
TCP中采用滑动窗口来进行传输控制,滑动窗口的大小意味着接收方还有多大的缓冲区可以用于接收数据。
发送方可以通过滑动窗口的大小来确定应该发送多少字节的数据。
当滑动窗口为0时,发送方一般不能再发送数据报,但有两种情况除外,一种情况是可以发送紧急数据,例如,允许用户终
止在远端机上的运行进程。
另一种情况是发送方可以发送一个1字节的数据报来通知接收方重新声明它希望接收的下一字节及发送方的滑动窗口大小。
(1).窗口机制
滑动窗口协议的基本原理就是在任意时刻,发送方都维持了一个连续的允许发送的帧的序号,称为发送窗口;同时,接收方也维持了一个连续的允许接收的帧的序号,称为接收窗口。
发送窗口和接收窗口的序号的上下界不一定要一样,甚至大小也可以不同。
不同的滑动窗口协议窗口大小一般不同。
发送方窗口内的序列号代表了那些已经被发送,但是还没有被确认的帧,或者是那些可以被发送的帧。
下面举一个例子(假设发送窗口尺寸为2,接收窗口尺寸为1):
分析:①初始态,发送方没有帧发出,发送窗口前后沿相重合。
接收方0号窗口打开,等待接收0号帧;②发送方打开0号窗口,表示已发出0帧但尚确认返回信息。
此时接收窗口状态不变;③发送方打开0、1号窗口,表示0、1号帧均在等待确认之列。
至此,发送方打开的窗口数已达规定限度,在未收到新的确认返回帧之前,发送方将暂停发送新的数据帧。
接收窗口此时状态仍未变;④接收方已收到0号帧,0号窗口关闭,1号窗口打开,表示准备接收1号帧。
此时发送窗口状态不变;⑤发送方收到接收方发来的0号帧确认返回信息,关闭0号窗口,表示从重发表中删除0号帧。
此时接收窗口状态仍不变;⑥发送方继续发送2号帧,2号窗口打开,表示2号帧也纳入待确认之列。
至此,发送方打开的窗口又已达规定限度,在未收到新的确认返回帧之前,发送方将暂停发送新的数据帧,此时接收窗口状态仍不变;⑦接收方已收到1号帧,1号窗口关闭,2号窗口打开,表示准备接收2号帧。
此时发送窗口状态不变;⑧发送方收到接收方发来的1号帧收毕的确认信息,关闭1号窗口,表示从重发表中删除1号帧。
此时接收窗口状态仍不变。
若从滑动窗口的观点来统一看待1比特滑动窗口、后退n及选择重传三种协议,它们的差别仅在于各自窗口尺寸的大小不同而已。
1比特滑动窗口协议:发送窗口=1,接收窗口=1;后退n协议:发送窗口>1,接收窗口=1;选择重传协议:发送窗口>1,接收窗口>1。
(2).1比特滑动窗口协议
当发送窗口和接收窗口的大小固定为1时,滑动窗口协议退化为停等协议(stop-and-wait)。
该协议规定发送方每发送一帧后就要停下来,等待接收方已正确接收的确认(acknowledgement)返回后才能继续发送下一帧。
由于接收方需要判断接收到的帧是新发的帧还是重新发送的帧,因此发送方要为每一个帧加一个序号。
由于停等协议规定只有一帧完全发送成功后才能发送新的帧,因而只用一比特来编号就够了。
其发送方和接收方运行的流程图如图所示。
(3).后退n协议
由于停等协议要为每一个帧进行确认后才继续发送下一帧,大大降低了信道利用率,因此又提出了后退n协议。
后退n协议中,发送方在发完一个数据帧后,不停下来等待应答帧,而是连续发送若干个数据帧,即使在连续
发送过程中收到了接收方发来的应答帧,也可以继续发送。
且发送方在每发送完一个数据帧时都要设置超时定时器。
只要在所设置的超时时间内仍收到确认帧,就要重发相应的数据帧。
如:当发送方发送了N个帧后,若发现该N帧的前一个帧在计时器超时后仍未返回其确认信息,则该帧被判为出错或丢失,此时发送方就不得不重新发送出错帧及其后的N帧。
从这里不难看出,后退n协议一方面因连续发送数据帧而提高了效率,但另一方面,在重传时又必须把原来已正确传送过的数据帧进行重传(仅因这些数据帧之前有一个数据帧出了错),这种做法又使传送效率降低。
由此可见,若传输信道的传输质量很差因而误码率较大时,连续测协议不一定优于停止等待协议。
此协议中的发送窗口的大小为k,接收窗口仍是1。
(4).选择重传协议
在后退n协议中,接收方若发现错误帧就不再接收后续的帧,即使是正确到达的帧,这显然是一种浪费。
另一种效率更高的策略是当接收方发现某帧出错后,其后继续送来的正确的帧虽然不能立即递交给接收方的高层,但接收方仍可收下来,存放在一个缓冲区中,同时要求发送方重新传送出错的那一帧。
一旦收到重新传来的帧后,就可以原已存于缓冲区中的其余帧一并按正确的顺序递交高层。
这种方法称为选择重发(SELECTICE REPEAT),其工作过程如图所示。
显然,选择重发减少了浪费,但要求接收方有足够大的缓冲区空间。
滑动窗口功能:确认、差错控制、流量控制。
流量控制
TCP的特点之一是提供体积可变的滑动窗口机制,支持端到端的流量控制。
TCP的窗口以字节为单位进行调整,以适应接收方的处理能力。
处理过程如下:
减小窗口尺寸
(1)TCP连接阶段,双方协商窗口尺寸,同时接收方预留数据缓存区;
(2)发送方根据协商的结果,发送符合窗口尺寸的数据字节流,并等待对方的确认;
(3)发送方根据确认信息,改变窗口的尺寸,增加或者减少发送未得到确认的字节流中的字节数。
调整过程包括:如果出现发送拥塞,发送窗口缩小为原来的一半,同时将超时重传的时间间隔扩大一倍。
滑动窗口机制为端到端设备间的数据传输提供了可靠的流量控制机制。
然而,它只能在源端设备和目的端设备起作用,当网络中间设备(例如路由器等)发生拥塞时,滑动窗口机制将不起作用。