LSST Applications g070148d5b3+33e5256705,g0d53e28543+25c8b88941,g0da5cf3356+2dd1178308,g1081da9e2a+62d12e78cb,g17e5ecfddb+7e422d6136,g1c76d35bf8+ede3a706f7,g295839609d+225697d880,g2e2c1a68ba+cc1f6f037e,g2ffcdf413f+853cd4dcde,g38293774b4+62d12e78cb,g3b44f30a73+d953f1ac34,g48ccf36440+885b902d19,g4b2f1765b6+7dedbde6d2,g5320a0a9f6+0c5d6105b6,g56b687f8c9+ede3a706f7,g5c4744a4d9+ef6ac23297,g5ffd174ac0+0c5d6105b6,g6075d09f38+66af417445,g667d525e37+2ced63db88,g670421136f+2ced63db88,g71f27ac40c+2ced63db88,g774830318a+463cbe8d1f,g7876bc68e5+1d137996f1,g7985c39107+62d12e78cb,g7fdac2220c+0fd8241c05,g96f01af41f+368e6903a7,g9ca82378b8+2ced63db88,g9d27549199+ef6ac23297,gabe93b2c52+e3573e3735,gb065e2a02a+3dfbe639da,gbc3249ced9+0c5d6105b6,gbec6a3398f+0c5d6105b6,gc9534b9d65+35b9f25267,gd01420fc67+0c5d6105b6,geee7ff78d7+a14128c129,gf63283c776+ede3a706f7,gfed783d017+0c5d6105b6,w.2022.47
LSST Data Management Base Package
Loading...
Searching...
No Matches
checksum.py
Go to the documentation of this file.
1import hashlib
2import zlib
3import pickle
4
5import lsst.afw.image as afwImage
6
7__all__ = ["checksum", ]
8
9# Image types to support
10exposureTypes = (afwImage.ExposureF, afwImage.ExposureD,)
11maskedImageTypes = (afwImage.MaskedImageF, afwImage.MaskedImageD,)
12decoratedImageTypes = (afwImage.DecoratedImageF, afwImage.DecoratedImageD,)
13imageTypes = (afwImage.ImageF, afwImage.ImageD, afwImage.ImageI,)
14
15PROTOCOL = 2 # Pickling protocol
16
17# Functions for creating the checksum
18sumFunctions = {
19 "CRC32": lambda obj: zlib.crc32(pickle.dumps(obj, PROTOCOL)),
20 "MD5": lambda obj: hashlib.md5(pickle.dumps(obj, PROTOCOL)).hexdigest(),
21}
22
23
24def checksum(obj, header=None, sumType="MD5"):
25 """!Calculate a checksum of an object
26
27 We have special handling for images (e.g., breaking a MaskedImage into
28 its various components), but the object may be any picklable type.
29
30 @param obj Object for which to calculate the checksum
31 @param header FITS header (PropertyList) to update with checksum values, or None
32 @param sumType Type of checksum to calculate
33 @return dict with header keyword,value pairs
34 """
35 assert sumType in sumFunctions, "Unknown sumType: %s" % (sumType,)
36 func = sumFunctions[sumType]
37
38 results = {}
39
40 if isinstance(obj, exposureTypes):
41 obj = obj.getMaskedImage()
42 if isinstance(obj, decoratedImageTypes):
43 obj = obj.getImage()
44
45 if isinstance(obj, maskedImageTypes):
46 results[sumType + "_IMAGE"] = func(obj.getImage())
47 results[sumType + "_MASK"] = func(obj.getMask())
48 results[sumType + "_VARIANCE"] = func(obj.getVariance())
49 elif isinstance(obj, imageTypes):
50 results[sumType + "_IMAGE"] = func(obj)
51 else:
52 results[sumType] = func(obj)
53
54 if header is not None:
55 for k, v in results.items():
56 header.add(k, v)
57
58 return results