123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- #include "view/MainWindow.h"
- #include "helper/GenerateMiniDump.h"
- #include <QApplication>
- #include <QTranslator>
- #include <QScreen>
- #include <QDesktopWidget>
- #include <QTextCodec>
- #include <locale>
- #include <QSettings>
- #include "FileUtil.h"
- #include "ImportDataUtil.h"
- #include "dbService/ClassSet.h"
- #include "algorithm/GreyClusterEvaluation.h"
- #include <algorithm/MatterElementAnalysis.h>
- #include <windows.h>
- void test()
- {
- MEAMat mat;
- MEARangeMat ranges;
- // 样本1
- mat << QVector<double> { 2, 35, 2, 90, 2.5, 35, 70, 2.5, 35, 30, 2.5, 70, 25, 2, 50, 1, 45, 8, 60, 1 };
- // 样本2
- mat << QVector<double> { 4, 20, 3, 40, 0.5, 55, 90, 1.2, 55, 70, 1.2, 90, 60, 6, 20, 3, 75, 25, 25, 3 };
- qDebug() << mat[0].size() << mat[1].size();
- // 等级1
- ranges << QVector<MEARange> {
- { 0, true, false, 0, 1 }, { 1, true, false, 50, 100 }, { 2, true, false, 0, 1 },
- { 3, true, false, 60, 100 }, { 4, true, false, 3, 100 }, { 5, true, false, 0, 30 },
- { 6, true, false, 0, 60 }, { 7, true, false, 0, 1 }, { 8, true, false, 0, 30 },
- { 9, true, false, 0, 60 }, { 10, true, false, 2, 100 }, { 11, true, false, 0, 60 },
- { 12, true, false, 0, 30 }, { 13, true, false, 0, 1 }, { 14, true, false, 60, 100 },
- { 15, true, false, 0, 1 }, { 16, true, false, 0, 30 }, { 17, true, false, 0, 5 },
- { 18, true, false, 50, 100 }, { 19, true, false, 0, 1 },
- };
- // 等级1
- ranges << QVector<MEARange> {
- { 0, true, false, 2, 3 }, { 1, true, false, 5, 100 }, { 2, true, false, 1, 2 },
- { 3, true, false, 45, 60 }, { 4, true, false, 2, 3 }, { 5, true, false, 30, 50 },
- { 6, true, false, 60, 80 }, { 7, true, false, 1, 1.5 }, { 8, true, false, 30, 50 },
- { 9, true, false, 60, 80 }, { 10, true, false, 1.5, 2 }, { 11, true, false, 60, 80 },
- { 12, true, false, 30, 50 }, { 13, true, false, 1, 3 }, { 14, true, false, 45, 60 },
- { 15, true, false, 1, 2 }, { 16, true, false, 30, 50 }, { 17, true, false, 5, 10 },
- { 18, true, false, 30, 50 }, { 19, true, false, 1, 2 },
- };
- ranges << QVector<MEARange> {
- { 1, true, false, 3, 4 }, { 1, true, false, 20, 30 }, { 2, true, false, 2, 3 },
- { 3, true, false, 30, 45 }, { 4, true, false, 1, 2 }, { 5, true, false, 50, 80 },
- { 6, true, false, 80, 95 }, { 7, true, false, 1.5, 2 }, { 8, true, false, 50, 80 },
- { 9, true, false, 80, 95 }, { 10, true, false, 1, 1.5 }, { 11, true, false, 80, 95 },
- { 12, true, false, 50, 80 }, { 13, true, false, 3, 5 }, { 14, true, false, 30, 45 },
- { 15, true, false, 2, 3 }, { 16, true, false, 50, 80 }, { 17, true, false, 10, 20 },
- { 18, true, false, 20, 30 }, { 19, true, false, 2, 3 },
- };
- // 2
- ranges << QVector<MEARange> {
- { 0, true, false, 5, 100 }, { 1, true, false, 0, 20 }, { 2, true, false, 3, 100 },
- { 3, true, false, 0, 30 }, { 4, true, false, 0, 1 }, { 5, true, false, 80, 100 },
- { 6, true, false, 95, 100 }, { 7, true, false, 2, 100 }, { 8, true, false, 80, 100 },
- { 9, true, false, 95, 100 }, { 10, true, false, 0, 1 }, { 11, true, false, 95, 100 },
- { 12, true, false, 80, 100 }, { 13, true, false, 5, 100 }, { 14, true, false, 0, 30 },
- { 15, true, false, 3, 100 }, { 16, true, false, 80, 100 }, { 17, true, false, 20, 100 },
- { 18, true, false, 0, 20 }, { 19, true, false, 3, 100 }
- };
- // 等级范围p
- ranges << QVector<MEARange> {
- { 0, true, false, 0, 140 }, { 1, true, false, 120, 0 }, { 2, true, false, 0, 140 },
- { 3, true, false, 140, 0 }, { 4, true, false, 140, 0 }, { 5, true, false, 0, 100 },
- { 6, true, false, 0, 100 }, { 7, true, false, 0, 140 }, { 8, true, false, 0, 100 },
- { 9, true, false, 0, 100 }, { 10, true, false, 0, 100 }, { 11, true, false, 0, 100 },
- { 12, true, false, 0, 100 }, { 13, true, false, 0, 140 }, { 14, true, false, 140, 0 },
- { 15, true, false, 0, 140 }, { 16, true, false, 0, 100 }, { 17, true, false, 0, 140 },
- { 18, true, false, 140, 0 }, { 19, true, false, 0, 140 },
- };
- // 等级
- MatterElementAnalysis me(mat, ranges);
- me.evaluate({ 0.05558152, 0.01462673, 0.12860136, 0.0567758, 0.02524748, 0.05098171, 0.31008254,
- 0.12573223, 0.01327194, 0.01461917, 0.01931854, 0.05014989, 0.06026197, 0.01258931,
- 0.0281506, 0.00588096, 0.01585843, 0.00331298, 0.00740806, 0.00154762 });
- QVector<int> index = me.getBestIndex();
- qDebug() << index;
- }
- void cTest() { }
- int main(int argc, char *argv[])
- {
- DUMP_FILE_HOOK_HANLE;
- QTextCodec::setCodecForLocale(QTextCodec::codecForName("UTF-8"));
- std::locale::global(std::locale(""));
- #ifndef QT_NO_OPENGL
- QCoreApplication::setAttribute(Qt::AA_ShareOpenGLContexts, true);
- #endif
- QCoreApplication::setAttribute(Qt::AA_DontCreateNativeWidgetSiblings, true);
- QCoreApplication::setAttribute(Qt::AA_DisableShaderDiskCache, true);
- // Set application attributes
- #if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
- QCoreApplication::setAttribute(Qt::AA_UseHighDpiPixmaps, true);
- QApplication::setAttribute(Qt::AA_EnableHighDpiScaling, true);
- #endif
- QCoreApplication::setAttribute(Qt::AA_CompressHighFrequencyEvents, true);
- QApplication a(argc, argv);
- a.setApplicationVersion("2.1");
- a.setApplicationName("QFD2");
- a.setApplicationDisplayName("伪装防护评估系统软件");
- Q_INIT_RESOURCE(qfluentwidgets);
- QTranslator *translator = new QTranslator();
- translator->load(QLocale::system(), ":/resource/i18n/qfluentwidgets_zh.qm");
- QCoreApplication::installTranslator(translator);
- MainWindow *w = new MainWindow;
- // test();
- // 居中显示窗体
- w->move((QApplication::primaryScreen()->availableGeometry().width() - w->width()) / 2,
- (QApplication::primaryScreen()->availableGeometry().height() - w->height()) / 2);
- QSettings config("config.ini", QSettings::IniFormat);
- config.setIniCodec("UTF-8");
- int roleType = config.value("USERCONFIG/RoleType", "").toInt();
- if (roleType == 0) {
- w->show();
- } else {
- qDebug() << "---------------------";
- // TODO 导入文件入库操作
- bool result = FileUtil().importEngineerFile();
- if (result) {
- ImportDataUtil().importSystemData();
- w->show();
- } else {
- delete w;
- qDebug() << "----";
- qApp->exit();
- }
- }
- // w.show();
- QFont font;
- font.setPointSize(14);
- a.setFont(font);
- setbuf(stdout, NULL);
- DWORD processId = GetCurrentProcessId();
- qDebug() << __FUNCTION__ << __LINE__ << processId << endl;
- printf("Process ID: %u\n", processId);
- int ret = a.exec();
- delete w;
- return ret;
- }
|