r"""
Tunable Parameters for TurtleBot4 Nav2 Bayesian Optimization

Hardware: TurtleBot4 with ROS2 Humble
"""

from typing import Dict, Any, List, Tuple

# =============================================================================
# PARAMETER DEFINITIONS WITH RANGES AND DESCRIPTIONS
# =============================================================================

class TunableParameters:
    """
    Complete set of tunable parameters for Nav2 configuration.
    Each parameter includes description, impact on objectives, and valid bounds.
    
    Impact categories for each parameter:
    - energy: Impact on energy efficiency (Wh/m)
    - time: Impact on task completion time (seconds)
    - safety: Impact on collision avoidance
    - task_completion: Impact on whether goal is successfully reached
    """
    
    # =========================================================================
    # CONTROLLER SERVER - DWB LOCAL PLANNER
    # =========================================================================
    
    CONTROLLER_VELOCITY_LIMITS = {
        'min_vel_x': {
            'name': 'FollowPath.min_vel_x',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 0.0,
            'value_type': float,
            'bounds': (-0.3, 0.0),  # m/s
            'description': 'Minimum forward velocity',
            'impact': {
                'energy': 'Low - Affects ability to move slowly, minor energy impact',
                'time': 'Medium - Higher values prevent very slow movement',
                'safety': 'Low - Ensures some minimum motion capability',
                'task_completion': 'Low - Too high may prevent reaching tight goals'
            }
        },
        'max_vel_x': {
            'name': 'FollowPath.max_vel_x',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 0.26,
            'value_type': float,
            'bounds': (0.1, 0.5),  # m/s
            'description': 'Maximum forward velocity',
            'impact': {
                'energy': 'HIGH - Higher speeds increase energy consumption significantly',
                'time': 'HIGH - Directly affects task completion time',
                'safety': 'HIGH - Higher speeds reduce reaction time to obstacles',
                'task_completion': 'Medium - Too low may timeout, too high may overshoot goal'
            }
        },
        'max_vel_theta': {
            'name': 'FollowPath.max_vel_theta',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 1.0,
            'value_type': float,
            'bounds': (0.5, 2.0),  # rad/s
            'description': 'Maximum rotational velocity',
            'impact': {
                'energy': 'HIGH - Faster rotation consumes more energy',
                'time': 'HIGH - Affects time spent rotating to goal orientation',
                'safety': 'Medium - Very fast rotation can destabilize robot',
                'task_completion': 'Medium - Too low slows goal approach, too high reduces precision'
            }
        },
        'min_speed_xy': {
            'name': 'FollowPath.min_speed_xy',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 0.0,
            'value_type': float,
            'bounds': (0.0, 0.1),  # m/s
            'description': 'Minimum translational speed (combined x,y)',
            'impact': {
                'energy': 'Low - Prevents very slow inefficient movements',
                'time': 'Medium - Forces minimum speed or stop',
                'safety': 'Low - Ensures decisive motion',
                'task_completion': 'Low - Too high may prevent fine positioning at goal'
            }
        },
        'max_speed_xy': {
            'name': 'FollowPath.max_speed_xy',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 0.26,
            'value_type': float,
            'bounds': (0.1, 0.5),  # m/s
            'description': 'Maximum translational speed (combined x,y)',
            'impact': {
                'energy': 'HIGH - Caps overall translational energy usage',
                'time': 'HIGH - Limits maximum achievable speed',
                'safety': 'HIGH - Primary safety limit on speed',
                'task_completion': 'Medium - Too low increases timeout risk, too high reduces control'
            }
        },
        'min_speed_theta': {
            'name': 'FollowPath.min_speed_theta',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 0.0,
            'value_type': float,
            'bounds': (0.0, 0.3),  # rad/s
            'description': 'Minimum rotational speed',
            'impact': {
                'energy': 'Low - Prevents inefficient slow rotations',
                'time': 'Low - Forces faster rotations or stop',
                'safety': 'Low - Ensures decisive rotation',
                'task_completion': 'Low - May affect final orientation alignment at goal'
            }
        },
    }
    
    CONTROLLER_ACCELERATION_LIMITS = {
        'acc_lim_x': {
            'name': 'FollowPath.acc_lim_x',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 2.5,
            'value_type': float,
            'bounds': (1.0, 4.0),  # m/s²
            'description': 'Linear acceleration limit',
            'impact': {
                'energy': 'HIGH - Aggressive acceleration wastes energy',
                'time': 'HIGH - Faster acceleration reduces time to reach speed',
                'safety': 'Medium - Very high values can cause wheel slip',
                'task_completion': 'Medium - Too low slows progress, too high reduces stability'
            }
        },
        'acc_lim_theta': {
            'name': 'FollowPath.acc_lim_theta',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 3.2,
            'value_type': float,
            'bounds': (1.5, 5.0),  # rad/s²
            'description': 'Angular acceleration limit',
            'impact': {
                'energy': 'HIGH - Aggressive rotation acceleration uses more power',
                'time': 'HIGH - Affects how quickly robot can change heading',
                'safety': 'Medium - Excessive values can destabilize robot',
                'task_completion': 'Medium - Affects responsiveness in dynamic environments'
            }
        },
        'decel_lim_x': {
            'name': 'FollowPath.decel_lim_x',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': -2.5,
            'value_type': float,
            'bounds': (-4.0, -1.0),  # m/s²
            'description': 'Linear deceleration limit (negative value)',
            'impact': {
                'energy': 'HIGH - Aggressive braking recovers less energy',
                'time': 'Medium - Affects stopping distance and safety margins',
                'safety': 'HIGH - Too aggressive can cause instability, too slow increases collision risk',
                'task_completion': 'HIGH - Critical for precise stopping at goal, too slow causes overshoot'
            }
        },
        'decel_lim_theta': {
            'name': 'FollowPath.decel_lim_theta',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': -3.2,
            'value_type': float,
            'bounds': (-5.0, -1.5),  # rad/s²
            'description': 'Angular deceleration limit (negative value)',
            'impact': {
                'energy': 'Medium - Affects energy during rotation stops',
                'time': 'Low - Minor impact on overall time',
                'safety': 'Medium - Affects ability to stop rotation quickly',
                'task_completion': 'Medium - Affects final orientation precision at goal'
            }
        },
    }
    
    CONTROLLER_TRAJECTORY_SAMPLING = {
        'vx_samples': {
            'name': 'FollowPath.vx_samples',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 20,
            'value_type': int,
            'bounds': (10, 40),  # count
            'description': 'Number of forward velocity samples for trajectory generation',
            'impact': {
                'energy': 'Medium - More samples find better energy-efficient trajectories',
                'time': 'Medium - More samples increase planning time but find faster paths',
                'safety': 'HIGH - More samples improve obstacle avoidance quality',
                'task_completion': 'HIGH - More samples increase success rate in complex environments'
            }
        },
        'vtheta_samples': {
            'name': 'FollowPath.vtheta_samples',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 20,
            'value_type': int,
            'bounds': (10, 40),  # count
            'description': 'Number of rotational velocity samples',
            'impact': {
                'energy': 'Medium - Better trajectory optimization with more samples',
                'time': 'Medium - More samples increase planning time',
                'safety': 'HIGH - Critical for finding safe turning trajectories',
                'task_completion': 'HIGH - Critical for navigating tight spaces and reaching goal'
            }
        },
        'sim_time': {
            'name': 'FollowPath.sim_time',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 1.7,
            'value_type': float,
            'bounds': (1.0, 3.0),  # seconds
            'description': 'Trajectory simulation lookahead time',
            'impact': {
                'energy': 'Medium - Longer lookahead enables better energy planning',
                'time': 'HIGH - Longer lookahead slows planning but improves path quality',
                'safety': 'HIGH - Longer lookahead provides more obstacle avoidance time',
                'task_completion': 'HIGH - Longer lookahead improves success in dynamic environments'
            }
        },
        'linear_granularity': {
            'name': 'FollowPath.linear_granularity',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 0.05,
            'value_type': float,
            'bounds': (0.02, 0.1),  # meters
            'description': 'Distance between points in simulated trajectory',
            'impact': {
                'energy': 'Low - Finer granularity slightly improves trajectory quality',
                'time': 'Low - Finer granularity increases computation time',
                'safety': 'Medium - Finer resolution improves collision checking accuracy',
                'task_completion': 'Low - Minor impact on goal reaching capability'
            }
        },
        'angular_granularity': {
            'name': 'FollowPath.angular_granularity',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 0.025,
            'value_type': float,
            'bounds': (0.01, 0.05),  # radians
            'description': 'Angular distance between trajectory points',
            'impact': {
                'energy': 'Low - Minor impact on trajectory quality',
                'time': 'Low - Finer resolution increases computation',
                'safety': 'Medium - Affects rotational collision checking',
                'task_completion': 'Low - Minor impact on goal reaching'
            }
        },
    }
    
    CONTROLLER_DWB_CRITICS = {
        'BaseObstacle.scale': {
            'name': 'FollowPath.BaseObstacle.scale',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 0.02,
            'value_type': float,
            'bounds': (0.01, 0.1),
            'description': 'Weight for obstacle avoidance cost',
            'impact': {
                'energy': 'Medium - Higher weight forces wider clearance, longer paths',
                'time': 'Medium - Higher weight may slow robot near obstacles',
                'safety': 'CRITICAL - Primary parameter for obstacle avoidance behavior',
                'task_completion': 'CRITICAL - Too low causes collisions, too high may block valid paths'
            }
        },
        'PathAlign.scale': {
            'name': 'FollowPath.PathAlign.scale',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 32.0,
            'value_type': float,
            'bounds': (10.0, 60.0),
            'description': 'Weight for staying aligned with global path',
            'impact': {
                'energy': 'HIGH - Higher values keep robot on planned path (more efficient)',
                'time': 'Medium - Affects path following vs shortcutting behavior',
                'safety': 'Medium - Can force robot away from obstacles if path is close',
                'task_completion': 'HIGH - Proper alignment critical for following global plan to goal'
            }
        },
        'PathAlign.forward_point_distance': {
            'name': 'FollowPath.PathAlign.forward_point_distance',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 0.1,
            'value_type': float,
            'bounds': (0.05, 0.3),  # meters
            'description': 'Lookahead distance for path alignment',
            'impact': {
                'energy': 'Low - Affects smoothness of path following',
                'time': 'Low - Longer lookahead reduces oscillations',
                'safety': 'Low - Indirect impact on trajectory stability',
                'task_completion': 'Medium - Affects path tracking accuracy'
            }
        },
        'GoalAlign.scale': {
            'name': 'FollowPath.GoalAlign.scale',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 24.0,
            'value_type': float,
            'bounds': (10.0, 60.0),
            'description': 'Weight for aligning heading toward goal',
            'impact': {
                'energy': 'Medium - Higher values prioritize goal orientation',
                'time': 'HIGH - Affects approach behavior and final rotation',
                'safety': 'Low - Primarily affects goal region behavior',
                'task_completion': 'CRITICAL - Essential for achieving goal pose with correct orientation'
            }
        },
        'GoalAlign.forward_point_distance': {
            'name': 'FollowPath.GoalAlign.forward_point_distance',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 0.1,
            'value_type': float,
            'bounds': (0.05, 0.3),  # meters
            'description': 'Lookahead distance for goal alignment',
            'impact': {
                'energy': 'Low - Affects smoothness of goal approach',
                'time': 'Low - Impacts final approach behavior',
                'safety': 'Low - Minor impact on goal approach',
                'task_completion': 'Medium - Affects final approach precision'
            }
        },
        'PathDist.scale': {
            'name': 'FollowPath.PathDist.scale',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 32.0,
            'value_type': float,
            'bounds': (10.0, 60.0),
            'description': 'Weight for making progress along path',
            'impact': {
                'energy': 'HIGH - Higher values encourage progress, reduce wandering',
                'time': 'HIGH - Directly affects speed of progress toward goal',
                'safety': 'Low - Can override safety if too high',
                'task_completion': 'HIGH - Drives forward progress, prevents getting stuck'
            }
        },
        'GoalDist.scale': {
            'name': 'FollowPath.GoalDist.scale',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 24.0,
            'value_type': float,
            'bounds': (10.0, 60.0),
            'description': 'Weight for reducing distance to goal',
            'impact': {
                'energy': 'HIGH - Encourages direct approach vs path following',
                'time': 'HIGH - Strong influence on shortcutting behavior',
                'safety': 'Medium - High values may ignore path safety',
                'task_completion': 'CRITICAL - Primary driver for reaching goal position'
            }
        },
        'RotateToGoal.scale': {
            'name': 'FollowPath.RotateToGoal.scale',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 32.0,
            'value_type': float,
            'bounds': (10.0, 60.0),
            'description': 'Weight for rotating to goal orientation at end',
            'impact': {
                'energy': 'Medium - Affects energy spent on final rotation',
                'time': 'HIGH - Controls time spent on final orientation',
                'safety': 'Low - Primarily affects final behavior',
                'task_completion': 'CRITICAL - Required to achieve full goal pose (position + orientation)'
            }
        },
        'RotateToGoal.slowing_factor': {
            'name': 'FollowPath.RotateToGoal.slowing_factor',
            'set_param': '/controller_server/set_parameters',
            'get_param': '/controller_server/get_parameters',
            'default': 5.0,
            'value_type': float,
            'bounds': (2.0, 10.0),
            'description': 'How much to slow down during final rotation',
            'impact': {
                'energy': 'Low - Affects energy during final rotation',
                'time': 'Medium - Higher values slow final rotation',
                'safety': 'Low - Controls final rotation smoothness',
                'task_completion': 'Medium - Too slow may timeout, too fast reduces precision'
            }
        },
    }
    
    # =========================================================================
    # LOCAL COSTMAP
    # =========================================================================
    
    LOCAL_COSTMAP = {
        'local_width': {
            'name': 'width',
            'set_param': '/local_costmap/local_costmap/set_parameters',
            'get_param': '/local_costmap/local_costmap/get_parameters',
            'default': 3,
            'value_type': int,
            'bounds': (2, 5),  # meters
            'description': 'Width of local costmap window',
            'impact': {
                'energy': 'Low - Larger map enables better local planning',
                'time': 'Medium - Larger map increases computation time',
                'safety': 'HIGH - Larger map sees obstacles earlier',
                'task_completion': 'HIGH - Larger window improves obstacle avoidance and replanning'
            }
        },
        'local_height': {
            'name': 'height',
            'set_param': '/local_costmap/local_costmap/set_parameters',
            'get_param': '/local_costmap/local_costmap/get_parameters',
            'default': 3,
            'value_type': int,
            'bounds': (2, 5),  # meters
            'description': 'Height of local costmap window',
            'impact': {
                'energy': 'Low - Larger map enables better local planning',
                'time': 'Medium - Larger map increases computation time',
                'safety': 'HIGH - Larger map sees obstacles earlier',
                'task_completion': 'HIGH - Larger window improves obstacle avoidance and replanning'
            }
        },
        'local_resolution': {
            'name': 'resolution',
            'set_param': '/local_costmap/local_costmap/set_parameters',
            'get_param': '/local_costmap/local_costmap/get_parameters',
            'default': 0.06,
            'value_type': float,
            'bounds': (0.04, 0.1),  # meters per cell
            'description': 'Size of each costmap cell',
            'impact': {
                'energy': 'Low - Finer resolution improves path quality slightly',
                'time': 'HIGH - Finer resolution dramatically increases computation',
                'safety': 'HIGH - Finer resolution improves obstacle representation',
                'task_completion': 'Medium - Better obstacle detection but slower planning'
            }
        },
        'local_inflation_radius': {
            'name': 'inflation_layer.inflation_radius',
            'set_param': '/local_costmap/local_costmap/set_parameters',
            'get_param': '/local_costmap/local_costmap/get_parameters',
            'default': 0.35,
            'value_type': float,
            'bounds': (0.3, 0.6),  # meters
            'description': 'Distance to inflate obstacles (safety buffer)',
            'impact': {
                'energy': 'HIGH - Larger inflation forces wider paths, more distance',
                'time': 'Medium - Larger radius may block narrow passages',
                'safety': 'CRITICAL - Primary safety margin around obstacles',
                'task_completion': 'CRITICAL - Too large blocks passages, too small causes collisions'
            }
        },
        'local_cost_scaling_factor': {
            'name': 'inflation_layer.cost_scaling_factor',
            'set_param': '/local_costmap/local_costmap/set_parameters',
            'get_param': '/local_costmap/local_costmap/get_parameters',
            'default': 4.0,
            'value_type': float,
            'bounds': (2.0, 10.0),
            'description': 'Exponential decay rate of cost from obstacles',
            'impact': {
                'energy': 'Medium - Higher values penalize proximity more strongly',
                'time': 'Low - Affects path selection near obstacles',
                'safety': 'HIGH - Controls how aggressively robot avoids obstacles',
                'task_completion': 'HIGH - Affects path feasibility near obstacles'
            }
        },
    }
    
    # =========================================================================
    # GLOBAL COSTMAP
    # =========================================================================
    
    GLOBAL_COSTMAP = {
        'global_resolution': {
            'name': 'resolution',
            'set_param': '/global_costmap/global_costmap/set_parameters',
            'get_param': '/global_costmap/global_costmap/get_parameters',
            'default': 0.06,
            'value_type': float,
            'bounds': (0.04, 0.1),  # meters per cell
            'description': 'Size of each costmap cell',
            'impact': {
                'energy': 'Low - Affects global path quality',
                'time': 'HIGH - Finer resolution increases planning time',
                'safety': 'Medium - Better obstacle representation',
                'task_completion': 'Medium - Better obstacle detection but slower planning'
            }
        },
        'global_inflation_radius': {
            'name': 'inflation_layer.inflation_radius',
            'set_param': '/global_costmap/global_costmap/set_parameters',
            'get_param': '/global_costmap/global_costmap/get_parameters',
            'default': 0.35,
            'value_type': float,
            'bounds': (0.3, 0.6),  # meters
            'description': 'Distance to inflate obstacles (safety buffer)',
            'impact': {
                'energy': 'HIGH - Larger inflation creates longer global paths',
                'time': 'Medium - May block optimal paths',
                'safety': 'CRITICAL - Global path safety margin',
                'task_completion': 'CRITICAL - Too large blocks valid global paths, too small causes collisions'
            }
        },
        'global_cost_scaling_factor': {
            'name': 'inflation_layer.cost_scaling_factor',
            'set_param': '/global_costmap/global_costmap/set_parameters',
            'get_param': '/global_costmap/global_costmap/get_parameters',
            'default': 4.0,
            'value_type': float,
            'bounds': (2.0, 10.0),
            'description': 'Exponential decay rate of cost from obstacles',
            'impact': {
                'energy': 'Medium - Affects global path routing',
                'time': 'Low - Minor impact on path selection',
                'safety': 'HIGH - Global obstacle avoidance behavior',
                'task_completion': 'HIGH - Affects global path feasibility and routing'
            }
        },
    }

    
    # =========================================================================
    # BEHAVIOR SERVER
    # =========================================================================
    
    BEHAVIOR_SERVER = {
        'simulate_ahead_time': {
            'name': 'simulate_ahead_time',
            'set_param': '/behavior_server/set_parameters',
            'get_param': '/behavior_server/get_parameters',
            'default': 2.0,
            'value_type': float,
            'bounds': (1.0, 3.0),  # seconds
            'description': 'Simulation time for behavior planning (spin, backup)',
            'impact': {
                'energy': 'Low - Affects behavior trajectory quality',
                'time': 'Low - Planning time for recovery behaviors',
                'safety': 'Medium - Longer simulation improves behavior safety',
                'task_completion': 'HIGH - Better simulation improves recovery success, critical for unstuck'
            }
        },
        'max_rotational_vel': {
            'name': 'max_rotational_vel',
            'set_param': '/behavior_server/set_parameters',
            'get_param': '/behavior_server/get_parameters',
            'default': 1.0,
            'value_type': float,
            'bounds': (0.5, 2.0),  # rad/s
            'description': 'Maximum rotation velocity for recovery behaviors',
            'impact': {
                'energy': 'Medium - Affects energy during recovery',
                'time': 'Medium - Faster recovery from stuck situations',
                'safety': 'Medium - Too fast may cause instability during recovery',
                'task_completion': 'HIGH - Critical for recovery behaviors to reach goal after getting stuck'
            }
        },
        'min_rotational_vel': {
            'name': 'min_rotational_vel',
            'set_param': '/behavior_server/set_parameters',
            'get_param': '/behavior_server/get_parameters',
            'default': 0.4,
            'value_type': float,
            'bounds': (0.2, 0.8),  # rad/s
            'description': 'Minimum rotation velocity for recovery behaviors',
            'impact': {
                'energy': 'Low - Ensures efficient recovery rotations',
                'time': 'Low - Prevents very slow recovery',
                'safety': 'Low - Ensures decisive recovery motion',
                'task_completion': 'Medium - Ensures effective recovery actions to continue toward goal'
            }
        },
        'rotational_acc_lim': {
            'name': 'rotational_acc_lim',
            'set_param': '/behavior_server/set_parameters',
            'get_param': '/behavior_server/get_parameters',
            'default': 3.2,
            'value_type': float,
            'bounds': (1.5, 5.0),  # rad/s²
            'description': 'Rotational acceleration limit for behaviors',
            'impact': {
                'energy': 'Medium - Affects recovery behavior energy',
                'time': 'Low - Minor impact on recovery time',
                'safety': 'Medium - Aggressive acceleration during recovery risks',
                'task_completion': 'Medium - Affects recovery behavior effectiveness'
            }
        },
    }
    
    # =========================================================================
    # HELPER METHODS
    # =========================================================================
    
    @classmethod
    def get_all_parameters(cls) -> Dict[str, Dict[str, Any]]:
        """
        Get all tunable parameters as a flat dictionary.
        
        Returns:
            Dictionary with parameter names as keys and their properties as values
        """
        all_params = {}
        
        # Combine all parameter groups
        param_groups = [
            cls.CONTROLLER_VELOCITY_LIMITS,
            cls.CONTROLLER_ACCELERATION_LIMITS,
            cls.CONTROLLER_TRAJECTORY_SAMPLING,
            cls.CONTROLLER_DWB_CRITICS,
            cls.LOCAL_COSTMAP,
            cls.GLOBAL_COSTMAP,
            cls.BEHAVIOR_SERVER,
        ]
        
        for group in param_groups:
            all_params.update(group)
        
        return all_params
    
    @classmethod
    def get_parameter_names(cls) -> List[str]:
        """Get list of all parameter names."""
        return list(cls.get_all_parameters().keys())
    
    @classmethod
    def get_default_values(cls) -> Dict[str, float]:
        """Get dictionary of parameter names to default values."""
        all_params = cls.get_all_parameters()
        return {name: props['default'] for name, props in all_params.items()}
    
    @classmethod
    def get_parameter_bounds(cls) -> Dict[str, Tuple[float, float]]:
        """Get dictionary of parameter names to (min, max) ranges."""
        all_params = cls.get_all_parameters()
        return {name: props['bounds'] for name, props in all_params.items()}
    
    @classmethod
    def get_high_impact_parameters(cls, objective: str = 'energy') -> List[str]:
        """
        Get parameters with HIGH or CRITICAL impact on specified objective.
        
        Args:
            objective: 'energy', 'time', or 'safety'
            
        Returns:
            List of parameter names with high impact
        """
        all_params = cls.get_all_parameters()
        high_impact = []
        
        for name, props in all_params.items():
            impact = props['impact'].get(objective, '')
            if 'HIGH' in impact.upper() or 'CRITICAL' in impact.upper():
                high_impact.append(name)
        
        return high_impact

