Skip to content

Commit

Permalink
unify env and env_from specs
Browse files Browse the repository at this point in the history
  • Loading branch information
shipengcheng1230 committed Nov 16, 2023
1 parent 18d522a commit 3e552cf
Showing 1 changed file with 16 additions and 16 deletions.
32 changes: 16 additions & 16 deletions sdk/python/v1beta1/kubeflow/katib/api/katib_client.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,6 @@
from kubeflow.katib.constants import constants
from kubeflow.katib.utils import utils
from kubernetes import client, config
from kubernetes.client.models import V1EnvVar, V1EnvFromSource


class KatibClient(object):
Expand Down Expand Up @@ -141,8 +140,7 @@ def tune(
parameters: Dict[str, Any],
base_image: str = constants.BASE_IMAGE_TENSORFLOW,
namespace: Optional[str] = None,
env: Union[Dict[str, str], List[V1EnvVar], None] = None,
env_from: Union[V1EnvFromSource, List[V1EnvFromSource], None] = None,
env_per_trial: Optional[Union[Dict[str, str], List[Union[client.V1EnvVar, client.V1EnvFromSource]]]] = None,
algorithm_name: str = "random",
algorithm_settings: Union[dict, List[models.V1beta1AlgorithmSetting], None] = None,
objective_metric_name: str = None,
Expand Down Expand Up @@ -175,13 +173,12 @@ def tune(
objective function.
base_image: Image to use when executing the objective function.
namespace: Namespace for the Experiment.
env: Environment variable(s) to be attached to each trial container. You can either specifiy
a list of kubernetes.client.models.V1EnvVar (documented here:
https://github.com/kubernetes-client/python/blob/master/kubernetes/docs/V1EnvVar.md) or a dictionary
corresponding to the environment variable name and value pair(s).
env_from: Source(s) of environment variables to be populated in each trial container. You can either specify
a kubernetes.client.models.V1EnvFromSource (documented here:
https://github.com/kubernetes-client/python/blob/master/kubernetes/docs/V1EnvFromSource.md) or a list of such a type.
env_per_trial: Environment variable(s) to be attached to each trial container.
You can specify a dictionary as a mapping object representing the environment variables.
Otherwise, you can specify a list, in which the element can either be a kubernetes.client.models.V1EnvVar (documented here:
https://github.com/kubernetes-client/python/blob/master/kubernetes/docs/V1EnvVar.md)
or a kubernetes.client.models.V1EnvFromSource (documented here:
https://github.com/kubernetes-client/python/blob/master/kubernetes/docs/V1EnvFromSource.md)
algorithm_name: Search algorithm for the HyperParameter tuning.
algorithm_settings: Settings for the search algorithm given.
For available fields, check this doc: https://www.kubeflow.org/docs/components/katib/experiment/#search-algorithms-in-detail.
Expand Down Expand Up @@ -328,12 +325,15 @@ def tune(
requests=resources_per_trial,
limits=resources_per_trial,
)

if isinstance(env, dict):
env = [V1EnvVar(name=str(k), value=str(v)) for k, v in env.items()]

if isinstance(env_from, V1EnvFromSource):
env_from = [env_from]

if isinstance(env_per_trial, dict):
env, env_from = [client.V1EnvVar(name=str(k), value=str(v)) for k, v in env_per_trial.items()] or None, None

if env_per_trial:
env = [x for x in env_per_trial if isinstance(x, client.V1EnvVar)] or None
env_from = [x for x in env_per_trial if isinstance(x, client.V1EnvFromSource)] or None
else:
env, env_from = None, None

# Create Trial specification.
trial_spec = client.V1Job(
Expand Down

0 comments on commit 3e552cf

Please sign in to comment.