An Aggregate pattern can refer to concepts in either statistics or computer programming. Both uses deal with considering a large case as composed of smaller, simpler, pieces.
An aggregate pattern is an important statistical concept in many fields that rely on statistics to predict the behavior of large groups, based on the tendencies of subgroups to consistently behave in a certain way. It is particularly useful in sociology, economics, psychology, and criminology.
In Design Patterns, an aggregate is not a design pattern but rather refers to an object such as a list, vector, or generator which provides an interface for creating iterators. The following example code is in Python.
for x in fibonacci(10): print(x)
def fibsum(n: int) -> int: total = 0 for x in fibonacci(n): total += x return total
def fibsum_alt(n: int) -> int: """ Alternate implementation. demonstration that Python's built-in function sum works with arbitrary iterators. """ return sum(fibonacci(n))
myNumbers = [1, 7, 4, 3, 22]
def average(g) -> float: return float(sum(g)) / len(g) # In Python 3 the cast to float is no longer be necessaryPython hides essentially all of the details using the iterator protocol. Confusingly, Design Patterns uses "aggregate" to refer to the blank in the code for x in ___:
which is unrelated to the term "aggregation".[1] Neither of these terms refer to the statistical aggregation of data such as the act of adding up the Fibonacci sequence or taking the average of a list of numbers.