Skip to main content

Complete computer vision and deep learning toolkit with GPU acceleration

Project description

Neurova

Python package for image processing, computer vision, deep learning, and classical machine learning

Most people who work with images and visual data end up in the same repeating cycle: you have an idea, you want to load an image, detect something, extract some numbers, feed them into a model, and see if it works. Instead you spend half the time hunting compatible versions, rewriting the same preprocessing code, and debugging why things break when you move from laptop to GPU.

Neurova exists to break that cycle. One install, one namespace, and you can go from raw image to trained model without constantly switching tools or fighting data format mismatches.

Python Version License PyPI

Navigation: Installation · Quick Start · Modules · Built-in Datasets · Examples · Documentation


Why Neurova

  • Single install, everything included — face detection cascades, sample images, Fashion-MNIST, tabular datasets all bundled
  • Consistent conventions — same array shapes, color orders, and device handling across all modules
  • Classical and deep learning together — swap histogram features for conv features without rewriting your pipeline
  • GPU acceleration optional — add CuPy and training gets 10-100x faster, no code changes needed
  • Pure Python — no compilation, works on Windows, macOS, Linux, Colab, anywhere Python runs

Key Features

Image Processing

  • Color space conversions (RGB, BGR, HSV, LAB, YCrCb, XYZ)
  • Geometric transforms (resize, rotate, flip, affine, perspective)
  • Filtering (blur, sharpen, edge detection, morphology)
  • Segmentation (thresholding, watershed, contours)

Computer Vision

  • Feature detection (Harris corners, HOG descriptors)
  • Face detection and recognition (Haar, LBP, DNN-based)
  • Object detection with cascade classifiers
  • Template matching and tracking

Deep Learning

  • Neural network layers (Linear, Conv2D, MaxPool2D, ReLU, Softmax)
  • Tensor operations with automatic differentiation
  • Optimizers (SGD, Adam, RMSprop)
  • Loss functions (MSE, CrossEntropy, BCE)

Machine Learning

  • Classification (KNN, Naive Bayes, Decision Trees, Random Forest, SVM)
  • Regression (Linear, Ridge, Polynomial)
  • Clustering (KMeans, DBSCAN, Hierarchical)
  • Dimensionality reduction (PCA, t-SNE)

Built-in Datasets

  • Tabular: Iris, Titanic, Boston Housing, Wine, Diabetes
  • Time Series: Air Passengers, Sunspots, Daily Temperatures
  • Clustering: Mall Customers, Penguins
  • Images: Fashion-MNIST, sample images (fruits, lena, building, etc.)
  • Cascade classifiers: Haar, LBP, HOG cascades included

GPU Acceleration

  • Optional CuPy backend for NVIDIA GPU support
  • Automatic device selection
  • 10-100x speedups on compatible hardware

Installation

# Basic installation
pip install neurova

# With GPU support (NVIDIA)
pip install neurova cupy-cuda12x

# Development installation
git clone https://github.com/nalystresearch/neurova.git
cd neurova
pip install -e ".[dev]"

See INSTALLATION.md for platform-specific guides and GPU setup.

Quick Start

Image Processing

import neurova as nv
from neurova import io, transform, filters, core

# Load image
img = io.read_image("photo.jpg")

# Color conversion
gray = core.to_grayscale(img)
hsv = core.convert_color_space(img, core.ColorSpace.BGR, core.ColorSpace.HSV)

# Apply filters
blurred = filters.gaussian_blur(img, kernel_size=5)
edges = filters.canny_edges(gray, low=50, high=150)

# Save result
io.write_image("edges.jpg", edges)

Using Built-in Datasets

from neurova import datasets

# Load sample images (options: 'fruits', 'lena', 'building', etc.)
img = datasets.load_sample_image('fruits')

# Load tabular data
iris = datasets.load_iris()
boston = datasets.load_boston_housing()

# Load Fashion-MNIST for neural network training
(train_images, train_labels), (test_images, test_labels) = datasets.load_fashion_mnist()

Machine Learning

from neurova import datasets
from neurova.ml import KNearestNeighbors, KMeans, PCA

# Load data
df = datasets.load_iris()
X = df[['sepal_length', 'sepal_width', 'petal_length', 'petal_width']].values
y = df['species'].astype('category').cat.codes.values

# Classification
knn = KNearestNeighbors(n_neighbors=3)
knn.fit(X, y)
predictions = knn.predict(X[:5])

# Clustering
kmeans = KMeans(n_clusters=3)
kmeans.fit(X)
clusters = kmeans.predict(X)

# Dimensionality reduction
pca = PCA(n_components=2)
X_reduced = pca.fit_transform(X)

Neural Networks

from neurova import datasets
from neurova.neural import layers, Tensor, optim

# Load Fashion-MNIST
(train_images, train_labels), _ = datasets.load_fashion_mnist()

# Create model
model = layers.Sequential([
    layers.Linear(784, 128),
    layers.ReLU(),
    layers.Linear(128, 10),
    layers.Softmax()
])

# Training loop
optimizer = optim.SGD(model.parameters(), lr=0.01)
for batch in training_data:
    x, y = batch
    output = model.forward(x)
    loss = compute_loss(output, y)
    optimizer.step()

Face Detection

from neurova import datasets
from neurova.face import FaceDetector

# Load sample image
img = datasets.load_sample_image('lena')

# Detect faces
detector = FaceDetector(method='haar')
faces = detector.detect(img)

