Skip to content

Commit

Permalink
Update all instances of MinimumPreferenceOccurances to directly use T…
Browse files Browse the repository at this point in the history
…ransitionCriterion (facebook#2135)

Summary:

X-link: facebookresearch/aepsych#327

This diff updates MinimumPreferenceOccurances to directly inherit from its source in TransitionCriterion file

In following diffs we will:
- Completely remove the completion criterion file
- update all four completion criterion defined in aepsych code here: https://www.internalfb.com/code/fbsource/[409e3dfb01ec5c613d34e58c491d63e8051d10d9]/fbcode/frl/ae/aepsych/tests/generators/test_completion_criteria.py?lines=12-15
- revisit storage
- remove all todos in gennode, genstrat, and transitioncriterion classes related to maintaining this deprecated code
- update AEPsych GSs as needed
- determine if run indefinetly can be replaced by simply having gen_unlimited_trials = true

Differential Revision: D52852317
  • Loading branch information
mgarrard authored and facebook-github-bot committed Jan 19, 2024
1 parent 9b336f0 commit caac26e
Show file tree
Hide file tree
Showing 4 changed files with 6 additions and 20 deletions.
18 changes: 1 addition & 17 deletions ax/modelbridge/completion_criterion.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,7 @@

from logging import Logger

from ax.modelbridge.transition_criterion import (
MinimumPreferenceOccurances,
TransitionCriterion,
)
from ax.modelbridge.transition_criterion import TransitionCriterion
from ax.utils.common.logger import get_logger

logger: Logger = get_logger(__name__)
Expand All @@ -24,16 +21,3 @@ class CompletionCriterion(TransitionCriterion):
"CompletionCriterion is deprecated, please use TransitionCriterion instead."
)
pass


class MinimumPreferenceOccurances(MinimumPreferenceOccurances):
"""
Deprecated child class that has been replaced by `MinimumPreferenceOccurances`
in `TransitionCriterion`, and will be fully reaped in a future release.
"""

logger.warning(
"CompletionCriterion, which MinimumPreferenceOccurance inherits from, is"
" deprecated. Please use TransitionCriterion instead."
)
pass
3 changes: 1 addition & 2 deletions ax/modelbridge/tests/test_completion_criterion.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,9 @@
import pandas as pd
from ax.core.base_trial import TrialStatus
from ax.core.data import Data
from ax.modelbridge.completion_criterion import MinimumPreferenceOccurances
from ax.modelbridge.generation_strategy import GenerationStep, GenerationStrategy
from ax.modelbridge.registry import Models
from ax.modelbridge.transition_criterion import MinTrials
from ax.modelbridge.transition_criterion import MinimumPreferenceOccurances, MinTrials
from ax.utils.common.testutils import TestCase
from ax.utils.testing.core_stubs import get_experiment

Expand Down
3 changes: 2 additions & 1 deletion ax/modelbridge/tests/test_transition_criterion.py
Original file line number Diff line number Diff line change
Expand Up @@ -409,7 +409,8 @@ def test_repr(self) -> None:
self.assertEqual(
str(minimum_preference_occurances_criterion),
"MinimumPreferenceOccurances({'metric_name': 'm1', 'threshold': 3, "
+ "'transition_to': None, 'block_gen_if_met': False})",
+ "'transition_to': None, 'block_gen_if_met': False, "
"'block_transition_if_unmet': True})",
)
deprecated_min_trials_criterion = MinimumTrialsInStatus(
status=TrialStatus.COMPLETED, threshold=3
Expand Down
2 changes: 2 additions & 0 deletions ax/modelbridge/transition_criterion.py
Original file line number Diff line number Diff line change
Expand Up @@ -340,12 +340,14 @@ def __init__(
threshold: int,
transition_to: Optional[str] = None,
block_gen_if_met: Optional[bool] = False,
block_transition_if_unmet: Optional[bool] = True,
) -> None:
self.metric_name = metric_name
self.threshold = threshold
super().__init__(
transition_to=transition_to,
block_gen_if_met=block_gen_if_met,
block_transition_if_unmet=block_transition_if_unmet,
)

def is_met(
Expand Down

0 comments on commit caac26e

Please sign in to comment.