// Copyright (c) 2022 PaddlePaddle Authors. All Rights Reserved.//// Licensed 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.#pragma once#include "paddle/fluid/platform/place.h"#include "paddle/phi/api/include/api.h"namespacepaddle{namespacedistributed{usingTensor=paddle::experimental::Tensor;usingPlace=paddle::platform::Place;// Get the list of devices from list of tensorsstd::vector<Place>GetPlaceList(conststd::vector<Tensor>&tensors);// Get the deviceList String from the list of devicesstd::stringGetKeyFromPlaces(conststd::vector<Place>&places);boolCheckTensorsInCudaPlace(conststd::vector<Tensor>&tensors);}// namespace distributed}// namespace paddle