| /* |
| * Copyright (C) 2017 The Android Open Source Project |
| * |
| * 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. |
| */ |
| |
| #define LOG_TAG "SampleDriverQuant" |
| |
| #include <HalInterfaces.h> |
| #include <Utils.h> |
| #include <android-base/logging.h> |
| #include <hidl/LegacySupport.h> |
| |
| #include <thread> |
| #include <vector> |
| |
| #include "SampleDriverPartial.h" |
| |
| namespace android { |
| namespace nn { |
| namespace sample_driver { |
| |
| class SampleDriverQuant : public SampleDriverPartial { |
| public: |
| SampleDriverQuant() : SampleDriverPartial("nnapi-sample_quant") {} |
| hardware::Return<void> getCapabilities_1_3(getCapabilities_1_3_cb cb) override; |
| |
| private: |
| std::vector<bool> getSupportedOperationsImpl(const V1_3::Model& model) const override; |
| }; |
| |
| hardware::Return<void> SampleDriverQuant::getCapabilities_1_3(getCapabilities_1_3_cb cb) { |
| android::nn::initVLogMask(); |
| VLOG(DRIVER) << "getCapabilities()"; |
| |
| V1_3::Capabilities capabilities = { |
| .relaxedFloat32toFloat16PerformanceScalar = {.execTime = 50.0f, .powerUsage = 1.0f}, |
| .relaxedFloat32toFloat16PerformanceTensor = {.execTime = 50.0f, .powerUsage = 1.0f}, |
| .operandPerformance = nonExtensionOperandPerformance<HalVersion::V1_3>({50.0f, 1.0f}), |
| .ifPerformance = {.execTime = 50.0f, .powerUsage = 1.0f}, |
| .whilePerformance = {.execTime = 50.0f, .powerUsage = 1.0f}}; |
| |
| cb(V1_3::ErrorStatus::NONE, capabilities); |
| return hardware::Void(); |
| } |
| |
| static bool isQuantized(V1_3::OperandType opType) { |
| return opType == V1_3::OperandType::TENSOR_QUANT8_ASYMM || |
| opType == V1_3::OperandType::TENSOR_QUANT8_ASYMM_SIGNED; |
| } |
| |
| std::vector<bool> SampleDriverQuant::getSupportedOperationsImpl(const V1_3::Model& model) const { |
| const size_t count = model.main.operations.size(); |
| std::vector<bool> supported(count); |
| for (size_t i = 0; i < count; i++) { |
| const V1_3::Operation& operation = model.main.operations[i]; |
| if (!isExtensionOperationType(operation.type) && operation.inputs.size() > 0) { |
| const V1_3::Operand& firstOperand = model.main.operands[operation.inputs[0]]; |
| supported[i] = isQuantized(firstOperand.type); |
| if (operation.type == V1_3::OperationType::SELECT) { |
| const V1_3::Operand& secondOperand = model.main.operands[operation.inputs[1]]; |
| supported[i] = isQuantized(secondOperand.type); |
| } |
| } |
| } |
| return supported; |
| } |
| |
| } // namespace sample_driver |
| } // namespace nn |
| } // namespace android |
| |
| using android::sp; |
| using android::nn::sample_driver::SampleDriverQuant; |
| |
| int main() { |
| sp<SampleDriverQuant> driver(new SampleDriverQuant()); |
| return driver->run(); |
| } |