// Copyright (c) 2020 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#ifdef PADDLE_WITH_NCCL#include <cuda.h>#include <cuda_runtime.h>#include <nccl.h>#include "paddle/fluid/framework/lod_tensor.h"#include "paddle/fluid/framework/selected_rows.h"#include "paddle/fluid/framework/variable.h"#include "paddle/fluid/imperative/nccl_context.h"namespacepaddle{namespaceimperative{voidAllReduce(constframework::Variable&src,framework::Variable*dst,constParallelStrategy&strategy);}// namespace imperative}// namespace paddle#endif