apple / coremltools

Core ML tools contain supporting tools for Core ML model conversion, editing, and validation.
https://coremltools.readme.io
BSD 3-Clause "New" or "Revised" License
4.33k stars 627 forks source link

AttributeError: 'list' object has no attribute 'val'. When set flexible input shapes #2037

Open ThuyyTran opened 10 months ago

ThuyyTran commented 10 months ago

🐞Describing the bug

Traceback (most recent call last):
  File "/media/anlab/data-2tb/ANLAB_THUY/ImageSearcher/ConvertSolar2Coreml.py", line 119, in <module>
    mlprogram = ct.convert(
  File "/home/anlab/anaconda3/envs/convertmodel1/lib/python3.9/site-packages/coremltools/converters/_converters_entry.py", line 551, in convert
    mlmodel = mil_convert(
  File "/home/anlab/anaconda3/envs/convertmodel1/lib/python3.9/site-packages/coremltools/converters/mil/converter.py", line 188, in mil_convert
    return _mil_convert(model, convert_from, convert_to, ConverterRegistry, MLModel, compute_units, **kwargs)
  File "/home/anlab/anaconda3/envs/convertmodel1/lib/python3.9/site-packages/coremltools/converters/mil/converter.py", line 212, in _mil_convert
    proto, mil_program = mil_convert_to_proto(
  File "/home/anlab/anaconda3/envs/convertmodel1/lib/python3.9/site-packages/coremltools/converters/mil/converter.py", line 286, in mil_convert_to_proto
    prog = frontend_converter(model, **kwargs)
  File "/home/anlab/anaconda3/envs/convertmodel1/lib/python3.9/site-packages/coremltools/converters/mil/converter.py", line 108, in __call__
    return load(*args, **kwargs)
  File "/home/anlab/anaconda3/envs/convertmodel1/lib/python3.9/site-packages/coremltools/converters/mil/frontend/torch/load.py", line 75, in load
    return _perform_torch_convert(converter, debug)
  File "/home/anlab/anaconda3/envs/convertmodel1/lib/python3.9/site-packages/coremltools/converters/mil/frontend/torch/load.py", line 114, in _perform_torch_convert
    prog = converter.convert()
  File "/home/anlab/anaconda3/envs/convertmodel1/lib/python3.9/site-packages/coremltools/converters/mil/frontend/torch/converter.py", line 484, in convert
    convert_nodes(self.context, self.graph)
  File "/home/anlab/anaconda3/envs/convertmodel1/lib/python3.9/site-packages/coremltools/converters/mil/frontend/torch/ops.py", line 93, in convert_nodes
    add_op(context, node)
  File "/home/anlab/anaconda3/envs/convertmodel1/lib/python3.9/site-packages/coremltools/converters/mil/frontend/torch/ops.py", line 3923, in avg_pool2d
    _avg_pool(context, node, inputs)
  File "/home/anlab/anaconda3/envs/convertmodel1/lib/python3.9/site-packages/coremltools/converters/mil/frontend/torch/ops.py", line 3876, in _avg_pool
    strides = mb.const(val=kernel_sizes.val, name=strides.name)
AttributeError: 'list' object has no attribute 'val'

To Reproduce

mlprogram = ct.convert( traced_model, minimum_deployment_target=ct.target.iOS13, inputs=[input_tensor], outputs=[ct.TensorType(name="embeddings")], convert_to="neuralnetwork", compute_units=ct.ComputeUnit.CPU_ONLY, ) saved_model = 'ModelConvert/TestModel/Solar300_image_CPU_FlexibleInput.mlmodel' outputmodel.save(saved_model)


## System environment 
 - coremltools version: 7.0
 - OS (e.g. MacOS version or Linux type): Linux
 - Any other relevant version information (e.g. PyTorch or TensorFlow version): Torch 1.9.1
xorange commented 10 months ago

Could you try https://github.com/apple/coremltools/pull/2050 to see if it fixes this problem ? Or could you provide a standalone minimum example for reproduce ?

ThuyyTran commented 10 months ago

Could you try #2050 to see if it fixes this problem ? Or could you provide a standalone minimum example for reproduce ?

I tried to change the code in file coremltools/converters/mil/frontend/torch/ops.py similar to #2050. But when I convert the model, it always pauses at a certain threshold. I tried waiting but it didn't seem to work. you can reproduce using my colab code here: https://colab.research.google.com/drive/1jqT_K3ValOyfc_o_2od44eiz4UiE8xAk?usp=sharing

xorange commented 10 months ago

Could you try #2050 to see if it fixes this problem ? Or could you provide a standalone minimum example for reproduce ?

I tried to change the code in file coremltools/converters/mil/frontend/torch/ops.py similar to #2050. But when I convert the model, it always pauses at a certain threshold. I tried waiting but it didn't seem to work. you can reproduce using my colab code here: https://colab.research.google.com/drive/1jqT_K3ValOyfc_o_2od44eiz4UiE8xAk?usp=sharing

OK. I also notice the pause and has a plan yet to be implemented. I'll try your code after the optimization.

ThuyyTran commented 10 months ago

@xorange Thanks. Looking forward to hearing from you.

xorange commented 10 months ago

My PR focused on "padding" and failed to fix this problem. I've encountered the same situation on another net structure with a similar root cause.

I'll try to generalize my fix for these.