SetPairAnalysis.cpp 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. #include "SetPairAnalysis.h"
  2. #include <QDebug>
  3. /********************************************************************
  4. *@Demo1归一化均值
  5. * QVector<SetPairAnalysis::EvaluateIndex> rMat;
  6. * rMat << SetPairAnalysis::EvaluateIndex { 70, 20, 10 };
  7. * rMat << SetPairAnalysis::EvaluateIndex { 70, 18, 12 };
  8. * QVector<qreal> wMat, eMat;
  9. * wMat << 1.0 << 0.5 << 1.0;
  10. * eMat << 1.0 << 1.0 << -1.0;
  11. * SetPairAnalysis spa(rMat, wMat, eMat);
  12. * SetPairAnalysis::Relations r = spa.getRelations();
  13. * qDebug() << r;
  14. *
  15. *@Demo2总体平衡均值
  16. * QVector<SetPairAnalysis::EvaluateIndex> rMat;
  17. * QVector<qreal> wMat, eMat;
  18. * rMat << SetPairAnalysis::EvaluateIndex { 2.5, 66, 80, 800 };
  19. * rMat << SetPairAnalysis::EvaluateIndex { 3.0, 79, 77, 810 };
  20. * rMat << SetPairAnalysis::EvaluateIndex { 3.5, 85, 90, 900 };
  21. * rMat << SetPairAnalysis::EvaluateIndex { 4.0, 98, 92, 920 };
  22. * rMat << SetPairAnalysis::EvaluateIndex { 3.5, 83, 88, 780 };
  23. * wMat << 0.3 << 0.5 << 0.15 << 0.05;
  24. * eMat << 1.0 << 1.0 << 1.0 << 1.0;
  25. * QVector<bool> dir;
  26. * dir << false << true << false << false;
  27. * SetPairAnalysis spa(rMat, wMat, eMat, dir);
  28. * SetPairAnalysis::Relations r = spa.getRelations();
  29. * qDebug() << r;
  30. *
  31. *
  32. ********************************************************************/
  33. SetPairAnalysis::SetPairAnalysis(const QVector<SetPairAnalysis::EvaluateIndex> &rMat, const QVector<qreal> &wMat,
  34. const QVector<qreal> &eMat, const QVector<bool> &optiDir)
  35. : m_rMat(rMat), m_wMat(wMat), m_eMat(eMat)
  36. {
  37. Q_ASSERT(rMat.count() != 0);
  38. Q_ASSERT(rMat.at(0).count() != 0);
  39. // Q_ASSERT(rMat.at(0).count() == wMat.count());
  40. if (optiDir.isEmpty()) {
  41. for (auto &r : m_rMat) {
  42. qreal sum = 0;
  43. for (int i = 0; i < r.count(); ++i) {
  44. sum += r.at(i);
  45. }
  46. for (int i = 0; i < r.count(); ++i) {
  47. r[i] = r[i] / sum;
  48. }
  49. }
  50. } else {
  51. EvaluateIndex optiIndex = EvaluateIndex(m_rMat.at(0).count());
  52. for (int r = 0; r < m_rMat.count(); ++r) {
  53. for (int i = 0; i < m_rMat.at(r).count(); ++i) {
  54. if (r == 0) {
  55. optiIndex[i] = m_rMat.at(r).at(i);
  56. } else {
  57. if (optiDir.at(i)) { //最大值
  58. if (optiIndex.at(i) < m_rMat.at(r).at(i)) {
  59. optiIndex[i] = m_rMat.at(r).at(i);
  60. }
  61. } else {
  62. if (optiIndex.at(i) > m_rMat.at(r).at(i)) {
  63. optiIndex[i] = m_rMat.at(r).at(i);
  64. }
  65. }
  66. }
  67. }
  68. }
  69. // qDebug() << optiIndex;
  70. for (auto &r : m_rMat) {
  71. for (int i = 0; i < r.count(); ++i) {
  72. if (optiDir.at(i)) { //最大值
  73. // qDebug() << r[i] << "/" << optiIndex.at(i);
  74. r[i] = r[i] / optiIndex.at(i);
  75. } else {
  76. // qDebug() << optiIndex.at(i) << "/" << r[i];
  77. r[i] = optiIndex.at(i) / r[i];
  78. }
  79. }
  80. // qDebug() << "next";
  81. }
  82. }
  83. // qDebug() << m_rMat;
  84. if (m_eMat.isEmpty()) {
  85. m_eMat = QVector<qreal>(m_wMat.count(), 1.0);
  86. }
  87. }
  88. SetPairAnalysis::Relations SetPairAnalysis::getRelations() const
  89. {
  90. Relations uMat;
  91. for (auto r : m_rMat) {
  92. qreal ui = 0;
  93. for (int i = 0; i < r.count(); ++i) {
  94. ui += r.at(i) * m_wMat.at(i) * m_eMat.at(i);
  95. }
  96. uMat << ui;
  97. }
  98. return uMat;
  99. }