23 repositorios
Thin interface layers mapping high-level Python calls to optimized low-level machine code routines.
Distinct from C Interoperability Layers: Distinct from C Interoperability Layers: focuses on the specific performance-oriented bridge for numerical data processing.
Explore 23 awesome GitHub repositories matching operating systems & systems programming · Python-C Interfaces. Refine with filters or upvote what's useful.
NumPy is a foundational library for scientific computing in Python, providing a comprehensive framework for managing and manipulating large-scale numerical information. It centers on high-performance multidimensional array objects that serve as the primary data structure for complex mathematical operations and data analysis workflows. The library distinguishes itself through specialized mechanisms for handling multidimensional data, including advanced indexing, slicing, and broadcasting techniques that allow for efficient operations across arrays of varying shapes. It utilizes strided metadat
Provides a high-performance bridge between Python and compiled C/Fortran code for numerical processing.
This project is a comprehensive educational resource and technical documentation suite for learning and developing deep learning models. It serves as an open-source textbook, implementation manual, and framework tutorial designed to guide users through the mathematical foundations and practical application of neural networks. The resource provides detailed instructional content on building various model architectures, including convolutional and recurrent neural networks. It includes a dedicated distributed training guide and a learning path that covers the fundamentals of tensors, automatic
Provides documentation on using Python-C interfaces to access high-performance backend components.
pybind11 is a header-only C++ binding library that exposes C++ functions and classes as Python modules. It serves as a language bridge, mapping native types, inheritance hierarchies, and lambda functions into compatible Python objects to enable high-performance native code execution. The library includes specialized integration for NumPy arrays, utilizing buffer protocols to bind native C++ data without copying memory. It provides a toolkit for mapping C++ standard library data structures and smart pointers into the Python environment while maintaining cross-language memory management. The p
Provides the low-level interface layer that maps Python calls to C++ native routines.
SciPy is a scientific computing library for Python that provides a comprehensive collection of mathematical algorithms and numerical tools for research and engineering. It functions as a high-performance numerical analysis framework, bridging high-level Python code with compiled C and Fortran routines to execute complex computations at hardware speeds. The library is built upon array-based data structures that utilize strided memory layouts to enable efficient data manipulation and slicing. By employing vectorized operation dispatch and linking to optimized hardware-specific linear algebra li
Bridges high-level Python code with compiled C and Fortran routines to execute complex computations at hardware speeds.
dlib is a C++ machine learning toolkit and data analysis framework. It provides a collection of algorithms and utilities for building predictive modeling applications and performing statistical analysis on large datasets within native C++ environments. The project functions as a binding library that wraps low-level C++ machine learning algorithms into high-level Python scripting interfaces. This allows for the integration of high-performance native implementations with Python for machine learning development. The framework covers the implementation of predictive models, the execution of mach
Implements a high-performance interface layer mapping C++ machine learning classes to Python objects.
Open3D is a software toolkit designed for the processing, alignment, and reconstruction of three-dimensional data. It functions as a computer vision geometry engine that enables the manipulation of point clouds, meshes, and volumetric grids derived from sensor inputs. The library distinguishes itself through a high-performance computational core that executes geometric processing tasks in native code, paired with a binding layer that exposes these capabilities to high-level languages for rapid prototyping. It provides specialized algorithms for spatial registration, allowing users to merge mu
Exposes high-performance C++ computational kernels to Python for rapid prototyping and efficient data analysis workflows.
QGIS is a professional, open-source desktop geographic information system designed for the creation, editing, visualization, and analysis of complex spatial data. It functions as a comprehensive environment for managing vector, raster, and point cloud datasets, providing the tools necessary to perform coordinate transformations, georeferencing, and geographic calculations. The platform distinguishes itself through a modular architecture that supports deep system integration via third-party plugins and a hybrid runtime that combines high-performance compiled code with an interpreted scripting
Combines high-performance C++ core processing with an interpreted Python scripting layer for automation.
GPU-Puzzles is an interactive learning environment and tutorial designed for mastering CUDA GPU kernel development. It serves as an educational tool and lab where users solve coding puzzles to understand how to map high-level logic to low-level GPU hardware instructions. The platform focuses on teaching parallel computing concepts and GPU architecture. Users practice developing parallel algorithms and managing GPU memory through a series of hands-on challenges. The environment utilizes a bridge between Python and CUDA to execute kernels and provide real-time feedback by validating outputs ag
Interfaces a high-level Python scripting environment with low-level C-style CUDA kernel code.
This project is a Python wrapper for the TA-Lib C library, serving as a financial technical analysis library and quantitative trading tool. It provides a collection of mathematical functions designed to analyze market price movements, identify trading signals, and recognize candlestick patterns within financial data. The library focuses on the computation of trend, momentum, and volume metrics. It includes specialized tools for candlestick pattern recognition to detect recurring price action shapes in both historical and real-time data. The system integrates with NumPy arrays to process cont
Provides a high-performance interface mapping Python calls to the optimized C routines of the TA-Lib library.
This project is a Python wrapper for the TA-Lib library, providing a technical analysis library for computing moving averages, momentum, and volatility metrics for financial time series analysis. It serves as a financial indicator calculator that processes price and volume arrays to generate technical signals and pattern recognition. The library includes an incremental data processor capable of computing the most recent technical indicator values as new streaming market data arrives. This allows for real-time price monitoring and the processing of streaming data without recalculating entire d
Provides a thin interface layer mapping Python calls to optimized C routines for high-performance financial calculations.
Esta biblioteca proporciona una interfaz programática para monitorear los recursos del sistema y gestionar los ciclos de vida de los procesos. Funciona como una utilidad multiplataforma que recupera métricas en tiempo real sobre la utilización del hardware y permite la inspección y el control de los procesos del sistema en ejecución. El proyecto normaliza estructuras de datos de sistemas operativos dispares en una interfaz unificada, permitiendo una interacción consistente con la información a nivel de kernel independientemente del entorno del host. Al utilizar extensiones compiladas para interactuar directamente con las API nativas del sistema, proporciona una forma consistente de acceder a los datos de rendimiento y gestionar los estados de las tareas que de otro modo requerirían utilidades de línea de comandos específicas de la plataforma. La biblioteca cubre una amplia gama de tareas de administración del sistema y perfilado de rendimiento, incluida la recopilación de datos granulares sobre procesadores, memoria, discos e interfaces de red. Está diseñada para integrarse en scripts para automatizar el monitoreo de la salud del hardware y la gestión de la estabilidad de las aplicaciones.
Provides a high-performance bridge between high-level code and native system APIs using compiled extensions.
CuPy es una biblioteca de computación de matrices CUDA que implementa una interfaz compatible con NumPy para ejecutar operaciones de matrices y computación numérica en GPUs NVIDIA. Sirve como una biblioteca numérica acelerada por GPU y una implementación de SciPy basada en CUDA, descargando cálculos pesados al hardware gráfico para aumentar la velocidad de procesamiento para cargas de trabajo científicas y de ingeniería. La biblioteca permite el intercambio de tensores entre múltiples frameworks, permitiendo que los búferes de datos se compartan entre diferentes frameworks de aprendizaje profundo utilizando diseños de memoria estandarizados para evitar copias de memoria. También admite la integración de kernels de GPU personalizados, permitiendo que los datos de las matrices se conecten a APIs de bajo nivel para un control preciso sobre la ejecución del hardware. En términos generales, el proyecto cubre flujos de trabajo de procesamiento de matrices y computación científica de alto rendimiento. Sus capacidades incluyen la aceleración de cálculos de matrices y la provisión de herramientas para cálculos numéricos a gran escala.
Provides high-performance Python-C++ interfaces to wrap low-level CUDA calls for scientific computing.
llama-cpp-python provides a Python interface for the llama.cpp library, enabling the execution of large language models with hardware acceleration. It functions as a GGUF model loader and a structured text generator capable of running inference servers and multimodal runtimes for processing both text and image inputs. The project distinguishes itself through a local inference server that exposes model capabilities via an OpenAI-compatible web API. It supports advanced execution techniques including speculative decoding, weight quantization, and layer-based GPU offloading to manage memory acro
Maps high-level Python function calls to optimized low-level C++ memory operations for model execution.
Cutlass is a collection of C++ templates and Python interfaces for implementing high-performance linear algebra operations on NVIDIA GPUs. It provides a kernel composition framework for designing custom GPU kernels and a mixed-precision tensor library capable of executing operations across diverse data formats, ranging from 64-bit floating point to 4-bit integers. The project features a toolkit for operator fusion that integrates activation functions and bias calculations directly into matrix multiplication kernels to reduce memory passes. It also includes a Python-based domain-specific langu
Provides a high-level Python DSL to define kernel configurations and layouts without requiring C++ glue code.
pysheeet es una biblioteca de referencia técnica que proporciona una colección curada de fragmentos de código y patrones de implementación para el desarrollo avanzado en Python, integración de sistemas y computación de alto rendimiento. Sirve como una guía completa para implementar programación de red de bajo nivel, extensiones nativas en C y programación asíncrona y concurrente. El proyecto proporciona frameworks especializados para el desarrollo y despliegue de modelos de lenguaje de gran tamaño, incluyendo herramientas para inferencia distribuida en GPU y servicio de alto rendimiento. También incluye patrones detallados para la orquestación de clústeres de computación de alto rendimiento, cubriendo la asignación de recursos de GPU y la gestión de cargas de trabajo en múltiples nodos. La biblioteca cubre una amplia superficie de capacidades, incluyendo comunicación de red segura y criptografía, mapeo objeto-relacional y gestión de bases de datos, y la implementación de estructuras de datos y algoritmos complejos. También proporciona utilidades para la gestión de memoria, interoperabilidad nativa a través de interfaces de funciones externas e integración de sistemas operativos a nivel de sistema.
Provides mechanisms for calling Python functions and methods from within a native C extension.
orjson is a high-performance Python library for serializing and deserializing JSON data. It functions as both a JSON parsing library and a serialization engine, converting data between native Python objects and UTF-8 encoded bytes. The project provides specialized support for converting complex Python data structures, including dataclasses, datetime objects, and NumPy arrays and scalars, into JSON format. It also allows for the insertion of pre-serialized JSON blobs into documents to maintain processing speed. The library includes capabilities for memory-efficient deserialization through key
Implements a high-performance bridge between the Rust core and Python via a C-API interface.
InterviewGuide is a comprehensive technical interview preparation platform that covers the full spectrum of software engineering recruitment, from foundational computer science concepts through to offer negotiation. It provides structured learning paths across algorithms, operating systems, databases, networking, and programming languages, with a particular emphasis on C++ and Go. The platform aggregates real interview experiences and company-specific questions from major tech employers, offering candidates a searchable database of past written exam problems and detailed accounts of actual int
Provides a comparison guide between C++ and Python highlighting key language differences.
Este proyecto es una biblioteca de evaluación de calidad de video y un conjunto de herramientas diseñadas para cuantificar la degradación de video e identificar artefactos de banding. Proporciona una métrica de calidad de video perceptual que compara flujos de video distorsionados contra una referencia de alta calidad para estimar la percepción visual humana. El kit de herramientas incluye un sistema especializado para entrenar y validar modelos de calidad perceptual personalizados utilizando conjuntos de datos específicos. También cuenta con un índice multiescala sensible al contraste específicamente para detectar artefactos de contorno y banding en flujos de video. La biblioteca cubre el cálculo de métricas de video objetivas y el análisis de compresión de video, utilizando tanto medidas matemáticas tradicionales como algoritmos basados en fusión. Estas capacidades permiten la evaluación de diferentes codificadores o bitrates y la identificación de distorsiones visuales específicas. La implementación consiste en una biblioteca central escrita en C con un wrapper de enlace en Python para análisis de alto nivel y entrenamiento de modelos.
Provides a Python interface that wraps the C core for high-level video analysis and model training.
NCCL es una biblioteca de comunicación de alto rendimiento y un framework de computación distribuida en GPU diseñado para ejecutar intercambios de datos colectivos y punto a punto a través de múltiples GPUs en sistemas de uno o varios nodos. Sirve como capa de transporte RDMA para GPU y orquestador de memoria, facilitando la sincronización de gran ancho de banda de datos y gradientes de modelos para el entrenamiento e inferencia distribuida en GPU. La biblioteca se distingue por su capacidad para ejecutar primitivas de comunicación directamente desde kernels de GPU, eliminando la CPU anfitriona del camino crítico. Utiliza la selección de rutas consciente de la topología para optimizar el movimiento de datos y emplea transporte de red basado en RDMA, incluyendo InfiniBand y NVLink, para permitir el acceso a memoria de copia cero entre dispositivos a través de diferentes nodos físicos. El proyecto cubre una amplia gama de patrones de comunicación colectiva, incluyendo reducciones, broadcasts, gathers e intercambios all-to-all, junto con acceso remoto a memoria punto a punto. Proporciona una gestión integral de comunicadores para inicializar, particionar y redimensionar grupos de GPU, así como una gestión de memoria especializada para registrar buffers y coordinar memoria compartida de dispositivo. El sistema incluye un conjunto de herramientas de monitoreo y observabilidad para el seguimiento de la salud, registro de diagnósticos y monitoreo de eventos en tiempo real, así como interfaces de integración para frameworks de aprendizaje automático, CUDA graphs, MPI y Python.
Exposes core high-performance communication primitives through a Python interface for easier integration into ML workflows.
matplotlib-cpp es una biblioteca C++ de solo cabecera y wrapper que permite la creación de visualizaciones 2D y 3D llamando a funciones de Matplotlib directamente desde código C++. Sirve como una interfaz de trazado para generar gráficos de líneas, barras y superficies utilizando un backend basado en Python. La biblioteca está diseñada como una integración ligera que proporciona capacidades de trazado sin requerir un proceso de compilación complejo o binarios compilados. Cubre una gama de capacidades de visualización, incluyendo renderizado de datos multidimensionales, trazado de campos vectoriales y la disposición de múltiples subgráficos. El kit de herramientas también admite la producción de animaciones dinámicas y la exportación de las visualizaciones generadas como archivos de imagen.
Provides the mechanism to invoke Python plotting functions from within a compiled C++ environment.