in spotify_confidence/analysis/frequentist/confidence_computers/confidence_computer.py [0:0]
def achieved_power(self, level_1, level_2, mde, alpha, groupby):
groupby = listify(groupby)
level_columns = get_remaning_groups(self._all_group_columns, groupby)
kwargs = {NUMERATOR: self._numerator, DENOMINATOR: self._denominator}
return (
self._compute_differences(
level_columns,
[(level_1, level_2)],
True,
groupby,
level_as_reference=True,
nims=None,
final_expected_sample_size_column=None,
mde_column=None,
) # TODO: IS this right?
.pipe(lambda df: df if groupby == [] else df.set_index(groupby))
.assign(
achieved_power=lambda df: df.apply(
lambda row: confidence_computers[row[self._method_column]].achieved_power(
row, mde=mde, alpha=alpha, **kwargs
),
axis=1,
)
)
)[["level_1", "level_2", "achieved_power"]]