Code Monkey home page Code Monkey logo

seam-carving's Introduction

Seam Carving

PyPI Unit Test License: MIT codecov

A super-fast Python implementation of Seam carving for content-aware image resizing, and the forward energy function proposed in Improved seam carving for video retargeting.

With seam carving algorithm, the image could be intelligently resized while keeping the important contents undistorted. The carving process could be further guided, so that an object could be removed from the image without apparent artifacts.

Installation

Install a stable version from PyPI.

pip install seam-carving

Or install the latest version from GitHub.

pip install git+https://github.com/li-plus/seam-carving.git@master

Quick Start

To resize an image using seam carving:

import numpy as np
from PIL import Image
import seam_carving

src = np.array(Image.open("fig/castle.jpg"))
src_h, src_w, _ = src.shape
dst = seam_carving.resize(
    src,  # source image (rgb or gray)
    size=(src_w - 200, src_h),  # target size
    energy_mode="backward",  # choose from {backward, forward}
    order="width-first",  # choose from {width-first, height-first}
    keep_mask=None,  # object mask to protect from removal
)
Image.fromarray(dst).show()

To remove an object from the image:

src = np.array(Image.open("fig/beach.jpg"))
mask = np.array(Image.open("fig/beach_girl.png").convert("L"))
dst = seam_carving.resize(src, drop_mask=mask)
Image.fromarray(dst).show()

For more examples, please refer to example/demo.ipynb.

Example Results

Scaling Up & Down

Resizing along the x-axis using the original backward energy function:

Backward Energy vs Forward Energy

Reducing the width using backward & forward energy functions:

Aspect Ratio Change

The image width and height could be changed simultaneously in an optimal seam order, but the order has little effect on the final result. Currently we only support two kinds of seam orders: width-first and height-first. In width-first mode, we remove or insert all vertical seams first, and then the horizontal ones, while height-first is the opposite.

Object Protection

The protected mask is not affected by seam removal and insertion.

Object Removal

Specify an object mask to remove (red) and a mask to protect (green, optional).

Benchmarks

We compare the performance of our implementation and other popular Python repos on castle.jpg (600x407). The image is narrowed or widened by 200 pixels using backward energy (BE) or forward energy (FE), respectively. Below is the running time (second) evaluated on a MacBook Pro.

Methods BE -200px BE +200px FE -200px FE +200px
vivianhylee/seam-carving 168.47 179.52 89.24 90.27
andrewdcampbell/seam-carving 119.47 126.44 133.29 133.73
sameeptandon/python-seam-carving 69.18 95.21 N/A N/A
dharness/seam_carving 50.25 57.86 N/A N/A
Ours 1.03 1.08 1.07 1.17

References

  • Avidan, S., & Shamir, A. (2007). Seam carving for content-aware image resizing. In ACM SIGGRAPH 2007 papers (pp. 10-es). [paper] [blog]
  • Rubinstein, M., Shamir, A., & Avidan, S. (2008). Improved seam carving for video retargeting. ACM transactions on graphics (TOG), 27(3), 1-9. [paper]
  • Das, A. (2019). Improved seam carving with forward energy. [blog]

seam-carving's People

Contributors

li-plus avatar

Stargazers

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

Watchers

 avatar  avatar  avatar  avatar

seam-carving's Issues

Possible Speedup

This library is not as fast as preferred, so I have a suggestion. you could use numba or jit to speedup your functions, I'll make my own version and submit a pull request soon.

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.