Code Monkey home page Code Monkey logo

blenderline's Introduction

GPLv3 Python Blender GPLv3 Documentation Status

1. Table of Contents

Table of Contents

2. Description

BlenderLine is an open-source tool for generating synthetic image data for object detection, segmentation, and counting tasks in manufacturing settings. Leveraging 3D CAD models commonly found in manufacturing plants, BlenderLine automatically generates large and diverse datasets with pixel-perfect labels, reducing the time and effort traditionally required for manual data collection and annotation.

3. Overview

4. Features

  • Flexible: BlenderLine imposes as little constraints on your 3D modeling workflow as possible, giving you the freedom to model your production line as you see fit.
  • Declarative: Instead of having to write the generation code yourself, BlenderLine enables you to define the desired behavior of objects on your production line using declarative configuration files.
  • Powerful: Despite using declarative configuration files, BlenderLine is powerful enough to support a wide variety of use cases, ranging from narrow bottle counting lines (see examples/example_beer) to wide conveyor belts (example planned).
  • Convenient: BlenderLine includes tools to easily convert generated datasets into common computer vision dataset formats:
    • yolo_detection
    • yolo_segmentation (planned)
    • coco_detection (planned)
    • coco_segmentation (planned)

5. Installation

The simplest way to install BlenderLine is using pip:

pip install blenderline

Alternatively, you can choose to clone the repository to make a local pip installation:

git clone https://github.com/maxvandenhoven/blenderline
cd blenderline
pip install -e .

Note that, by default, BlenderLine assumes that Blender is installed and available on your system PATH, meaning that the Blender CLI can be invoked using only the blender command. The platform-dependent documentation below can help you add Blender to your system PATH:

Alternatively, you can use the optional --blender argument in blenderline generate to specify where Blender is installed on your system.

6. Usage

Generate Images

The blenderline generate command is used to generate a dataset of synthetic images from a configuration file. You can test BlenderLine with the provided examples/example_beer/images.json example as follows:

blenderline generate --config examples/example_beer/images.json --target data/raw

This will generate a dataset with the following structure:

data/
+- raw/
   +- example_beer/
      +- train/
      |  +- 0/
      |  |  +- image__f0825a6262fc__0001.png
      |  |  +- mask__0__8acdea079f10__0001.png
      |  |  +- mask__1__0181a303d637__0001.png
      |  |  +- ...
      |  +- 1/
      |     +- image__7abe7f02c7d9__0001.png
      |     +- mask__1__19abef8a5cef__0001.png
      |     +- mask__1__d980d4a83682__0001.png
      |     +- ...
      +- valid/
      |  +- 0/...
      |  +- 1/...
      +- label_mapping.json

While not strictly necessary, setting --target data/raw will create a folder structure that allows you to track different versions of the data, e.g., after using the blenderline convert command.

Note that the dataset root folder (here named example_beer) contains subfolders for different splits defined in the configuration file. Each split contains a numbered list of instance folders, each containing a rendered image and a set of masks. An example instance might look as follows:

Image and mask files use the following naming convention:

image__<random image ID>__0001.png
mask__<class ID>__<random mask ID>__0001.png
Convert Dataset

Coming soon!

7. Roadmap

Version Features
v0.1.0 (current) Image generation pipeline + CLI interface
v0.2.0 YOLO detection conversion pipeline + CLI interface
v0.3.0 Documentation + tutorial + second example
v0.4.0 YOLO segmentation conversion pipeline + CLI interface
v0.5.0 COCO detection conversion pipeline + CLI interface
v0.6.0 COCO segmentation conversion pipeline + CLI interface

blenderline's People

Contributors

maxvandenhoven avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

Forkers

rahulmr

blenderline's Issues

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.