class RecommendedParameters:
    """
    Recommended parameter ordering for Bayesian Optimization.
    Provides an ordered list of parameters with all necessary metadata for setting.
    """
    
    # Define the order of parameters for X tensor
    PARAMETER_ORDER = [
        # Controller Velocity Limits (4 params)
        'min_vel_x',
        'max_vel_x',
        'max_vel_theta',
        'max_speed_xy',
        
        # Controller Acceleration Limits (4 params)
        'acc_lim_x',
        'acc_lim_theta',
        'decel_lim_x',
        'decel_lim_theta',
        
        # Controller Trajectory Sampling (3 params)
        'vx_samples',
        'vtheta_samples',
        'sim_time',
        
        # Controller DWB Critics (6 params)
        'BaseObstacle.scale',
        'PathAlign.scale',
        'GoalAlign.scale',
        'PathDist.scale',
        'GoalDist.scale',
        'RotateToGoal.scale',
        
        # Planner SMAC (7 params)
        'max_planning_time',
        'analytic_expansion_ratio',
        'analytic_expansion_max_length',
        'minimum_turning_radius',
        'reverse_penalty',
        'non_straight_penalty',
        'cost_penalty',
        
        # Local Costmap (5 params)
        'local_width',           
        'local_height',
        'local_resolution',
        'local_inflation_radius',
        'local_cost_scaling_factor',

        # Global Costmap (3 params)
        'global_resolution',
        'global_inflation_radius',
        'global_cost_scaling_factor',
    ]
    
    @classmethod
    def get_ordered_parameters(cls) -> List[Tuple[str, Dict[str, Any]]]:
        """
        Get parameters in order with all metadata needed for setting.
        
        Returns:
            List of tuples (param_key, param_metadata) in the order defined by PARAMETER_ORDER
        """
        all_params = TunableParameters.get_all_parameters()
        ordered = []
        
        # Add parameters from PARAMETER_ORDER
        for param_key in cls.PARAMETER_ORDER:
            if param_key in all_params:
                ordered.append((param_key, all_params[param_key]))
        
        return ordered
    
    @classmethod
    def get_bounds_array(cls) -> List[Tuple[float, float]]:
        """Get bounds for all parameters in order."""
        return [param_data['bounds'] for _, param_data in cls.get_ordered_parameters()]
    
    @classmethod
    def get_default_values_array(cls) -> List[float]:
        """Get default values for all parameters in order."""
        return [param_data['default'] for _, param_data in cls.get_ordered_parameters()]
    
    @classmethod
    def get_parameter_count(cls) -> int:
        """Get total number of parameters."""
        return len(cls.get_ordered_parameters())


