No project description provided
Project description
bclearer core
The bclearer_core package is the foundational component of the bclearer framework, providing essential utilities and services required for the data pipeline architecture in semantic engineering. It encompasses core functionalities that are utilized across the entire framework, ensuring consistency and extensibility.
Overview
The bclearer_core library offers a collection of modules responsible for handling common tasks and configurations that are integral to the bclearer framework. These components form the backbone of the system and enable efficient management of knowledge, configurations, constants, and stages within the pipeline.
Structure
The package consists of several key modules:
- ckids: Manages unique identifiers within the bclearer framework, ensuring consistency and traceability across components.
- common_knowledge: Contains shared knowledge and common utilities that are used across the framework.
- configuration_managers: Responsible for managing and handling various configurations for bclearer applications and processes.
- configurations: Defines standard configuration structures and utilities for the framework.
- constants: Stores and manages global constants used throughout the bclearer framework.
- nf: Manages foundational operations, providing core support for various tasks.
- pipeline_builder: Provides CLI tooling to generate and manage pipeline structures based on configuration.
- substages: Handles the different substages of the data pipeline, offering utilities to manage transitions and execution within stages.
Installation
To install this package, use pip:
pip install bclearer_core
Or, clone this repository and install it locally:
git clone <repository-url>
cd bclearer_core
pip install .
Usage
To use the core functionalities, import the desired module. For example:
from bclearer_core import configurations
# Example usage
config = configurations.load_configuration(config_path="path/to/config.yaml")
print(config)
Pipeline Builder
The Pipeline Builder is a powerful tool included in bclearer_core that helps you generate and manage bclearer pipeline structures based on JSON configuration. It eliminates the need to manually create the complex directory and file structure required for bclearer pipelines.
Using the Pipeline Builder CLI
To access the pipeline builder CLI tool, you need to install the full bclearer PDK (not just bclearer-core). The tool can be used in two ways:
Option 1: Using Python module syntax
# Generate a sample configuration file
python -m bclearer_core.pipeline_builder sample --output my_config.json
# Create a new pipeline from configuration file
python -m bclearer_core.pipeline_builder create --config my_config.json
# Create a pipeline interactively
python -m bclearer_core.pipeline_builder create --interactive
# Create a pipeline in a specific output directory
python -m bclearer_core.pipeline_builder create --config my_config.json --output /path/to/output/directory
# Update an existing pipeline with new components
python -m bclearer_core.pipeline_builder update --config updated_config.json --pipeline path/to/domain_name_pipelines
# Show detailed help
python -m bclearer_core.pipeline_builder help
Option 2: Installing the full bclearer package
If you install the full bclearer package (which includes all components including core, interop_services, and orchestration_services), you'll have access to the bclearer-pipeline-builder command directly:
# First, install the full package from the GitHub repository
pip install git+https://github.com/your-org/bclearer.git
# Then you can use the command directly
bclearer-pipeline-builder sample --output my_config.json
bclearer-pipeline-builder create --config my_config.json
bclearer-pipeline-builder create --interactive
Configuration Structure
The pipeline configuration uses a JSON structure that defines the domain, pipelines, thin slices, stages, sub-stages, and b-units:
{
"domain_name": "example_domain",
"pipelines": [
{
"name": "example_pipeline",
"thin_slices": [
{
"name": "example_thin_slice",
"stages": [
{
"name": "1c_collect",
"sub_stages": [
{
"name": "sub_stage_1",
"b_units": ["example_b_unit"]
}
],
"b_units": ["collector_b_unit"]
},
// More stages: 2l_load, 3e_evolve, 4a_assimilate, 5r_reuse
]
}
]
}
]
}
Creating a New Pipeline in Your Project
Follow these steps to create a new bclearer pipeline in your project:
-
First, make sure you have bclearer_core installed in your project:
pip install bclearer-core
-
Generate a sample configuration file:
python -m bclearer_core.pipeline_builder sample --output my_pipeline_config.json
-
Edit the configuration file to match your pipeline requirements.
-
Create the pipeline structure:
python -m bclearer_core.pipeline_builder create --config my_pipeline_config.json --output ./pipelines/
-
The tool will generate a complete pipeline structure including:
- Pipeline orchestrators
- Stage orchestrators
- Sub-stage orchestrators
- Thin slice orchestrators
- B-unit skeletons
- Application runner
- Test infrastructure
-
Customize the generated code to implement your specific pipeline logic.
Updating an Existing Pipeline
When your pipeline requirements change, you can update an existing pipeline:
-
Modify your configuration file to add new components.
-
Run the update command:
python -m bclearer_core.pipeline_builder update --config updated_config.json --pipeline ./pipelines/example_domain_pipelines
-
This will add new components without modifying existing ones.
Interactive Pipeline Creation
For guided pipeline creation:
python -m bclearer_core.pipeline_builder create --interactive
This will walk you through a series of prompts to define your pipeline structure.
Contributions
Contributions are highly appreciated! Feel free to submit issues, pull requests, or feature requests to enhance the core functionality.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file bclearer_core-0.2.0.tar.gz.
File metadata
- Download URL: bclearer_core-0.2.0.tar.gz
- Upload date:
- Size: 85.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
04b19eb2c42ba23c86839fd2cb22133af8656eb8af1a98586cd29a123f03f85d
|
|
| MD5 |
6fd4d51b8361d9f30b08f14766d36e8d
|
|
| BLAKE2b-256 |
5fee3c957119fbc576daba06cba73ab5e87cf427367e1ac05115ed05cb26b940
|
File details
Details for the file bclearer_core-0.2.0-py3-none-any.whl.
File metadata
- Download URL: bclearer_core-0.2.0-py3-none-any.whl
- Upload date:
- Size: 220.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cdd704e84673846c2ac38e93eca3c64a618b2b4faae88f4adf6f52f1c838927a
|
|
| MD5 |
97aaac569eb95f1f52baf8bb371a248e
|
|
| BLAKE2b-256 |
2bdd1901a4680b36e98ea1b96c54c029a54d5577934ea7d43edd0d826c507343
|