import logging
import logging.config

def configure_logging(level=logging.INFO):
    config = {
        'version': 1,
        'disable_existing_loggers': False,
        'formatters': {
            'standard': {
                'format': '%(asctime)s [%(levelname)s] %(name)s: %(message)s'
            },
        },
        'handlers': {
            'default': {
                'level': level,
                'formatter': 'standard',
                'class': 'logging.StreamHandler',
                'stream': 'ext://sys.stdout',  # Default is stderr
            },
        },
        'loggers': {
            '': {  # root logger
                'handlers': ['default'],
                'level': level,
                'propagate': True
            },
            'aiva.frequency_scaling': {
                'handlers': ['default'],
                'level': level,
                'propagate': False
            },
        }
    }

    logging.config.dictConfig(config)

# Example usage (can be called from main script):
# configure_logging(level=logging.DEBUG)