Become a leader in the IoT community!

New DevHeads get a 320-point leaderboard boost when joining the DevHeads IoT Integration Community. In addition to learning and advising, active community leaders are rewarded with community recognition and free tech stuff. Start your Legendary Collaboration now!

Step 1 of 5

CREATE YOUR PROFILE *Required

OR
Step 2 of 5

WHAT BRINGS YOU TO DEVHEADS? *Choose 1 or more

Collaboration & Work 🤝
Learn & Grow 📚
Contribute Experience & Expertise 🔧
Step 3 of 5

WHAT'S YOUR INTEREST OR EXPERTISE? *Choose 1 or more

Hardware & Design 💡
Embedded Software 💻
Edge Networking
Step 4 of 5

Personalize your profile

Step 5 of 5

Read & agree to our COMMUNITY RULES

  1. We want this server to be a welcoming space! Treat everyone with respect. Absolutely no harassment, witch hunting, sexism, racism, or hate speech will be tolerated.
  2. If you see something against the rules or something that makes you feel unsafe, let staff know by messaging @admin in the "support-tickets" tab in the Live DevChat menu.
  3. No age-restricted, obscene or NSFW content. This includes text, images, or links featuring nudity, sex, hard violence, or other graphically disturbing content.
  4. No spam. This includes DMing fellow members.
  5. You must be over the age of 18 years old to participate in our community.
  6. Our community uses Answer Overflow to index content on the web. By posting in this channel your messages will be indexed on the worldwide web to help others find answers.
  7. You agree to our Terms of Service (https://www.devheads.io/terms-of-service/) and Privacy Policy (https://www.devheads.io/privacy-policy)
By clicking "Finish", you have read and agreed to the our Terms of Service and Privacy Policy.

Segmentation Fault with Flatten() in TensorFlow Lite for Microcontrollers on STM32F746NG

I’m building a CNN model to run on an STM32F746NG Discovery board following the “TensorFlow Lite for Microcontrollers” tutorials and the TinyML book. I know that the supported TensorFlow-Keras functions are listed in the all_ops_resolver.cc file (https://github.com/tensorflow/tensorflow/blob/master/tensorflow/lite/micro/all_ops_resolver.cc), but I’m having trouble with the Flatten() function. It doesn’t seem to be listed, even though it’s such a basic operation. I’m using other functions from the list, and my model looks like this:

model = models.Sequential()
model.add(layers.Conv2D(16, (3, 3), activation=’relu’, input_shape=(36, 36, 1)))
model.add(layers.MaxPooling2D((2, 2)))
model.add(layers.Conv2D(32, (3, 3), activation=’relu’, input_shape=(36, 36, 1)))
model.add(layers.MaxPooling2D((2, 2)))
model.add(layers.Conv2D(64, (3, 3), activation=’relu’, input_shape=(36, 36, 1)))
model.add(layers.MaxPooling2D((2, 2)))
model.add(layers.Flatten()) # Potential issue here
model.add(layers.Dense(8, activation=’softmax’))
model.add(layers.Dense(2))

model.summary()

model.compile(optimizer=’adam’,
loss=tf.keras.losses.SparseCategoricalCrossentropy(from_logits=True),
metrics=[‘accuracy’])

I get a segmentation fault when running the model on the STM32F746NG board, no matter how much memory I allocate. I suspect the issue might be related to the Flatten() function, but I wanted to ask: is Flatten() supported by TensorFlow Lite for Microcontrollers? If not, does it go by a different name or is there an alternative I should use? The segmentation fault seems to be triggered in the process, and I’m trying to figure out if it’s specific to this function or something else in my setup.

Has anyone encountered this issue or found a workaround for Flatten() on the STM32F746NG with TensorFlow Lite?

  1. Marvee Amasi#0000

    Since `Flatten()` is a simple operation that reshapes the data from a multi dimensional array to a single dimensional array, you can replace it with a Reshape operation, which is supported in TensorFlow Lite for Microcontrollers

  2. Marvee Amasi#0000

    You can reshape the data without relying on `Flatten()` by adding a Reshape layer.

  3. Marvee Amasi#0000

    This might be helpful
    0reshaping.txt

  4. Renuel Roberts#0000

    @wafa_ath You’re encountering a segmentation fault when running your `CNN` model on the `STM32F746NG` board using `TensorFlow` Lite, specifically when using the `Flatten()` function. Based on your description, the issue might `stem` from the fact that `Flatten()` is not explicitly supported in `TensorFlow Lite` for Microcontrollers, as it’s not included in the `all_ops_resolver.cc` file. However `Flatten()` is a common operation in standard `TensorFlow` models, it’s not supported by `TensorFlow Lite` for Microcontrollers. However, you can achieve the same `functionality` by replacing the `Flatten()` layer with a `Reshape layer`, which is supported in `TensorFlow Lite` for Microcontrollers and performs the equivalent `operation—flattening` a `multi-dimensional` tensor into a `1D array`.

    Here’s how you can modify your model to replace the `Flatten()` layer:
    “`
    model = models.Sequential()
    model.add(layers.Conv2D(16, (3, 3), activation=’relu’, input_shape=(36, 36, 1)))
    model.add(layers.MaxPooling2D((2, 2)))
    model.add(layers.Conv2D(32, (3, 3), activation=’relu’))
    model.add(layers.MaxPooling2D((2, 2)))
    model.add(layers.Conv2D(64, (3, 3), activation=’relu’))
    model.add(layers.MaxPooling2D((2, 2)))

    # Replace Flatten() with Reshape
    model.add(layers.Reshape((-1,))) # This layer automatically flattens the tensor

    model.add(layers.Dense(8, activation=’softmax’))
    model.add(layers.Dense(2))

    model.summary()

    model.compile(optimizer=’adam’,
    loss=tf.keras.losses.SparseCategoricalCrossentropy(from_logits=True),
    metrics=[‘accuracy’])
    “`

  5. wafa_ath#0000

    Thanks so much for the suggestion! I tried replacing Flatten() with Reshape((-1,)), but I’m still getting the same segmentation fault after that layer on the STM32F746NG. I also checked and adjusted memory allocation, but no luck so far.

    I’m wondering if the issue might be related to the overall model size or how the layers are handled during deployment. If anyone has other ideas or suggestions on how to fix this, I’d love to hear them!

    Thanks again for the help—I really appreciate it!

CONTRIBUTE TO THIS THREAD

Browse other questions tagged 

Leaderboard

RANKED BY XP

All time
  • 1.
    Avatar
    @Nayel115
    1620 XP
  • 2.
    Avatar
    @UcGee
    650 XP
  • 3.
    Avatar
    @melta101
    600 XP
  • 4.
    Avatar
    @lifegochi
    250 XP
  • 5.
    Avatar
    @Youuce
    180 XP
  • 6.
    Avatar
    @hemalchevli
    170 XP