Skip to content
Snippets Groups Projects
defaults.py 2.01 KiB
Newer Older
Alán Muñoz's avatar
Alán Muñoz committed
# File with defaults for ease of use
import typing as t
from pathlib import PosixPath

import h5py
def exparams_from_meta(
    meta: t.Union[dict, PosixPath, str], extras: t.Collection[str] = ["ph"]
):
Alán Muñoz's avatar
Alán Muñoz committed
    """
    Obtain parameters from metadata of hdf5 file
    """
    meta = meta if isinstance(meta, dict) else load_attributes(meta)
    base = {
        "tree": {"general": {"None": ["area", "volume", "eccentricity"]}},
Alán Muñoz's avatar
Alán Muñoz committed
        "multichannel_ops": {},
    }

    av_channels = {
        "Citrine",
        "GFP",
        "GFPFast",
        "mCherry",
        "pHluorin405",
        "Flavin",
        "Cy5",
        "mKO2",
    }

    default_reductions = {"max"}
    default_metrics = {
        "mean",
        "median",
        "imBackground",
Alán Muñoz's avatar
Alán Muñoz committed
        "max5px",
        "nuc_est_conv",
Alán Muñoz's avatar
Alán Muñoz committed
    default_rm = {r: default_metrics for r in default_reductions}
    # default_rm["None"] = ["nuc_conv_3d"] # Uncomment this to add nuc_conv_3d (slow)
Alán Muñoz's avatar
Alán Muñoz committed

    av_flch = av_channels.intersection(meta["channels/channel"]).difference(
Alán Muñoz's avatar
Alán Muñoz committed
        {"Brightfield", "DIC", "BrightfieldGFP"}
Alán Muñoz's avatar
Alán Muñoz committed
    )

    for ch in av_flch:
        base["tree"][ch] = default_rm

    base["sub_bg"] = av_flch

    # Additional extraction defaults when channels available
    if "ph" in extras:
        if {"pHluorin405", "GFPFast"}.issubset(av_flch):
            sets = {
                b + a: (x, y)
                for a, x in zip(
                    ["", "_bgsub"],
                    (
                        ["GFPFast", "pHluorin405"],
                        ["GFPFast_bgsub", "pHluorin405_bgsub"],
                    ),
                )
                for b, y in zip(["em_ratio", "gsum"], ["div0", "add"])
            }
            for i, v in sets.items():
                base["multichannel_ops"][i] = [
                    *v,
                    default_rm,
                ]
def load_attributes(file: t.Union[str, PosixPath], group="/"):
Alán Muñoz's avatar
Alán Muñoz committed
    with h5py.File(file, "r") as f:
        meta = dict(f[group].attrs.items())
    return meta