Skip to main content

A Python package for loading petroleum datasets

Project description

per-datasets

A Python package for loading reservoir datasets from API endpoints.

Installation

pip install per-datasets

Quick Start

Option 1: Using Global API Key (Recommended)

First, set your API key globally:

# Set API key globally (works across all projects)
per-datasets set-key "your_api_key_here"

# Or use interactive setup
per-datasets interactive

Then use in your Python code:

import per_datasets as pds

# Initialize without API key (uses global key)
pds.initialize()

# Load a random reservoir dataset
df_random = pds.reservoir.load_random()
print(f"Loaded dataset with shape: {df_random.shape}")

Option 2: Using API Key in Code

import per_datasets as pds

# Initialize with your API key
pds.initialize('your_api_key_here')

# Load a random reservoir dataset
df_random = pds.reservoir.load_random()
print(f"Loaded dataset with shape: {df_random.shape}")

Workflows

The package includes Dockerized workflows for common operations:

Available Workflows

  1. Add Workflow - Adds two numbers together
  2. Subtract Workflow - Subtracts one number from another
  3. PINN Workflow - Trains a Physics-Informed Neural Network (Transformer-based)

Running Workflows in Python

You can run workflows directly in Python:

from per_datasets.workflows import add, subtract, pinn

# Run simple workflows
print(add(5, 3))       # 8
print(subtract(10, 4)) # 6

# Run PINN training workflow
results = pinn(epochs=50)
print(f"Final Loss: {results['final_loss']}")

# Visualize the loss history dynamically
from per_datasets import visual # Or use pds.visual if imported as pds
visual.line_plot(results, y='loss_history', title="PINN Training Loss")

Building Workflow Containers

# Build all workflow Docker images
./build_workflows.sh

# Or build individually
docker build -t perd-add-workflow -f per_datasets/workflows/add/Dockerfile .
docker build -t perd-subtract-workflow -f per_datasets/workflows/substract/Dockerfile .

Running Workflows

# Run add workflow
docker run --rm perd-add-workflow 5.2 3.8

# Run subtract workflow
docker run --rm perd-subtract-workflow 10.5 4.3

See per_datasets/workflows/README.md for more details.

Command Line Interface

The package includes a CLI for managing API keys globally:

# Set API key globally
per-datasets set-key "your_api_key_here"

# Check configuration status
per-datasets status

# Get stored API key (masked)
per-datasets get-key

# Remove API key
per-datasets remove-key

# Interactive setup
per-datasets interactive

# Clear all configuration
per-datasets clear

# Show help
per-datasets --help

Complete Usage Examples

import per_datasets as pds

# Initialize (uses global key if available)
pds.initialize()

# Load a random reservoir dataset
df_random = pds.reservoir.load_random()
print(f"Loaded dataset with shape: {df_random.shape}")

# Load a specific dataset by ID
df_specific = pds.reservoir.load('your_dataset_id')

# Get information about available datasets
info = pds.get_dataset_info()

API Reference

initialize(api_key=None)

Initialize the per_datasets module with API credentials.

Parameters:

  • api_key (str, optional): The API key for authentication. If not provided, uses globally stored key.

Note: If no API key is provided and none is stored globally, raises a ValueError with instructions to set a global key.

load_random()

Loads a random reservoir model from the API endpoint and returns as pandas DataFrame.

Returns:

  • pandas.DataFrame: A DataFrame containing the dataset

Configuration Management

The package stores configuration in ~/.per_datasets/config.json by default:

{
  "api_key": "your_api_key_here"
}

Benefits of Global Configuration:

  • No API key in code: Keep sensitive keys out of your source code
  • Cross-project: Use the same API key across multiple projects
  • Secure: API keys are stored in user's home directory
  • Override: Can still provide API key in code to override global setting
  • Easy management: Use CLI commands to manage keys

Security Notes:

  • API keys are stored in plain text in your home directory
  • Only you can access the configuration file
  • Consider using environment variables for production deployments

Dependencies

  • requests>=2.25.1
  • pandas>=1.3.0

License

MIT

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Add tests if applicable
  5. Submit a pull request

Development

To set up the development environment:

git clone https://github.com/P-E-R-D/library-py.git
cd per-datasets
pip install -e .

Building and Publishing

Automatic Deployment (Recommended)

This package uses GitHub Actions for automatic deployment to PyPI:

  1. Make your changes to the code
  2. Update version numbers in per_datasets/__init__.py and pyproject.toml
  3. Create a git tag with the new version:
    git tag v0.2.0
    git push origin v0.2.0
    
  4. GitHub Actions automatically builds and uploads to PyPI!

See DEPLOYMENT.md for detailed setup instructions.

Manual Publishing

python -m build
twine upload dist/*

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

per_datasets-0.0.5a1.tar.gz (21.9 kB view details)

Uploaded Source

Built Distribution

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

per_datasets-0.0.5a1-py3-none-any.whl (24.5 kB view details)

Uploaded Python 3

File details

Details for the file per_datasets-0.0.5a1.tar.gz.

File metadata

  • Download URL: per_datasets-0.0.5a1.tar.gz
  • Upload date:
  • Size: 21.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for per_datasets-0.0.5a1.tar.gz
Algorithm Hash digest
SHA256 340d28e1b13f91c0b4e0f34fc823dc308a4b897cb8b0892bbcc884804d798f92
MD5 098d3675a75e05a77681e7d0bd0c5062
BLAKE2b-256 ae9e6d259911fd393c565b170cdc47734b9510f9ba9c597ee8062d2ec7ee632a

See more details on using hashes here.

File details

Details for the file per_datasets-0.0.5a1-py3-none-any.whl.

File metadata

  • Download URL: per_datasets-0.0.5a1-py3-none-any.whl
  • Upload date:
  • Size: 24.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for per_datasets-0.0.5a1-py3-none-any.whl
Algorithm Hash digest
SHA256 28dd9500f1e74dc97dbd34cfc15f9941a07f98e919b3ae8135223ca18004b8a8
MD5 2119350f6dcd4edf710d52e5a710ea8d
BLAKE2b-256 7b651683cbaaef37ce7ecc9c4fb40c95c961b068c5f61c8c0edb0315bebf840f

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