added leverage slider
This commit is contained in:
@ -1,112 +1,112 @@
|
||||
#!/usr/bin/env python3
|
||||
"""
|
||||
Enhanced Scalping Dashboard Launcher
|
||||
# #!/usr/bin/env python3
|
||||
# """
|
||||
# Enhanced Scalping Dashboard Launcher
|
||||
|
||||
Features:
|
||||
- 1-second OHLCV bar charts instead of tick points
|
||||
- 15-minute server-side tick cache for model training
|
||||
- Enhanced volume visualization with buy/sell separation
|
||||
- Ultra-low latency WebSocket streaming
|
||||
- Real-time candle aggregation from tick data
|
||||
"""
|
||||
# Features:
|
||||
# - 1-second OHLCV bar charts instead of tick points
|
||||
# - 15-minute server-side tick cache for model training
|
||||
# - Enhanced volume visualization with buy/sell separation
|
||||
# - Ultra-low latency WebSocket streaming
|
||||
# - Real-time candle aggregation from tick data
|
||||
# """
|
||||
|
||||
import sys
|
||||
import logging
|
||||
import argparse
|
||||
from pathlib import Path
|
||||
# import sys
|
||||
# import logging
|
||||
# import argparse
|
||||
# from pathlib import Path
|
||||
|
||||
# Add project root to path
|
||||
project_root = Path(__file__).parent
|
||||
sys.path.insert(0, str(project_root))
|
||||
# # Add project root to path
|
||||
# project_root = Path(__file__).parent
|
||||
# sys.path.insert(0, str(project_root))
|
||||
|
||||
from web.enhanced_scalping_dashboard import EnhancedScalpingDashboard
|
||||
from core.data_provider import DataProvider
|
||||
from core.enhanced_orchestrator import EnhancedTradingOrchestrator
|
||||
# from web.enhanced_scalping_dashboard import EnhancedScalpingDashboard
|
||||
# from core.data_provider import DataProvider
|
||||
# from core.enhanced_orchestrator import EnhancedTradingOrchestrator
|
||||
|
||||
def setup_logging(level: str = "INFO"):
|
||||
"""Setup logging configuration"""
|
||||
log_level = getattr(logging, level.upper(), logging.INFO)
|
||||
# def setup_logging(level: str = "INFO"):
|
||||
# """Setup logging configuration"""
|
||||
# log_level = getattr(logging, level.upper(), logging.INFO)
|
||||
|
||||
logging.basicConfig(
|
||||
level=log_level,
|
||||
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
|
||||
handlers=[
|
||||
logging.StreamHandler(sys.stdout),
|
||||
logging.FileHandler('logs/enhanced_dashboard.log', mode='a')
|
||||
]
|
||||
)
|
||||
# logging.basicConfig(
|
||||
# level=log_level,
|
||||
# format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
|
||||
# handlers=[
|
||||
# logging.StreamHandler(sys.stdout),
|
||||
# logging.FileHandler('logs/enhanced_dashboard.log', mode='a')
|
||||
# ]
|
||||
# )
|
||||
|
||||
# Reduce noise from external libraries
|
||||
logging.getLogger('urllib3').setLevel(logging.WARNING)
|
||||
logging.getLogger('requests').setLevel(logging.WARNING)
|
||||
logging.getLogger('websockets').setLevel(logging.WARNING)
|
||||
# # Reduce noise from external libraries
|
||||
# logging.getLogger('urllib3').setLevel(logging.WARNING)
|
||||
# logging.getLogger('requests').setLevel(logging.WARNING)
|
||||
# logging.getLogger('websockets').setLevel(logging.WARNING)
|
||||
|
||||
def main():
|
||||
"""Main function to launch enhanced scalping dashboard"""
|
||||
parser = argparse.ArgumentParser(description='Enhanced Scalping Dashboard with 1s Bars and 15min Cache')
|
||||
parser.add_argument('--host', default='127.0.0.1', help='Host to bind to (default: 127.0.0.1)')
|
||||
parser.add_argument('--port', type=int, default=8051, help='Port to bind to (default: 8051)')
|
||||
parser.add_argument('--debug', action='store_true', help='Enable debug mode')
|
||||
parser.add_argument('--log-level', default='INFO', choices=['DEBUG', 'INFO', 'WARNING', 'ERROR'],
|
||||
help='Logging level (default: INFO)')
|
||||
# def main():
|
||||
# """Main function to launch enhanced scalping dashboard"""
|
||||
# parser = argparse.ArgumentParser(description='Enhanced Scalping Dashboard with 1s Bars and 15min Cache')
|
||||
# parser.add_argument('--host', default='127.0.0.1', help='Host to bind to (default: 127.0.0.1)')
|
||||
# parser.add_argument('--port', type=int, default=8051, help='Port to bind to (default: 8051)')
|
||||
# parser.add_argument('--debug', action='store_true', help='Enable debug mode')
|
||||
# parser.add_argument('--log-level', default='INFO', choices=['DEBUG', 'INFO', 'WARNING', 'ERROR'],
|
||||
# help='Logging level (default: INFO)')
|
||||
|
||||
args = parser.parse_args()
|
||||
# args = parser.parse_args()
|
||||
|
||||
# Setup logging
|
||||
setup_logging(args.log_level)
|
||||
logger = logging.getLogger(__name__)
|
||||
# # Setup logging
|
||||
# setup_logging(args.log_level)
|
||||
# logger = logging.getLogger(__name__)
|
||||
|
||||
try:
|
||||
logger.info("=" * 80)
|
||||
logger.info("ENHANCED SCALPING DASHBOARD STARTUP")
|
||||
logger.info("=" * 80)
|
||||
logger.info("Features:")
|
||||
logger.info(" - 1-second OHLCV bar charts (instead of tick points)")
|
||||
logger.info(" - 15-minute server-side tick cache for model training")
|
||||
logger.info(" - Enhanced volume visualization with buy/sell separation")
|
||||
logger.info(" - Ultra-low latency WebSocket streaming")
|
||||
logger.info(" - Real-time candle aggregation from tick data")
|
||||
logger.info("=" * 80)
|
||||
# try:
|
||||
# logger.info("=" * 80)
|
||||
# logger.info("ENHANCED SCALPING DASHBOARD STARTUP")
|
||||
# logger.info("=" * 80)
|
||||
# logger.info("Features:")
|
||||
# logger.info(" - 1-second OHLCV bar charts (instead of tick points)")
|
||||
# logger.info(" - 15-minute server-side tick cache for model training")
|
||||
# logger.info(" - Enhanced volume visualization with buy/sell separation")
|
||||
# logger.info(" - Ultra-low latency WebSocket streaming")
|
||||
# logger.info(" - Real-time candle aggregation from tick data")
|
||||
# logger.info("=" * 80)
|
||||
|
||||
# Initialize core components
|
||||
logger.info("Initializing data provider...")
|
||||
data_provider = DataProvider()
|
||||
# # Initialize core components
|
||||
# logger.info("Initializing data provider...")
|
||||
# data_provider = DataProvider()
|
||||
|
||||
logger.info("Initializing enhanced trading orchestrator...")
|
||||
orchestrator = EnhancedTradingOrchestrator(data_provider)
|
||||
# logger.info("Initializing enhanced trading orchestrator...")
|
||||
# orchestrator = EnhancedTradingOrchestrator(data_provider)
|
||||
|
||||
# Create enhanced dashboard
|
||||
logger.info("Creating enhanced scalping dashboard...")
|
||||
dashboard = EnhancedScalpingDashboard(
|
||||
data_provider=data_provider,
|
||||
orchestrator=orchestrator
|
||||
)
|
||||
# # Create enhanced dashboard
|
||||
# logger.info("Creating enhanced scalping dashboard...")
|
||||
# dashboard = EnhancedScalpingDashboard(
|
||||
# data_provider=data_provider,
|
||||
# orchestrator=orchestrator
|
||||
# )
|
||||
|
||||
# Launch dashboard
|
||||
logger.info(f"Launching dashboard at http://{args.host}:{args.port}")
|
||||
logger.info("Dashboard Features:")
|
||||
logger.info(" - Main chart: ETH/USDT 1s OHLCV bars with volume subplot")
|
||||
logger.info(" - Secondary chart: BTC/USDT 1s bars")
|
||||
logger.info(" - Volume analysis: Real-time volume comparison")
|
||||
logger.info(" - Tick cache: 15-minute rolling window for model training")
|
||||
logger.info(" - Trading session: $100 starting balance with P&L tracking")
|
||||
logger.info(" - System performance: Real-time callback monitoring")
|
||||
logger.info("=" * 80)
|
||||
# # Launch dashboard
|
||||
# logger.info(f"Launching dashboard at http://{args.host}:{args.port}")
|
||||
# logger.info("Dashboard Features:")
|
||||
# logger.info(" - Main chart: ETH/USDT 1s OHLCV bars with volume subplot")
|
||||
# logger.info(" - Secondary chart: BTC/USDT 1s bars")
|
||||
# logger.info(" - Volume analysis: Real-time volume comparison")
|
||||
# logger.info(" - Tick cache: 15-minute rolling window for model training")
|
||||
# logger.info(" - Trading session: $100 starting balance with P&L tracking")
|
||||
# logger.info(" - System performance: Real-time callback monitoring")
|
||||
# logger.info("=" * 80)
|
||||
|
||||
dashboard.run(
|
||||
host=args.host,
|
||||
port=args.port,
|
||||
debug=args.debug
|
||||
)
|
||||
# dashboard.run(
|
||||
# host=args.host,
|
||||
# port=args.port,
|
||||
# debug=args.debug
|
||||
# )
|
||||
|
||||
except KeyboardInterrupt:
|
||||
logger.info("Dashboard stopped by user (Ctrl+C)")
|
||||
except Exception as e:
|
||||
logger.error(f"Error running enhanced dashboard: {e}")
|
||||
logger.exception("Full traceback:")
|
||||
sys.exit(1)
|
||||
finally:
|
||||
logger.info("Enhanced Scalping Dashboard shutdown complete")
|
||||
# except KeyboardInterrupt:
|
||||
# logger.info("Dashboard stopped by user (Ctrl+C)")
|
||||
# except Exception as e:
|
||||
# logger.error(f"Error running enhanced dashboard: {e}")
|
||||
# logger.exception("Full traceback:")
|
||||
# sys.exit(1)
|
||||
# finally:
|
||||
# logger.info("Enhanced Scalping Dashboard shutdown complete")
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
# if __name__ == "__main__":
|
||||
# main()
|
||||
|
Reference in New Issue
Block a user