Skip to main content

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:

  1. First, make sure you have bclearer_core installed in your project:

    pip install bclearer-core
    
  2. Generate a sample configuration file:

    python -m bclearer_core.pipeline_builder sample --output my_pipeline_config.json
    
  3. Edit the configuration file to match your pipeline requirements.

  4. Create the pipeline structure:

    python -m bclearer_core.pipeline_builder create --config my_pipeline_config.json --output ./pipelines/
    
  5. 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
  6. 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:

  1. Modify your configuration file to add new components.

  2. Run the update command:

    python -m bclearer_core.pipeline_builder update --config updated_config.json --pipeline ./pipelines/example_domain_pipelines
    
  3. 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


Download files

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

Source Distribution

bclearer_core-0.3.2.tar.gz (90.0 kB view details)

Uploaded Source

Built Distribution

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

bclearer_core-0.3.2-py3-none-any.whl (231.7 kB view details)

Uploaded Python 3

File details

Details for the file bclearer_core-0.3.2.tar.gz.

File metadata

  • Download URL: bclearer_core-0.3.2.tar.gz
  • Upload date:
  • Size: 90.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for bclearer_core-0.3.2.tar.gz
Algorithm Hash digest
SHA256 65b210a679e41d9b6a0b65849d7b627d40dfc418f6f29f695c066e2c40a484f0
MD5 ff8ad94397494484a077bd17db1307b1
BLAKE2b-256 07c2dbfce6e5c921c99ec22bc062ff067f7bdc0ca7501e1233a697b421717726

See more details on using hashes here.

File details

Details for the file bclearer_core-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: bclearer_core-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 231.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for bclearer_core-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 7efbe5789f926349e535d8f59477eb0dfa2504c373494418ebc2075f3f0ec807
MD5 174ab5d60c2cb5492979ba5344c2b2f0
BLAKE2b-256 c16d7d929b2c59de2741b09bafc71a29f89144b29c506f3c828b64bd8de36260

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