gtld2-diag-scripts/rolling bearing/defects/rb-rollers-fault.js

55 lines
3.0 KiB
JavaScript
Raw Normal View History

2023-11-26 11:50:07 +03:00
"use strict";
var imp = gtl.import("user-functions.js");
export function defect() {
let frq = imp.BSF(); //функциональная чатота
let num = 20; //количество отрисованных гармоник
//присваиваем набору гармоник переменную, добавляем гармоники: частота, кол-во (default = 10), цвет, вес.
var spen_BSF0 = spen.add_harms_set(frq, num, 0xff994000, 1); //раковины и сколы на телах качения "оранжевый"
for (let i = 0; i <= num - 1; i++) { spen_BSF0.harms[i].tolerance = (1 + i) * frq * imp.tolerance() };
spen_BSF0.name = 'Раковины и сколы на телах качения';
//добавляем модулирующие гармоники: частота, кол-во, цвет, вес
spen.harms_sets[8].modulate(imp.FTF(), 2, 0xff996000, 1); //модуляция Fтк +/- Fс "горчичный"
var ausp_BSF0 = ausp.add_harms_set(frq, num, 0xff994000, 2); //раковины и сколы на телах качения "оранжевый"
for (let i = 0; i <= num - 1; i++) { ausp_BSF0.harms[i].tolerance = (1 + i) * frq * imp.tolerance() };
ausp_BSF0.name = 'Раковины и сколы на телах качения';
//добавляем модулирующие гармоники: частота, кол-во, цвет, вес
ausp.harms_sets[3].modulate(imp.FTF(), 2, 0xff996000, 1); //модуляция Fтк +/- Fс "горчичный"
var Defect = false;
//вывод количества гармоник
//spen.harms_sets[0].get_count(1, 2, 1, true);
//1 - начало отсчета гармоники;
//2 - допуситмое количество пропущенных в ряду;
//3 - количество модулирующих с одной стороны;
//4 - модулирующие с двух сторон (true);
//раковины и сколы на телах качения
if (
spen.harms_sets[8].get_count(0, 1, 1) >= 3 &&
ausp.harms_sets[3].get_count(0, 3, 1) >= 3
) {
Defect = true;
Defect_type.push("Раковины и сколы на телах качения");
for (let i = 0; i <= num - 1; i++) {
if (spen_BSF0.harms[i].is_present == true)
gtl.log.info("Раковины и сколы на телах качения. Признаки в ES " + (i + 1) + "Fтк +/- Fс", imp.mod_factor(spen_BSF0.harms[i].amplitude, spen_BSF0.harms[i].base));
}
for (let i = 0; i <= num - 1; i++) {
if (ausp_BSF0.harms[i].is_present == true)
gtl.log.info("Раковины и сколы на телах качения. Признаки в AS " + (i + 1) + "Fтк +/- Fс", ausp_BSF0.harms[i].amplitude);
}
}
else
gtl.log.info("Раковины и сколы на телах качения", "Признаков дефекта не обнаружено");
return Defect;
};