slides available at bit.ly/pymcon-cell-counting

\text{cells/mL} = (\text{cells counted})/ ( \text{squares counted}) \cdot \\\\ \;\;\;\;\;\;\; (\text{dilution factor}) / 0.0001 \text{mL}

slides available at bit.ly/pymcon-cell-counting

\text{cells/mL} = (\text{95})/ ( \text{5}) \cdot \\\\ \;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\; (\text{1000}) / 0.0001 \text{mL}

slides available at bit.ly/pymcon-cell-counting

\text{cells/mL} = (\text{95})/ ( \text{5}) \cdot \\\\ \;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\;\; (\text{1000}) / 0.0001 \text{mL} \\ = 4.75B \;\text{cells} / \text{mL}

slides available at bit.ly/pymcon-cell-counting

slides available at bit.ly/pymcon-cell-counting

slides available at bit.ly/pymcon-cell-counting

\text{cells/mL} = (\text{cells counted})/ ( \text{squares counted}) \cdot \\\\ \;\;\;\;\;\;\; (\text{\color{red}dilution factor}) / 0.0001 \text{mL}

slides available at bit.ly/pymcon-cell-counting

slides available at bit.ly/pymcon-cell-counting

\text{cells/mL} = (\text{cells counted})/ ( \text{squares counted}) \cdot \\\\ \;\;\;\;\;\;\; (\text{\color{red}dilution factor}) / \color{red}{0.0001} \text{mL}

slides available at bit.ly/pymcon-cell-counting

\text{cells/mL} = (\text{\color{red} cells counted})/ ( \text{squares counted}) \cdot \\\\ \;\;\;\;\;\;\; (\text{\color{red}dilution factor}) / \color{red}{0.0001} \text{mL}
import pymc3 as pm

BILLION = 1e9
TOTAL_SQUARES = 25

squares_counted = 5
yeast_counted = 95
yeast_conc = pm.Normal("cells/mL", mu=2 * BILLION, sd=0.4 * BILLION)

yeast_slurry_volume = pm.Normal("initial yeast slurry volume (mL)", 
                                mu=1.0, 
                                sd=0.01)    
shaker1_volume = pm.Normal("shaker1 volume (mL)", 
                           mu=9.0, 
                           sd=0.05)
dilution_shaker1 = (yeast_slurry_volume / 
                    (yeast_slurry_volume + shaker1_volume))


shaker2_volume = pm.Normal("shaker2 volume (mL)", 
                           mu=9.0, 
                           sd=0.05)
shaker1_to_shaker2_volume = pm.Normal("shaker1 to shaker2 (mL)", 
                                      mu=1.0, 
                                      sd=0.01)
dilution_shaker2 = (shaker1_to_shaker2_volume / 
                    (shaker1_to_shaker2_volume + shaker2_volume))


shaker3_volume = pm.Normal("shaker3 volume (mL)", 
                           mu=9.0, 
                           sd=0.05)
shaker2_to_shaker3_volume = pm.Normal("shaker2 to shaker3 (mL)", 
                                      mu=1.0, 
                                      sd=0.01)
dilution_shaker3 = (shaker2_to_shaker3_volume / 
                    (shaker2_to_shaker3_volume + shaker3_volume))

...
dilution_shaker1 = (yeast_slurry_volume / 
                    (yeast_slurry_volume + shaker1_volume))
...

dilution_shaker2 = (shaker1_to_shaker2_volume / 
                    (shaker1_to_shaker2_volume + shaker2_volume))
...

dilution_shaker3 = (shaker2_to_shaker3_volume / 
                    (shaker2_to_shaker3_volume + shaker3_volume))
...

final_dilution_factor = dilution_shaker1 * dilution_shaker2 * dilution_shaker3

volume_of_chamber = pm.Gamma("volume of chamber (mL)", mu=0.0001, sd=0.0001 / 20)
\text{N yeast} = \text{yeast conc} \cdot \text{final dilution factor} \cdot \text{shaker3 volume}
\text{prob removed} = \text{volume of chamber} / \text{ shaker3 volume}
\text{prob removed} << 1
\text{N yeast} >> 0
\text{prob removed} << 1
\text{N yeast} >> 0

Poisson Approximation

...
final_dilution_factor = dilution_shaker1 * dilution_shaker2 * dilution_shaker3

volume_of_chamber = pm.Gamma("volume of chamber (mL)", mu=0.0001, sd=0.0001 / 20)

yeast_visible = pm.Poisson("cells in visible portion", 
                               mu=yeast_conc * final_dilution_factor * volume_of_chamber)
import pymc3 as pm

BILLION = 1e9
TOTAL_SQUARES = 25

squares_counted = 5
yeast_counted = 95

...
yeast_visible = pm.Poisson("cells in visible portion", 
                           mu=yeast_conc * final_dilution_factor * volume_of_chamber)

number_of_counted_cells = pm.Binomial("number of counted cells", 
                                      yeast_visible, squares_counted/TOTAL_SQUARES,
                                      observed=yeast_counted)

Measuring cell density in a noisy environment

By Cam DP

Measuring cell density in a noisy environment

  • 174