!7463 move train.quant to compression module & add QuantizationAwareTraining
Merge pull request !7463 from yuchaojie/quant2pull/7463/MERGE
commit
3b55a25f8d
@ -0,0 +1,17 @@
|
||||
# Copyright 2020 Huawei Technologies Co., Ltd
|
||||
#
|
||||
# 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.
|
||||
# ============================================================================
|
||||
"""
|
||||
Compression export module.
|
||||
"""
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,52 @@
|
||||
# Copyright 2020 Huawei Technologies Co., Ltd
|
||||
#
|
||||
# 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.
|
||||
# ============================================================================
|
||||
"""Base Class of Quantizer."""
|
||||
|
||||
from abc import ABC, abstractmethod
|
||||
from enum import Enum
|
||||
|
||||
__all__ = ["OptimizeOption", "Quantizer"]
|
||||
|
||||
|
||||
class OptimizeOption(Enum):
|
||||
"""
|
||||
An enum for the model quantization optimize option.
|
||||
"""
|
||||
# using quantization aware training
|
||||
QAT = "QAT"
|
||||
|
||||
def __str__(self):
|
||||
return self.value
|
||||
|
||||
|
||||
class Quantizer(ABC):
|
||||
"""
|
||||
Base class of Quantizer. You can implement different kind of quantizer to get different quantization result.
|
||||
|
||||
Notes:
|
||||
This class is an abstract class.
|
||||
|
||||
Args:
|
||||
optimize_option (OptimizeOption, list or tuple): Specifies the quant algorithm and options. Default: None.
|
||||
"""
|
||||
def __init__(self,
|
||||
optimize_option=None):
|
||||
if not isinstance(optimize_option, list) and not isinstance(optimize_option, tuple):
|
||||
optimize_option = [optimize_option]
|
||||
self.optimize_option = optimize_option
|
||||
|
||||
@abstractmethod
|
||||
def quantize(self, network):
|
||||
pass
|
Loading…
Reference in new issue