Least frequently used: Difference between revisions
Citation bot (talk | contribs) Add: s2cid. | Use this bot. Report bugs. | Suggested by Guy Harris | #UCB_webform |
|||
(14 intermediate revisions by 8 users not shown) | |||
Line 1: | Line 1: | ||
{{Short description|Algorithm for caching data}} |
|||
{{Use dmy dates|date= |
{{Use dmy dates|date=November 2022}} |
||
'''Least Frequently Used''' ('''LFU''') is a type of [[cache algorithm]] used to manage [[Cache (computing)|memory]] within a computer. The standard characteristics of this method involve the system keeping track of the number of times a [[Page (computer memory)|block]] is [[Reference (computer science)|referenced]] in memory. When the cache is full and requires more room the system will purge the item with the lowest reference frequency. |
'''Least Frequently Used''' ('''LFU''') is a type of [[cache algorithm]] used to manage [[Cache (computing)|memory]] within a computer. The standard characteristics of this method involve the system keeping track of the number of times a [[Page (computer memory)|block]] is [[Reference (computer science)|referenced]] in memory. When the cache is full and requires more room the system will purge the item with the lowest reference frequency. |
||
LFU is sometimes combined with a [[Least Recently Used]] algorithm and called LRFU.<ref>Donghee Lee |
LFU is sometimes combined with a [[Least Recently Used]] algorithm and called LRFU.<ref>{{cite journal |author1=Donghee Lee |author2=Jongmoo Choi |author3=Jong-Hun Kim |author4=S.H. Noh |author5=Sang Lyul Min |author6=Yookun Cho |author7=Chong Sang Kim |url=https://ieeexplore.ieee.org/document/970573 |title=LRFU: a spectrum of policies that subsumes the least recently used and least frequently used policies |journal=IEEE Transactions on Computers |volume=50 |issue=12 |date=December 2001 |pages=1352–1361 |doi=10.1109/TC.2001.970573|s2cid=2636466 }}</ref> |
||
==Implementation== |
==Implementation== |
||
The simplest method to employ an LFU algorithm is to assign a counter to every block that is loaded into the cache. Each time a reference is made to that block the counter is increased by one. When the cache reaches capacity and has a new block waiting to be inserted the system will search for the block with the lowest counter and remove it from the cache.<ref>Silvano Maffeis |
The simplest method to employ an LFU algorithm is to assign a counter to every block that is loaded into the cache. Each time a reference is made to that block the counter is increased by one. When the cache reaches capacity and has a new block waiting to be inserted the system will search for the block with the lowest counter and remove it from the cache, in case of a tie (i.e., two or more keys with the same frequency), the [[Least Recently Used]] key would be invalidated.<ref>{{cite journal |author=Silvano Maffeis |url=http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.48.8399&rep=rep1&type=pdf |title=Cache Management Algorithms for Flexible Filesystems |journal=ACM SIGMETRICS Performance Evaluation Review |volume=21 |issue=2 |date=December 1993 |pages=16–25 |doi=10.1145/174215.174219 |citeseerx=10.1.1.48.8399| s2cid=7624318 }}</ref> |
||
* Ideal LFU: there is a counter for each item in the catalogue |
* Ideal LFU: there is a counter for each item in the catalogue |
||
* Practical LFU: there is a counter for the items stored in cache. The counter is forgotten if the item is evicted. |
|||
* tic toc |
|||
==Problems== |
==Problems== |
||
While the LFU method may seem like an intuitive approach to memory management it is not without faults. Consider an item in memory which is referenced repeatedly for a short period of time and is not accessed again for an extended period of time. Due to how rapidly it was just accessed its counter has increased drastically even though it will not be used again for a decent amount of time. This leaves other blocks which may actually be used more frequently susceptible to purging simply because they were accessed through a different method.<ref>William Stallings |
While the LFU method may seem like an intuitive approach to memory management it is not without faults. Consider an item in memory which is referenced repeatedly for a short period of time and is not accessed again for an extended period of time. Due to how rapidly it was just accessed its counter has increased drastically even though it will not be used again for a decent amount of time. This leaves other blocks which may actually be used more frequently susceptible to purging simply because they were accessed through a different method.<ref>{{cite book |author=William Stallings |title=Operating Systems: Internals and Design Principles |edition=7th |date=2012}}</ref> |
||
Moreover, new items that just entered the cache are subject to being removed very soon again, because they start with a low counter, even though they might be used very frequently after that. Due to major issues like these, an explicit LFU system is fairly uncommon; instead, there are hybrids that utilize LFU concepts.<ref>B.T. Zivkoz |
Moreover, new items that just entered the cache are subject to being removed very soon again, because they start with a low counter, even though they might be used very frequently after that. Due to major issues like these, an explicit LFU system is fairly uncommon; instead, there are hybrids that utilize LFU concepts.<ref>{{cite conference |author1=B.T. Zivkoz |author2=A.J. Smith |url=https://ieeexplore.ieee.org/document/567612 |title=Disk Caching in Large Database and Timeshared Systems |book-title= Proceedings Fifth International Symposium on Modeling, Analysis, and Simulation of Computer and Telecommunication Systems |doi=10.1109/MASCOT.1997.567612 |date=1997}}</ref> |
||
==See also== |
==See also== |
||
* [[Paging]] |
|||
* [[ |
* [[Cache replacement policies]] |
||
* [[Memory paging]] |
|||
* |
* {{section link|Page replacement algorithm|Not frequently used}} |
||
==References== |
==References== |
||
{{Reflist |
{{Reflist}} |
||
== External links == |
== External links == |
Latest revision as of 10:02, 31 July 2023
Least Frequently Used (LFU) is a type of cache algorithm used to manage memory within a computer. The standard characteristics of this method involve the system keeping track of the number of times a block is referenced in memory. When the cache is full and requires more room the system will purge the item with the lowest reference frequency.
LFU is sometimes combined with a Least Recently Used algorithm and called LRFU.[1]
Implementation
[edit]The simplest method to employ an LFU algorithm is to assign a counter to every block that is loaded into the cache. Each time a reference is made to that block the counter is increased by one. When the cache reaches capacity and has a new block waiting to be inserted the system will search for the block with the lowest counter and remove it from the cache, in case of a tie (i.e., two or more keys with the same frequency), the Least Recently Used key would be invalidated.[2]
- Ideal LFU: there is a counter for each item in the catalogue
- Practical LFU: there is a counter for the items stored in cache. The counter is forgotten if the item is evicted.
Problems
[edit]While the LFU method may seem like an intuitive approach to memory management it is not without faults. Consider an item in memory which is referenced repeatedly for a short period of time and is not accessed again for an extended period of time. Due to how rapidly it was just accessed its counter has increased drastically even though it will not be used again for a decent amount of time. This leaves other blocks which may actually be used more frequently susceptible to purging simply because they were accessed through a different method.[3]
Moreover, new items that just entered the cache are subject to being removed very soon again, because they start with a low counter, even though they might be used very frequently after that. Due to major issues like these, an explicit LFU system is fairly uncommon; instead, there are hybrids that utilize LFU concepts.[4]
See also
[edit]References
[edit]- ^ Donghee Lee; Jongmoo Choi; Jong-Hun Kim; S.H. Noh; Sang Lyul Min; Yookun Cho; Chong Sang Kim (December 2001). "LRFU: a spectrum of policies that subsumes the least recently used and least frequently used policies". IEEE Transactions on Computers. 50 (12): 1352–1361. doi:10.1109/TC.2001.970573. S2CID 2636466.
- ^ Silvano Maffeis (December 1993). "Cache Management Algorithms for Flexible Filesystems". ACM SIGMETRICS Performance Evaluation Review. 21 (2): 16–25. CiteSeerX 10.1.1.48.8399. doi:10.1145/174215.174219. S2CID 7624318.
- ^ William Stallings (2012). Operating Systems: Internals and Design Principles (7th ed.).
- ^ B.T. Zivkoz; A.J. Smith (1997). "Disk Caching in Large Database and Timeshared Systems". Proceedings Fifth International Symposium on Modeling, Analysis, and Simulation of Computer and Telecommunication Systems. doi:10.1109/MASCOT.1997.567612.
External links
[edit]- An O(1) algorithm for implementing the LFU cache eviction scheme, 16 August 2010, by Ketan Shah, Anirban Mitra and Dhruv Matani