Skip to main content

Function Caching in Python

 


Learning Sections          show

Function Caching in Python

Function caching is a technique used to store the results of expensive function calls and reuse those results when the same inputs occur again. Python's functools module provides a built-in way to cache function results using the lru_cache decorator.


Using lru_cache from functools

The lru_cache decorator caches the results of a function based on its inputs. It uses a Least Recently Used (LRU) caching strategy to manage the cache size:


from functools import lru_cache

# Apply the lru_cache decorator
@lru_cache(maxsize=128)
def fib(n):
    if n == 0:
        return 0
    elif n == 1:
        return 1
    else:
        return fib(n - 1) + fib(n - 2)

# Call the cached function
print(fib(10))
    

In this example, the Fibonacci function results are cached, so repeated calls with the same input are faster.


Parameters of lru_cache
  • maxsize: Defines the maximum size of the cache. If the cache exceeds this size, the least recently used items are discarded. Setting it to None disables the LRU feature and allows the cache to grow without bound.
  • typed: If set to True, arguments of different types will be cached separately. For example, f(3) and f(3.0) will be treated as distinct calls with separate cache entries.

Benefits of Function Caching
  • Performance Improvement: Function caching can significantly improve the performance of your program by reducing the need to recompute results for the same inputs.
  • Resource Efficiency: Reduces the consumption of computational resources for functions that are called multiple times with the same arguments.
  • Ease of Use: The lru_cache decorator is easy to apply and requires minimal code changes to implement caching.

Popular posts from this blog

Generators in Python

  Learning Sections          show Generators in Python Generators are a special type of iterator in Python that allow you to iterate over a sequence of items without storing them all in memory at once. They are useful for generating large sequences of data on-the-fly, or for processing data in a memory-efficient manner. Creating Generators In Python, generators are created using generator functions or generator expressions: # Generator function def my_generator ( n ): for i in range ( n ): yield i # Generator expression my_generator = ( i for i in range ( 10 )) A generator function uses the yield keyword to yield values one at a time, while a generator expression creates an anonymous generator. Iterating Over Generators You can iterate over the values produced by a generator using a for loop: for value in my_generator ( 5 ): print ( value ) This w...

Inheritance in Python

  Learning Sections          show Inheritance in Python Inheritance is a fundamental concept in object-oriented programming (OOP) that allows a class to inherit attributes and methods from another class. The class that inherits is called the child class or subclass, and the class being inherited from is called the parent class or superclass. Basic Inheritance In Python, a child class inherits from a parent class by specifying the parent class in parentheses after the child class name. Example: class Animal : def __init__ ( self , name ): self . name = name def speak ( self ): raise NotImplementedError ( "Subclass must implement this method" ) class Dog ( Animal ): def speak ( self ): return "Woof!" class Cat ( Animal ): def speak ( self ): return "Meow!" # Create instances of Dog and Cat dog = Dog ( "Buddy" ) cat = Cat ( "Whiskers" ...

If else Conditional Statements in Python

  Learning Sections     show If-Else Conditional Statements Conditional statements allow you to execute different blocks of code based on certain conditions. The most common conditional statement is the if statement. It can be used alone, or combined with elif (else if) and else statements to handle multiple conditions. If Statement The if statement evaluates a condition, and if the condition is true, the block of code indented under the if statement is executed. # If statement example x = 10 if x >> 0 : print ( "x is positive" ) If-Else Statement The if-else statement adds an additional block of code that runs if the condition is false. # If-else statement example x = -10 if x >> 0 : print ( "x is positive" ) else : print ( "x is non-positive" ) If-Elif-Else Statement The if-elif-else statement allows you to check multiple conditions. The fir...