MNN/backupcode/cpubackend/CPUSelu.cpp

52 lines
1.4 KiB
C++
Raw Normal View History

2019-04-17 10:49:11 +08:00
//
// CPUSelu.cpp
// MNN
//
// Created by MNN on 2018/08/05.
// Copyright © 2018, Alibaba Group Holding Limited
//
2019-12-27 22:16:57 +08:00
#include "backend/cpu/CPUSelu.hpp"
2019-04-17 10:49:11 +08:00
#include <math.h>
2019-12-27 22:16:57 +08:00
#include "backend/cpu/CPUBackend.hpp"
#include "core/Macro.h"
2019-04-17 10:49:11 +08:00
namespace MNN {
CPUSelu::CPUSelu(Backend *b, const MNN::Op *op) : MNN::Execution(b) {
auto selu = op->main_as_Selu();
mScale = selu->scale();
mAlpha = selu->alpha();
}
ErrorCode CPUSelu::onExecute(const std::vector<Tensor *> &inputs, const std::vector<Tensor *> &outputs) {
MNN_ASSERT(1 == inputs.size());
MNN_ASSERT(1 == outputs.size());
MNN_ASSERT(inputs[0]->buffer().type.bytes() == 4);
auto scaleAlpha = mAlpha * mScale;
auto ptr = inputs[0]->host<float>();
auto outptr = outputs[0]->host<float>();
int size = inputs[0]->size() / sizeof(float);
for (int i = 0; i < size; i++) {
if (ptr[i] < 0.f) {
outptr[i] = scaleAlpha * (::expf(ptr[i]) - 1.f);
} else {
outptr[i] = mScale * ptr[i];
}
}
return NO_ERROR;
}
class CPUSeluCreator : public CPUBackend::Creator {
public:
virtual Execution *onCreate(const std::vector<Tensor *> &inputs, const std::vector<Tensor *> &outputs,
const MNN::Op *op, Backend *backend) const override {
return new CPUSelu(backend, op);
}
};
REGISTER_CPU_OP_CREATOR(CPUSeluCreator, OpType_Selu);
} // namespace MNN