Git Product home page Git Product logo

wrap_opencv-python-headless's Introduction

wrap_opencv-python-headless

rebrand opencv-python-headless as opencv-python

Introduction

If you want to install OpenCV as a Python package, or include it as a dependency in another, (unless you want to build your own,) you'll first have to decide on a flavour (and top-level package name):

Select the correct package for your environment:

There are four different packages (see options 1, 2, 3 and 4 below) and you should SELECT ONLY ONE OF THEM. Do not install multiple different packages in the same environment. There is no plugin architecture: all the packages use the same namespace (cv2). If you installed multiple different packages in the same environment, uninstall them all with pip uninstall and reinstall only one package.

a. Packages for standard desktop environments (Windows, macOS, almost any GNU/Linux distribution)

  • Option 1 - Main modules package: pip install opencv-python
  • Option 2 - Full package (contains both main modules and contrib/extra modules): pip install opencv-contrib-python (check contrib/extra modules listing from OpenCV documentation)

b. Packages for server (headless) environments (such as Docker, cloud environments etc.), no GUI library dependencies

These packages are smaller than the two other packages above because they do not contain any GUI functionality (not compiled with Qt / other GUI components). This means that the packages avoid a heavy dependency chain to X11 libraries and you will have for example smaller Docker images as a result. You should always use these packages if you do not use cv2.imshow et al. or you are using some other package (such as PyQt) than OpenCV to create your GUI.

  • Option 3 - Headless main modules package: pip install opencv-python-headless
  • Option 4 - Headless full package (contains both main modules and contrib/extra modules): pip install opencv-contrib-python-headless (check contrib/extra modules listing from OpenCV documentation)

This creates a problem for dependent packages, though: Whatever OpenCV flavour you choose to depend on, your dependents will also rely on that particular choice. To make matters worse, pip does not consider these flavours as conflict when installed in parallel (despite all sharing the same submodule/subpackage name cv2).

So practically, if you depend on some OpenCV-dependent packages, but want to avoid the X11 dependencies, any of your dependencies could drag them back in if it chose to require opencv-python instead of opencv-python-headless.

If, however, you know for certain that none of them actually need X11, and might thus easily have been chosen headless, then this package is for you. It merely re-brands opencv-python-headless as opencv-python by requiring the former but providing the latter in an otherwise empty package.

You can install this package prior to other dependencies and thus block any subsequent installation of the actual prebuilt opencv-python. (But to make this work including a mirrored version number, opencv-python-headless needs to be installed early, too. Thus, installing this package will also install opencv-python-headless if not already present.)

Installation

# git clone and chdir, then pip:
pip install .
# or, pip via git:
pip install opencv-python@git+https://github.com/bertsky/wrap_opencv-python-headless

wrap_opencv-python-headless's People

Contributors

bertsky avatar chhinric avatar

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.