2024-11-25 14:01:09 +03:00
|
|
|
from __future__ import annotations
|
|
|
|
|
|
|
|
|
|
import os
|
2024-12-09 16:05:34 +03:00
|
|
|
from typing import Optional, Union, Any
|
|
|
|
|
from cachetools import LRUCache
|
2024-11-25 14:01:09 +03:00
|
|
|
|
|
|
|
|
import pandas as pd
|
|
|
|
|
from PyQt5.QtCore import QThread, QObject, QTimer
|
2024-11-25 17:20:00 +03:00
|
|
|
from PyQt5.QtWidgets import QWidget, QTabWidget
|
2024-12-09 16:05:34 +03:00
|
|
|
from PyQt5.QtOpenGL import QGLWidget
|
2024-12-05 13:18:53 +03:00
|
|
|
from OptAlgorithm import OptAlgorithm
|
2024-11-25 14:01:09 +03:00
|
|
|
import pandas as pd
|
2024-12-03 17:21:22 +03:00
|
|
|
import pandas as pd
|
|
|
|
|
import numpy as np
|
|
|
|
|
|
|
|
|
|
|
2024-11-25 14:01:09 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
class BaseMediator:
|
|
|
|
|
def __init__(self,
|
|
|
|
|
monitor: BaseDirectoryMonitor,
|
|
|
|
|
converter: BaseDataConverter,
|
2024-12-04 20:01:30 +03:00
|
|
|
passportFormer: BasePointPassportFormer,
|
2024-11-25 14:01:09 +03:00
|
|
|
plot: BasePlotWidget,
|
2024-11-26 18:16:55 +03:00
|
|
|
controller: BaseController):
|
2024-11-25 14:01:09 +03:00
|
|
|
self._monitor = monitor
|
|
|
|
|
self._monitor.mediator = self
|
|
|
|
|
self._converter = converter
|
|
|
|
|
self._converter.mediator = self
|
2024-12-04 20:01:30 +03:00
|
|
|
self._passportFormer = passportFormer
|
|
|
|
|
self._passportFormer.mediator = self
|
2024-11-25 14:01:09 +03:00
|
|
|
self._plot = plot
|
|
|
|
|
self._plot.mediator = self
|
|
|
|
|
self._controller = controller
|
2024-11-26 18:16:55 +03:00
|
|
|
self._controller.mediator = self
|
2024-11-25 14:01:09 +03:00
|
|
|
|
|
|
|
|
def notify(self,
|
2024-12-04 20:01:30 +03:00
|
|
|
source: Union[BaseDirectoryMonitor, BaseDataConverter, BasePointPassportFormer, BasePlotWidget],
|
|
|
|
|
data: Union[list[str], list[pd.DataFrame], list[list], list[QWidget]]):
|
2024-11-25 17:20:00 +03:00
|
|
|
...
|
|
|
|
|
def push_settings (self, data: list[dict]):
|
2024-11-25 14:01:09 +03:00
|
|
|
...
|
|
|
|
|
|
|
|
|
|
class BaseDirectoryMonitor:
|
|
|
|
|
|
|
|
|
|
update_timer = QTimer()
|
|
|
|
|
|
|
|
|
|
def __init__(self,
|
|
|
|
|
mediator: Optional[BaseMediator] = None):
|
|
|
|
|
super().__init__()
|
2024-11-25 17:20:00 +03:00
|
|
|
self._directory_path = None
|
|
|
|
|
self._update_time = None
|
2024-11-25 14:01:09 +03:00
|
|
|
|
|
|
|
|
self._mediator = mediator
|
2024-11-25 17:20:00 +03:00
|
|
|
|
2024-11-25 14:01:09 +03:00
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def directory_path(self) -> str:
|
|
|
|
|
return self._directory_path
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def update_time(self) -> int:
|
|
|
|
|
return self._update_time
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def files(self) -> list[str]:
|
|
|
|
|
return self._files
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def mediator(self) -> BaseMediator:
|
|
|
|
|
return self._mediator
|
|
|
|
|
|
|
|
|
|
@mediator.setter
|
|
|
|
|
def mediator(self, mediator: BaseMediator) -> None:
|
|
|
|
|
self._mediator = mediator
|
|
|
|
|
|
|
|
|
|
def _init_state(self):
|
|
|
|
|
files = os.listdir(self._directory_path)
|
|
|
|
|
self._files = files
|
|
|
|
|
|
|
|
|
|
def start(self):
|
2024-12-06 11:11:47 +03:00
|
|
|
self.update_timer.start(int(self._update_time))
|
2024-11-25 14:01:09 +03:00
|
|
|
|
2024-11-25 17:20:00 +03:00
|
|
|
def stop(self):
|
|
|
|
|
self.update_timer.stop()
|
|
|
|
|
|
|
|
|
|
def update_settings(self, data: list[dict]) -> None:
|
|
|
|
|
...
|
|
|
|
|
|
|
|
|
|
def force_all_dir(self):
|
|
|
|
|
...
|
|
|
|
|
|
2024-11-25 14:01:09 +03:00
|
|
|
class BaseDataConverter:
|
|
|
|
|
def __init__(self, mediator: Optional[BaseMediator] = None):
|
|
|
|
|
self._mediator = mediator
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def mediator(self) -> BaseMediator:
|
|
|
|
|
return self._mediator
|
|
|
|
|
|
|
|
|
|
@mediator.setter
|
|
|
|
|
def mediator(self, mediator: BaseMediator) -> None:
|
|
|
|
|
self._mediator = mediator
|
|
|
|
|
|
|
|
|
|
def convert_data(self, files: list[str]) -> None:
|
|
|
|
|
...
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class BasePlotWidget:
|
|
|
|
|
def __init__(self,
|
2024-11-25 17:20:00 +03:00
|
|
|
mediator: Optional[BaseMediator] = None):
|
2024-11-25 14:01:09 +03:00
|
|
|
super().__init__()
|
|
|
|
|
self._mediator = mediator
|
|
|
|
|
|
|
|
|
|
self._stage_colors = {
|
2024-12-09 19:54:08 +03:00
|
|
|
"Closing": [220, 20, 60, 100], # Crimson
|
|
|
|
|
"Squeeze": [30, 144, 255, 100], # Dodger Blue
|
|
|
|
|
"Welding": [128, 128, 128, 100], # Gray
|
|
|
|
|
"Relief": [34, 139, 34, 100], # Forest Green
|
|
|
|
|
"Oncomming": [255, 165, 0, 100] # Orange
|
|
|
|
|
}
|
2024-11-25 14:01:09 +03:00
|
|
|
self._plt_channels = {
|
|
|
|
|
"Electrode Force, N & Welding Current, kA": {
|
|
|
|
|
"Settings": {
|
|
|
|
|
"zoom": False,
|
2024-12-02 11:04:15 +03:00
|
|
|
"stages": True,
|
2024-12-04 20:01:30 +03:00
|
|
|
"performance": True,
|
2024-12-16 13:59:42 +03:00
|
|
|
"ideals": True,
|
2024-12-16 14:24:26 +03:00
|
|
|
"mirror ME": False,
|
|
|
|
|
"workpiece": False
|
2024-11-25 14:01:09 +03:00
|
|
|
},
|
|
|
|
|
"Real_signals": [
|
|
|
|
|
{
|
|
|
|
|
"name": "Electrode Force, N ME",
|
|
|
|
|
"pen": 'r',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
"name": "Electrode Force, N FE",
|
|
|
|
|
"pen": 'w',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
"name": "Welding Current ME",
|
|
|
|
|
"pen": "y",
|
|
|
|
|
}
|
|
|
|
|
],
|
|
|
|
|
"Ideal_signals": [
|
|
|
|
|
{
|
|
|
|
|
"name": "Force",
|
|
|
|
|
"pen": {'color': 'g', 'width':3},
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
},
|
2024-12-06 12:29:27 +03:00
|
|
|
"Electrode Position, mm": {
|
2024-11-25 14:01:09 +03:00
|
|
|
"Settings": {
|
2024-12-05 11:19:55 +03:00
|
|
|
"zoom": False,
|
|
|
|
|
"stages": True,
|
2024-12-04 20:01:30 +03:00
|
|
|
"performance": False,
|
2024-12-16 13:59:42 +03:00
|
|
|
"ideals": True,
|
2024-12-16 14:24:26 +03:00
|
|
|
"mirror ME": True,
|
|
|
|
|
"workpiece": True
|
2024-11-25 14:01:09 +03:00
|
|
|
},
|
|
|
|
|
"Real_signals": [
|
|
|
|
|
{
|
2024-12-05 11:19:55 +03:00
|
|
|
"name": "Rotor Position, mm ME",
|
2024-12-06 12:29:27 +03:00
|
|
|
"pen": {'color': 'r', 'width':2},
|
2024-11-25 14:01:09 +03:00
|
|
|
},
|
|
|
|
|
{
|
2024-12-05 11:19:55 +03:00
|
|
|
"name": "Rotor Position, mm FE",
|
2024-12-06 12:29:27 +03:00
|
|
|
"pen": {'color': 'w', 'width':2},
|
2024-11-25 14:01:09 +03:00
|
|
|
}
|
|
|
|
|
],
|
|
|
|
|
"Ideal_signals": [
|
|
|
|
|
{
|
2024-12-06 12:29:27 +03:00
|
|
|
"name": "Position ME",
|
|
|
|
|
"pen": {'color': 'g', 'width':4},
|
2024-12-05 11:19:55 +03:00
|
|
|
},
|
|
|
|
|
{
|
2024-12-06 12:29:27 +03:00
|
|
|
"name": "Position FE",
|
|
|
|
|
"pen": {'color': 'b', 'width':4},
|
2024-11-25 14:01:09 +03:00
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
},
|
|
|
|
|
"Electrode Speed, mm/s": {
|
|
|
|
|
"Settings": {
|
|
|
|
|
"zoom": False,
|
2024-12-02 11:04:15 +03:00
|
|
|
"stages": True,
|
2024-12-04 20:01:30 +03:00
|
|
|
"performance": False,
|
2024-12-16 13:59:42 +03:00
|
|
|
"ideals": True,
|
2024-12-16 14:24:26 +03:00
|
|
|
"mirror ME": False,
|
|
|
|
|
"workpiece": False
|
2024-11-25 14:01:09 +03:00
|
|
|
},
|
|
|
|
|
"Real_signals": [
|
|
|
|
|
{
|
|
|
|
|
"name": "Rotor Speed, mm/s ME",
|
|
|
|
|
"pen": 'r',
|
|
|
|
|
"zoom": False
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
"name": "Rotor Speed, mm/s FE",
|
|
|
|
|
"pen": 'w',
|
|
|
|
|
"zoom": False
|
|
|
|
|
}
|
|
|
|
|
],
|
|
|
|
|
"Ideal_signals": [
|
|
|
|
|
{
|
|
|
|
|
"name": "Rotor Speed ME",
|
2024-12-06 12:29:27 +03:00
|
|
|
"pen": {'color': 'g', 'width':3},
|
2024-11-25 14:01:09 +03:00
|
|
|
"zoom": False
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
"name": "Rotor Speed FE",
|
2024-12-06 12:29:27 +03:00
|
|
|
"pen": {'color': 'b', 'width':3},
|
2024-11-25 14:01:09 +03:00
|
|
|
"zoom": False
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
},
|
|
|
|
|
}
|
2024-12-09 19:54:08 +03:00
|
|
|
def set_style(self, object: Union[QTabWidget, QWidget]) -> None:
|
|
|
|
|
object.setStyleSheet(
|
|
|
|
|
"""QLabel {
|
|
|
|
|
color: #ffffff;
|
|
|
|
|
font-size: 26px;
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
font-family: "Segoe UI", sans-serif;
|
|
|
|
|
}""")
|
2024-12-03 17:21:22 +03:00
|
|
|
|
2024-11-25 14:01:09 +03:00
|
|
|
@property
|
|
|
|
|
def mediator(self) -> BaseMediator:
|
|
|
|
|
return self._mediator
|
|
|
|
|
|
|
|
|
|
@mediator.setter
|
|
|
|
|
def mediator(self, mediator: BaseMediator) -> None:
|
|
|
|
|
self._mediator = mediator
|
2024-11-25 17:20:00 +03:00
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def opt(self) -> BaseIdealDataBuilder:
|
|
|
|
|
return self._opt
|
|
|
|
|
|
|
|
|
|
@opt.setter
|
|
|
|
|
def opt(self, opt: BaseIdealDataBuilder):
|
|
|
|
|
self._opt = opt
|
2024-11-25 14:01:09 +03:00
|
|
|
|
|
|
|
|
def build(self, data: list[pd.DataFrame]) -> list[QWidget]:
|
|
|
|
|
...
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class BaseController(QObject):
|
|
|
|
|
|
|
|
|
|
def send_widgets(self, widgets: list[QWidget]) -> None:
|
|
|
|
|
...
|
|
|
|
|
|
2024-11-26 18:16:55 +03:00
|
|
|
def push_settings(self, settings: list[dict]) -> None:
|
|
|
|
|
...
|
2024-11-25 14:01:09 +03:00
|
|
|
|
2024-11-25 17:20:00 +03:00
|
|
|
|
2024-11-25 14:01:09 +03:00
|
|
|
class BaseIdealDataBuilder(OptAlgorithm):
|
2024-12-04 20:01:30 +03:00
|
|
|
|
2024-12-03 17:21:22 +03:00
|
|
|
def __init__(self, params: list[dict]):
|
|
|
|
|
operator_params, system_params = params
|
2024-11-25 17:20:00 +03:00
|
|
|
self.mul = system_params['time_capture']
|
2024-12-02 11:04:15 +03:00
|
|
|
self.welding_time = operator_params['time_wielding']
|
2024-11-25 17:20:00 +03:00
|
|
|
super().__init__(operator_params, system_params)
|
2024-12-09 16:05:34 +03:00
|
|
|
|
2024-11-25 14:01:09 +03:00
|
|
|
|
|
|
|
|
def _get_data(self, end_timestamp:float, func:function) -> pd.DataFrame:
|
|
|
|
|
data = []
|
|
|
|
|
for i in range (0, int(end_timestamp*self.mul)):
|
|
|
|
|
time = i/self.mul
|
|
|
|
|
X1, X2, V1, V2, F = func(time)
|
2024-12-06 12:29:27 +03:00
|
|
|
data.append({"time":time, "Position FE":X1*1000,"Position ME":X2*1000, "Rotor Speed FE":V1*1000, "Rotor Speed ME":V2*1000, "Force":F})
|
2024-11-25 14:01:09 +03:00
|
|
|
return pd.DataFrame(data)
|
|
|
|
|
|
|
|
|
|
def get_closingDF(self) -> pd.DataFrame:
|
2024-11-25 17:20:00 +03:00
|
|
|
...
|
2024-11-25 14:01:09 +03:00
|
|
|
|
|
|
|
|
def get_compressionDF(self) -> pd.DataFrame:
|
2024-11-25 17:20:00 +03:00
|
|
|
...
|
2024-11-25 14:01:09 +03:00
|
|
|
|
|
|
|
|
def get_openingDF(self) -> pd.DataFrame:
|
2024-11-25 17:20:00 +03:00
|
|
|
...
|
2024-11-25 14:01:09 +03:00
|
|
|
|
|
|
|
|
def get_tmovementDF(self) -> pd.DataFrame:
|
2024-11-25 17:20:00 +03:00
|
|
|
...
|
2024-11-25 14:01:09 +03:00
|
|
|
|
2024-12-02 11:04:15 +03:00
|
|
|
def get_weldingDF(self) -> pd.DataFrame:
|
2024-11-25 17:20:00 +03:00
|
|
|
...
|
2024-12-02 12:09:31 +03:00
|
|
|
|
|
|
|
|
def get_oncomingDF(self) -> pd.DataFrame:
|
|
|
|
|
...
|
2024-11-25 14:01:09 +03:00
|
|
|
|
|
|
|
|
def get_ideal_timings(self) -> list[float, float, float, float]:
|
2024-11-25 17:20:00 +03:00
|
|
|
...
|
|
|
|
|
|
2024-12-02 11:04:15 +03:00
|
|
|
def get_cycle_time(self) -> float:
|
|
|
|
|
result = sum(self.get_ideal_timings())
|
|
|
|
|
return result
|
2024-11-25 14:01:09 +03:00
|
|
|
|
2024-11-25 17:20:00 +03:00
|
|
|
class BaseMainWindow(QWidget):
|
|
|
|
|
def __init__(self,
|
2024-11-26 18:16:55 +03:00
|
|
|
controller: Optional[BaseController] = None):
|
2024-11-25 17:20:00 +03:00
|
|
|
super().__init__()
|
2024-11-26 18:16:55 +03:00
|
|
|
self._controller = controller
|
2024-11-26 18:28:05 +03:00
|
|
|
...
|
2024-11-25 17:20:00 +03:00
|
|
|
|
|
|
|
|
@property
|
2024-11-26 18:16:55 +03:00
|
|
|
def controller(self) -> BaseController:
|
|
|
|
|
return self._controller
|
2024-11-25 17:20:00 +03:00
|
|
|
|
2024-11-26 18:16:55 +03:00
|
|
|
@controller.setter
|
|
|
|
|
def controller(self, controller: BaseController) -> None:
|
|
|
|
|
self._controller = controller
|
2024-11-25 17:20:00 +03:00
|
|
|
|
|
|
|
|
def set_style(self, object: Union[QTabWidget, QWidget]) -> None:
|
|
|
|
|
object.setStyleSheet("""
|
|
|
|
|
QWidget {
|
|
|
|
|
background-color: #0D1117;
|
|
|
|
|
font-family: "Segoe UI", sans-serif;
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
}
|
|
|
|
|
QMessageBox {
|
|
|
|
|
background-color: #161B22;
|
|
|
|
|
font-family: "Segoe UI", sans-serif;
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
}
|
|
|
|
|
QPushButton {
|
|
|
|
|
background-color: #FFCC00;
|
|
|
|
|
color: #0D1117;
|
|
|
|
|
padding: 12px 25px;
|
|
|
|
|
border: 2px solid #E6B800;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
font-family: "Segoe UI", sans-serif;
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
}
|
|
|
|
|
QPushButton:hover:!disabled {
|
|
|
|
|
background-color: #FFD700;
|
|
|
|
|
}
|
|
|
|
|
QPushButton:disabled {
|
|
|
|
|
background-color: #555555;
|
|
|
|
|
color: #cccccc;
|
|
|
|
|
border: none;
|
|
|
|
|
}
|
|
|
|
|
QLabel {
|
|
|
|
|
color: #ffffff;
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
font-family: "Segoe UI", sans-serif;
|
|
|
|
|
}
|
2024-12-02 18:41:02 +03:00
|
|
|
""")
|
|
|
|
|
|
2024-12-03 17:21:22 +03:00
|
|
|
class BasePointPassportFormer:
|
2024-12-04 20:01:30 +03:00
|
|
|
|
|
|
|
|
def __init__(self,
|
|
|
|
|
mediator: Optional[BaseMediator] = None):
|
|
|
|
|
self._mediator = mediator
|
2024-12-03 17:21:22 +03:00
|
|
|
self._clear_stage = "Welding"
|
|
|
|
|
self._stages = [
|
|
|
|
|
"Closing",
|
|
|
|
|
"Squeeze",
|
|
|
|
|
"Welding",
|
2024-12-05 07:31:48 +03:00
|
|
|
"Relief",
|
|
|
|
|
"Oncomming"
|
2024-12-03 17:21:22 +03:00
|
|
|
]
|
2024-12-05 11:19:55 +03:00
|
|
|
self._tesla_stages = [
|
|
|
|
|
"Tesla squeeze",
|
|
|
|
|
"Tesla closing",
|
|
|
|
|
"Tesla welding",
|
|
|
|
|
"Tesla oncomming_relief"
|
|
|
|
|
]
|
2024-12-09 16:05:34 +03:00
|
|
|
self._params = []
|
|
|
|
|
self._ideal_data_cashe = LRUCache(maxsize=1000)
|
|
|
|
|
self._OptAlgorithm_operator_params = [
|
|
|
|
|
"dist_open_start_1",
|
|
|
|
|
"dist_open_start_2",
|
|
|
|
|
"dist_open_after_1",
|
|
|
|
|
"dist_open_after_2",
|
|
|
|
|
"dist_open_end_1",
|
|
|
|
|
"dist_open_end_2",
|
|
|
|
|
"dist_close_end_1",
|
|
|
|
|
"dist_close_end_2",
|
|
|
|
|
"time_command",
|
|
|
|
|
"time_robot_movement",
|
|
|
|
|
"object_thickness",
|
|
|
|
|
"force_target",
|
|
|
|
|
"force_capture",
|
|
|
|
|
"time_wielding"]
|
|
|
|
|
self._OptAlgorithm_system_params = [
|
|
|
|
|
"a_max_1",
|
|
|
|
|
"v_max_1",
|
|
|
|
|
"a_max_2",
|
|
|
|
|
"v_max_2",
|
|
|
|
|
"mass_1",
|
|
|
|
|
"mass_2",
|
|
|
|
|
"k_hardness_1",
|
|
|
|
|
"k_hardness_2",
|
|
|
|
|
"torque_max_1",
|
|
|
|
|
"torque_max_2",
|
|
|
|
|
"transmission_ratio_1",
|
|
|
|
|
"transmission_ratio_2",
|
|
|
|
|
"position_start_1",
|
|
|
|
|
"position_start_2",
|
|
|
|
|
"k_prop",
|
|
|
|
|
"time_capture"]
|
2024-12-03 17:21:22 +03:00
|
|
|
|
|
|
|
|
def _find_indexes(self,
|
|
|
|
|
signal: str,
|
2024-12-09 16:05:34 +03:00
|
|
|
dataframe: pd.DataFrame) -> tuple[np.ndarray, np.ndarray]:
|
2024-12-03 17:21:22 +03:00
|
|
|
stage_diff = np.diff(dataframe[signal])
|
|
|
|
|
start_idx = np.where(stage_diff == 1)
|
|
|
|
|
finish_idx = np.where(stage_diff == -1)
|
|
|
|
|
return start_idx[0], finish_idx[0]
|
|
|
|
|
|
|
|
|
|
def _find_events(self,
|
|
|
|
|
signal: str,
|
|
|
|
|
times:pd.Series,
|
2024-12-09 16:05:34 +03:00
|
|
|
dataframe: pd.DataFrame) -> tuple[list[float], list[float]]:
|
2024-12-03 17:21:22 +03:00
|
|
|
start_idx, finish_idx = self._find_indexes(signal, dataframe)
|
2024-12-09 16:05:34 +03:00
|
|
|
|
|
|
|
|
if len(start_idx) > 0 and len(finish_idx) > 0 and start_idx[0] > finish_idx[0]:
|
2024-12-05 13:27:54 +03:00
|
|
|
start_idx = np.insert(start_idx, 0, 0)
|
2024-12-09 16:05:34 +03:00
|
|
|
start_list = times.iloc[start_idx].tolist() if len(start_idx) > 0 else []
|
|
|
|
|
end_list = times.iloc[finish_idx].tolist() if len(finish_idx) > 0 else []
|
2024-12-03 17:21:22 +03:00
|
|
|
if len(start_list) - len(end_list) == 1:
|
2024-12-09 16:05:34 +03:00
|
|
|
end_list.append(float(times.iloc[-1]))
|
|
|
|
|
|
2024-12-03 17:21:22 +03:00
|
|
|
return start_list, end_list
|
|
|
|
|
|
|
|
|
|
def _filter_events(self,
|
|
|
|
|
times: pd.Series,
|
2024-12-09 16:05:34 +03:00
|
|
|
dataframe: pd.DataFrame) -> tuple[dict[str, list[list[float]]], int]:
|
2024-12-03 17:21:22 +03:00
|
|
|
events = {}
|
2024-12-09 16:05:34 +03:00
|
|
|
point_quantity = 0
|
2024-12-03 17:21:22 +03:00
|
|
|
if self._clear_stage in self._stages:
|
|
|
|
|
start_list, end_list = self._find_events(self._clear_stage, times, dataframe)
|
|
|
|
|
point_quantity = len(start_list)
|
2024-12-09 16:05:34 +03:00
|
|
|
if point_quantity == 0:
|
|
|
|
|
#TODO: добавить обработку исключения
|
|
|
|
|
return []
|
|
|
|
|
|
2024-12-03 17:21:22 +03:00
|
|
|
for stage in self._stages:
|
|
|
|
|
start_list, end_list = self._find_events(stage, times, dataframe)
|
2024-12-05 13:18:53 +03:00
|
|
|
temp = min([len(start_list), len(end_list)])
|
|
|
|
|
if temp < point_quantity:
|
2024-12-09 16:05:34 +03:00
|
|
|
print ("cant find enough", stage)
|
|
|
|
|
start_list += [0]*(point_quantity - temp)
|
|
|
|
|
end_list += [1]*(point_quantity - temp)
|
|
|
|
|
|
|
|
|
|
events[stage] = [start_list, end_list]
|
2024-12-04 20:01:30 +03:00
|
|
|
return events, point_quantity
|
2024-12-03 17:21:22 +03:00
|
|
|
|
2024-12-04 20:01:30 +03:00
|
|
|
def _build_ideal_data(self,
|
2024-12-03 17:21:22 +03:00
|
|
|
idealDataBuilder: Optional[BaseIdealDataBuilder] = None,
|
2024-12-09 16:05:34 +03:00
|
|
|
params: list[dict] = None) -> dict:
|
2024-12-03 17:21:22 +03:00
|
|
|
self.opt = idealDataBuilder(params)
|
2024-12-04 20:01:30 +03:00
|
|
|
stage_ideals = {
|
2024-12-03 17:21:22 +03:00
|
|
|
"Closing": self._opt.get_closingDF(),
|
|
|
|
|
"Squeeze": self._opt.get_compressionDF(),
|
|
|
|
|
"Welding": self._opt.get_weldingDF(),
|
|
|
|
|
"Relief": self._opt.get_openingDF(),
|
2024-12-04 20:01:30 +03:00
|
|
|
"Oncomming": self._opt.get_oncomingDF(),
|
2024-12-05 12:02:07 +03:00
|
|
|
"Ideal cycle": self._opt.get_cycle_time(),
|
|
|
|
|
"Ideal timings": self._opt.get_ideal_timings()
|
2024-12-03 17:21:22 +03:00
|
|
|
}
|
2024-12-04 20:01:30 +03:00
|
|
|
return stage_ideals
|
|
|
|
|
|
|
|
|
|
def form_passports(self) -> list[list[pd.DataFrame, dict, list]]:
|
|
|
|
|
...
|
2024-12-03 17:21:22 +03:00
|
|
|
|
2024-12-04 20:01:30 +03:00
|
|
|
def update_settings(self, params: list) -> None:
|
2024-12-03 17:21:22 +03:00
|
|
|
...
|
2024-12-04 20:01:30 +03:00
|
|
|
|
2024-12-09 16:05:34 +03:00
|
|
|
def _generate_cache_key(self,
|
|
|
|
|
params_list: list[dict[str, Any]]) -> tuple[tuple[tuple[str, Any], ...], tuple[tuple[str, Any], ...]]:
|
|
|
|
|
"""
|
|
|
|
|
Преобразует params_list в хешируемый ключ для кэша.
|
|
|
|
|
"""
|
|
|
|
|
operator_settings, system_settings = params_list
|
|
|
|
|
|
|
|
|
|
# Преобразуем словари в отсортированные кортежи пар ключ-значение
|
|
|
|
|
operator_tuple = frozenset((key, value)
|
|
|
|
|
for key, value in operator_settings.items()
|
|
|
|
|
if str(key) in self._OptAlgorithm_operator_params)
|
|
|
|
|
|
|
|
|
|
system_tuple = frozenset((key, value)
|
|
|
|
|
for key, value in system_settings.items()
|
|
|
|
|
if str(key) in self._OptAlgorithm_system_params)
|
|
|
|
|
return (operator_tuple, system_tuple)
|
2024-12-03 17:21:22 +03:00
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def opt(self) -> BaseIdealDataBuilder:
|
|
|
|
|
return self._opt
|
|
|
|
|
|
|
|
|
|
@opt.setter
|
|
|
|
|
def opt(self, opt: BaseIdealDataBuilder):
|
2024-12-04 20:01:30 +03:00
|
|
|
self._opt = opt
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def mediator(self) -> BaseMediator:
|
|
|
|
|
return self._mediator
|
|
|
|
|
|
|
|
|
|
@mediator.setter
|
|
|
|
|
def mediator(self, mediator: BaseMediator) -> None:
|
|
|
|
|
self._mediator = mediator
|