Metadata-Version: 2.4
Name: deezy
Version: 1.3.0rc6
Summary: Dolby Encoding Engine Wrapper
Author: jessielw
License: MIT License
        
        Copyright (c) 2023 jlw4049
        
        Permission is hereby granted, free of charge, to any person obtaining a copy
        of this software and associated documentation files (the "Software"), to deal
        in the Software without restriction, including without limitation the rights
        to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
        copies of the Software, and to permit persons to whom the Software is
        furnished to do so, subject to the following conditions:
        
        The above copyright notice and this permission notice shall be included in all
        copies or substantial portions of the Software.
        
        THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
        IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
        FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
        AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
        LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
        OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
        SOFTWARE.
        
Project-URL: Source, https://github.com/jessielw/deezy
Project-URL: Tracker, https://github.com/jessielw/DeeZy/issues
Keywords: audio,dolby,encoding,dee,ddp,atmos,ac4
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Topic :: Multimedia :: Sound/Audio
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Requires-Python: <3.14,>=3.9
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: pymediainfo
Requires-Dist: tomlkit
Requires-Dist: platformdirs>=2.6.0
Requires-Dist: typing-extensions>=4.15.0
Requires-Dist: rich>=14.1.0
Requires-Dist: oslex2>=0.1.5
Requires-Dist: guessit>=3.8.0
Dynamic: license-file

# DeeZy

A powerful, portable audio encoding tool built around the Dolby Encoding Engine (DEE) with support for Dolby Digital (DD), Dolby Digital Plus (DDP), DDP BluRay, Dolby Atmos, and Dolby AC-4 encoding.

[![Build and Release](https://github.com/jessielw/DeeZy/actions/workflows/release.yml/badge.svg)](https://github.com/jessielw/DeeZy/actions/workflows/release.yml) [![Tests](https://github.com/jessielw/DeeZy/actions/workflows/test.yml/badge.svg)](https://github.com/jessielw/DeeZy/actions/workflows/test.yml)

## ✨ Key Features

- **🎵 Multiple Audio Formats**: Support for Dolby Digital (DD), Dolby Digital Plus (DDP), DDP BluRay, Dolby Atmos, and Dolby AC-4
- **🔧 Portable**: No installation required - just download and run
- **⚙️ Smart Configuration**: TOML-based config system with customizable default bitrates and presets
- **🎛️ Flexible Encoding**: Automatic channel detection, smart bitrate defaults, and advanced audio processing
- **🌟 Atmos Support**: Full support for streaming and BluRay Atmos encoding
- **🆕 AC-4 Support**: Next-generation Dolby AC-4 codec with advanced features and device optimization
- **📁 Batch Processing**: Process multiple files or use glob patterns for bulk operations
- **🎚️ Advanced Controls**: Dynamic range compression, stereo downmix options, and loudness normalization
- **⚡ Smart Dependencies**: Auto-detection of tools with fallback to portable structure
- **🔍 Audio Analysis**: Built-in audio stream inspection and metadata display
- **🎯 Preset System**: Define custom encoding workflows for different use cases

## 📦 Installation

DeeZy is completely portable - no installation needed! Just download the binary for your platform.

> As of **v1.2.5** you can choose between **bundled** or **standalone**.
>
> - Bundled: DeeZy will have a folder **bundle** beside the executable. This increases execution times of the executable substantially and prevents the executable from unpacking on every launch. If DeeZy is being put on a system PATH or included in another program this is the ideal choice.
> - Standalone: This is just a **single** item, the DeeZy executable. This will unpack as needed when executed.

### Option 1: System PATH (Recommended)

Add FFMPEG, DEE (Dolby Encoding Engine), and optionally TrueHDD to your system PATH, then use DeeZy anywhere.

### Option 2: Portable Structure

Create an `apps` folder beside the DeeZy executable:

```
deezy.exe (or deezy on Linux)
└── apps/
    ├── ffmpeg/
    │   └── ffmpeg.exe
    ├── dee/
    │   └── dee.exe
    └── truehdd/         # Only needed for Atmos/AC-4 encoding
        └── truehdd.exe
```

### Install via pipx / PyPI

If you'd like to install the CLI and get the `deezy` command on your PATH, the recommended approach is to use pipx:

```powershell
pipx install deezy
```

You can also install from a local copy (for development):

```powershell
pipx install --editable .
# or
pipx install --spec .
```

After installing with pipx, the `deezy` shim will be available on your PATH (if pipx setup added its shim directory to PATH). Run `deezy --help` to confirm.

## 📤 Publishing

This repository includes a GitHub Actions workflow (`.github/workflows/publish-pypi.yml`) that will build and publish the package to PyPI when a Git tag prefixed with `v` is pushed (for example `v1.3.0rc5`).

To use the workflow, add a `PYPI_API_TOKEN` secret to your repository (created from https://pypi.org/manage/project/<your-project>/). The workflow expects the token to be stored in `secrets.PYPI_API_TOKEN`.

### Dependencies

- **FFMPEG** - Required for all operations
- **DEE (Dolby Encoding Engine)** - Required for DD/DDP encoding
- **[TrueHDD](https://github.com/truehdd/truehdd)** - Only required when encoding Atmos content

## ⚙️ Configuration System

DeeZy includes a powerful TOML-based configuration system that eliminates repetitive command-line arguments and allows you to set encoding defaults and create reusable presets.

### Quick Configuration Setup

```bash
# Generate a default configuration file
deezy config generate

# Check configuration status
deezy config info

# Use a custom config file
deezy --config my-config.toml encode ddp input.mkv

# Overwrite existing configuration
deezy config generate --overwrite
```

### Configuration File Structure

The configuration file (`deezy-conf.toml`) supports:

- **Tool dependency paths** (FFmpeg, DEE, truehdd)
- **Global encoding defaults** applied to all formats
- **Default bitrates** per codec and channel layout
- **Format-specific settings** that override global defaults
- **Custom presets** for different workflows

```toml
[dependencies]
# Paths to external tools (leave empty for auto-detection)
ffmpeg = ""
dee = ""
truehd = ""

[global_defaults]
# Settings applied to all encoding formats
keep_temp = false
temp_dir = ""
track_index = 0
drc_line_mode = "film_light"
drc_rf_mode = "film_light"
custom_dialnorm = 0
metering_mode = "1770_3"
dialogue_intelligence = true
speech_threshold = 15
stereo_down_mix = "loro"

[default_bitrates]
# Customize default bitrates for each codec/channel combination
# These are used when no --bitrate is specified

[default_bitrates.dd]
mono = 192        # Dolby Digital 1.0
stereo = 224      # Dolby Digital 2.0
surround = 448    # Dolby Digital 5.1

[default_bitrates.ddp]
mono = 64         # Dolby Digital Plus 1.0
stereo = 128      # Dolby Digital Plus 2.0
surround = 192    # Dolby Digital Plus 5.1
surroundex = 384  # Dolby Digital Plus 7.1

[default_bitrates.atmos]
streaming = 448   # Dolby Atmos Streaming mode
bluray = 448      # Dolby Atmos Bluray mode

[presets]
# Define custom presets as command strings
streaming_ddp = "encode ddp --channels surround --bitrate 448"
bluray_atmos = "encode atmos --atmos-mode bluray --bitrate 768"
quick_stereo = "encode ddp --channels stereo --bitrate 192"
ac4_stereo = "encode ac4 --bitrate 256"
```

### Configuration Location

DeeZy looks for `deezy-conf.toml` beside the executable for portable usage. You can also specify a custom config file with `--config path/to/config.toml`.

## Note on user config location

When DeeZy generates a user-wide configuration it will place it in a platform-appropriate
user config folder. On Windows this resolves to a single folder under your local app data,
for example:

C:\Users\<you>\AppData\Local\deezy\deezy-conf.toml

On other platforms the standard platformdirs user config location is used (for example
`~/.config/deezy/deezy-conf.toml` on many Linux distributions). DeeZy will still check
the current working directory first, allowing per-project configs to take precedence.

### Priority System

Configuration values are applied in order of priority:
**CLI Arguments** > **Config Defaults** > **Format-Specific Defaults** > **Built-in Fallback Defaults**

- **CLI Arguments**: Any argument provided directly on the command line takes highest priority
- **Config Defaults**: Values from the `[global_defaults]` section of your config file
- **Format-Specific Defaults**: Smart defaults based on encoding format (e.g., DD/DDP use 1770-3 metering, Atmos uses 1770-4)
- **Built-in Fallback Defaults**: Hardcoded defaults when nothing else is configured

### Smart Defaults System

DeeZy automatically applies intelligent defaults based on the encoding format when arguments are not specified:

**Smart Default Bitrates** (based on codec and channel layout):

- **DD 5.1**: 448 kbps (configurable)
- **DDP Stereo**: 128 kbps (configurable)
- **DDP 5.1**: 192 kbps (configurable)
- **DDP 7.1**: 384 kbps (configurable)
- **Atmos Streaming**: 448 kbps (configurable)

**Smart Channel Defaults** (when `--channels` not specified):

- **DD**: AUTO (automatically detects best channel layout)
- **DDP**: AUTO (automatically detects best channel layout)
- **DDP-BluRay**: SURROUNDEX (7.1 for BluRay releases)
- **Atmos**: No channel argument (uses source layout)

**Smart Metering Mode Defaults** (when `--metering-mode` not specified):

### Per-source default bitrates (opt-in)

If you'd like DeeZy to pick default bitrates based on the source audio's channel count, you can opt-in to the optional "per-source" sections in the configuration file.

- Location: `[default_source_bitrates.<codec>]` (for example `[default_source_bitrates.ddp]`)
- Keys: name them `ch_1` .. `ch_8` (lowercase preferred). Each key is the source channel count and the value is the default bitrate in kbps.
- Supported codecs: `dd`, `ddp` (support channels 1..8); `ac4` is meaningful for immersive sources (6..8).
- How it works: When no `--bitrate` is provided on the CLI/preset, encoders will look for a matching `ch_N` value for the detected source channel count and use that bitrate. If the config value isn't an allowed bitrate for the encoder's current channel/format settings, the encoder will choose the nearest allowed bitrate defined in its internal choices.
- Precedence: CLI bitrate > per-source config (`default_source_bitrates`) > format-level config (`default_bitrates`) > built-in defaults.

Example (in the generated `deezy-conf.toml`, these are commented out by default; uncomment to enable):

```toml
#[default_source_bitrates.ddp]
# ch_1 = 64
# ch_2 = 128
# ch_6 = 192
# ch_7 = 384
# ch_8 = 384
```

This opt-in approach keeps the default configuration conservative while allowing site- or workflow-specific defaults when desired.

- **DD/DDP**: 1770-3 (standard for traditional surround formats)
- **Atmos**: 1770-4 (supports advanced Atmos loudness requirements)

### Preset System

Create reusable encoding profiles for different workflows using simple command strings:

```bash
# Use a preset for encoding (format determined from preset)
deezy encode preset --name streaming_ddp input.mkv

# Override preset settings as needed
deezy encode preset --name bluray_atmos --bitrate 1024 input.mkv

# List available presets
deezy config info
```

### Preset Configuration

Presets are defined as command strings in the `[presets]` section of your config file. This makes them simple to create and understand:

```toml
[presets]
# Simple preset examples using command strings
streaming_ddp = "encode ddp --channels surround --bitrate 448"
bluray_dd = "encode dd --channels surround --bitrate 640"
auto_stereo_ddp = "encode ddp --channels stereo"
streaming_atmos = "encode atmos --atmos-mode streaming"

# Advanced presets with multiple options
high_quality_ddp = "encode ddp --channels surround --bitrate 768 --drc-line-mode music_standard"
custom_atmos = "encode atmos --atmos-mode bluray --bitrate 1024 --custom-dialnorm 5"
legacy_dd = "encode dd --channels surround --bitrate 448 --drc-line-mode film_light --metering-mode 1770_3"
```

**Preset Benefits:**

- **Simple format**: Just write the command as you would use it on the CLI
- **Easy to read**: Command strings are self-documenting
- **Override capable**: Add extra arguments when using the preset to override settings
- **Validation**: DeeZy validates preset commands and suggests fixes for errors

**Usage Examples:**

```bash
# Use preset as-is
deezy encode preset --name streaming_ddp input.mkv

# Override preset bitrate
deezy encode preset --name streaming_ddp --bitrate 640 input.mkv

# Use preset with additional options
deezy encode preset --name auto_stereo_ddp --keep-temp --output custom.ec3 input.mkv
```

### Benefits

**Before Configuration:**

```bash
deezy encode ddp --ffmpeg "C:/tools/ffmpeg.exe" --dee "C:/apps/dee.exe" --channels 6 --bitrate 448 --drc-line-mode film_light input.mkv
```

**After Configuration:**

```bash
deezy encode ddp input.mkv  # Uses smart defaults and your configured tools!
```

## 🚀 Quick Start

```bash
# Set up configuration once
deezy config generate

# Encode to Dolby Digital Plus with smart defaults
deezy encode ddp input.mkv

# Encode to Dolby Atmos
deezy encode atmos --atmos-mode streaming input.mkv

# Encode to Dolby AC-4
deezy encode ac4 input.mkv

# Use a predefined preset
deezy encode preset --name streaming_ddp input.mkv

# Batch encode multiple files
deezy encode ddp *.mkv

# Get audio track information
deezy info input.mkv

# Check temp folder status
deezy temp info

# Clean old temp files
deezy temp clean
```

## CLI additions and batch features

Recent CLI additions expand batch processing and working-directory control. These flags are available on the `encode` command and are useful for automated workflows, CI, and headless environments.

- `--parse-elementary-delay`

  - When input is an elementary (demuxed) stream, parse any delay string in the filename and reset it to zero during encoding. If an explicit `--output` filename is supplied the output name will not be altered.

- `--working-dir PATH`

  - Use this directory to store DeeZy working files (logs, batch-results). If not set, DeeZy uses a default workspace beside the executable or the value from your config file (`[global_defaults].working_dir`).

- `--batch-summary-output`

  - When enabled, DeeZy will collect per-file results into a JSON summary saved in a `batch-results` folder inside the working directory.

- `--batch-output-dir PATH`

  - When used with `--batch-summary-output`, instructs DeeZy to place encoded output files into the given directory instead of beside the inputs. DeeZy will validate that this directory exists and is writable before starting work.

- `--overwrite`

  - Globally allow overwriting of existing output files. When not provided and a target file already exists, the job will be skipped and recorded as `skipped` in the batch summary.

- `--max-parallel N`

  - Process up to N files in parallel. Default is 1 (sequential). Use this to speed up batch runs when machine resources allow.

Per-phase limits and jitter

-- `--limit-ffmpeg`, `--limit-dee`, `--limit-truehdd`

- Fine-tune concurrency for the heavy processing phases: the FFmpeg stage, the DEE (Dolby Encoding Engine) stage, and truehdd decoding stage respectively.
- If any of these flags are omitted they will default to the value supplied to `--max-parallel`. This keeps phase limits consistent with the overall worker count.
- If a per-phase value is set greater than `--max-parallel` the CLI will cap the phase limit to `--max-parallel` and emit a warning at startup.

- `--jitter-ms`

  - When set (>0), introduces a small random delay (up to the given milliseconds) before entering heavy phases (FFmpeg, DEE, truehdd). This reduces load spikes when many jobs start simultaneously and helps avoid thrashing on constrained systems.

- `--max-logs N` and `--max-batch-results N`
  - Per-run overrides for retention trimming. These flags override the config defaults for the current run and control how many log files and batch-result JSON files are kept in the working directory. Set to `0` to keep none.

These options respect the priority system: CLI arguments override config defaults.

Example: parsing elementary delay from filename

```bash
# Given an elementary input file whose name contains a delay tag:
# Migration.2023.BluRay..._track3_[jpn]_DELAY 36ms.aac

# Without parsing, the output filename will retain the delay metadata
# (unless you explicitly pass --output):
deezy encode dd Migration.2023..._DELAY\ 36ms.aac

# With parsing enabled (and no explicit --output), DeeZy will strip the
# delay tag from the generated output filename and treat the audio as 0ms delay:
deezy encode dd --parse-elementary-delay Migration.2023..._DELAY\ 36ms.aac
# Result: generated output file will not contain the `[DELAY 36ms]` suffix
```

## What's new (high level)

From recent changes (see `CHANGELOG.md` for full details):

- AC-4 support: `encode ac4` with profiles and DRC presets.
- Improved preset handling: `deezy encode preset --name YOUR_PRESET` and the ability to override preset values from the CLI.
- Better error handling and logging in debug mode, and smarter temp-folder management for batch runs.
- Batch processing improvements: centralized logs and batch-results directories, per-file JSON summary output, and retention trimming to avoid unbounded log accumulation.

### Example: batch run

```bash
# Encode all MKV files in a folder, place outputs in a central directory,
# write batch summary JSON and keep logs/batch-results under a working dir.
deezy --log-to-file encode ddp \
  --working-dir "C:/ci/deezy_work" \
  --batch-summary-output \
  --batch-output-dir "C:/ci/deezy_outputs" \
  --max-parallel 4 \
  *.mkv
```

## Batch summary JSON schema

When `--batch-summary-output` is enabled, DeeZy writes a JSON summary per batch into the `batch-results` folder inside the working directory. The JSON contains `batch_info` and a `results` array with one entry per input file.

Top-level structure:

- `batch_info` (object)

  - `timestamp` (ISO8601) - when the batch run started
  - `command` (string) - reconstructed command line used to run DeeZy
  - `total_files` (int) - number of files requested
  - `successful` (int) - number of successful encodes
  - `failed` (int) - number of failures
  - `skipped` (int) - number of skipped files (existing output and no `--overwrite`)
  - `processing` (int) - number still in progress when the summary was generated
  - `total_duration_seconds` (float|null) - total elapsed time for batch (if completed)
  - `max_parallel` (int) - maximum parallelism used for the batch

- `results` (array of objects) - each object has per-file metadata:
  - `input_file` (string) - original input path
  - `output_file` (string|null) - resolved output path if produced
  - `log_file` (string|null) - path to the per-file log (if `--log-to-file` used)
  - `status` (string) - one of `processing`, `success`, `failed`, `skipped`
  - `file_id` (string) - internal identifier used for unique naming
  - `start_time` (ISO8601) - start time for the file
  - `end_time` (ISO8601|null) - end time if completed
  - `duration_seconds` (float|null) - elapsed seconds for the file
  - `error` (string|null) - error message when `failed` or `skipped`

A small example file is included in the repository at `example_json_flows/sample_batch_results.json`.

## 📋 Usage

### Basic Commands

```bash
# Show version
deezy --version

# Get help for any command
deezy encode ddp --help

# Find files using glob patterns
deezy find "**/*.mkv"

# Analyze audio streams
deezy info input.mkv

# Manage configuration
deezy config generate
```

### Global Options

| Option                 | Description                                           |
| ---------------------- | ----------------------------------------------------- |
| `--version`            | Show program version                                  |
| `--config CONFIG_FILE` | Path to configuration file (default: deezy-conf.toml) |
| `--log-level LEVEL`    | Set log level (critical, error, warning, info, debug) |
| `--log-to-file`        | Write log to file (input path with .log suffix)       |
| `--no-progress-bars`   | Disable progress bars                                 |
| `-h, --help`           | Show help message                                     |

### Main Commands

| Command             | Description                                  |
| ------------------- | -------------------------------------------- |
| `encode dd`         | Dolby Digital encoding                       |
| `encode ddp`        | Dolby Digital Plus encoding                  |
| `encode ddp-bluray` | Dolby Digital Plus BluRay encoding           |
| `encode atmos`      | Dolby Atmos encoding                         |
| `encode ac4`        | Dolby AC-4 encoding                          |
| `encode preset`     | Preset-based encoding (format auto-detected) |
| `find`              | File discovery with glob patterns            |
| `info`              | Audio stream analysis and metadata display   |
| `config`            | Configuration file management                |
| `temp`              | Temporary folder management                  |

## 🎵 Audio Encoding

### Dolby Digital (DD) Encoding

Perfect for legacy compatibility and smaller file sizes.

```bash
# Basic DD encoding with smart defaults
deezy encode dd input.mkv

# Specify channel layout and bitrate
deezy encode dd --channels 6 --bitrate 448 input.mkv

# Custom output path and keep temporary files
deezy encode dd --output "output.ac3" --keep-temp input.mkv
```

**Channel Options:**

- `0` (AUTO), `1` (MONO), `2` (STEREO), `6` (5.1 SURROUND)

**Common Options:**

- `--bitrate`: Bitrate in Kbps (uses smart defaults if not specified)
- `--drc-line-mode`: Dynamic range compression (film_standard, film_light, music_standard, music_light, speech)
- `--stereo-down-mix`: Stereo downmix method (auto, loro, ltrt, dpl2)

**Advanced DD Options:**

- `--track-index`: Track selection with FFmpeg-style notation (see Track Selection section below)
- `--delay`: Audio delay adjustment (--delay=-10ms or --delay=10s)
- `--custom-dialnorm`: Custom dialnorm value (0 to disable)
- `--metering-mode`: Loudness metering (1770_1, 1770_2, 1770_3, leqa)
- `--no-dialogue-intelligence`: Disable dialogue intelligence
- `--speech-threshold`: Speech detection threshold (0-100)

### Dolby Digital Plus (DDP) Encoding

Enhanced quality with higher bitrates and advanced features.

```bash
# Basic DDP encoding with smart defaults
deezy encode ddp input.mkv

# High-quality 5.1 encoding
deezy encode ddp --channels 6 --bitrate 448 input.mkv

# 7.1 surround encoding
deezy encode ddp --channels 8 --bitrate 768 input.mkv
```

**Channel Options:**

- `0` (AUTO), `1` (MONO), `2` (STEREO), `6` (5.1 SURROUND), `8` (7.1 SURROUNDEX)

**Key Features:**

- **📈 Higher Bitrates**: Support for bitrates up to 1024+ Kbps
- **🎚️ Advanced Processing**: Enhanced audio processing options
- **� Smart Defaults**: Automatic bitrate selection based on channel layout

### Dolby Digital Plus BluRay (DDP-BluRay) Encoding

Specialized DDP encoding optimized for BluRay disc mastering.

```bash
# BluRay DDP encoding (defaults to 7.1)
deezy encode ddp-bluray input.mkv

# Custom bitrate for BluRay
deezy encode ddp-bluray --bitrate 1536 input.mkv
```

### Dolby Atmos Encoding

Professional Atmos encoding for immersive audio.

```bash
# Atmos encoding with streaming mode (default)
deezy encode atmos input.mkv

# BluRay Atmos encoding
deezy encode atmos --atmos-mode bluray --bitrate 768 input.mkv
```

**Atmos Options:**

- `--atmos-mode`: `streaming` or `bluray`
- `--thd-warp-mode`: Warp mode for truehdd processing (`normal`)
- `--bed-conform`: Enable bed conformance

### Dolby AC-4 Encoding

Next-generation audio codec with advanced features and flexibility.

```bash
# Basic AC-4 encoding with smart defaults
deezy encode ac4 input.mkv

# AC-4 encoding with custom profile
deezy encode ac4 --encoding-profile ims_music --bitrate 512 input.mkv

# AC-4 with legacy presentation for backward compatibility
deezy encode ac4 --ims-legacy-presentation --bitrate 448 input.mkv
```

**AC-4 Features:**

- **🎼 Advanced Profiles**: Support for IMS and IMS Music encoding profiles
- **🔧 Flexible DRC**: Multiple DRC settings for different playback scenarios
- **📱 Device Optimization**: Separate DRC for portable devices, headphones, and home theater
- **🔄 Legacy Compatibility**: Optional backward compatibility presentation
- **🎚️ Enhanced Metering**: Full support for all loudness metering standards including 1770-4

**AC-4 Input Requirements & Atmos Support:**

AC-4 encoding requires specific input characteristics for optimal results:

- **📋 Minimum Channels**: Input must be 6 channels (5.1) or higher
- **🎵 Atmos Metadata Preservation**: TrueHD Atmos sources automatically retain immersive audio objects in the AC-4 output
- **🔄 Non-Atmos Sources**: Standard multichannel audio (non-TrueHD Atmos) will be encoded without object metadata
- **⚡ Automatic Detection**: DeeZy automatically detects TrueHD Atmos sources and preserves spatial audio information

```bash
# TrueHD Atmos input → AC-4 with immersive stereo + object metadata
deezy encode ac4 atmos_truehd_source.mkv

# Standard 5.1 input → AC-4 without object metadata
deezy encode ac4 standard_51_source.mkv

# Stereo input → Will fail (minimum 6 channels required)
deezy encode ac4 stereo_source.mkv  # Error: insufficient channels
```

**AC-4 Basic Options:**

- `--encoding-profile`: Encoding profile (`ims`, `ims_music`) - use `ims_music` for music content
- `--ims-legacy-presentation`: Add backward compatibility presentation
- `--bitrate`: Bitrate in Kbps (uses smart defaults if not specified)

**AC-4 Advanced DRC Options:**

AC-4 supports multiple independent DRC settings for different playback scenarios:

- `--ddp-drc`: DDP-compatible DRC settings
- `--flat-panel-drc`: Optimized for flat panel TV speakers
- `--home-theatre-drc`: Home theater system optimization
- `--portable-headphones-drc`: Portable device and headphone optimization
- `--portable-speakers-drc`: Small speaker optimization

Each DRC option accepts the full range of dynamic range settings:
`none`, `film_standard`, `film_light`, `music_standard`, `music_light`, `speech`

```bash
# AC-4 with multiple DRC profiles for different playback scenarios
deezy encode ac4 \
  --ddp-drc film_light \
  --home-theatre-drc music_standard \
  --portable-headphones-drc speech \
  input.mkv
```

Use `deezy encode --help` or `deezy encode [format] --help` to see all available options for each encoding format.

## 🎯 Track Selection

DeeZy supports flexible track selection using FFmpeg-style notation for precise control over which audio track to encode.

### Track Selection Syntax

| Format | Description                      | Example             | Use Case                                |
| ------ | -------------------------------- | ------------------- | --------------------------------------- |
| `N`    | Audio track N (default behavior) | `--track-index 1`   | Select second audio track               |
| `a:N`  | Audio track N (explicit)         | `--track-index a:1` | Same as above, but explicit             |
| `s:N`  | Stream index N (any track type)  | `--track-index s:3` | Select fourth stream regardless of type |

### How Track Selection Works

**Audio Track Index (`N` or `a:N`):**

- Uses PyMediaInfo's audio track collection
- `0` = First audio track, `1` = Second audio track, etc.
- This is the traditional behavior that matches audio track order

**Stream Index (`s:N`):**

- Uses PyMediaInfo's general track collection (skips container metadata)
- `s:0` = First stream (usually video), `s:1` = Second stream (usually first audio), etc.
- Matches FFmpeg's `0:N` stream mapping exactly

### Examples

```bash
# Traditional audio track selection (current behavior)
deezy encode ddp --track-index 0 input.mkv    # First audio track
deezy encode ddp --track-index 1 input.mkv    # Second audio track
deezy encode ddp --track-index a:1 input.mkv  # Same as above, explicit

# Stream-based selection (new capability)
deezy encode ddp --track-index s:2 input.mkv  # Third stream (might be second audio)
deezy encode ddp --track-index s:4 input.mkv  # Fifth stream

# When to use stream index:
# - Complex files with multiple video tracks
# - When you need to match FFmpeg's stream numbering exactly
# - Files with mixed track ordering (video/audio/subtitle interspersed)
```

### Understanding Your Media File

Use the `info` command to understand your file's track structure:

```bash
deezy info input.mkv
```

The output shows:

- **Track 0, Track 1, etc.** - These correspond to audio track indices (`--track-index N` or `--track-index a:N`)
- **Stream order** - Use tools like `ffprobe` or MediaInfo to see overall stream structure for `--track-index s:N`

### Compatibility Notes

- **Default behavior unchanged**: `--track-index 2` still selects the third audio track as before
- **Audio encoding only**: Stream selection (`s:N`) is validated to ensure it points to an audio stream
- **Error handling**: Clear error messages if you select a non-audio stream for encoding

## 🔍 File Management & Analysis

### Find Files

Powerful file discovery with glob pattern support.

```bash
# Find all MKV files in current directory
deezy find "*.mkv"

# Find all video files recursively
deezy find "**/*.{mkv,mp4,avi}"

# Show only filenames (not full paths)
deezy find -n "**/*.mkv"
```

Use `deezy find --help` for additional options.

### Audio Stream Analysis

Get detailed information about audio tracks before encoding.

```bash
# Analyze audio streams
deezy info input.mkv

# Analyze multiple files
deezy info *.mkv
```

Use `deezy info --help` for additional options.

The `Track 0`, `Track 1`, etc. shown in the output correspond to audio track indices used with `--track-index`. See the [Track Selection](#-track-selection) section for detailed information about track selection options.

### Configuration Management

Manage DeeZy's configuration system for streamlined workflows.

```bash
# Generate default configuration file
deezy config generate

# Show current configuration status
deezy config info

# Generate config with overwrite protection disabled
deezy config generate --overwrite
```

Use `deezy config --help` for additional options and subcommands.

### Temporary Folder Management

DeeZy creates temporary folders during encoding operations. These folders contain intermediate files like WAV audio and DEE configuration files. The temp management system provides tools to monitor and clean up these folders.

#### Temp Folder Structure

DeeZy organizes temporary files in a clean structure:

```
%TEMP%/deezy/           # Parent folder for all DeeZy operations
├── job_abc123/         # Individual job folders (no deezy_ prefix)
├── job_def456/         # Each job gets a unique folder
└── job_ghi789/         # Clean, organized structure
```

This approach keeps your system temp directory clean and makes it easy to manage DeeZy-related temporary files.

#### Temp Management Commands

```bash
# Show temp folder information
deezy temp info

# Clean old temp folders (24 hours by default)
deezy temp clean

# Clean folders older than specific age
deezy temp clean --max-age 1  # 1 hour

# Preview what would be cleaned (dry run)
deezy temp clean --dry-run

# Clean very old folders with dry run
deezy temp clean --max-age 168 --dry-run  # 1 week
```

**Temp Info Output:**

```
DeeZy temp folder: C:\Users\Username\AppData\Local\Temp\deezy
Job folders: 3
Total size: 2.1 MB
```

**Temp Clean Features:**

- **Safe by default**: 24-hour age limit prevents accidental deletion of active jobs
- **Dry run mode**: Preview what would be deleted without making changes
- **Flexible age control**: Specify custom age thresholds in hours
- **Size reporting**: Shows how much space will be freed
- **Error handling**: Gracefully handles permission issues and locked files

**When to Use Temp Management:**

- **After batch processing**: Clean up after encoding many files
- **Storage maintenance**: Free up disk space from old encoding jobs
- **Debugging cleanup**: Remove temp files after troubleshooting
- **Scheduled maintenance**: Regular cleanup of accumulated temp files

Use `deezy temp --help` for additional options and subcommands.

## 🎯 Input Types & Patterns

DeeZy supports flexible input handling for batch processing:

### Multiple Files

```bash
# Process multiple files with same settings
deezy encode ddp input1.mkv input2.mp4 input3.avi

# Files with spaces (use quotes)
deezy encode ddp "Movie Name (2023).mkv" "Another Movie.mkv"
```

### Glob Patterns

```bash
# All MKV files in directory
deezy encode ddp "directory/*.mkv"

# Recursive search for all video files
deezy encode ddp "movies/**/*.{mkv,mp4,avi}"

# Pattern matching
deezy encode ddp "*TrueHD*.mkv"
```

## 🛠️ Advanced Configuration

### Configuration-Driven Workflows

The configuration system enables powerful workflow optimizations:

```bash
# Set up your environment once
deezy config generate
# Edit config file with your tool paths, defaults, and presets

# Now use clean commands for different scenarios:

# Use smart defaults - automatically applies format-specific settings
deezy encode ddp input.mkv

# Use presets for consistent workflows
deezy encode preset --name streaming_ddp input.mkv
deezy encode preset --name bluray_atmos input.mkv

# Override specific settings when needed
deezy encode preset --name streaming_ddp --bitrate 1024 input.mkv

# Batch processing with consistent preset settings
deezy encode preset --name streaming_ddp "season01/**/*.mkv"
```

**Configuration Benefits:**

- **Eliminate repetitive arguments** - Set tool paths and defaults once
- **Project consistency** - Same encoding settings across files
- **Environment portability** - Share config files between machines
- **Workflow optimization** - Different configs for different use cases

### Bitrate Guidelines

| Format     | Layout           | Default Bitrate | Accepted Range | Use Case               |
| ---------- | ---------------- | --------------- | -------------- | ---------------------- |
| DD         | MONO             | 192 kbps        | 96-640 kbps    | Mono content           |
| DD         | Stereo           | 224 kbps        | 96-640 kbps    | Stereo content         |
| DD         | 5.1              | 448 kbps        | 224-640 kbps   | Legacy compatibility   |
| DDP        | MONO             | 64 kbps         | 32-1024 kbps   | Mono streaming         |
| DDP        | Stereo           | 128 kbps        | 96-1024 kbps   | Stereo streaming       |
| DDP        | 5.1              | 192 kbps        | 192-1024 kbps  | Streaming services     |
| DDP        | 7.1              | 384 kbps        | 384-1024 kbps  | High-quality releases  |
| DDP BluRay | 7.1              | 384 kbps        | 768-1664 kbps  | BluRay mastering       |
| Atmos      | Streaming        | 448 kbps        | 384-1024 kbps  | Streaming Atmos        |
| Atmos      | BluRay           | 1280 kbps       | 1152-1664 kbps | BluRay Atmos           |
| AC-4       | Immersive stereo | 256 kbps        | 64-320 kbps    | High-quality streaming |

_Note: All defaults are configurable via the configuration system_

### Dynamic Range Compression (DRC)

Available for both line mode and RF mode:

- **film_standard**: Heavy compression for noisy environments
- **film_light**: Light compression maintaining dynamics (default)
- **music_standard**: Balanced for music content
- **music_light**: Minimal compression for audiophile listening
- **speech**: Optimized for dialogue clarity

```bash
# Set DRC for line and RF modes
deezy encode ddp --drc-line-mode film_light --drc-rf-mode music_light input.mkv
```

### Temporary File Management

Use `-k/--keep-temp` to retain intermediate files for debugging or manual processing. Temporary files include:

- **WAV files**: Decoded audio streams
- **JSON files**: DEE job configurations
- **LOG files**: Encoding process details

DeeZy automatically organizes temporary files under a dedicated `deezy` folder in your system temp directory. Use the temp management commands to monitor and clean up these files:

```bash
# Monitor temp folder usage
deezy temp info

# Clean up after batch processing
deezy temp clean --max-age 1

# Debug with temp files and clean up afterward
deezy encode ddp --keep-temp input.mkv
deezy temp clean --dry-run  # Check what will be cleaned
deezy temp clean            # Clean up when ready
```

## 📚 Examples & Workflows

### Movie Encoding Workflow

```bash
# 1. Set up configuration once
deezy config generate

# 2. Analyze the source
deezy info "Movie.Name.2023.UHD.mkv"

# 3. Encode with preset for consistency
deezy encode preset --name bluray_atmos "Movie.Name.2023.UHD.mkv"

# 4. Or customize settings manually
deezy encode atmos --atmos-mode bluray --bitrate 768 "Movie.Name.2023.UHD.mkv"

# 5. Verify output
deezy info "Movie.Name.2023.UHD.DDP.Atmos.ec3"
```

### Batch TV Series Processing

```bash
# Find all episodes
deezy find "TV.Series.S01**/*.mkv"

# Encode entire season with streaming preset
deezy encode preset --name streaming_ddp "TV.Series.S01**/*.mkv"

# Or with custom settings for dialogue-heavy content
deezy encode ddp --channels 6 --bitrate 448 --drc-line-mode speech "TV.Series.S01**/*.mkv"

# Clean up temp files after batch processing
deezy temp info         # Check temp folder status
deezy temp clean        # Clean up old temp files
```

### Quality Control

```bash
# Keep temporary files for analysis
deezy encode ddp --keep-temp input.mkv

# Use custom temp directory
deezy encode ddp --temp-dir "C:\debug\" input.mkv
```

## 🚨 Troubleshooting

### Common Issues

**"truehdd decoder not found"**

- Ensure truehdd decoder is installed and in PATH
- Only required for Atmos encoding from TrueHD sources

**"Invalid bitrate for channel layout"**

- Check the bitrate guidelines table for appropriate values
- DeeZy will automatically adjust to the nearest valid bitrate if possible

**"FFmpeg not found"**

- Install FFmpeg and add to system PATH
- Required for all audio processing operations

**"DEE executable not found"**

- Install Dolby Encoding Engine
- Set DEE path with `--dee` parameter or in config file

**"Configuration file issues"**

- Use `deezy config info` to check config status
- Regenerate config with `deezy config generate --overwrite`
- Ensure TOML syntax is valid in manual edits

**"Disk space issues"**

- Check temp folder usage with `deezy temp info`
- Clean old temp files with `deezy temp clean`
- Use `--temp-dir` to specify alternative temp location
- Monitor temp folder growth during batch processing

**"Temp folder permission errors"**

- Ensure write permissions to system temp directory
- Use `--temp-dir` to specify accessible location
- Check `deezy temp info` for temp folder location

### Debug Mode

```bash
# Enable verbose logging
deezy --log-level debug encode ddp input.mkv

# Write logs to file and keep temporary files
deezy --log-to-file encode ddp --keep-temp --temp-dir "C:\debug\" input.mkv

# Use custom config for troubleshooting
deezy --config debug-config.toml encode ddp input.mkv
```

## 🔗 Resources

- **📖 Dolby Encoding Engine Documentation**: `docs/dolbyencodingengineusersguide.pdf`
- **🔧 Channel Layout Reference**: `deezy/enums/`
- **🎵 Audio Filter Documentation**: DEE user guide for advanced filtering

## 📄 License

This project is licensed under the terms specified in the LICENSE file.

---
