Skip to content

Commit

Permalink
Merge pull request #179 from Microsoft/v-ruzha
Browse files Browse the repository at this point in the history
modifed to issue #85
  • Loading branch information
kitstar authored May 3, 2018
2 parents 0ee5434 + dec29db commit e84841c
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 8 deletions.
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,8 @@ $ mmtoir -f keras -w imagenet_inception_v3.h5 -o keras_inception_v3

- [Tensorflow slim model "ResNet V2 152" to PyTorch](https://github.com/Microsoft/MMdnn/blob/master/docs/tf2pytorch.md)

- [Mxnet model "LResNet50E-IR" to Tensorflow](https://github.com/Microsoft/MMdnn/issues/85) and [related issue](https://github.com/Microsoft/MMdnn/issues/135)

### Users' Examples

- [MXNet "ResNet-152-11k" to PyTorch](https://github.com/Microsoft/MMdnn/issues/6)
Expand Down
3 changes: 3 additions & 0 deletions mmdnn/conversion/mxnet/mxnet_parser.py
Original file line number Diff line number Diff line change
Expand Up @@ -898,6 +898,9 @@ def _convert_scalar_operator(self, source_node, new_op):
value = source_node.get_attr('scalar')
value_node = self.IR_graph.node.add()
value_node.name = source_node.real_name + "_second"
# left strip the "_" at the beginning of the name
# Issue #85, #135
value_node.name = value_node.name.lstrip('_')
value_node.op = 'Constant'
self.set_weight(value_node.name, 'value', np.array([value], np.float32))

Expand Down
35 changes: 27 additions & 8 deletions mmdnn/conversion/tensorflow/tensorflow_emitter.py
Original file line number Diff line number Diff line change
Expand Up @@ -240,14 +240,33 @@ def emit_FullyConnected(self, IR_node):
bias_str = "bias_initializer = tf.constant_initializer(__weights_dict['{}']['bias']), ".format(IR_node.name)
else: bias_str = ""

code = "{:<15} = tf.layers.dense({}, {}, {}{}use_bias = {})".format(
IR_node.variable_name,
self.parent_variable_name(IR_node),
IR_node.layer.attr['units'].i,
kernel_str,
bias_str,
IR_node.layer.attr['use_bias'].b)
self.add_body(1, code)
# check whether flatten operator should be added
parent = self.IR_graph.get_parent(IR_node.name, [0])
parent_shape = shape_to_list(parent.get_attr('_output_shapes')[0])
if len(parent_shape) > 2:
# flatten is needed
self.add_body(1, "{:<15} = tf.contrib.layers.flatten({})".format(
IR_node.variable_name + '_flatten',
self.parent_variable_name(IR_node)))

code = "{:<15} = tf.layers.dense({}, {}, {}{}use_bias = {})".format(
IR_node.variable_name,
IR_node.variable_name + '_flatten',
IR_node.layer.attr['units'].i,
kernel_str,
bias_str,
IR_node.layer.attr['use_bias'].b)
self.add_body(1, code)

else:
code = "{:<15} = tf.layers.dense({}, {}, {}{}use_bias = {})".format(
IR_node.variable_name,
self.parent_variable_name(IR_node),
IR_node.layer.attr['units'].i,
kernel_str,
bias_str,
IR_node.layer.attr['use_bias'].b)
self.add_body(1, code)


def emit_Flatten(self, IR_node):
Expand Down

0 comments on commit e84841c

Please sign in to comment.