for (x, y, w, h) in faces:
    print(f"Face at ({x}, {y}) size {w}x{h}")

Modules

Module Description
neurova.core Image class, color spaces, array operations
neurova.io Image and video I/O
neurova.transform Geometric transformations
neurova.filters Convolution, blur, edge detection, morphology
neurova.features Corner, edge, keypoint detection
neurova.detection Object and template detection
neurova.face Face detection and recognition
neurova.segmentation Thresholding, watershed, contours
neurova.neural Neural network layers and training
neurova.ml Machine learning algorithms
neurova.datasets Built-in datasets and sample images
neurova.augmentation Data augmentation pipelines
neurova.video Video processing and analysis
neurova.calibration Camera calibration and 3D geometry
neurova.nvc Computer vision utility functions

Built-in Datasets

Neurova includes ready-to-use datasets for testing and development:

Tabular Data

from neurova import datasets

# Iris flower classification
datasets.load_iris()
# Boston housing regression
datasets.load_boston_housing()
# Titanic survival classification
datasets.load_titanic()
# Diabetes prediction
datasets.load_diabetes()
# Wine classification
datasets.load_wine()

Time Series

# Monthly airline passengers
datasets.load_air_passengers()
# Daily temperature readings
datasets.load_daily_temperatures()
# Monthly sunspot counts
datasets.load_sunspots()

Clustering

# Customer segmentation
datasets.load_mall_customers()
# Palmer penguins dataset
datasets.load_penguins()

Images

# Sample RGB image
datasets.load_sample_image('fruits')
# Classic test image
datasets.load_sample_image('lena')
# Architectural features
datasets.load_sample_image('building')
# Calibration pattern
datasets.load_sample_image('chessboard')
# 70,000 fashion images
datasets.load_fashion_mnist()

Cascade Classifiers

# Face detection
datasets.get_haarcascade('frontalface_default')
# Eye detection
datasets.get_haarcascade('eye')
# LBP face detection
datasets.get_lbpcascade('frontalface')

Examples

The examples/ directory contains comprehensive tutorials:

Chapter Topic Description
01 Getting Started Basic setup and image operations
02 Image Transforms Color spaces, geometric transforms
03 Filters Blur, sharpen, edge detection, morphology
04 Features Corner detection, HOG descriptors
05 Detection Object and template detection
06 Face Face detection and recognition
07 Machine Learning Classification, regression, clustering
08 Neural Networks Building and training neural networks
09 Datasets Using built-in datasets
10 Video Video processing and analysis
11 Segmentation Thresholding, contours, watershed
12 GPU Performance GPU acceleration with CuPy

Running Examples

# Run any chapter example
python examples/chapter_07_machine_learning.py

# Run face detection project
python examples/face_recognition_project/01_collect_faces.py

Dependencies

Required

  • Python >= 3.8
  • NumPy >= 1.19.0

Optional

  • Pillow: Extended image format support
  • pandas: For tabular dataset loading
  • CuPy: GPU acceleration

Documentation

Document Description
INSTALLATION.md Installation and setup guide
QUICKSTART.md Quick reference and API overview
GETTING_STARTED.md Development guide
ARCHITECTURE.md Module structure and design
DOCS_INDEX.md Full documentation index

Performance

Neurova is optimized using:

  • NumPy vectorization for fast array operations
  • Efficient memory management with minimal copies
  • Parallel processing for batch operations
  • Optional GPU acceleration via CuPy

Contributing

Contributions welcome! See CONTRIBUTING.md for guidelines.

License

Apache License 2.0 - Copyright (c) 2025 Squid Consultancy Group (SCG)

This software is free for educational, academic, and non-commercial use. For commercial use, please contact Squid Consultancy Group (SCG) for licensing terms.

See LICENSE for details.

Trademarks

Neurova is an independent project developed by Squid Consultancy Group (SCG). The following are trademarks of their respective owners and are mentioned only for compatibility and interoperability purposes:

  • TensorFlow® is a trademark of Google LLC
  • PyTorch® is a trademark of Meta Platforms, Inc.
  • OpenCV® is a trademark of OpenCV team
  • CUDA® is a trademark of NVIDIA Corporation

This project is not affiliated with, endorsed by, or sponsored by any of these organizations.

Changelog

See CHANGELOG.md for version history.


Maintained by Squid Consultancy Group (SCG)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

neurova-0.0.6.tar.gz (96.8 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

neurova-0.0.6-py3-none-any.whl (97.0 MB view details)

Uploaded Python 3

File details

Details for the file neurova-0.0.6.tar.gz.

File metadata

  • Download URL: neurova-0.0.6.tar.gz
  • Upload date:
  • Size: 96.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for neurova-0.0.6.tar.gz
Algorithm Hash digest
SHA256 7cf027398bec35171d69cc2bb47bbdaad915a93c162629bbea371f5cde9cd68e
MD5 7950d1e91f9c052f1fa1f2bca78ce733
BLAKE2b-256 bd821fc22b881dbce3f065fbf9cb67363df70e9548896fa71d797ecd6b798a06

See more details on using hashes here.

File details

Details for the file neurova-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: neurova-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 97.0 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for neurova-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 98f8df3554080e0cdec60b4702421b621c1ba80db770e5b6e45af6f76b7182ec
MD5 ec901e79f175a920808ff2666a01f31f
BLAKE2b-256 bbf5b5b2e7a538150f64ac6867a9ff471bddc81e6358a31c31fdc2263b9322c6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page