All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.hadoop.yarn.api.resource.PlacementConstraintTransformations Maven / Gradle / Ivy

The newest version!
/**
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.apache.hadoop.yarn.api.resource;

import java.util.ListIterator;

import org.apache.hadoop.classification.InterfaceAudience.Private;
import org.apache.hadoop.yarn.api.records.AllocationTagNamespaceType;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.AbstractConstraint;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.And;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.CardinalityConstraint;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.CompositeConstraint;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.DelayedOr;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.Or;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.SingleConstraint;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.TargetConstraint;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.TargetConstraint.TargetOperator;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.TargetExpression;
import org.apache.hadoop.yarn.api.resource.PlacementConstraint.TimedPlacementConstraint;
import org.apache.hadoop.yarn.exceptions.YarnRuntimeException;

/**
 * This class contains inner classes that define transformation on a
 * {@link PlacementConstraint} expression.
 */
@Private
public class PlacementConstraintTransformations {

  /**
   * The default implementation of the {@link PlacementConstraint.Visitor} that
   * does a traversal of the constraint tree, performing no action for the lead
   * constraints.
   */
  public static class AbstractTransformer
      implements PlacementConstraint.Visitor {

    private PlacementConstraint placementConstraint;

    public AbstractTransformer(PlacementConstraint placementConstraint) {
      this.placementConstraint = placementConstraint;
    }

    /**
     * This method performs the transformation of the
     * {@link #placementConstraint}.
     *
     * @return the transformed placement constraint.
     */
    public PlacementConstraint transform() {
      AbstractConstraint constraintExpr =
          placementConstraint.getConstraintExpr();

      // Visit the constraint tree to perform the transformation.
      constraintExpr = constraintExpr.accept(this);

      return new PlacementConstraint(constraintExpr);
    }

    @Override
    public AbstractConstraint visit(SingleConstraint constraint) {
      // Do nothing.
      return constraint;
    }

    @Override
    public AbstractConstraint visit(TargetExpression expression) {
      // Do nothing.
      return null;
    }

    @Override
    public AbstractConstraint visit(TargetConstraint constraint) {
      // Do nothing.
      return constraint;
    }

    @Override
    public AbstractConstraint visit(CardinalityConstraint constraint) {
      // Do nothing.
      return constraint;
    }

    private AbstractConstraint visitAndOr(
        CompositeConstraint constraint) {
      for (ListIterator iter =
          constraint.getChildren().listIterator(); iter.hasNext();) {
        AbstractConstraint child = iter.next();
        child = child.accept(this);
        iter.set(child);
      }
      return constraint;
    }

    @Override
    public AbstractConstraint visit(And constraint) {
      return visitAndOr(constraint);
    }

    @Override
    public AbstractConstraint visit(Or constraint) {
      return visitAndOr(constraint);
    }

    @Override
    public AbstractConstraint visit(DelayedOr constraint) {
      constraint.getChildren().forEach(
          child -> child.setConstraint(child.getConstraint().accept(this)));
      return constraint;
    }

    @Override
    public AbstractConstraint visit(TimedPlacementConstraint constraint) {
      // Do nothing.
      return null;
    }
  }

  /**
   * Visits a {@link PlacementConstraint} tree and substitutes each
   * {@link TargetConstraint} and {@link CardinalityConstraint} with an
   * equivalent {@link SingleConstraint}.
   */
  public static class SingleConstraintTransformer extends AbstractTransformer {

    public SingleConstraintTransformer(PlacementConstraint constraint) {
      super(constraint);
    }

    @Override
    public AbstractConstraint visit(TargetConstraint constraint) {
      AbstractConstraint newConstraint;
      if (constraint.getOp() == TargetOperator.IN) {
        newConstraint = new SingleConstraint(constraint.getScope(), 1,
            Integer.MAX_VALUE, constraint.getTargetExpressions());
      } else if (constraint.getOp() == TargetOperator.NOT_IN) {
        newConstraint = new SingleConstraint(constraint.getScope(), 0, 0,
            constraint.getTargetExpressions());
      } else {
        throw new YarnRuntimeException(
            "Encountered unexpected type of constraint target operator: "
                + constraint.getOp());
      }
      return newConstraint;
    }

    @Override
    public AbstractConstraint visit(CardinalityConstraint constraint) {
      return new SingleConstraint(constraint.getScope(),
          constraint.getMinCardinality(), constraint.getMaxCardinality(),
          new TargetExpression(TargetExpression.TargetType.ALLOCATION_TAG,
              AllocationTagNamespaceType.SELF.toString(),
              constraint.getAllocationTags()));
    }
  }

  /**
   * Visits a {@link PlacementConstraint} tree and, whenever possible,
   * substitutes each {@link SingleConstraint} with a {@link TargetConstraint}.
   * When such a substitution is not possible, we keep the original
   * {@link SingleConstraint}.
   */
  public static class SpecializedConstraintTransformer
      extends AbstractTransformer {

    public SpecializedConstraintTransformer(PlacementConstraint constraint) {
      super(constraint);
    }

    @Override
    public AbstractConstraint visit(SingleConstraint constraint) {
      AbstractConstraint transformedConstraint = constraint;
      // Check if it is a target constraint.
      if (constraint.getMinCardinality() == 1
          && constraint.getMaxCardinality() == Integer.MAX_VALUE) {
        transformedConstraint = new TargetConstraint(TargetOperator.IN,
            constraint.getScope(), constraint.getTargetExpressions());
      } else if (constraint.getMinCardinality() == 0
          && constraint.getMaxCardinality() == 0) {
        transformedConstraint = new TargetConstraint(TargetOperator.NOT_IN,
            constraint.getScope(), constraint.getTargetExpressions());
      }

      return transformedConstraint;
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy