"""
Central configuration file for close_drawer task.
All scripts (dataset generator, debug tools, camera adjustment) read from this file.
"""
import numpy as np

# ============================================================================
# Cabinet Configuration
# ============================================================================
# Position cabinet so drawer is reachable by robot (robot base at origin)
# No rotation - drawer opens in +Y direction (toward robot at origin)
# Cabinet at Y=-0.7, when drawer open 0.1m, handle is at Y~=-0.35 (closer to robot)
CABINET_POSITION = [0.3, -0.6, 0.77]  # X, Y, Z - cabinet in -Y region
CABINET_ORIENTATION_DEGREES = 0.0     # No rotation - keep original orientation

# ============================================================================
# Drawer Configuration
# ============================================================================
DRAWER_VARIATION = 2  # 0=bottom, 1=middle, 2=top
SUCCESS_THRESHOLD = 0.06  # RLBench success condition: drawer_joint ≤ 0.06m
SUCCESS_MARGIN = 0.02     # How far below threshold to aim (2cm margin)

# ============================================================================
# Robot Configuration
# ============================================================================
# Panda home joint configuration
# Adjusted to match the height of the TOP drawer handle (variation=2)
# Original: [0, 0, 0, -1.57, 0, 1.57, 0.785] - EE too high
# Slight shoulder tilt and elbow adjustment to lower EE to top drawer height
HOME_JOINTS = np.array([0, 0.15, 0, -1.7, 0, 1.7, 0.785])

# ============================================================================
# Trajectory Configuration
# ============================================================================

# Phase step allocation (total: 88 steps)
PHASE_STEPS = {
    "reach": 64,        # Phase 1: shaped start -> handle position (SHAPED)
    "push": 24,         # Phase 2: push drawer closed (linear motion)
    # Note: No retreat phase - success is determined by drawer state, not robot position
}

# Waypoint offsets
# Note: Without rotation, drawer opens toward +Y (toward robot at origin)
# Cabinet is at Y=-0.7, handle when open is at Y~=-0.35 (closer to robot)
# To CLOSE it, we push in -Y direction (into cabinet body, away from robot)
# RLBench success: must move > 6cm from 0.1m start, so push_distance must be > 0.06m
WAYPOINT_OFFSETS = {
    "prehandle_offset_y": 0.15,    # Approach from +Y side (in front of open drawer, toward robot)
    "push_distance": 0.08,         # How far to push (8cm to ensure > 6cm movement for success)
    "retreat_distance": 0.08,      # (unused - no retreat phase)
}

# Calculate DRAWER_OPEN_AMOUNT from push_distance and success condition
# Formula: DRAWER_OPEN_AMOUNT = push_distance + (SUCCESS_THRESHOLD - SUCCESS_MARGIN)
# After push: drawer ends at DRAWER_OPEN_AMOUNT - push_distance = SUCCESS_THRESHOLD - SUCCESS_MARGIN
DRAWER_OPEN_AMOUNT = WAYPOINT_OFFSETS["push_distance"] + (SUCCESS_THRESHOLD - SUCCESS_MARGIN)

# ============================================================================
# Control Point Configuration
# ============================================================================
CONTROL_POINT_RADIUS = 0.09  # Control point sampling radius (meters)

# Control point noise parameters for generating variations
# Note: Position is fixed at 0.5, only angle and distance have noise
CP_ANGLE_NOISE = 0.15   # Noise range for angle (radians)
CP_DIST_NOISE = 0.05    # Noise range for distance fraction
# Position is fixed at 0.5 (middle of trajectory), no noise applied

# ============================================================================
# Dataset Generation Configuration
# ============================================================================
NUM_MODES = 10         # Number of different control point modes for training
DEMOS_PER_MODE = 5     # Number of noisy demos per control point mode

# ============================================================================
# Workspace/Table Configuration
# ============================================================================
# Extend the workspace table along Y axis to accommodate cabinet placement
# Scale factors: [X, Y, Z] - 1.0 means original size
WORKSPACE_SCALE = [1.0, 2.0, 1.0]  # Double the Y dimension

# ============================================================================
# Camera Configuration
# ============================================================================
# Camera position and orientation for video recording
# These values should be adjusted using adjust_camera_interactive.py
CAMERA_POSITION = [1.2499991655349731, 0.4000000059604645, 1.579999327659607]
CAMERA_ORIENTATION = [2.158409595489502, -0.934466540813446, 0.48761194944381714]

# Camera image size for video recording
CAMERA_IMAGE_SIZE = [256, 256]

# ============================================================================
# Helper Functions
# ============================================================================

def get_cabinet_orientation_radians():
    """Get cabinet orientation in radians."""
    import math
    return [0, 0, math.radians(CABINET_ORIENTATION_DEGREES)]


def print_config_summary():
    """Print a summary of the current configuration."""
    print("="*70)
    print("CLOSE DRAWER CONFIGURATION")
    print("="*70)
    print(f"Cabinet:")
    print(f"  Position:    {CABINET_POSITION}")
    print(f"  Orientation: {CABINET_ORIENTATION_DEGREES}° around Z")
    print(f"\nDrawer:")
    print(f"  Variation:   {DRAWER_VARIATION} ({'bottom' if DRAWER_VARIATION==0 else 'middle' if DRAWER_VARIATION==1 else 'top'})")
    print(f"  Open amount: {DRAWER_OPEN_AMOUNT}m")
    print(f"\nTrajectory:")
    print(f"  Phase steps: {PHASE_STEPS}")
    print(f"  Total steps: {sum(PHASE_STEPS.values())}")
    print(f"  Waypoint offsets: {WAYPOINT_OFFSETS}")
    print(f"\nControl Points:")
    print(f"  Radius: {CONTROL_POINT_RADIUS}m")
    print(f"  Noise: angle={CP_ANGLE_NOISE}, dist={CP_DIST_NOISE}, pos={CP_POS_NOISE}")
    print(f"\nDataset:")
    print(f"  Modes: {NUM_MODES}")
    print(f"  Demos per mode: {DEMOS_PER_MODE}")
    print(f"  Total episodes: {NUM_MODES * DEMOS_PER_MODE}")
    print(f"\nCamera:")
    print(f"  Position: {CAMERA_POSITION}")
    print(f"  Orientation: {CAMERA_ORIENTATION}")
    print("="*70)
