CN110990300A - 一种基于使用热度的高速缓冲存储器替换方法及系统 - Google Patents
一种基于使用热度的高速缓冲存储器替换方法及系统 Download PDFInfo
- Publication number
- CN110990300A CN110990300A CN201911327529.3A CN201911327529A CN110990300A CN 110990300 A CN110990300 A CN 110990300A CN 201911327529 A CN201911327529 A CN 201911327529A CN 110990300 A CN110990300 A CN 110990300A
- Authority
- CN
- China
- Prior art keywords
- heat
- cache
- value
- block
- cpu data
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/0802—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
- G06F12/0806—Multiuser, multiprocessor or multiprocessing cache systems
- G06F12/0808—Multiuser, multiprocessor or multiprocessing cache systems with cache invalidating means
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Memory System Of A Hierarchy Structure (AREA)
Abstract
本公开公开了一种基于使用热度的高速缓冲存储器替换方法及系统,包括:将Cache分为n个Cache块,n个Cache块和其对应的热度值组成热度对比组;根据接收的CPU数据读取请求,判断待读取的CPU数据是否存在于Cache中,若命中,查找命中的Cache块和其对应的热度值,根据预设热度增强因子增加热度值,其余未命中Cache块的热度值根据热度衰减因子进行衰减,在命中的Cache块中读取CPU数据;若未命中,查找热度值最小且小于或等于替换阈值的Cache块,将待读取的CPU数据替换到该Cache块中,其余未替换Cache块的热度值根据热度衰减因子进行衰减。统计Cache中代码的访问频率,并在访问热度降低后进行替换;通过热度增强因子、热度衰减因子参数,适用于不同的执行代码,保持较高的命中率。
Description
技术领域
本公开涉及数据存储和读取技术领域,特别是涉及一种基于使用热度的高速缓冲存储器替换方法及系统。
背景技术
本部分的陈述仅仅是提供了与本公开相关的背景技术信息,不必然构成在先技术。
高速缓冲存储器(Cache)是位于CPU(中央处理器)和DRAM(动态随机存储器)或者flash(闪存存储器)之间的存储系统,一般Cache相较与DRAM或者flash来说容量较小,速度快。CPU的速度远高于内存,当CPU直接从内存中存取数据时要等待一定时间周期,而Cache则可以保存CPU刚用过或循环使用的一部分数据,如果CPU需要再次使用该部分数据时可从Cache中直接调用,这样就避免了重复存取数据,减少了CPU的等待时间,因而提高了系统的效率。
但是由于Cache容量明显小于内存,所以Cache只能暂存很小一部分内存中的数据。正是由于Cache空间的稀缺性,如何存储CPU中最频繁访问的数据是提高Cache性能的关键,其中替换算法是提高Cache性能的重要算法。
现存替换算法一般包括:FIFO(先进先出替换算法),Random(随机替换算法),LFU(最少使用替换算法),LRU(最近最少使用替换算法)等。但是,Cache命中率高的算法一般实现复杂,资源占用量大;而算法简单,资源占用少的算法就会存在命中率不高,或者严重依赖代码执行规律,灵活度低,不能根据代码灵活改变替换策略的问题。
发明内容
为了解决上述问题,本公开提出了一种基于使用热度的高速缓冲存储器替换方法及系统,利用计数器进行计数,统计Cache中代码的访问频率,并在访问热度降低后及时进行替换;通过配置热度增强因子、热度衰减因子参数,灵活的适用于不同的执行代码,提高Cache效率,并且算法实现简单,无需使用复杂的占用资源较多的链表,且能保持较高的命中率。
为了实现上述目的,本公开采用如下技术方案:
第一方面,本公开提供一种基于使用热度的高速缓冲存储器替换方法,包括:
将高速缓冲存储器Cache分为n个Cache块,n个Cache块和其对应的热度值组成热度对比组;
根据接收的CPU数据读取请求,判断待读取的CPU数据是否存在于Cache中,若命中,在热度对比组中查找命中的Cache块和其对应的热度值,根据预设热度增强因子增加热度值,其余未命中Cache块的热度值根据热度衰减因子进行衰减,在命中的Cache块中读取CPU数据;
若未命中,在热度对比组中查找热度值最小且小于或等于替换阈值的Cache块,将待读取的CPU数据替换到该Cache块中,其余未替换Cache块的热度值根据热度衰减因子进行衰减。
作为可能的一些实现方式,所述将待读取的CPU数据替换到该Cache块中,将替换后的Cache块的热度值置为初始热度值,其余未替换Cache块的热度值根据热度衰减因子进行衰减,若衰减后的热度值小于或等于0,则将该热度值置为0。
作为可能的一些实现方式,查找热度值最小的Cache块,若该热度值大于替换阈值,则不进行替换,并且将所有Cache块根据热度衰减因子进行衰减,若衰减后的热度值小于或等于0,则将该热度值置为0。
作为可能的一些实现方式,所述查找热度值最小且小于或等于替换阈值的Cache块时,若存在相同热度值的Cache块,任意选择其中一个作为待替换的Cache块。
作为可能的一些实现方式,对命中的Cache块的热度值进行增强,若增强后的热度值大于热度峰值,则将该热度值置为热度峰值。
作为可能的一些实现方式,所述对其余未命中Cache块的热度值根据热度衰减因子进行衰减,若衰减后的热度值小于或等于0,则将该热度值置为0。
作为可能的一些实现方式,所述热度衰减因子和热度增强因子为固定值或随着热度值的变化而变化。
第二方面,本公开提供一种基于使用热度的高速缓冲存储器替换系统,包括:
分块模块,其用于将高速缓冲存储器Cache分为n个Cache块,n个Cache块和其对应的热度值组成热度对比组;
数据读取模块,其用于根据接收的CPU数据读取请求,判断待读取的CPU数据是否存在于Cache中,若命中,在热度对比组中查找命中的Cache块和其对应的热度值,根据预设热度增强因子增加热度值,其余未命中Cache块的热度值根据热度衰减因子进行衰减,在命中的Cache块中读取CPU数据;
替换模块,其用于若未命中,在热度对比组中查找热度值最小且小于或等于替换阈值的Cache块,将待读取的CPU数据替换到该Cache块中,其余未替换Cache块的热度值根据热度衰减因子进行衰减。
第三方面,本公开提供一种电子设备,其特征是,包括存储器和处理器以及存储在存储器上并在处理器上运行的计算机指令,所述计算机指令被处理器运行时,完成一种基于使用热度的高速缓冲存储器替换方法所述的步骤。
第四方面,本公开提供一种计算机可读存储介质,其特征是,用于存储计算机指令,所述计算机指令被处理器执行时,完成一种基于使用热度的高速缓冲存储器替换方法所述的步骤。
与现有技术相比,本公开的有益效果为:
本公开替换方法灵活,可动态配置、调整参数初始热度值S,热度衰减因子b,热度增强因子i,热度峰值M,替换阈值R等,以便适用于不同的代码使用热度规律和不同代码风格,通用性高,提高Cache命中率,达到稳定的较高命中率;
本公开替换算法简单,容易实现,基于使用热度进行替换,符合CPU数据使用规律,并且资源占用量少,提高替换反应速度,能快速低成本的实现较高命中率的高速缓存替换算法;
本公开替换算法通过计数值的增加和衰减统计数据使用热度,替换热度值小的数据,增强命中的数据块热度值,衰减未命中的数据块热度值。相较与单纯的计数值增加的方式,本公开引入使用热度、热度峰值、初始热度、替换阈值等概念,能更符合代码使用热度变化的规律,逐渐减少代码的使用对当前替换造成的影响,增加替换灵活度。
附图说明
构成本公开的一部分的说明书附图用来提供对本公开的进一步理解,本公开的示意性实施例及其说明用于解释本公开,并不构成对本公开的不当限定。
图1为实施例中Cache分块标记和热度计数示意图;
图2为本公开方法流程示意图。
具体实施方式:
下面结合附图与实施例对本公开做进一步说明。
应该指出,以下详细说明都是例示性的,旨在对本公开提供进一步的说明。除非另有指明,本文使用的所有技术和科学术语具有与本公开所属技术领域的普通技术人员通常理解的相同含义。
需要注意的是,这里所使用的术语仅是为了描述具体实施方式,而非意图限制根据本公开的示例性实施方式。如在这里所使用的,除非上下文另外明确指出,否则单数形式也意图包括复数形式,此外,还应当理解的是,当在本说明书中使用术语“包含”和/或“包括”时,其指明存在特征、步骤、操作、器件、组件和/或它们的组合。
一般来说,Cache命中率高的算法一般实现复杂,占用资源多;而算法简单,资源占用少的算法就会存在命中率不高,或者严重依赖代码执行规律等问题。而本公开提出的方法仅利用计数器进行计数,统计Cache中的代码使用热度,对于热度低的数据及时进行替换。
如果发生命中,则把命中Cache块的计数值加上一个热度增强因子,如果Cache中代码被频繁使用,则热度不断增强,其中的数据不会被替换;
如果没有发生命中,则Cache块的计数值减去一个热度衰减因子,如果长时间不被使用,则热度逐渐降低,就会被替换;
并且通过配置热度增强因子、热度衰减因子等多个参数,能灵活适应于不同的代码使用规律,达到稳定的较高Cache命中率。
所以,本公开主要包括两个分支:命中和没有命中。如果发生命中,则增加命中块的热度值,衰减其余未命中块的热度值;如果没有发生命中,则替换该块的数据,热度值设置为固定初始值S,其余未替换块中的热度值则进行衰减;并且在未命中时,如果其余块热度值都较高,大于替换阈值R,则不进行替换,所有块热度进行衰减。
实施例1
本公开提供一种基于使用热度的高速缓冲存储器替换方法,包括:
S1:如图1所示,将高速缓冲存储器Cache分为n个Cache块,n个Cache块和其对应的热度值组成热度对比组;
该对比组中,一共有n个块进行热度对比,对比块命名为B1~Bn,其对应的计数值是C1~Cn。
S2:定义参数值
a.初始热度值S:在发生数据替换后,该数据块Bx对应的Cx的初始计数值。
b.热度衰减因子b:在没有命中该块后,热度计数的递减值;该值即可以是固定值,也可以随着热度值的变化而变化。
c.热度增强因子i:在命中该块后,热度计数的增加值;该值即可以是固定值,也可以随着热度值的变化而变化。
d.热度峰值M:热度计数的顶峰值;引入热度峰值M既能减小计数器空间消耗,又能防止热度过热,在代码数据执行热度发生变化后,不能及时改变。
e.替换阈值R:在不命中后,如果存在数据块热度计数值小于该值,则进行替换;否则认为现存所有数据块热度较高,不进行替换;替换阈值R的加入能够避免偶尔产生的数据读取冲击之前热度很高的数据,影响后续命中率。
S3:通过热度计数值的增加和衰减统计数据使用热度,替换热度值小的数据,增强命中的数据块热度值,衰减未命中的数据块热度值,如图2所示,
(1)根据接收的CPU数据读取请求,判断待读取的CPU数据是否存在于Cache中,如果Cache中的数据没有命中,则执行(2),否则执行(5);
(2)在所有Cache热度对比组中,查找热度计数值最小Cy和其对应的块By,如果该计数值Cy大于替换阈值R,则执行(3);如果该计数值Cy小于等于替换阈值R,则执行(4);
(3)新数据不进行替换,所有块的热度进行衰减(Cx=Cx-d);如减去衰减因子后,Cx小于0,则把该值Cx置为0;如果减去衰减后大于0,则把热度值Cx置为衰减之后的数值,然后流程执行结束;
(4)新数据进行替换,替换的数据块热度值置为初始热度值S,其余未命中的数据块热度值进行衰减(Cx=Cx-d);如减去衰减因子d后,Cx小于0,则把该值Cx置为0;如果减去衰减d后大于0,则把热度值Cx置为衰减之后的数值,然后流程执行结束;
(5)查找命中的数据块Bk和其对应的热度值Ck,并对Ck进行热度增强(Ck=Ck+i);如加上增强因子i后,Ck大于热度峰值M,则把Ck置为M;如果加上增强因子i后小于等于M,则把热度值Ck置为增强之后的数值;
(6)其余未命中的数据块热度值进行衰减(Cx=Cx-d);如减去衰减因子d后,Cx小于0,则把该值Cx置为0;如果减去衰减d后大于0,则把热度值Cx置为该衰减之后的值,然后流程执行结束。
其中,热度增强因子i即可以是固定值,也可以是变值,例如可以随着热度的增加,热度增强因子i逐渐变小,防止热度增强过快;
热度衰减因子d即可以是固定值,也可以是变值,例如可以随着热度的衰减,热度衰减因子d逐渐变小,防止热度衰减过快。
实施例2
本公开提供一种基于使用热度的高速缓冲存储器替换系统,包括:
分块模块,其用于将高速缓冲存储器Cache分为n个Cache块,n个Cache块和其对应的热度值组成热度对比组;
数据读取模块,其用于根据接收的CPU数据读取请求,判断待读取的CPU数据是否存在于Cache中,若命中,在热度对比组中查找命中的Cache块和其对应的热度值,根据预设热度增强因子增加热度值,其余未命中Cache块的热度值根据热度衰减因子进行衰减,在命中的Cache块中读取CPU数据;
替换模块,其用于若未命中,在热度对比组中查找热度值最小且小于或等于替换阈值的Cache块,将待读取的CPU数据替换到该Cache块中,其余未替换Cache块的热度值根据热度衰减因子进行衰减。
实施例3
本公开提供一种电子设备,其特征是,包括存储器和处理器以及存储在存储器上并在处理器上运行的计算机指令,所述计算机指令被处理器运行时,完成一种基于使用热度的高速缓冲存储器替换方法所述的步骤。
实施例4
本公开提供一种计算机可读存储介质,其特征是,用于存储计算机指令,所述计算机指令被处理器执行时,完成一种基于使用热度的高速缓冲存储器替换方法所述的步骤。
以上仅为本公开的优选实施例而已,并不用于限制本公开,对于本领域的技术人员来说,本公开可以有各种更改和变化。凡在本公开的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本公开的保护范围之内。
上述虽然结合附图对本公开的具体实施方式进行了描述,但并非对本公开保护范围的限制,所属领域技术人员应该明白,在本公开的技术方案的基础上,本领域技术人员不需要付出创造性劳动即可做出的各种修改或变形仍在本公开的保护范围以内。
Claims (10)
1.一种基于使用热度的高速缓冲存储器替换方法,其特征在于,包括:
将高速缓冲存储器Cache分为n个Cache块,n个Cache块和其对应的热度值组成热度对比组;
根据接收的CPU数据读取请求,判断待读取的CPU数据是否存在于Cache中,若命中,在热度对比组中查找命中的Cache块和其对应的热度值,根据预设热度增强因子增加热度值,其余未命中Cache块的热度值根据热度衰减因子进行衰减,在命中的Cache块中读取CPU数据;
若未命中,在热度对比组中查找热度值最小且小于或等于替换阈值的Cache块,将待读取的CPU数据替换到该Cache块中,其余未替换Cache块的热度值根据热度衰减因子进行衰减。
2.如权利要求1所述的一种基于使用热度的高速缓冲存储器替换方法,其特征在于,
所述将待读取的CPU数据替换到该Cache块中,将替换后的Cache块的热度值置为初始热度值,其余未替换Cache块的热度值根据热度衰减因子进行衰减,若衰减后的热度值小于或等于0,则将该热度值置为0。
3.如权利要求1所述的一种基于使用热度的高速缓冲存储器替换方法,其特征在于,
查找热度值最小的Cache块,若该热度值大于替换阈值,则不进行替换,并且将所有Cache块根据热度衰减因子进行衰减,若衰减后的热度值小于或等于0,则将该热度值置为0。
4.如权利要求1所述的一种基于使用热度的高速缓冲存储器替换方法,其特征在于,
所述查找热度值最小且小于或等于替换阈值的Cache块时,若存在相同热度值的Cache块,任意选择其中一个作为待替换的Cache块。
5.如权利要求1所述的一种基于使用热度的高速缓冲存储器替换方法,其特征在于,
对命中的Cache块的热度值进行增强,若增强后的热度值大于热度峰值,则将该热度值置为热度峰值。
6.如权利要求1所述的一种基于使用热度的高速缓冲存储器替换方法,其特征在于,
所述对其余未命中Cache块的热度值根据热度衰减因子进行衰减,若衰减后的热度值小于或等于0,则将该热度值置为0。
7.如权利要求1所述的一种基于使用热度的高速缓冲存储器替换方法,其特征在于,
所述热度衰减因子和热度增强因子为固定值或随着热度值的变化而变化。
8.一种基于使用热度的高速缓冲存储器替换系统,其特征在于,包括:
分块模块,其用于将高速缓冲存储器Cache分为n个Cache块,n个Cache块和其对应的热度值组成热度对比组;
数据读取模块,其用于根据接收的CPU数据读取请求,判断待读取的CPU数据是否存在于Cache中,若命中,在热度对比组中查找命中的Cache块和其对应的热度值,根据预设热度增强因子增加热度值,其余未命中Cache块的热度值根据热度衰减因子进行衰减,在命中的Cache块中读取CPU数据;
替换模块,其用于若未命中,在热度对比组中查找热度值最小且小于或等于替换阈值的Cache块,将待读取的CPU数据替换到该Cache块中,其余未替换Cache块的热度值根据热度衰减因子进行衰减。
9.一种电子设备,其特征是,包括存储器和处理器以及存储在存储器上并在处理器上运行的计算机指令,所述计算机指令被处理器运行时,完成权利要求1-7任一项方法所述的步骤。
10.一种计算机可读存储介质,其特征是,用于存储计算机指令,所述计算机指令被处理器执行时,完成权利要求1-7任一项方法所述的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911327529.3A CN110990300B (zh) | 2019-12-20 | 2019-12-20 | 一种基于使用热度的高速缓冲存储器替换方法及系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911327529.3A CN110990300B (zh) | 2019-12-20 | 2019-12-20 | 一种基于使用热度的高速缓冲存储器替换方法及系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110990300A true CN110990300A (zh) | 2020-04-10 |
CN110990300B CN110990300B (zh) | 2021-12-14 |
Family
ID=70074375
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201911327529.3A Active CN110990300B (zh) | 2019-12-20 | 2019-12-20 | 一种基于使用热度的高速缓冲存储器替换方法及系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110990300B (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113177069A (zh) * | 2021-05-08 | 2021-07-27 | 中国科学院声学研究所 | 一种高速缓存与查询系统及查询方法 |
CN116257463A (zh) * | 2023-01-04 | 2023-06-13 | 格兰菲智能科技有限公司 | 混合存储方法、装置、计算机设备、存储介质 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103902473A (zh) * | 2012-12-31 | 2014-07-02 | 华为技术有限公司 | 一种数据处理方法及数据缓存系统 |
CN104794064A (zh) * | 2015-04-21 | 2015-07-22 | 华中科技大学 | 一种基于区域热度的缓存管理方法 |
CN106897030A (zh) * | 2017-02-28 | 2017-06-27 | 郑州云海信息技术有限公司 | 一种缓存数据管理方法及装置 |
CN107168652A (zh) * | 2017-05-19 | 2017-09-15 | 郑州云海信息技术有限公司 | 一种提升SSD Cache读性能的方法 |
CN107305475A (zh) * | 2016-04-22 | 2017-10-31 | 中国科学院微电子研究所 | 一种flashcache混合存储系统的缓存调度方法及系统 |
-
2019
- 2019-12-20 CN CN201911327529.3A patent/CN110990300B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103902473A (zh) * | 2012-12-31 | 2014-07-02 | 华为技术有限公司 | 一种数据处理方法及数据缓存系统 |
CN104794064A (zh) * | 2015-04-21 | 2015-07-22 | 华中科技大学 | 一种基于区域热度的缓存管理方法 |
CN107305475A (zh) * | 2016-04-22 | 2017-10-31 | 中国科学院微电子研究所 | 一种flashcache混合存储系统的缓存调度方法及系统 |
CN106897030A (zh) * | 2017-02-28 | 2017-06-27 | 郑州云海信息技术有限公司 | 一种缓存数据管理方法及装置 |
CN107168652A (zh) * | 2017-05-19 | 2017-09-15 | 郑州云海信息技术有限公司 | 一种提升SSD Cache读性能的方法 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113177069A (zh) * | 2021-05-08 | 2021-07-27 | 中国科学院声学研究所 | 一种高速缓存与查询系统及查询方法 |
CN116257463A (zh) * | 2023-01-04 | 2023-06-13 | 格兰菲智能科技有限公司 | 混合存储方法、装置、计算机设备、存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN110990300B (zh) | 2021-12-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8677071B2 (en) | Control of processor cache memory occupancy | |
US11086792B2 (en) | Cache replacing method and apparatus, heterogeneous multi-core system and cache managing method | |
CN109313610B (zh) | 用于高速缓存替换策略的缩放集合竞争 | |
US7284096B2 (en) | Systems and methods for data caching | |
US20180314646A1 (en) | Cache management method, cache controller, and computer system | |
CN110990300B (zh) | 一种基于使用热度的高速缓冲存储器替换方法及系统 | |
US6829679B2 (en) | Different caching treatment of memory contents based on memory region | |
CN105335102A (zh) | 一种缓存数据处理方法及装置 | |
KR102344008B1 (ko) | 데이터 스토어 및 데이터 스토어에 데이터를 할당하는 방법 | |
JP2008503922A (ja) | 組込みシステムのためのメモリ圧縮アーキテクチャ | |
US20170010830A1 (en) | Semiconductor Device and Cache Memory Control Method | |
GB2509755A (en) | Partitioning a shared cache using masks associated with threads to avoiding thrashing | |
US20170300417A1 (en) | Multi-Way Set Associative Cache and Processing Method Thereof | |
CN115617712A (zh) | 一种基于组相联高速缓存Cache的LRU替换算法 | |
US9792228B2 (en) | Enhancing lifetime of non-volatile cache by injecting random replacement policy | |
CN111427804B (zh) | 一种减少缺页中断次数的方法、存储介质及智能终端 | |
Itshak et al. | AMSQM: adaptive multiple super-page queue management | |
CN113094392A (zh) | 数据缓存的方法和装置 | |
US9311988B2 (en) | Storage control system and method, and replacing system and method | |
CN107861819B (zh) | 一种缓存组负载均衡的方法、装置和计算机可读存储介质 | |
Snir et al. | On the theory of spatial and temporal locality | |
CN104808967A (zh) | 一种处理器的动态数据预取系统 | |
US9767043B2 (en) | Enhancing lifetime of non-volatile cache by reducing intra-block write variation | |
Banerjee et al. | A New Proposed Hybrid Page Replacement Algorithm (HPRA) in Real Time Systems. | |
CN108287795B (zh) | 一种处理器缓存替换方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |