{"level": "INFO", "message": "PLC Generation Workflow started", "timestamp": "2025-09-01T16:24:08.690206", "module": "__main__", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "excel_file": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/PLC Data Generator/data/SAT9_MCM02.xlsx", "project_name": "SAT9_MCM02"} {"level": "INFO", "message": "Starting data processing step", "timestamp": "2025-09-01T16:24:08.690510", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} === Step 1: PLC Data Generator stdout === Loading IO path mappings... Loaded IO path mappings: APF: 11 rows M12DR: 16 rows Hub: 16 rows SorterHub: 16 rows SIO: 16 rows IB16: 16 rows OB16E: 16 rows IB16S: 16 rows Available sheets: ['NETWORK_PLC', 'DESC_PLC'] Found DESC sheet: DESC_PLC Found NETWORK sheet: NETWORK_PLC DESC columns: ['TAGNAME', 'TERM', 'DESCA', 'DESCB'] NETWORK columns: ['DPM', 'DPM_IP', 'Name', 'PartNumber', 'IP'] Classifying signals and adding IO paths... Signal classification results: SPARE: 516 I: 255 O: 52 IOLink: 13 Device type distribution: APF: 660 M12DR: 112 Hub: 16 IB16: 16 OB16E: 16 IB16S: 16 IO Path mapping results: Successful mappings: 836/836 (100.0%) Found 3 TAGNAMEs present in DESC but not in NETWORK_PLC. Adding unique DPM names not present in DESC or NETWORK_PLC.Name: ['DPM1_PS1_1', 'DPM1_PS1_4', 'DPM1_PS2_1', 'DPM2_PS1_1', 'DPM2_PS2_1'] ================================================================================ WARNING: The following issues were found but processing will continue: ================================================================================ - TAGNAME 'SLOT5_IB16' from DESC sheet not found in NETWORK_PLC sheet. - TAGNAME 'SLOT6_OB16E' from DESC sheet not found in NETWORK_PLC sheet. - TAGNAME 'SLOT7_IB16S' from DESC sheet not found in NETWORK_PLC sheet. ================================================================================ Continuing with processing... Normalizing TAGNAME, DESC, and IO_PATH columns for VFDs only in the final output... Removed 7 duplicate rows (exact matches) before saving DESC_IP sheet. Final result has 839 rows Sample of merged data: TAGNAME TERM DESCA ... SIGNAL DEVICE_TYPE IO_PATH 0 PDP2_PMM ... NaN NaN NaN 1 SLOT5_IB16 I0 MCM02 ... I IB16 Local:5:I.Data.0 2 SLOT5_IB16 I1 MCM02 ... I IB16 Local:5:I.Data.1 3 SLOT5_IB16 I10 SPARE ... SPARE IB16 Local:5:I.Data.10 4 SLOT5_IB16 I11 SPARE ... SPARE IB16 Local:5:I.Data.11 5 SLOT5_IB16 I12 SPARE ... SPARE IB16 Local:5:I.Data.12 6 SLOT5_IB16 I13 SPARE ... SPARE IB16 Local:5:I.Data.13 7 SLOT5_IB16 I14 SPARE ... SPARE IB16 Local:5:I.Data.14 8 SLOT5_IB16 I15 SPARE ... SPARE IB16 Local:5:I.Data.15 9 SLOT5_IB16 I2 MCM02 ... I IB16 Local:5:I.Data.2 [10 rows x 11 columns] New Excel file created: SAT9_MCM02_DESC_IP_MERGED.xlsx The file contains all original sheets plus the new 'DESC_IP' sheet with merged data. DEBUG: Processing Excel file: /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/PLC Data Generator/data/SAT9_MCM02.xlsx DEBUG: Full project pattern matched: SAT9_MCM02 DEBUG: Final subsystem name: SAT9_MCM02 Reading input file: SAT9_MCM02_DESC_IP_MERGED.xlsx Removed 13 IOLink rows (including beacons, FIOH channels, and all other IOLink entries) Removed 10 blank name/description rows Saving output file: SAT9_MCM02_OUTPUT.csv Processing complete! Created standard output file: DESC_IP_MERGED.xlsx === Step 1: PLC Data Generator stderr === === Step 1 File Copy === Copied SAT9_MCM02_DESC_IP_MERGED.xlsx to /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/DESC_IP_MERGED.xlsx {"level": "INFO", "message": "Data processing completed successfully", "timestamp": "2025-09-01T16:24:12.441166", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Starting routine generation step", "timestamp": "2025-09-01T16:24:12.441399", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Logging to file: /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/logs/workflow_SAT9_MCM02_20250901_162408.log", "timestamp": "2025-09-01T16:24:14.420956", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "=== Generating All PLC Artifacts ===", "timestamp": "2025-09-01T16:24:14.423110", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Generating SafetyProgram L5X...", "timestamp": "2025-09-01T16:24:14.423313", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "WARNING", "message": "LimitedSafetyProgramGenerator is deprecated; using ModernSafetyProgramGenerator", "timestamp": "2025-09-01T16:24:14.437406", "module": "src.container", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Starting ModernSafetyProgramGenerator generation", "timestamp": "2025-09-01T16:24:14.437681", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Creating SafetyProgram XML structure", "timestamp": "2025-09-01T16:24:14.437873", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Registered plugin: main_routine (core)", "timestamp": "2025-09-01T16:24:14.452337", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: apf (device)", "timestamp": "2025-09-01T16:24:14.459849", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: belt_tracking (device)", "timestamp": "2025-09-01T16:24:14.464546", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: cb_monitor (device)", "timestamp": "2025-09-01T16:24:14.469251", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: d2c_chute (device)", "timestamp": "2025-09-01T16:24:14.474112", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: dpm (device)", "timestamp": "2025-09-01T16:24:14.478621", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: encoder (device)", "timestamp": "2025-09-01T16:24:14.483484", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: estops (safety)", "timestamp": "2025-09-01T16:24:14.491902", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: estop_check (safety)", "timestamp": "2025-09-01T16:24:14.495857", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: extendo (device)", "timestamp": "2025-09-01T16:24:14.500178", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: fioh (device)", "timestamp": "2025-09-01T16:24:14.504272", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: fiom (device)", "timestamp": "2025-09-01T16:24:14.508376", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: flow_ctrl (device)", "timestamp": "2025-09-01T16:24:14.512293", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: fpe (device)", "timestamp": "2025-09-01T16:24:14.516300", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: inputs (safety)", "timestamp": "2025-09-01T16:24:14.520213", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: jpe (device)", "timestamp": "2025-09-01T16:24:14.524221", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: mcm (core)", "timestamp": "2025-09-01T16:24:14.528174", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: outputs (safety)", "timestamp": "2025-09-01T16:24:14.532080", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: pb_chute (device)", "timestamp": "2025-09-01T16:24:14.535987", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: pmm (device)", "timestamp": "2025-09-01T16:24:14.540038", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: rack (core)", "timestamp": "2025-09-01T16:24:14.543862", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: resets (safety)", "timestamp": "2025-09-01T16:24:14.547839", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: safety_tag_map (core)", "timestamp": "2025-09-01T16:24:14.551851", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: speed_ctrl (device)", "timestamp": "2025-09-01T16:24:14.555367", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: station_epc (safety)", "timestamp": "2025-09-01T16:24:14.558918", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: station_jr_chute (device)", "timestamp": "2025-09-01T16:24:14.562477", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: station_jr_pb (device)", "timestamp": "2025-09-01T16:24:14.566188", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: station_ss_pb (device)", "timestamp": "2025-09-01T16:24:14.569669", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: station_s_pb (device)", "timestamp": "2025-09-01T16:24:14.573313", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: taching_belts (device)", "timestamp": "2025-09-01T16:24:14.576997", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "DEBUG", "message": "Registered plugin: zones (safety)", "timestamp": "2025-09-01T16:24:14.581036", "module": "src.plugin_system", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "plugin_discovery"} {"level": "INFO", "message": "Generating safety routines...", "timestamp": "2025-09-01T16:24:14.581279", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: inputs", "timestamp": "2025-09-01T16:24:15.370841", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: inputs", "timestamp": "2025-09-01T16:24:15.378499", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: outputs", "timestamp": "2025-09-01T16:24:15.383792", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Zones: subsystem key", "timestamp": "2025-09-01T16:24:15.386517", "module": "src.data_loader", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "subsystem": "DEFAULT", "found": false} {"level": "DEBUG", "message": "Zones: heuristic best match", "timestamp": "2025-09-01T16:24:15.398355", "module": "src.data_loader", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "best_key": "MCM02", "score": 16} {"level": "DEBUG", "message": "Zones: loaded", "timestamp": "2025-09-01T16:24:15.399579", "module": "src.data_loader", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "rows": 9} {"level": "INFO", "message": "Successfully generated routine: outputs", "timestamp": "2025-09-01T16:24:15.401482", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: resets", "timestamp": "2025-09-01T16:24:15.401828", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: resets", "timestamp": "2025-09-01T16:24:15.405041", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: zones", "timestamp": "2025-09-01T16:24:15.405410", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Found DCS controllers for PS1_8: {'EPC2', 'EPC1'}", "timestamp": "2025-09-01T16:24:15.406726", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Found DCS controllers for PS2_7: {'EPC2', 'EPC1'}", "timestamp": "2025-09-01T16:24:15.407153", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Found DCS controllers for UL1_1: {'EPC2', 'EPC1'}", "timestamp": "2025-09-01T16:24:15.407545", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Found DCS controllers for UL2_2: {'ESTOP1'}", "timestamp": "2025-09-01T16:24:15.407827", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Found DCS controllers for UL3_2: {'ESTOP1'}", "timestamp": "2025-09-01T16:24:15.408070", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Found DCS controllers for UL4_2: {'ESTOP1'}", "timestamp": "2025-09-01T16:24:15.408350", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Found DCS controllers for UL5_2: {'ESTOP1'}", "timestamp": "2025-09-01T16:24:15.408608", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Found DCS controllers for UL6_1: {'EPC2', 'EPC1'}", "timestamp": "2025-09-01T16:24:15.408965", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Available DCS controllers: {'PS1_8': {'EPC2', 'EPC1'}, 'PS2_7': {'EPC2', 'EPC1'}, 'UL1_1': {'EPC2', 'EPC1'}, 'UL2_2': {'ESTOP1'}, 'UL3_2': {'ESTOP1'}, 'UL4_2': {'ESTOP1'}, 'UL5_2': {'ESTOP1'}, 'UL6_1': {'EPC2', 'EPC1'}}", "timestamp": "2025-09-01T16:24:15.409169", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Zone 02-01 candidates: ['PS1_1', 'PS1_2', 'PS1_3', 'PS1_4', 'PS1_5', 'PS1_6', 'PS1_7', 'PS1_8']", "timestamp": "2025-09-01T16:24:15.409847", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS1_1 in zone 02-01", "timestamp": "2025-09-01T16:24:15.410080", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS1_2 in zone 02-01", "timestamp": "2025-09-01T16:24:15.410256", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS1_3 in zone 02-01", "timestamp": "2025-09-01T16:24:15.410416", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS1_4 in zone 02-01", "timestamp": "2025-09-01T16:24:15.410569", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS1_5 in zone 02-01", "timestamp": "2025-09-01T16:24:15.410725", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS1_6 in zone 02-01", "timestamp": "2025-09-01T16:24:15.410903", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS1_7 in zone 02-01", "timestamp": "2025-09-01T16:24:15.411064", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Zones: rung", "timestamp": "2025-09-01T16:24:15.411266", "module": "src.routines.zones", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "zone": "02-01", "interlock": "MCM02", "dcs_list": ["PS1_8_EPC1_DCS_CTRL.O1", "PS1_8_EPC2_DCS_CTRL.O1"]} {"level": "DEBUG", "message": "Zone 02-02 candidates: ['UL1_1', 'UL1_2', 'UL1_3', 'UL1_4', 'UL1_5', 'UL1_6', 'UL1_7']", "timestamp": "2025-09-01T16:24:15.411652", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL1_2 in zone 02-02", "timestamp": "2025-09-01T16:24:15.411859", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL1_3 in zone 02-02", "timestamp": "2025-09-01T16:24:15.412016", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL1_4 in zone 02-02", "timestamp": "2025-09-01T16:24:15.412167", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL1_5 in zone 02-02", "timestamp": "2025-09-01T16:24:15.412317", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL1_6 in zone 02-02", "timestamp": "2025-09-01T16:24:15.412458", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL1_7 in zone 02-02", "timestamp": "2025-09-01T16:24:15.412614", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Zones: rung", "timestamp": "2025-09-01T16:24:15.412775", "module": "src.routines.zones", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "zone": "02-02", "interlock": "MCM02", "dcs_list": ["UL1_1_EPC1_DCS_CTRL.O1", "UL1_1_EPC2_DCS_CTRL.O1"]} {"level": "DEBUG", "message": "Zone 02-03 candidates: ['UL2_1', 'UL2_2', 'UL2_3', 'UL2_4', 'UL2_5', 'UL2_6', 'UL2_7', 'UL2_8', 'UL2_9']", "timestamp": "2025-09-01T16:24:15.413174", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL2_1 in zone 02-03", "timestamp": "2025-09-01T16:24:15.413386", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL2_3 in zone 02-03", "timestamp": "2025-09-01T16:24:15.413568", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL2_4 in zone 02-03", "timestamp": "2025-09-01T16:24:15.413718", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL2_5 in zone 02-03", "timestamp": "2025-09-01T16:24:15.413872", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL2_6 in zone 02-03", "timestamp": "2025-09-01T16:24:15.414019", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL2_7 in zone 02-03", "timestamp": "2025-09-01T16:24:15.414204", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL2_8 in zone 02-03", "timestamp": "2025-09-01T16:24:15.414383", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL2_9 in zone 02-03", "timestamp": "2025-09-01T16:24:15.414584", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Zones: rung", "timestamp": "2025-09-01T16:24:15.414764", "module": "src.routines.zones", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "zone": "02-03", "interlock": "MCM02", "dcs_list": ["UL2_2_ESTOP1_DCS_CTRL.O1"]} {"level": "DEBUG", "message": "Zone 02-04 candidates: ['UL3_1', 'UL3_2', 'UL3_3', 'UL3_4', 'UL3_5', 'UL3_6', 'UL3_7', 'UL3_8', 'UL3_9']", "timestamp": "2025-09-01T16:24:15.415123", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL3_1 in zone 02-04", "timestamp": "2025-09-01T16:24:15.415332", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL3_3 in zone 02-04", "timestamp": "2025-09-01T16:24:15.415493", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL3_4 in zone 02-04", "timestamp": "2025-09-01T16:24:15.415657", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL3_5 in zone 02-04", "timestamp": "2025-09-01T16:24:15.415825", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL3_6 in zone 02-04", "timestamp": "2025-09-01T16:24:15.415977", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL3_7 in zone 02-04", "timestamp": "2025-09-01T16:24:15.416118", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL3_8 in zone 02-04", "timestamp": "2025-09-01T16:24:15.416274", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL3_9 in zone 02-04", "timestamp": "2025-09-01T16:24:15.416454", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Zones: rung", "timestamp": "2025-09-01T16:24:15.416612", "module": "src.routines.zones", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "zone": "02-04", "interlock": "MCM02", "dcs_list": ["UL3_2_ESTOP1_DCS_CTRL.O1"]} {"level": "DEBUG", "message": "Zone 02-05 candidates: ['PS2_1', 'PS2_2', 'PS2_3', 'PS2_4', 'PS2_5', 'PS2_6', 'PS2_7']", "timestamp": "2025-09-01T16:24:15.416963", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS2_1 in zone 02-05", "timestamp": "2025-09-01T16:24:15.417135", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS2_2 in zone 02-05", "timestamp": "2025-09-01T16:24:15.417283", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS2_3 in zone 02-05", "timestamp": "2025-09-01T16:24:15.417457", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS2_4 in zone 02-05", "timestamp": "2025-09-01T16:24:15.417597", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS2_5 in zone 02-05", "timestamp": "2025-09-01T16:24:15.417745", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base PS2_6 in zone 02-05", "timestamp": "2025-09-01T16:24:15.417903", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Zones: rung", "timestamp": "2025-09-01T16:24:15.418063", "module": "src.routines.zones", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "zone": "02-05", "interlock": "MCM02", "dcs_list": ["PS2_7_EPC1_DCS_CTRL.O1", "PS2_7_EPC2_DCS_CTRL.O1"]} {"level": "DEBUG", "message": "Zone 02-06 candidates: ['UL4_1', 'UL4_2', 'UL4_3', 'UL4_4', 'UL4_5', 'UL4_6', 'UL4_7', 'UL4_8', 'UL4_9']", "timestamp": "2025-09-01T16:24:15.418394", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL4_1 in zone 02-06", "timestamp": "2025-09-01T16:24:15.418647", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL4_3 in zone 02-06", "timestamp": "2025-09-01T16:24:15.418820", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL4_4 in zone 02-06", "timestamp": "2025-09-01T16:24:15.418995", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL4_5 in zone 02-06", "timestamp": "2025-09-01T16:24:15.419154", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL4_6 in zone 02-06", "timestamp": "2025-09-01T16:24:15.419312", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL4_7 in zone 02-06", "timestamp": "2025-09-01T16:24:15.419494", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL4_8 in zone 02-06", "timestamp": "2025-09-01T16:24:15.419648", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL4_9 in zone 02-06", "timestamp": "2025-09-01T16:24:15.419798", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Zones: rung", "timestamp": "2025-09-01T16:24:15.419967", "module": "src.routines.zones", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "zone": "02-06", "interlock": "MCM02", "dcs_list": ["UL4_2_ESTOP1_DCS_CTRL.O1"]} {"level": "DEBUG", "message": "Zone 02-07 candidates: ['UL5_1', 'UL5_2', 'UL5_3', 'UL5_4', 'UL5_5', 'UL5_6', 'UL5_7', 'UL5_8', 'UL5_9']", "timestamp": "2025-09-01T16:24:15.420300", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL5_1 in zone 02-07", "timestamp": "2025-09-01T16:24:15.420478", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL5_3 in zone 02-07", "timestamp": "2025-09-01T16:24:15.420635", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL5_4 in zone 02-07", "timestamp": "2025-09-01T16:24:15.420800", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL5_5 in zone 02-07", "timestamp": "2025-09-01T16:24:15.421006", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL5_6 in zone 02-07", "timestamp": "2025-09-01T16:24:15.421200", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL5_7 in zone 02-07", "timestamp": "2025-09-01T16:24:15.421392", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL5_8 in zone 02-07", "timestamp": "2025-09-01T16:24:15.421556", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL5_9 in zone 02-07", "timestamp": "2025-09-01T16:24:15.421697", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Zones: rung", "timestamp": "2025-09-01T16:24:15.421875", "module": "src.routines.zones", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "zone": "02-07", "interlock": "MCM02", "dcs_list": ["UL5_2_ESTOP1_DCS_CTRL.O1"]} {"level": "DEBUG", "message": "Zone 02-08 candidates: ['UL6_1', 'UL6_2', 'UL6_3', 'UL6_4', 'UL6_5', 'UL6_6', 'UL6_7', 'UL6_8']", "timestamp": "2025-09-01T16:24:15.422349", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL6_2 in zone 02-08", "timestamp": "2025-09-01T16:24:15.422556", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL6_3 in zone 02-08", "timestamp": "2025-09-01T16:24:15.422892", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL6_4 in zone 02-08", "timestamp": "2025-09-01T16:24:15.423050", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL6_5 in zone 02-08", "timestamp": "2025-09-01T16:24:15.423233", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL6_6 in zone 02-08", "timestamp": "2025-09-01T16:24:15.423382", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL6_7 in zone 02-08", "timestamp": "2025-09-01T16:24:15.423557", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "No DCS controllers found for base UL6_8 in zone 02-08", "timestamp": "2025-09-01T16:24:15.423731", "module": "src.routines.zones", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Zones: rung", "timestamp": "2025-09-01T16:24:15.423880", "module": "src.routines.zones", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "zone": "02-08", "interlock": "MCM02", "dcs_list": ["UL6_1_EPC1_DCS_CTRL.O1", "UL6_1_EPC2_DCS_CTRL.O1"]} {"level": "INFO", "message": "Successfully generated routine: zones", "timestamp": "2025-09-01T16:24:15.424073", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: estops", "timestamp": "2025-09-01T16:24:15.424276", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: estops", "timestamp": "2025-09-01T16:24:15.426900", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Safety routine generation results: {'inputs': True, 'outputs': True, 'resets': True, 'zones': True, 'estops': True}", "timestamp": "2025-09-01T16:24:15.427109", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Added safety tag map with 5 tags", "timestamp": "2025-09-01T16:24:15.432106", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Routines created (6): MainRoutine, R010_INPUTS, R011_OUTPUTS, R012_RESETS, R020_ESTOPS, R030_ZONES", "timestamp": "2025-09-01T16:24:15.432336", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R010_INPUTS: 29 rungs | example: XIC(Local:7:I.Pt02.Status)XIC(Local:7:I.Pt03.Status)OTE(MCM_EPB_STATUS);", "timestamp": "2025-09-01T16:24:15.432517", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R011_OUTPUTS: 8 rungs | example: XIC(EStop_MCM_OK)XIC(EStop_02_01_OK)[OTE(PS1_1_VFD1:SO.STOOutput),OTE(PS1_2_VFD1:SO.STOOutput),OTE(PS1_3_VFD1:SO.STOOutput),OTE(PS1_4_VFD1:SO.STOOutput),OTE(...", "timestamp": "2025-09-01T16:24:15.432666", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R012_RESETS: 8 rungs | example: [XIC(SFT_PS1_8_S1_PB) ,XIC(SFT_MCM_S_PB)]OTE(RST_PS1_8_EPC1_ESTOP);", "timestamp": "2025-09-01T16:24:15.432825", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R030_ZONES: 9 rungs | example: XIC(PS1_8_EPC1_DCS_CTRL.O1)XIC(PS1_8_EPC2_DCS_CTRL.O1)OTE(EStop_02_01_OK);", "timestamp": "2025-09-01T16:24:15.433004", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R020_ESTOPS: 13 rungs | example: DCS(MCM_EPB_DCS_CTRL,EMERGENCY STOP,EQUIVALENT - ACTIVE HIGH,500,MANUAL,AUTOMATIC,Local:7:I.Pt02.Data,Local:7:I.Pt03.Data,MCM_EPB_STATUS,SFT_MCM_S_PB);", "timestamp": "2025-09-01T16:24:15.433181", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- MainRoutine: 1 rungs | example: [JSR(R010_INPUTS,0) ,JSR(R011_OUTPUTS,0) ,JSR(R012_RESETS,0) ,JSR(R020_ESTOPS,0) ,JSR(R030_ZONES,0) ];", "timestamp": "2025-09-01T16:24:15.433375", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "Successfully completed ModernSafetyProgramGenerator generation", "timestamp": "2025-09-01T16:24:15.433545", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Written ModernSafetyProgramGenerator to /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/SafetyProgram_Generated.L5X", "timestamp": "2025-09-01T16:24:15.436366", "module": "ModernSafetyProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "[SUCCESS] SafetyProgram written to /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/SafetyProgram_Generated.L5X", "timestamp": "2025-09-01T16:24:15.436579", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Generating MainProgram L5X...", "timestamp": "2025-09-01T16:24:15.436760", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "WARNING", "message": "LimitedMainProgramGenerator is deprecated; using ModernMainProgramGenerator", "timestamp": "2025-09-01T16:24:15.436929", "module": "src.container", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Starting ModernMainProgramGenerator generation", "timestamp": "2025-09-01T16:24:15.437133", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Creating MainProgram XML structure", "timestamp": "2025-09-01T16:24:15.437292", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Adding controller tags...", "timestamp": "2025-09-01T16:24:15.437497", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Zones: subsystem key", "timestamp": "2025-09-01T16:24:15.520635", "module": "src.data_loader", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "subsystem": "DEFAULT", "found": false} {"level": "DEBUG", "message": "Zones: heuristic best match", "timestamp": "2025-09-01T16:24:15.532044", "module": "src.data_loader", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "best_key": "MCM02", "score": 16} {"level": "DEBUG", "message": "Zones: loaded", "timestamp": "2025-09-01T16:24:15.532771", "module": "src.data_loader", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "rows": 9} {"level": "DEBUG", "message": "Extracting FPE data", "timestamp": "2025-09-01T16:24:15.683328", "module": "DataLoader", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "data_extraction", "type": "FPE"} {"level": "INFO", "message": "Data: FPE count=0", "timestamp": "2025-09-01T16:24:15.684138", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Extracting PMM data", "timestamp": "2025-09-01T16:24:15.684373", "module": "DataLoader", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "data_extraction", "type": "PMM"} {"level": "INFO", "message": "Data: PMM entries=1", "timestamp": "2025-09-01T16:24:15.685576", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "PMM processing PDP2_PMM", "timestamp": "2025-09-01T16:24:15.685874", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "PMM PDP2_PMM DPM=DPM2_PS2_1", "timestamp": "2025-09-01T16:24:15.686097", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "PMM PDP2_PMM PWM fault IO PDP2_FIOM1:I.Pt12.Data", "timestamp": "2025-09-01T16:24:15.686759", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "PMM PDP2_PMM configuration stored", "timestamp": "2025-09-01T16:24:15.686970", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Data: PMM configs=1", "timestamp": "2025-09-01T16:24:15.687170", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Extracting CB_MONITOR data", "timestamp": "2025-09-01T16:24:15.687376", "module": "DataLoader", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "data_extraction", "type": "CB_MONITOR"} {"level": "INFO", "message": "Data: CB PDPs=1", "timestamp": "2025-09-01T16:24:15.688825", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "CB_MONITOR PDP2: CBs=26 FIOs=2", "timestamp": "2025-09-01T16:24:15.689026", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "CB_MONITOR PDP2: configured CBs=26 positions=[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26] fault=PDP2_FIOH1:I.ConnectionFaulted", "timestamp": "2025-09-01T16:24:15.689254", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Data: CB configs=1", "timestamp": "2025-09-01T16:24:15.689460", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Tags created: total=311 | standard=17 safety=51 dcs=13 modules=222", "timestamp": "2025-09-01T16:24:15.690864", "module": "src.writers.xml_tag_writer", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "Added 311 controller tags", "timestamp": "2025-09-01T16:24:15.691150", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Generating main program routines...", "timestamp": "2025-09-01T16:24:15.691363", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: mcm", "timestamp": "2025-09-01T16:24:15.691590", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: mcm", "timestamp": "2025-09-01T16:24:15.691811", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: rack", "timestamp": "2025-09-01T16:24:15.692047", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: rack", "timestamp": "2025-09-01T16:24:15.692225", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: dpm", "timestamp": "2025-09-01T16:24:15.692443", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: dpm", "timestamp": "2025-09-01T16:24:15.694034", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: fiom", "timestamp": "2025-09-01T16:24:15.694281", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: fiom", "timestamp": "2025-09-01T16:24:15.695489", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: fioh", "timestamp": "2025-09-01T16:24:15.695702", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: fioh", "timestamp": "2025-09-01T16:24:15.696701", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: apf", "timestamp": "2025-09-01T16:24:15.697654", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: apf", "timestamp": "2025-09-01T16:24:15.700459", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: flow_ctrl", "timestamp": "2025-09-01T16:24:15.700962", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: flow_ctrl", "timestamp": "2025-09-01T16:24:15.702858", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Extracting SPEED_CTRL data", "timestamp": "2025-09-01T16:24:15.703086", "module": "DataLoader", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "data_extraction", "type": "SPEED_CTRL"} {"level": "INFO", "message": "Data: SPEED_CTRL VFDs=59", "timestamp": "2025-09-01T16:24:15.703501", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "SPEED_CTRL sample=PS1_1_VFD1, PS1_2_VFD1, PS1_3_VFD1, PS1_4_VFD1, PS1_5A_VFD1...", "timestamp": "2025-09-01T16:24:15.704499", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Data: SPEED_CTRL count=59", "timestamp": "2025-09-01T16:24:15.704690", "module": "DataLoader", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: speed_ctrl", "timestamp": "2025-09-01T16:24:15.704883", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: speed_ctrl", "timestamp": "2025-09-01T16:24:15.705157", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: estop_check", "timestamp": "2025-09-01T16:24:15.705364", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: estop_check", "timestamp": "2025-09-01T16:24:15.708556", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: safety_tag_map", "timestamp": "2025-09-01T16:24:15.708778", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Safety tag map: RST data has 7 rows", "timestamp": "2025-09-01T16:24:15.708989", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Added safety tag mapping: MCM02 -> Local:5:I.Data.0", "timestamp": "2025-09-01T16:24:15.709272", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Added safety tag mapping: PS1_8_S2_PB -> PS1_6_VFD1:I.IO_0", "timestamp": "2025-09-01T16:24:15.709532", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Added safety tag mapping: PS1_8_S1_PB -> PS1_8_VFD1:I.IO_0", "timestamp": "2025-09-01T16:24:15.709762", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Added safety tag mapping: PS2_7_S2_PB -> PS2_5_VFD1:I.IO_0", "timestamp": "2025-09-01T16:24:15.709995", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Added safety tag mapping: PS2_7_S1_PB -> PS2_7_VFD1:I.IO_0", "timestamp": "2025-09-01T16:24:15.710207", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Added safety tag mapping: UL1_1_SS1_STPB -> UL1_2_FIO1:I.Pt00.Data", "timestamp": "2025-09-01T16:24:15.710429", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Added safety tag mapping: UL6_1_SS1_STPB -> UL6_2_FIO1:I.Pt00.Data", "timestamp": "2025-09-01T16:24:15.710622", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Safety tag map: Generating 7 rungs", "timestamp": "2025-09-01T16:24:15.710805", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generated rung 1: XIC(Local:5:I.Data.0)OTE(MCM02);", "timestamp": "2025-09-01T16:24:15.710947", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generated rung 2: XIC(PS1_8_VFD1:I.IO_0)OTE(PS1_8_S1_PB);", "timestamp": "2025-09-01T16:24:15.711092", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generated rung 3: XIC(PS1_6_VFD1:I.IO_0)OTE(PS1_8_S2_PB);", "timestamp": "2025-09-01T16:24:15.711271", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generated rung 4: XIC(PS2_7_VFD1:I.IO_0)OTE(PS2_7_S1_PB);", "timestamp": "2025-09-01T16:24:15.711420", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generated rung 5: XIC(PS2_5_VFD1:I.IO_0)OTE(PS2_7_S2_PB);", "timestamp": "2025-09-01T16:24:15.711584", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generated rung 6: XIC(UL1_2_FIO1:I.Pt00.Data)OTE(UL1_1_SS1_STPB);", "timestamp": "2025-09-01T16:24:15.711728", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generated rung 7: XIC(UL6_2_FIO1:I.Pt00.Data)OTE(UL6_1_SS1_STPB);", "timestamp": "2025-09-01T16:24:15.711853", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Safety tag map: Generated 7 total rungs", "timestamp": "2025-09-01T16:24:15.711989", "module": "src.routines.safety_tag_map", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: safety_tag_map", "timestamp": "2025-09-01T16:24:15.712127", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: station_jr_pb", "timestamp": "2025-09-01T16:24:15.712269", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: station_jr_pb", "timestamp": "2025-09-01T16:24:15.712590", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Plugin station_ss_pb cannot generate with current data", "timestamp": "2025-09-01T16:24:15.712776", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: station_epc", "timestamp": "2025-09-01T16:24:15.712944", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: station_epc", "timestamp": "2025-09-01T16:24:15.713261", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: jpe", "timestamp": "2025-09-01T16:24:15.713458", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: jpe", "timestamp": "2025-09-01T16:24:15.714208", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Plugin fpe cannot generate with current data", "timestamp": "2025-09-01T16:24:15.714436", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: pmm", "timestamp": "2025-09-01T16:24:15.714645", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: pmm", "timestamp": "2025-09-01T16:24:15.714904", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: cb_monitor", "timestamp": "2025-09-01T16:24:15.715104", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: cb_monitor", "timestamp": "2025-09-01T16:24:15.715386", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: belt_tracking", "timestamp": "2025-09-01T16:24:15.715948", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: belt_tracking", "timestamp": "2025-09-01T16:24:15.717819", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Generating routine: main_routine", "timestamp": "2025-09-01T16:24:15.718045", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Generating MainRoutine with JSR calls", "timestamp": "2025-09-01T16:24:15.718240", "module": "src.routines.main_routine_plugin.MainRoutinePlugin", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated MainRoutine", "timestamp": "2025-09-01T16:24:15.718449", "module": "src.routines.main_routine_plugin.MainRoutinePlugin", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Successfully generated routine: main_routine", "timestamp": "2025-09-01T16:24:15.718616", "module": "src.plugin_system", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Main routine generation results: {'mcm': True, 'rack': True, 'dpm': True, 'fiom': True, 'fioh': True, 'apf': True, 'flow_ctrl': True, 'speed_ctrl': True, 'estop_check': True, 'safety_tag_map': True, 'station_jr_pb': True, 'station_ss_pb': False, 'station_epc': True, 'jpe': True, 'fpe': False, 'pmm': True, 'cb_monitor': True, 'belt_tracking': True, 'main_routine': True}", "timestamp": "2025-09-01T16:24:15.718808", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Routines created (17): MainRoutine, R010_MCM, R011_RACK, R020_DPM, R030_FIOM, R031_FIOH, R040_APF, R050_FLOW_CTRL, R051_SPEED_CTRL, R060_PMM, R070_CB_MONITOR, R090_STATION_JR_PB, R097_STATION_EPC, R100_JPE, R120_ESTOP_CHECK, R130_SAFETY_TAG_MAP, ZZZ_BeltTracking", "timestamp": "2025-09-01T16:24:15.719008", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R010_MCM: 2 rungs | example: NOP();", "timestamp": "2025-09-01T16:24:15.719176", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R011_RACK: 2 rungs | example: NOP();", "timestamp": "2025-09-01T16:24:15.719350", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R020_DPM: 6 rungs | example: NOP();", "timestamp": "2025-09-01T16:24:15.719521", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R030_FIOM: 8 rungs | example: NOP();", "timestamp": "2025-09-01T16:24:15.719670", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R031_FIOH: 2 rungs | example: NOP();", "timestamp": "2025-09-01T16:24:15.719811", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R040_APF: 60 rungs | example: NOP();", "timestamp": "2025-09-01T16:24:15.719985", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R050_FLOW_CTRL: 55 rungs | example: XIC(PS1_2_VFD1.CTRL.STS.Enabled)OTE(PS1_1_VFD1.CTRL.CMD.Interlock);", "timestamp": "2025-09-01T16:24:15.720201", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R051_SPEED_CTRL: 1 rungs | example: [MOVE(Speed_350_FPM,PS1_1_VFD1.CTRL.CMD.Speed_FPM) ,MOVE(Speed_350_FPM,PS1_2_VFD1.CTRL.CMD.Speed_FPM) ,MOVE(Speed_350_FPM,PS1_3_VFD1.CTRL.CMD.Speed_FPM) ,MOV...", "timestamp": "2025-09-01T16:24:15.720372", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R120_ESTOP_CHECK: 12 rungs | example: [XIO(PS1_8_VFD1:SI.In00Data) ,XIO(PS1_8_VFD1:SI.In01Data) ]XIO(PS1_1_VFD1:SO.STOOutput)XIO(PS1_2_VFD1:SO.STOOutput)XIO(PS1_3_VFD1:SO.STOOutput)XIO(PS1_4_VFD1...", "timestamp": "2025-09-01T16:24:15.720528", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R130_SAFETY_TAG_MAP: 8 rungs | example: XIC(Local:5:I.Data.0)OTE(MCM_S_PB);", "timestamp": "2025-09-01T16:24:15.720711", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R090_STATION_JR_PB: 10 rungs | example: AOI_STATION_JR_PB(PS1_1_JR1_PB.AOI,PS1_1_JR1_PB.HMI,PS1_1_JR1_PB.CTRL,NO_PARTNER,UL2_9_VFD1:I.IO_0,UL2_9_VFD1:O.IO_1)MOVE(PS1_1_JR1_PB.CTRL.STS.Log,PS1_1_JR1...", "timestamp": "2025-09-01T16:24:15.720879", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R097_STATION_EPC: 8 rungs | example: AOI_STATION_EPC(PS1_8_EPC1_STATION.AOI,MCM.CTRL,PS1_8_EPC1_STATION.HMI,PS1_8_S2_PB_STATION.CTRL,PS1_8_VFD1:I.ConnectionFaulted,PS1_8_VFD1:SI.In00Data,PS1_8_V...", "timestamp": "2025-09-01T16:24:15.721043", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R100_JPE: 67 rungs | example: AOI_JPE(PS1_1_TPE1.AOI,PS1_1_TPE1.HMI,PS1_1_TPE1.CTRL,PS1_1_VFD1.CTRL,PS1_1_JR1_PB.CTRL,UL1_7_VFD1:I.ConnectionFaulted,UL1_7_VFD1:I.In_2,YES,UL2_8_VFD1:O.IO_0);", "timestamp": "2025-09-01T16:24:15.721241", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R060_PMM: 2 rungs | example: NOP();", "timestamp": "2025-09-01T16:24:15.721442", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- R070_CB_MONITOR: 2 rungs | example: NOP();", "timestamp": "2025-09-01T16:24:15.721610", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- ZZZ_BeltTracking: 60 rungs | example: NOP();", "timestamp": "2025-09-01T16:24:15.721792", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "- MainRoutine: 1 rungs | example: [JSR(R010_MCM,0) ,JSR(R011_RACK,0) ,JSR(R020_DPM,0) ,JSR(R030_FIOM,0) ,JSR(R031_FIOH,0) ,JSR(R040_APF,0) ,JSR(R050_FLOW_CTRL,0) ,JSR(R051_SPEED_CTRL,0) ,JSR(...", "timestamp": "2025-09-01T16:24:15.721966", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "stage": "summary"} {"level": "INFO", "message": "Successfully completed ModernMainProgramGenerator generation", "timestamp": "2025-09-01T16:24:15.722146", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Written ModernMainProgramGenerator to /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/MainProgram_Generated.L5X", "timestamp": "2025-09-01T16:24:15.729605", "module": "ModernMainProgramGenerator", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "[SUCCESS] MainProgram written to /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/MainProgram_Generated.L5X", "timestamp": "2025-09-01T16:24:15.729791", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "Generating safety tag mapping...", "timestamp": "2025-09-01T16:24:15.729982", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Creating MappingWriter wrapper", "timestamp": "2025-09-01T16:24:15.730159", "module": "src.container", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "DEBUG", "message": "Creating DataLoader instance", "timestamp": "2025-09-01T16:24:15.730357", "module": "src.container", "file": "logging_config.py", "line": 126, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py", "excel_file": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/DESC_IP_MERGED.xlsx"} {"level": "INFO", "message": "[SUCCESS] Safety tag mapping written to /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/SafetyTagMapping.txt", "timestamp": "2025-09-01T16:24:15.807928", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": " - Safety tags: 5", "timestamp": "2025-09-01T16:24:15.808161", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} {"level": "INFO", "message": "=== All artifacts generated successfully! ===", "timestamp": "2025-09-01T16:24:15.808378", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} === Step 2: Routines Generator stdout === Found STATION_JR_PB config for PS1_1_JR1_PB Found STATION_JR_PB config for PS2_1_JR1_PB Found STATION_JR_PB config for PS2_1_JR2_PB Found STATION_JR_PB config for UL1_2_JR1_PB Found STATION_JR_PB config for UL2_3_JR1_PB Found STATION_JR_PB config for UL3_3_JR1_PB Found STATION_JR_PB config for UL4_3_JR1_PB Found STATION_JR_PB config for UL6_2_JR1_PB Found STATION_JR_PB config for UL5_3_JR1_PB Found STATION_JR_PB config for PS1_1_JR2_PB Found STATION_S_PB config for PS1_8_S2_PB Found STATION_S_PB config for PS1_8_S1_PB Found STATION_S_PB config for PS2_7_S2_PB Found STATION_S_PB config for PS2_7_S1_PB Found STATION_EPC config for PS1_8_EPC1 Found STATION_EPC config for PS2_7_EPC1 Found STATION_EPC config for UL1_1_EPC1 Found STATION_EPC config for UL6_1_EPC1 Found STATION_EPC config for PS1_8_EPC2 Found STATION_EPC config for PS2_7_EPC2 Found STATION_EPC config for UL1_1_EPC2 Found STATION_EPC config for UL6_1_EPC2 Found JPE config for PS1_4_TPE1 (missing station, missing beacon) Found JPE config for PS1_6_TPE1 (missing station, missing beacon) Found JPE config for PS1_6_TPE2 (missing station, missing beacon) Found JPE config for PS1_7_TPE1 (missing station, missing beacon) Found JPE config for PS1_8_TPE1 (missing station, missing beacon) Found JPE config for PS2_3_TPE1 (missing station, missing beacon) Found JPE config for PS2_3_TPE2 (missing station, missing beacon) Found JPE config for PS2_5_TPE1 (missing station, missing beacon) Found JPE config for PS2_5_TPE2 (missing station, missing beacon) Found JPE config for PS2_6_TPE1 (missing station, missing beacon) Found JPE config for PS2_7_TPE1 (missing station, missing beacon) Found JPE config for UL1_1_TPE1 (missing station, missing beacon) Found JPE config for UL1_4_TPE1 (missing station, missing beacon) Found JPE config for UL1_4_TPE2 (missing station, missing beacon) Found JPE config for UL1_5_TPE1 (missing station, missing beacon) Found JPE config for UL1_6_TPE1 (missing station, missing beacon) Found JPE config for PS1_1_TPE1 Found JPE config for UL2_5_TPE1 (missing station, missing beacon) Found JPE config for UL2_5_TPE2 (missing station, missing beacon) Found JPE config for UL2_6_TPE1 (missing station, missing beacon) Found JPE config for UL2_7_TPE1 (missing station, missing beacon) Found JPE config for UL2_8_TPE1 (missing station, missing beacon) Found JPE config for PS1_1_TPE2 Found JPE config for UL3_5_TPE1 (missing station, missing beacon) Found JPE config for UL3_5_TPE2 (missing station, missing beacon) Found JPE config for UL3_6_TPE1 (missing station, missing beacon) Found JPE config for UL3_7_TPE1 (missing station, missing beacon) Found JPE config for UL3_8_TPE1 (missing station, missing beacon) Found JPE config for PS1_1_TPE3 Found JPE config for UL4_5_TPE1 (missing station, missing beacon) Found JPE config for UL4_5_TPE2 (missing station, missing beacon) Found JPE config for UL4_6_TPE1 (missing station, missing beacon) Found JPE config for UL4_7_TPE1 (missing station, missing beacon) Found JPE config for PS2_1_TPE1 Found JPE config for UL5_5_TPE1 (missing station, missing beacon) Found JPE config for UL5_5_TPE2 (missing station, missing beacon) Found JPE config for UL5_6_TPE1 (missing station, missing beacon) Found JPE config for UL5_7_TPE1 (missing station, missing beacon) Found JPE config for UL5_8_TPE1 (missing station, missing beacon) Found JPE config for PS2_1_TPE2 Found JPE config for UL6_1_TPE1 (missing station, missing beacon) Found JPE config for UL6_4_TPE1 (missing station, missing beacon) Found JPE config for UL6_4_TPE2 (missing station, missing beacon) Found JPE config for UL6_5_TPE1 (missing station, missing beacon) Found JPE config for UL6_6_TPE1 (missing station, missing beacon) Found JPE config for UL6_7_TPE1 (missing station, missing beacon) Found JPE config for PS2_1_TPE3 Found JPE config for PS1_3_TPE1 (missing station, missing beacon) Found JPE config for UL1_2_TPE2 Found JPE config for UL2_3_TPE3 Found JPE config for UL3_3_TPE3 Found JPE config for UL4_3_TPE3 Found JPE config for UL6_2_TPE2 Found JPE config for PS1_3_TPE2 (missing station, missing beacon) Found JPE config for UL1_2_TPE1 Found JPE config for UL5_3_TPE3 (missing beacon) Found JPE config for UL6_2_TPE1 Found JPE config for PS1_1_TPE4 Found JPE config for PS2_1_TPE4 Found JPE config for UL2_3_TPE1 Found JPE config for UL2_3_TPE2 Found JPE config for UL3_3_TPE1 Found JPE config for UL3_3_TPE2 Found JPE config for UL4_3_TPE1 Found JPE config for UL4_3_TPE2 Found JPE config for UL5_3_TPE1 (missing beacon) Found JPE config for UL5_3_TPE2 (missing beacon) FIOM PDP2_FIOM1 -> DPM DPM2_PS2_1 FIOM UL1_2_FIO1 -> DPM DPM1_PS1_1 FIOM UL2_3_FIO1 -> DPM DPM1_PS1_1 FIOM UL3_3_FIO1 -> DPM DPM2_PS1_1 FIOM UL4_3_FIO1 -> DPM DPM1_PS2_1 FIOM UL5_3_FIO1 -> DPM DPM1_PS2_1 FIOM UL6_2_FIO1 -> DPM DPM2_PS2_1 FIOH PDP2_FIOH1 -> FIO PDP2_FIOM1 APF PS1_1_VFD1 -> DPM DPM2_PS1_1 APF PS1_2_VFD1 -> DPM DPM2_PS1_1 APF PS1_3_VFD1 -> DPM DPM1_PS1_4 APF PS1_4_VFD1 -> DPM DPM1_PS1_4 APF PS1_5A_VFD1 -> DPM DPM1_PS1_4 APF PS1_5B_VFD1 -> DPM DPM1_PS1_4 APF PS1_6_VFD1 -> DPM DPM1_PS1_4 APF PS1_7_VFD1 -> DPM DPM1_PS1_4 APF PS1_8_VFD1 -> DPM DPM1_PS1_4 APF PS2_1_VFD1 -> DPM DPM2_PS2_1 APF PS2_2_VFD1 -> DPM DPM2_PS2_1 APF PS2_3_VFD1 -> DPM DPM2_PS2_1 APF PS2_4A_VFD1 -> DPM DPM2_PS2_1 APF PS2_4B_VFD1 -> DPM DPM2_PS2_1 APF PS2_5_VFD1 -> DPM DPM2_PS2_1 APF PS2_6_VFD1 -> DPM DPM2_PS2_1 APF PS2_7_VFD1 -> DPM DPM2_PS2_1 APF UL1_1_VFD1 -> DPM DPM1_PS1_1 APF UL1_2_VFD1 -> DPM DPM1_PS1_1 APF UL1_3_VFD1 -> DPM DPM1_PS1_1 APF UL1_4_VFD1 -> DPM DPM1_PS1_1 APF UL1_5_VFD1 -> DPM DPM1_PS1_1 APF UL1_6_VFD1 -> DPM DPM1_PS1_1 APF UL1_7_VFD1 -> DPM DPM1_PS1_1 APF UL2_3_VFD1 -> DPM DPM1_PS1_1 APF UL2_4_VFD1 -> DPM DPM1_PS1_1 APF UL2_5_VFD1 -> DPM DPM1_PS1_1 APF UL2_6_VFD1 -> DPM DPM1_PS1_1 APF UL2_7_VFD1 -> DPM DPM1_PS1_1 APF UL2_8_VFD1 -> DPM DPM1_PS1_1 APF UL2_9_VFD1 -> DPM DPM1_PS1_1 APF UL3_3_VFD1 -> DPM DPM2_PS1_1 APF UL3_4_VFD1 -> DPM DPM2_PS1_1 APF UL3_5_VFD1 -> DPM DPM2_PS1_1 APF UL3_6_VFD1 -> DPM DPM2_PS1_1 APF UL3_7_VFD1 -> DPM DPM2_PS1_1 APF UL3_8_VFD1 -> DPM DPM2_PS1_1 APF UL3_9_VFD1 -> DPM DPM2_PS1_1 APF UL4_3_VFD1 -> DPM DPM1_PS2_1 APF UL4_4_VFD1 -> DPM DPM1_PS2_1 APF UL4_5_VFD1 -> DPM DPM1_PS2_1 APF UL4_6_VFD1 -> DPM DPM1_PS2_1 APF UL4_7_VFD1 -> DPM DPM1_PS2_1 APF UL4_8_VFD1 -> DPM DPM1_PS2_1 APF UL5_3_VFD1 -> DPM DPM1_PS2_1 APF UL5_4_VFD1 -> DPM DPM1_PS2_1 APF UL5_5_VFD1 -> DPM DPM1_PS2_1 APF UL5_6_VFD1 -> DPM DPM1_PS2_1 APF UL5_7_VFD1 -> DPM DPM1_PS2_1 APF UL5_8_VFD1 -> DPM DPM1_PS2_1 APF UL5_9_VFD1 -> DPM DPM1_PS2_1 APF UL6_1_VFD1 -> DPM DPM2_PS2_1 APF UL6_2_VFD1 -> DPM DPM2_PS2_1 APF UL6_3_VFD1 -> DPM DPM2_PS2_1 APF UL6_4_VFD1 -> DPM DPM2_PS2_1 APF UL6_5_VFD1 -> DPM DPM2_PS2_1 APF UL6_6_VFD1 -> DPM DPM2_PS2_1 APF UL6_7_VFD1 -> DPM DPM2_PS2_1 APF UL6_8_VFD1 -> DPM DPM2_PS2_1 - Added 12 E-stop check rungs [R090_STATION_JR_PB] Starting STATION_JR_PB routine generation... Found 10 STATION_JR_PB configurations Generated 10 STATION_JR_PB rungs [R0100_JPE] Starting JPE routine generation... Found 67 JPE configurations Generated 67 JPE rungs Belt tracking for PS1_1_VFD1 -> zzz_PS1_1Tracking Belt tracking for PS1_2_VFD1 -> zzz_PS1_2Tracking Belt tracking for PS1_3_VFD1 -> zzz_PS1_3Tracking Belt tracking for PS1_4_VFD1 -> zzz_PS1_4Tracking Belt tracking for PS1_5A_VFD1 -> zzz_PS1_5ATracking Belt tracking for PS1_5B_VFD1 -> zzz_PS1_5BTracking Belt tracking for PS1_6_VFD1 -> zzz_PS1_6Tracking Belt tracking for PS1_7_VFD1 -> zzz_PS1_7Tracking Belt tracking for PS1_8_VFD1 -> zzz_PS1_8Tracking Belt tracking for PS2_1_VFD1 -> zzz_PS2_1Tracking Belt tracking for PS2_2_VFD1 -> zzz_PS2_2Tracking Belt tracking for PS2_3_VFD1 -> zzz_PS2_3Tracking Belt tracking for PS2_4A_VFD1 -> zzz_PS2_4ATracking Belt tracking for PS2_4B_VFD1 -> zzz_PS2_4BTracking Belt tracking for PS2_5_VFD1 -> zzz_PS2_5Tracking Belt tracking for PS2_6_VFD1 -> zzz_PS2_6Tracking Belt tracking for PS2_7_VFD1 -> zzz_PS2_7Tracking Belt tracking for UL1_1_VFD1 -> zzz_UL1_1Tracking Belt tracking for UL1_2_VFD1 -> zzz_UL1_2Tracking Belt tracking for UL1_3_VFD1 -> zzz_UL1_3Tracking Belt tracking for UL1_4_VFD1 -> zzz_UL1_4Tracking Belt tracking for UL1_5_VFD1 -> zzz_UL1_5Tracking Belt tracking for UL1_6_VFD1 -> zzz_UL1_6Tracking Belt tracking for UL1_7_VFD1 -> zzz_UL1_7Tracking Belt tracking for UL2_3_VFD1 -> zzz_UL2_3Tracking Belt tracking for UL2_4_VFD1 -> zzz_UL2_4Tracking Belt tracking for UL2_5_VFD1 -> zzz_UL2_5Tracking Belt tracking for UL2_6_VFD1 -> zzz_UL2_6Tracking Belt tracking for UL2_7_VFD1 -> zzz_UL2_7Tracking Belt tracking for UL2_8_VFD1 -> zzz_UL2_8Tracking Belt tracking for UL2_9_VFD1 -> zzz_UL2_9Tracking Belt tracking for UL3_3_VFD1 -> zzz_UL3_3Tracking Belt tracking for UL3_4_VFD1 -> zzz_UL3_4Tracking Belt tracking for UL3_5_VFD1 -> zzz_UL3_5Tracking Belt tracking for UL3_6_VFD1 -> zzz_UL3_6Tracking Belt tracking for UL3_7_VFD1 -> zzz_UL3_7Tracking Belt tracking for UL3_8_VFD1 -> zzz_UL3_8Tracking Belt tracking for UL3_9_VFD1 -> zzz_UL3_9Tracking Belt tracking for UL4_3_VFD1 -> zzz_UL4_3Tracking Belt tracking for UL4_4_VFD1 -> zzz_UL4_4Tracking Belt tracking for UL4_5_VFD1 -> zzz_UL4_5Tracking Belt tracking for UL4_6_VFD1 -> zzz_UL4_6Tracking Belt tracking for UL4_7_VFD1 -> zzz_UL4_7Tracking Belt tracking for UL4_8_VFD1 -> zzz_UL4_8Tracking Belt tracking for UL5_3_VFD1 -> zzz_UL5_3Tracking Belt tracking for UL5_4_VFD1 -> zzz_UL5_4Tracking Belt tracking for UL5_5_VFD1 -> zzz_UL5_5Tracking Belt tracking for UL5_6_VFD1 -> zzz_UL5_6Tracking Belt tracking for UL5_7_VFD1 -> zzz_UL5_7Tracking Belt tracking for UL5_8_VFD1 -> zzz_UL5_8Tracking Belt tracking for UL5_9_VFD1 -> zzz_UL5_9Tracking Belt tracking for UL6_1_VFD1 -> zzz_UL6_1Tracking Belt tracking for UL6_2_VFD1 -> zzz_UL6_2Tracking Belt tracking for UL6_3_VFD1 -> zzz_UL6_3Tracking Belt tracking for UL6_4_VFD1 -> zzz_UL6_4Tracking Belt tracking for UL6_5_VFD1 -> zzz_UL6_5Tracking Belt tracking for UL6_6_VFD1 -> zzz_UL6_6Tracking Belt tracking for UL6_7_VFD1 -> zzz_UL6_7Tracking Belt tracking for UL6_8_VFD1 -> zzz_UL6_8Tracking - Added 59 belt tracking AOI calls Created safety tag mapping file: /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/SafetyTagMapping.txt === Step 2: Routines Generator stderr === [16:24:14] [INFO] [logging_config.py:128:_log_with_context] Logging to file: /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/logs/workflow_SAT9_MCM02_20250901_162408.log [16:24:14] [INFO] [logging_config.py:128:_log_with_context] === Generating All PLC Artifacts === [16:24:14] [INFO] [logging_config.py:128:_log_with_context] Generating SafetyProgram L5X... [16:24:14] [WARNING] [logging_config.py:128:_log_with_context] LimitedSafetyProgramGenerator is deprecated; using ModernSafetyProgramGenerator [16:24:14] [INFO] [logging_config.py:128:_log_with_context] Starting ModernSafetyProgramGenerator generation [16:24:14] [DEBUG] [logging_config.py:128:_log_with_context] Creating SafetyProgram XML structure [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: main_routine (core) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: apf (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: belt_tracking (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: cb_monitor (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: d2c_chute (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: dpm (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: encoder (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: estops (safety) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: estop_check (safety) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: extendo (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: fioh (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: fiom (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: flow_ctrl (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: fpe (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: inputs (safety) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: jpe (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: mcm (core) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: outputs (safety) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: pb_chute (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: pmm (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: rack (core) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: resets (safety) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: safety_tag_map (core) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: speed_ctrl (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: station_epc (safety) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: station_jr_chute (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: station_jr_pb (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: station_ss_pb (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: station_s_pb (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: taching_belts (device) [16:24:14] [DEBUG] [logging_config.py:126:_log_with_context] Registered plugin: zones (safety) [16:24:14] [INFO] [logging_config.py:128:_log_with_context] Generating safety routines... [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: inputs [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: inputs [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: outputs [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: subsystem key [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: heuristic best match [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: loaded [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: outputs [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: resets [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: resets [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: zones [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Found DCS controllers for PS1_8: {'EPC2', 'EPC1'} [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Found DCS controllers for PS2_7: {'EPC2', 'EPC1'} [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Found DCS controllers for UL1_1: {'EPC2', 'EPC1'} [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Found DCS controllers for UL2_2: {'ESTOP1'} [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Found DCS controllers for UL3_2: {'ESTOP1'} [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Found DCS controllers for UL4_2: {'ESTOP1'} [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Found DCS controllers for UL5_2: {'ESTOP1'} [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Found DCS controllers for UL6_1: {'EPC2', 'EPC1'} [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Available DCS controllers: {'PS1_8': {'EPC2', 'EPC1'}, 'PS2_7': {'EPC2', 'EPC1'}, 'UL1_1': {'EPC2', 'EPC1'}, 'UL2_2': {'ESTOP1'}, 'UL3_2': {'ESTOP1'}, 'UL4_2': {'ESTOP1'}, 'UL5_2': {'ESTOP1'}, 'UL6_1': {'EPC2', 'EPC1'}} [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Zone 02-01 candidates: ['PS1_1', 'PS1_2', 'PS1_3', 'PS1_4', 'PS1_5', 'PS1_6', 'PS1_7', 'PS1_8'] [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS1_1 in zone 02-01 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS1_2 in zone 02-01 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS1_3 in zone 02-01 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS1_4 in zone 02-01 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS1_5 in zone 02-01 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS1_6 in zone 02-01 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS1_7 in zone 02-01 [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: rung [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Zone 02-02 candidates: ['UL1_1', 'UL1_2', 'UL1_3', 'UL1_4', 'UL1_5', 'UL1_6', 'UL1_7'] [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL1_2 in zone 02-02 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL1_3 in zone 02-02 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL1_4 in zone 02-02 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL1_5 in zone 02-02 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL1_6 in zone 02-02 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL1_7 in zone 02-02 [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: rung [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Zone 02-03 candidates: ['UL2_1', 'UL2_2', 'UL2_3', 'UL2_4', 'UL2_5', 'UL2_6', 'UL2_7', 'UL2_8', 'UL2_9'] [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL2_1 in zone 02-03 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL2_3 in zone 02-03 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL2_4 in zone 02-03 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL2_5 in zone 02-03 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL2_6 in zone 02-03 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL2_7 in zone 02-03 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL2_8 in zone 02-03 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL2_9 in zone 02-03 [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: rung [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Zone 02-04 candidates: ['UL3_1', 'UL3_2', 'UL3_3', 'UL3_4', 'UL3_5', 'UL3_6', 'UL3_7', 'UL3_8', 'UL3_9'] [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL3_1 in zone 02-04 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL3_3 in zone 02-04 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL3_4 in zone 02-04 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL3_5 in zone 02-04 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL3_6 in zone 02-04 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL3_7 in zone 02-04 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL3_8 in zone 02-04 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL3_9 in zone 02-04 [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: rung [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Zone 02-05 candidates: ['PS2_1', 'PS2_2', 'PS2_3', 'PS2_4', 'PS2_5', 'PS2_6', 'PS2_7'] [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS2_1 in zone 02-05 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS2_2 in zone 02-05 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS2_3 in zone 02-05 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS2_4 in zone 02-05 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS2_5 in zone 02-05 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base PS2_6 in zone 02-05 [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: rung [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Zone 02-06 candidates: ['UL4_1', 'UL4_2', 'UL4_3', 'UL4_4', 'UL4_5', 'UL4_6', 'UL4_7', 'UL4_8', 'UL4_9'] [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL4_1 in zone 02-06 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL4_3 in zone 02-06 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL4_4 in zone 02-06 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL4_5 in zone 02-06 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL4_6 in zone 02-06 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL4_7 in zone 02-06 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL4_8 in zone 02-06 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL4_9 in zone 02-06 [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: rung [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Zone 02-07 candidates: ['UL5_1', 'UL5_2', 'UL5_3', 'UL5_4', 'UL5_5', 'UL5_6', 'UL5_7', 'UL5_8', 'UL5_9'] [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL5_1 in zone 02-07 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL5_3 in zone 02-07 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL5_4 in zone 02-07 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL5_5 in zone 02-07 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL5_6 in zone 02-07 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL5_7 in zone 02-07 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL5_8 in zone 02-07 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL5_9 in zone 02-07 [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: rung [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Zone 02-08 candidates: ['UL6_1', 'UL6_2', 'UL6_3', 'UL6_4', 'UL6_5', 'UL6_6', 'UL6_7', 'UL6_8'] [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL6_2 in zone 02-08 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL6_3 in zone 02-08 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL6_4 in zone 02-08 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL6_5 in zone 02-08 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL6_6 in zone 02-08 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL6_7 in zone 02-08 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] No DCS controllers found for base UL6_8 in zone 02-08 [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: rung [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: zones [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: estops [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: estops [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Safety routine generation results: {'inputs': True, 'outputs': True, 'resets': True, 'zones': True, 'estops': True} [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Added safety tag map with 5 tags [16:24:15] [INFO] [logging_config.py:126:_log_with_context] Routines created (6): MainRoutine, R010_INPUTS, R011_OUTPUTS, R012_RESETS, R020_ESTOPS, R030_ZONES [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R010_INPUTS: 29 rungs | example: XIC(Local:7:I.Pt02.Status)XIC(Local:7:I.Pt03.Status)OTE(MCM_EPB_STATUS); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R011_OUTPUTS: 8 rungs | example: XIC(EStop_MCM_OK)XIC(EStop_02_01_OK)[OTE(PS1_1_VFD1:SO.STOOutput),OTE(PS1_2_VFD1:SO.STOOutput),OTE(PS1_3_VFD1:SO.STOOutput),OTE(PS1_4_VFD1:SO.STOOutput),OTE(... [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R012_RESETS: 8 rungs | example: [XIC(SFT_PS1_8_S1_PB) ,XIC(SFT_MCM_S_PB)]OTE(RST_PS1_8_EPC1_ESTOP); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R030_ZONES: 9 rungs | example: XIC(PS1_8_EPC1_DCS_CTRL.O1)XIC(PS1_8_EPC2_DCS_CTRL.O1)OTE(EStop_02_01_OK); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R020_ESTOPS: 13 rungs | example: DCS(MCM_EPB_DCS_CTRL,EMERGENCY STOP,EQUIVALENT - ACTIVE HIGH,500,MANUAL,AUTOMATIC,Local:7:I.Pt02.Data,Local:7:I.Pt03.Data,MCM_EPB_STATUS,SFT_MCM_S_PB); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - MainRoutine: 1 rungs | example: [JSR(R010_INPUTS,0) ,JSR(R011_OUTPUTS,0) ,JSR(R012_RESETS,0) ,JSR(R020_ESTOPS,0) ,JSR(R030_ZONES,0) ]; [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully completed ModernSafetyProgramGenerator generation [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Written ModernSafetyProgramGenerator to /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/SafetyProgram_Generated.L5X [16:24:15] [INFO] [logging_config.py:128:_log_with_context] [SUCCESS] SafetyProgram written to /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/SafetyProgram_Generated.L5X [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Generating MainProgram L5X... [16:24:15] [WARNING] [logging_config.py:128:_log_with_context] LimitedMainProgramGenerator is deprecated; using ModernMainProgramGenerator [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Starting ModernMainProgramGenerator generation [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Creating MainProgram XML structure [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Adding controller tags... [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: subsystem key [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: heuristic best match [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Zones: loaded [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Extracting FPE data [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Data: FPE count=0 [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Extracting PMM data [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Data: PMM entries=1 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] PMM processing PDP2_PMM [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] PMM PDP2_PMM DPM=DPM2_PS2_1 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] PMM PDP2_PMM PWM fault IO PDP2_FIOM1:I.Pt12.Data [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] PMM PDP2_PMM configuration stored [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Data: PMM configs=1 [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Extracting CB_MONITOR data [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Data: CB PDPs=1 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] CB_MONITOR PDP2: CBs=26 FIOs=2 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] CB_MONITOR PDP2: configured CBs=26 positions=[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26] fault=PDP2_FIOH1:I.ConnectionFaulted [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Data: CB configs=1 [16:24:15] [INFO] [logging_config.py:126:_log_with_context] Tags created: total=311 | standard=17 safety=51 dcs=13 modules=222 [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Added 311 controller tags [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Generating main program routines... [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: mcm [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: mcm [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: rack [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: rack [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: dpm [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: dpm [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: fiom [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: fiom [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: fioh [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: fioh [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: apf [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: apf [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: flow_ctrl [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: flow_ctrl [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Extracting SPEED_CTRL data [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Data: SPEED_CTRL VFDs=59 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] SPEED_CTRL sample=PS1_1_VFD1, PS1_2_VFD1, PS1_3_VFD1, PS1_4_VFD1, PS1_5A_VFD1... [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Data: SPEED_CTRL count=59 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: speed_ctrl [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: speed_ctrl [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: estop_check [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: estop_check [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: safety_tag_map [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Safety tag map: RST data has 7 rows [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Added safety tag mapping: MCM02 -> Local:5:I.Data.0 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Added safety tag mapping: PS1_8_S2_PB -> PS1_6_VFD1:I.IO_0 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Added safety tag mapping: PS1_8_S1_PB -> PS1_8_VFD1:I.IO_0 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Added safety tag mapping: PS2_7_S2_PB -> PS2_5_VFD1:I.IO_0 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Added safety tag mapping: PS2_7_S1_PB -> PS2_7_VFD1:I.IO_0 [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Added safety tag mapping: UL1_1_SS1_STPB -> UL1_2_FIO1:I.Pt00.Data [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Added safety tag mapping: UL6_1_SS1_STPB -> UL6_2_FIO1:I.Pt00.Data [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Safety tag map: Generating 7 rungs [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generated rung 1: XIC(Local:5:I.Data.0)OTE(MCM02); [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generated rung 2: XIC(PS1_8_VFD1:I.IO_0)OTE(PS1_8_S1_PB); [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generated rung 3: XIC(PS1_6_VFD1:I.IO_0)OTE(PS1_8_S2_PB); [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generated rung 4: XIC(PS2_7_VFD1:I.IO_0)OTE(PS2_7_S1_PB); [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generated rung 5: XIC(PS2_5_VFD1:I.IO_0)OTE(PS2_7_S2_PB); [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generated rung 6: XIC(UL1_2_FIO1:I.Pt00.Data)OTE(UL1_1_SS1_STPB); [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generated rung 7: XIC(UL6_2_FIO1:I.Pt00.Data)OTE(UL6_1_SS1_STPB); [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Safety tag map: Generated 7 total rungs [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: safety_tag_map [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: station_jr_pb [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: station_jr_pb [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Plugin station_ss_pb cannot generate with current data [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: station_epc [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: station_epc [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: jpe [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: jpe [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Plugin fpe cannot generate with current data [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: pmm [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: pmm [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: cb_monitor [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: cb_monitor [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: belt_tracking [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: belt_tracking [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Generating routine: main_routine [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Generating MainRoutine with JSR calls [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated MainRoutine [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully generated routine: main_routine [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Main routine generation results: {'mcm': True, 'rack': True, 'dpm': True, 'fiom': True, 'fioh': True, 'apf': True, 'flow_ctrl': True, 'speed_ctrl': True, 'estop_check': True, 'safety_tag_map': True, 'station_jr_pb': True, 'station_ss_pb': False, 'station_epc': True, 'jpe': True, 'fpe': False, 'pmm': True, 'cb_monitor': True, 'belt_tracking': True, 'main_routine': True} [16:24:15] [INFO] [logging_config.py:126:_log_with_context] Routines created (17): MainRoutine, R010_MCM, R011_RACK, R020_DPM, R030_FIOM, R031_FIOH, R040_APF, R050_FLOW_CTRL, R051_SPEED_CTRL, R060_PMM, R070_CB_MONITOR, R090_STATION_JR_PB, R097_STATION_EPC, R100_JPE, R120_ESTOP_CHECK, R130_SAFETY_TAG_MAP, ZZZ_BeltTracking [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R010_MCM: 2 rungs | example: NOP(); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R011_RACK: 2 rungs | example: NOP(); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R020_DPM: 6 rungs | example: NOP(); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R030_FIOM: 8 rungs | example: NOP(); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R031_FIOH: 2 rungs | example: NOP(); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R040_APF: 60 rungs | example: NOP(); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R050_FLOW_CTRL: 55 rungs | example: XIC(PS1_2_VFD1.CTRL.STS.Enabled)OTE(PS1_1_VFD1.CTRL.CMD.Interlock); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R051_SPEED_CTRL: 1 rungs | example: [MOVE(Speed_350_FPM,PS1_1_VFD1.CTRL.CMD.Speed_FPM) ,MOVE(Speed_350_FPM,PS1_2_VFD1.CTRL.CMD.Speed_FPM) ,MOVE(Speed_350_FPM,PS1_3_VFD1.CTRL.CMD.Speed_FPM) ,MOV... [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R120_ESTOP_CHECK: 12 rungs | example: [XIO(PS1_8_VFD1:SI.In00Data) ,XIO(PS1_8_VFD1:SI.In01Data) ]XIO(PS1_1_VFD1:SO.STOOutput)XIO(PS1_2_VFD1:SO.STOOutput)XIO(PS1_3_VFD1:SO.STOOutput)XIO(PS1_4_VFD1... [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R130_SAFETY_TAG_MAP: 8 rungs | example: XIC(Local:5:I.Data.0)OTE(MCM_S_PB); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R090_STATION_JR_PB: 10 rungs | example: AOI_STATION_JR_PB(PS1_1_JR1_PB.AOI,PS1_1_JR1_PB.HMI,PS1_1_JR1_PB.CTRL,NO_PARTNER,UL2_9_VFD1:I.IO_0,UL2_9_VFD1:O.IO_1)MOVE(PS1_1_JR1_PB.CTRL.STS.Log,PS1_1_JR1... [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R097_STATION_EPC: 8 rungs | example: AOI_STATION_EPC(PS1_8_EPC1_STATION.AOI,MCM.CTRL,PS1_8_EPC1_STATION.HMI,PS1_8_S2_PB_STATION.CTRL,PS1_8_VFD1:I.ConnectionFaulted,PS1_8_VFD1:SI.In00Data,PS1_8_V... [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R100_JPE: 67 rungs | example: AOI_JPE(PS1_1_TPE1.AOI,PS1_1_TPE1.HMI,PS1_1_TPE1.CTRL,PS1_1_VFD1.CTRL,PS1_1_JR1_PB.CTRL,UL1_7_VFD1:I.ConnectionFaulted,UL1_7_VFD1:I.In_2,YES,UL2_8_VFD1:O.IO_0); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R060_PMM: 2 rungs | example: NOP(); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - R070_CB_MONITOR: 2 rungs | example: NOP(); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - ZZZ_BeltTracking: 60 rungs | example: NOP(); [16:24:15] [INFO] [logging_config.py:126:_log_with_context] - MainRoutine: 1 rungs | example: [JSR(R010_MCM,0) ,JSR(R011_RACK,0) ,JSR(R020_DPM,0) ,JSR(R030_FIOM,0) ,JSR(R031_FIOH,0) ,JSR(R040_APF,0) ,JSR(R050_FLOW_CTRL,0) ,JSR(R051_SPEED_CTRL,0) ,JSR(... [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Successfully completed ModernMainProgramGenerator generation [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Written ModernMainProgramGenerator to /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/MainProgram_Generated.L5X [16:24:15] [INFO] [logging_config.py:128:_log_with_context] [SUCCESS] MainProgram written to /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/MainProgram_Generated.L5X [16:24:15] [INFO] [logging_config.py:128:_log_with_context] Generating safety tag mapping... [16:24:15] [DEBUG] [logging_config.py:128:_log_with_context] Creating MappingWriter wrapper [16:24:15] [DEBUG] [logging_config.py:126:_log_with_context] Creating DataLoader instance [16:24:15] [INFO] [logging_config.py:128:_log_with_context] [SUCCESS] Safety tag mapping written to /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/SafetyTagMapping.txt [16:24:15] [INFO] [logging_config.py:128:_log_with_context] - Safety tags: 5 [16:24:15] [INFO] [logging_config.py:128:_log_with_context] === All artifacts generated successfully! === {"level": "INFO", "message": "Routine generation completed successfully", "timestamp": "2025-09-01T16:24:15.874078", "module": "__main__", "file": "logging_config.py", "line": 128, "function": "_log_with_context", "pathname": "/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/Routines Generator/src/logging_config.py"} === Step 3: IO Tree Generator stdout === Enhanced MCM Generator - Project: SAT9_MCM02 - Excel: /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/PLC Data Generator/DESC_IP_MERGED.xlsx - Boilerplate: SAT9_boilerplate - Mode: Single file -------------------------------------------------- Created 1 FIOH modules based on TERM analysis Found 7 IOLM modules Found 12 LPE modules Found 59 APF modules Found 5 DPM modules Found 1 PMM modules WARNING: 1 unknown modules found 1. UL2_2_EX1 - FMH (11.200.1.37) Created 7 IOLM modules with boilerplate selection: Device 'PDP2_FIOM1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) PDP2_FIOM1 (FIO PDP_FIO): Using variant boilerplate PDP_FIO_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/PDP_FIO_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/PDP_FIO_Module.L5X Device 'UL1_2_FIO1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) UL1_2_FIO1 (FIO D2CMaster): Using module-specific boilerplate UL1_2_FIO1_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/UL1_2_FIO1_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/UL1_2_FIO1_Module.L5X Device 'UL2_3_FIO1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) UL2_3_FIO1 (FIO D2CMaster): Using module-specific boilerplate UL2_3_FIO1_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/UL2_3_FIO1_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/UL2_3_FIO1_Module.L5X Device 'UL3_3_FIO1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) UL3_3_FIO1 (FIO D2CMaster): Using module-specific boilerplate UL3_3_FIO1_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/UL3_3_FIO1_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/UL3_3_FIO1_Module.L5X Device 'UL4_3_FIO1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) UL4_3_FIO1 (FIO D2CMaster): Using module-specific boilerplate UL4_3_FIO1_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/UL4_3_FIO1_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/UL4_3_FIO1_Module.L5X Device 'UL5_3_FIO1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) UL5_3_FIO1 (FIO D2CMaster): Using module-specific boilerplate UL5_3_FIO1_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/UL5_3_FIO1_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/UL5_3_FIO1_Module.L5X Device 'UL6_2_FIO1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) UL6_2_FIO1 (FIO D2CMaster): Using module-specific boilerplate UL6_2_FIO1_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/UL6_2_FIO1_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/UL6_2_FIO1_Module.L5X Device 'UL3_2_EX1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/EXTENDO_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/EXTENDO_Module.L5X Device 'UL4_2_EX1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/EXTENDO_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/EXTENDO_Module.L5X Device 'UL5_2_EX1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/EXTENDO_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/EXTENDO_Module.L5X Device 'PS1_1_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_7_5_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_7_5_HP.L5X Device 'PS1_2_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Device 'PS1_3_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Device 'PS1_4_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Device 'PS1_5A_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'PS1_5B_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'PS1_6_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'PS1_7_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'PS1_8_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'PS2_1_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_7_5_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_7_5_HP.L5X Device 'PS2_2_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Device 'PS2_3_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'PS2_4A_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'PS2_4B_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'PS2_5_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'PS2_6_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'PS2_7_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL1_1_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL1_2_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Device 'UL1_3_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Device 'UL1_4_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL1_5_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL1_6_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL1_7_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL2_3_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Device 'UL2_4_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Device 'UL2_5_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL2_6_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL2_7_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL2_8_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL2_9_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL3_3_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Device 'UL3_4_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Device 'UL3_5_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL3_6_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL3_7_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL3_8_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL3_9_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL4_3_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Device 'UL4_4_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Device 'UL4_5_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL4_6_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL4_7_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL4_8_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL5_3_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Device 'UL5_4_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Device 'UL5_5_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL5_6_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL5_7_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL5_8_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL5_9_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL6_1_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL6_2_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_5_HP.L5X Device 'UL6_3_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_3_HP.L5X Device 'UL6_4_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL6_5_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL6_6_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL6_7_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Device 'UL6_8_VFD1' matched no patterns, using fallback parent: SLOT2_EN4TR (Slot 2, IP 11.200.1.1) Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/APF_Module_2_HP.L5X Successfully loaded boilerplate: SAT9_boilerplate/PMM_Module.L5X PDP2_FIOH1 (FIOH PDP_FIOH): Using variant boilerplate PDP_FIOH_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/PDP_FIOH_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/PDP_FIOH_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/SLOT5_IB16_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/SLOT7_IB16S_Module.L5X Successfully loaded boilerplate: SAT9_boilerplate/SLOT6_OB16E_Module.L5X No EN4TR modules registered for creation Importing AOIs/DataTypes from base: /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/IO Tree Configuration Generator/BaseProgram.L5X Archived old L5X: SAT9_MCM02_20250901_161728.L5X Programs already exist (2 programs found), skipping empty program creation OK: Generated project: /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/SAT9_MCM02_20250901_162419.L5X Single file generation complete - ['/mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/SAT9_MCM02_20250901_162419.L5X'] === Step 3 Batch Script Creation === Creating project folder compilation for: SAT9_MCM02 Source L5X: /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02/SAT9_MCM02_20250901_162419.L5X Project directory: /mnt/c/Users/ilia.gurielidze/Projects/PLC Generation/generated_projects/SAT9_MCM02 Generated batch file: compile_SAT9_MCM02.bat SUCCESS: Project compilation ready! To compile on Windows: cd "C:\\Users\\ilia.gurielidze\\Projects\\PLC Generation\\generated_projects\\SAT9_MCM02" compile_SAT9_MCM02.bat