# =============================================================================
# PARAMETER COUNT SUMMARY
# =============================================================================

def print_parameter_summary():
    """Print summary of all tunable parameters."""
    
    params = TunableParameters.get_all_parameters()
    
    print("=" * 80)
    print("TUNABLE PARAMETERS SUMMARY")
    print("=" * 80)
    print(f"\nTotal Parameters: {len(params)}")
    
    print("\nParameters by Category:")
    print(f"  Controller Velocity Limits:     {len(TunableParameters.CONTROLLER_VELOCITY_LIMITS)}")
    print(f"  Controller Acceleration Limits: {len(TunableParameters.CONTROLLER_ACCELERATION_LIMITS)}")
    print(f"  Controller Trajectory Sampling: {len(TunableParameters.CONTROLLER_TRAJECTORY_SAMPLING)}")
    print(f"  Controller DWB Critics:         {len(TunableParameters.CONTROLLER_DWB_CRITICS)}")
    print(f"  Local Costmap:                  {len(TunableParameters.LOCAL_COSTMAP)}")
    print(f"  Global Costmap:                 {len(TunableParameters.GLOBAL_COSTMAP)}")
    print(f"  Behavior Server:                {len(TunableParameters.BEHAVIOR_SERVER)}")
    
    print("\nHigh Impact Parameters:")
    print(f"  Energy Efficiency: {len(TunableParameters.get_high_impact_parameters('energy'))}")
    print(f"  Task Time:         {len(TunableParameters.get_high_impact_parameters('time'))}")
    print(f"  Safety:            {len(TunableParameters.get_high_impact_parameters('safety'))}")
    
    print("\n" + "=" * 80)


if __name__ == "__main__":
    print_parameter_summary()
    
    # Example: Access specific parameter info
    print("\nExample - Parameter Details:")
    params = TunableParameters.get_all_parameters()
    example_param = 'max_vel_x'
    
    if example_param in params:
        info = params[example_param]
        print(f"\nParameter: {example_param}")
        print(f"  Default: {info['default']}")
        print(f"  Range: {info['bounds']}")
        print(f"  Description: {info['description']}")
        print(f"  Impact on Energy: {info['impact']['energy']}")
        print(f"  Impact on Time: {info['impact']['time']}")
        print(f"  Impact on Safety: {info['impact']['safety']}")