Skip to content

Commit

Permalink
Refactor temp_handler package and remove unused modules lowercase naming
Browse files Browse the repository at this point in the history
  • Loading branch information
haeussma committed Sep 21, 2024
1 parent be847a6 commit 3e37c81
Show file tree
Hide file tree
Showing 23 changed files with 4,854 additions and 0 deletions.
8 changes: 8 additions & 0 deletions mtphandler/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
import json # noqa
import os # noqa

from .mtp_logging import configure_logger
from .plate_manager import PlateManager # noqa


configure_logger()
1 change: 1 addition & 0 deletions mtphandler/ioutils/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@

146 changes: 146 additions & 0 deletions mtphandler/ioutils/calipytion.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,146 @@
from __future__ import annotations

import numpy as np
from calipytion import Calibrator
from calipytion.model import Sample, Standard, UnitDefinition

from mtphandler.model import Plate, Well
from mtphandler.molecule import Molecule
from mtphandler.tools import (
get_measurement,
get_species_condition,
measurement_is_blanked_for,
well_contains_species,
)


def _get_standard_wells(
plate: Plate,
protein_ids: list[str],
molecule: Molecule,
wavelength: float,
) -> list[Well]:
# Subset of wells, that contain specified species, do not contain a protein, and are blanked

# get wells with only one component, that does not contribute to the signal
buffer_blank_wells = []
standard_wells = []
for well in plate.wells:
measurement = get_measurement(well, wavelength)

# get all wells with one init condition that has a concentration grater than 0
int_concs_creater_than_zero = [
condition for condition in well.init_conditions if condition.init_conc > 0
]

if len(int_concs_creater_than_zero) == 1:
buffer_blank_wells.append(well)
print("found buffer blank well", well.id)

if not well_contains_species(well, molecule.id, conc_above_zero=True):
continue

if any(
[
well_contains_species(well, catalyst_id, conc_above_zero=True)
for catalyst_id in protein_ids
]
):
continue

if measurement_is_blanked_for(measurement, molecule.id):
standard_wells.append(well)

# Add wells with zero concentration to standard wells
if all(
[
blank_state.contributes_to_signal is False
for blank_state in measurement.blank_states
]
):
standard_wells.append(well)

print("found standard wells", len(standard_wells))

return standard_wells + buffer_blank_wells


def map_to_standard(
plate: Plate,
molecule: Molecule,
protein_ids: list[str],
wavelength: float,
) -> Standard:
standard_wells = _get_standard_wells(
plate=plate,
protein_ids=protein_ids,
molecule=molecule,
wavelength=wavelength,
)

# Map wells to samples of a standard
samples = []
phs = []
for well in standard_wells:
condition = get_species_condition(well, molecule.id)
measurement = get_measurement(well, wavelength)

samples.append(
Sample(
# id=well.id,
concentration=condition.init_conc,
conc_unit=UnitDefinition(**condition.conc_unit.model_dump()),
signal=float(np.nanmean(measurement.absorption)),
)
)
phs.append(well.ph)

# Check if all samples have the same pH
if not all([ph == phs[0] for ph in phs]):
raise ValueError(
f"Samples of standard {molecule.name} have different pH values: {phs}"
)
ph = phs[0]

temp_unit = UnitDefinition(**plate.temperature_unit.model_dump())

# Create standard
return Standard(
molecule_id=molecule.id,
molecule_symbol=molecule.id,
pubchem_cid=molecule.pubchem_cid,
molecule_name=molecule.name,
wavelength=wavelength,
samples=samples,
ph=ph,
temperature=plate.temperatures[0],
temp_unit=temp_unit,
)


def initialize_calibrator(
plate: Plate,
wavelength: float,
molecule: Molecule,
protein_ids: list[str],
cutoff: float | None = None,
) -> Calibrator:
"""
Initialize a calibrator for a given species.
Args:
plate (Plate): Plate with the wells.
wavelength (float): Wavelength of the measurements.
molecule (Molecule): Molecule to calibrate.
protein_ids (list[str]): IDs of the proteins that catalyze the reaction.
cutoff (float | None): Cutoff for the calibration. Calibration samples with
a signal above the cutoff are ignored.
"""
standard = map_to_standard(
plate=plate,
protein_ids=protein_ids,
molecule=molecule,
wavelength=wavelength,
)

return Calibrator.from_standard(standard, cutoff=cutoff)
Loading

0 comments on commit 3e37c81

Please sign in to comment.