!35119 fix bug in if_parser for py37

Merge pull request !35119 from hangq/rewrite-bug
This commit is contained in:
i-robot 2022-05-31 02:24:20 +00:00 committed by Gitee
commit bd10ee110c
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
2 changed files with 57 additions and 5 deletions

View File

@ -777,7 +777,20 @@ class Conv2dBnFoldQuantOneConv(Cell):
@classmethod @classmethod
def from_float(cls, convbn: Conv2dBnAct, quant_config: QuantConfig): def from_float(cls, convbn: Conv2dBnAct, quant_config: QuantConfig):
"""A class method to create `Conv2dBnFoldQuantOneConv` from a `Conv2dBnAct`""" """
A class method to create `Conv2dBnFoldQuantOneConv` from a `Conv2dBnAct`
Examples:
>>> from mindspore import nn
>>> ic = 10
>>> oc = 100
>>> kernel_size = 3
>>> conv_bn_op = nn.Conv2dBnAct(ic, oc, kernel_size)
>>> # when apply QAT on `conv_bn_op`, QAT need to create a quant Conv2dBnAct whose weight is fake-quanted,
>>> quant_config: QuantConfig = QuantConfig(weight=FakeQuantWithMinMaxObserver.partial_init(),
>>> activation=FakeQuantWithMinMaxObserver.partial_init())
>>> conv_bn_quant = nn.Conv2dBnFoldQuantOneConv.from_float(conv_bn_op, quant_config)
"""
kwargs = {'in_channels': convbn.conv.in_channels, kwargs = {'in_channels': convbn.conv.in_channels,
'out_channels': convbn.conv.out_channels, 'out_channels': convbn.conv.out_channels,
@ -1032,7 +1045,20 @@ class Conv2dBnFoldQuant(Cell):
@classmethod @classmethod
def from_float(cls, convbn: Conv2dBnAct, quant_config: QuantConfig): def from_float(cls, convbn: Conv2dBnAct, quant_config: QuantConfig):
"""A class method to create `Conv2dBnFoldQuantOneConv` from a `Conv2dBnAct`""" """
A class method to create `Conv2dBnFoldQuantOneConv` from a `Conv2dBnAct`
Examples:
>>> from mindspore import nn
>>> ic = 10
>>> oc = 100
>>> kernel_size = 3
>>> conv_bn_op = nn.Conv2dBnAct(ic, oc, kernel_size)
>>> # when apply QAT on `conv_bn_op`, QAT need to create a quant Conv2dBnAct whose weight is fake-quanted
>>> quant_config: QuantConfig = QuantConfig(weight=FakeQuantWithMinMaxObserver.partial_init(),
>>> activation=FakeQuantWithMinMaxObserver.partial_init())
>>> conv_bn_quant = nn.Conv2dBnFoldQuant.from_float(conv_bn_op, quant_config)
"""
kwargs = {'in_channels': convbn.conv.in_channels, kwargs = {'in_channels': convbn.conv.in_channels,
'out_channels': convbn.conv.out_channels, 'out_channels': convbn.conv.out_channels,
@ -1382,7 +1408,20 @@ class Conv2dQuant(Cell):
@classmethod @classmethod
def from_float(cls, conv: Conv2d, quant_config: QuantConfig): def from_float(cls, conv: Conv2d, quant_config: QuantConfig):
"""A class method to create `Conv2dQuant` from a `Conv2d`""" """
A class method to create `Conv2dQuant` from a `Conv2d`
Examples:
>>> from mindspore import nn
>>> ic = 10
>>> oc = 100
>>> kernel_size = 3
>>> conv_op = nn.Conv2d(ic, oc, kernel_size)
>>> # when apply QAT on `conv_op`, QAT need to create a quant conv2d whose weight is fake-quanted
>>> quant_config: QuantConfig = QuantConfig(weight=FakeQuantWithMinMaxObserver.partial_init(),
>>> activation=FakeQuantWithMinMaxObserver.partial_init())
>>> conv_quant = nn.Conv2dQuant.from_float(conv_op, quant_config)
"""
conv_quant = cls( conv_quant = cls(
conv.in_channels, conv.in_channels,
conv.out_channels, conv.out_channels,
@ -1522,7 +1561,19 @@ class DenseQuant(Cell):
@classmethod @classmethod
def from_float(cls, dense: Dense, quant_config: QuantConfig): def from_float(cls, dense: Dense, quant_config: QuantConfig):
"""A class method to create `DenseQuant` from a `Dense`""" """
A class method to create `DenseQuant` from a `Dense`
Examples:
>>> from mindspore import nn
>>> ic = 10
>>> oc = 100
>>> dense_op = nn.Dense(ic, oc)
>>> # when apply QAT on `dense_op`, QAT need to create a quant dense whose weight is fake-quanted
>>> quant_config: QuantConfig = QuantConfig(weight=FakeQuantWithMinMaxObserver.partial_init(),
>>> activation=FakeQuantWithMinMaxObserver.partial_init())
>>> dense_quant = nn.DenseQuant.from_float(dense_op, quant_config)
"""
dense_quant = cls( dense_quant = cls(
dense.in_channels, dense.in_channels,
dense.out_channels, dense.out_channels,

View File

@ -70,7 +70,8 @@ class IfParser(Parser):
continue continue
targets = ast_node.targets targets = ast_node.targets
for target in targets: for target in targets:
dst_bodies.append(ast.Assign(targets=[target], value=ast.Constant(value=0, ctx=ast.Load()))) dst_bodies.append(ast.Assign(targets=[target], value=ast.Constant(value=0, kind=None,
ctx=ast.Load())))
else: else:
dst_bodies.append(ast.Pass()) dst_bodies.append(ast.Pass())