OTSClassifyEngineClr.cpp 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. #include "stdafx.h"
  2. #include <msclr\marshal_cppstd.h>
  3. #include "OTSParticleClr.h"
  4. #include "PosXrayClr.h"
  5. #include "OTSClassifyEngineClr.h"
  6. namespace OTSCLRINTERFACE {
  7. using namespace msclr::interop;
  8. using namespace OTSCLRINTERFACE;
  9. COTSClassifyEngineClr::COTSClassifyEngineClr(EngineType engineType, System::String^ libFileName)
  10. {
  11. std::string file = marshal_as <std::string>(libFileName);
  12. switch (engineType)
  13. {
  14. case EngineType::ExpressionClassifyEng:
  15. engine = GetParticleEngine(file).get();
  16. break;
  17. case EngineType::InclutionEng:
  18. engine = GetInclutionEngine().get();
  19. break;
  20. case EngineType::SpectrumCompare:
  21. engine = GetCurveCompareEngine(file).get();
  22. break;
  23. default:
  24. break;
  25. }
  26. if (engine == NULL)
  27. {
  28. AfxMessageBox(_T("The ClassifyEng load failed!"));
  29. exit(1);
  30. }
  31. }
  32. bool COTSClassifyEngineClr::ReloadEngineDB()
  33. {
  34. return engine->Init();
  35. }
  36. bool COTSClassifyEngineClr::ClassifyByExpression(COTSParticleClr^ particle)
  37. {
  38. auto part = particle->GetOTSParticlePtr();
  39. auto xraydata = part->GetXrayInfo();
  40. return engine->ClassifyExpression(part, xraydata);
  41. }
  42. bool COTSClassifyEngineClr::ClassifyBySpectrum(COTSParticleClr^ particle)
  43. {
  44. auto part = particle->GetOTSParticlePtr();
  45. auto xraydata = part->GetXrayInfo();
  46. if (xraydata != nullptr)
  47. {
  48. return engine->ClassifyBySpectrum(part, xraydata);
  49. }
  50. else
  51. {
  52. return false;
  53. }
  54. }
  55. bool COTSClassifyEngineClr::ClassifyByExpressionTemporarySpectrum(COTSParticleClr^ particle)
  56. {
  57. auto part = particle->GetOTSParticlePtr();
  58. auto xraydata = part->GetXrayInfo();
  59. if (xraydata != nullptr)
  60. {
  61. return engine->ClassifyByExpressionTemporarySpectrum(part, xraydata);
  62. }
  63. else
  64. {
  65. return false;
  66. }
  67. }
  68. bool COTSClassifyEngineClr::ClassifyIncA(COTSParticleClr^ particle, int SteelTech)
  69. {
  70. auto part = particle->GetOTSParticlePtr();
  71. auto xraydata = part->GetXrayInfo();
  72. return engine->ClassifyIncA(part, SteelTech, xraydata);
  73. }
  74. bool COTSClassifyEngineClr::IfNeedMaxEDS(COTSParticleClr^ particle,double% maxedstime)
  75. {
  76. auto part = particle->GetOTSParticlePtr();
  77. auto xraydata = part->GetXrayInfo();
  78. double MaxEDSTime=0;
  79. bool rst= engine->IfNeedMaxEDS(part, xraydata, MaxEDSTime);
  80. if (rst)
  81. {
  82. maxedstime = MaxEDSTime;
  83. }
  84. return rst;
  85. }
  86. bool COTSClassifyEngineClr::ZeroElementProcess(COTSParticleClr^ particle)
  87. {
  88. return engine->ZeroElementProcess(particle->GetOTSParticlePtr());
  89. }
  90. }