Home >Backend Development >Python Tutorial >How Can I Efficiently Calculate Cumulative Sums in Python?

How Can I Efficiently Calculate Cumulative Sums in Python?

Barbara Streisand
Barbara StreisandOriginal
2024-12-05 21:29:09949browse

How Can I Efficiently Calculate Cumulative Sums in Python?

Efficient Calculation of Cumulative Sums in Lists

Accumulating the sum of consecutive elements in a list can be a common task in data analysis or numerical computations. For instance, given a list of time intervals time_interval = [4, 6, 12], we may want to find the cumulative sum of these intervals, resulting in t = [4, 10, 22].

Using a manual approach as demonstrated in the question, while effective, can be cumbersome for large lists. However, a more efficient solution is available using the numpy library:

import numpy as np

a = [4, 6, 12]

np.cumsum(a)
#array([ 4, 10, 22])

numpy's cumsum function provides a significant performance advantage over pure Python implementations, especially for large lists. Benchmarks have shown that numpy's cumsum outperforms manual accumulation by an order of magnitude:

timeit list(accumu(range(1000)))
10000 loops, best of 3: 161 us per loop

timeit list(accumu(xrange(1000)))
10000 loops, best of 3: 147 us per loop

timeit np.cumsum(np.arange(1000))
100000 loops, best of 3: 10.1 us per loop

Therefore, if you regularly work with numerical arrays, utilizing numpy's cumsum function is highly recommended for its efficiency and ease of use.

The above is the detailed content of How Can I Efficiently Calculate Cumulative Sums in Python?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn