官术网_书友最值得收藏!

Using stateful sets

Python offers several stateful collections, including the set collection. For our purposes, there are two use cases for a set: a stateful set that accumulates items, and frozenset that is used to optimize searches for an item.

We can create frozenset from an iterable in the same way we create a tuple object from an iterable fronzenset(some_iterable) method; this will create a structure that has the advantage of a very fast in operator. This can be used in an application that gathers data, creates a set, and then uses that frozenset to process some other data items.

We may have a set of colors that we will use as a kind of chroma-key: we will use this color to create a mask that will be used to combine two images. Pragmatically, a single color isn't appropriate, but a small set of very similar colors works best. In this case, we'll examine each pixel of an image file to see if the pixel is in the chroma-key set or not. For this kind of processing, the chroma-key colors are loaded into frozenset before processing the target images. For more information, read about chroma-key processing from the following link:

http://en.wikipedia.org/wiki/Chroma_key

As with mappings—specifically the Counter class—there are some algorithms that can benefit from a memoized set of values. Some functions benefit from memoization because a function is a mapping between domain values and range values, a job where mapping works well. A few algorithms benefit from a memoized set, which is stateful and grows as data is processed.

We'll return to memoization in Chapter 16, Optimizations and Improvements.

主站蜘蛛池模板: 郑州市| 花莲市| 久治县| 麻栗坡县| 陆良县| 拉萨市| 八宿县| 滦南县| 大同县| 漳州市| 张家界市| 池州市| 祁东县| 夏津县| 蚌埠市| 晋中市| 霍城县| 名山县| 清原| 林口县| 沙雅县| 常山县| 杭锦旗| 广宁县| 兴宁市| 满城县| 汝城县| 平山县| 平邑县| 密云县| 梁平县| 盘山县| 恩施市| 当雄县| 定兴县| 赣州市| 南平市| 三明市| 西充县| 长兴县| 万州区|