LSST Applications g0da5cf3356+25b44625d0,g17e5ecfddb+50a5ac4092,g1c76d35bf8+585f0f68a2,g295839609d+8ef6456700,g2e2c1a68ba+cc1f6f037e,g38293774b4+62d12e78cb,g3b44f30a73+2891c76795,g48ccf36440+885b902d19,g4b2f1765b6+0c565e8f25,g5320a0a9f6+bd4bf1dc76,g56364267ca+403c24672b,g56b687f8c9+585f0f68a2,g5c4744a4d9+78cd207961,g5ffd174ac0+bd4bf1dc76,g6075d09f38+3075de592a,g667d525e37+cacede5508,g6f3e93b5a3+da81c812ee,g71f27ac40c+cacede5508,g7212e027e3+eb621d73aa,g774830318a+18d2b9fa6c,g7985c39107+62d12e78cb,g79ca90bc5c+fa2cc03294,g881bdbfe6c+cacede5508,g91fc1fa0cf+82a115f028,g961520b1fb+2534687f64,g96f01af41f+f2060f23b6,g9ca82378b8+cacede5508,g9d27549199+78cd207961,gb065e2a02a+ad48cbcda4,gb1df4690d6+585f0f68a2,gb35d6563ee+62d12e78cb,gbc3249ced9+bd4bf1dc76,gbec6a3398f+bd4bf1dc76,gd01420fc67+bd4bf1dc76,gd59336e7c4+c7bb92e648,gf46e8334de+81c9a61069,gfed783d017+bd4bf1dc76,v25.0.1.rc3
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