OTSClassifyEngineClr.cpp 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  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. }
  27. bool COTSClassifyEngineClr::ReloadEngineDB()
  28. {
  29. return engine->Init();
  30. }
  31. bool COTSClassifyEngineClr::ClassifyByExpression(COTSParticleClr^ particle)
  32. {
  33. auto part = particle->GetOTSParticlePtr();
  34. auto xraydata = part->GetXrayInfo();
  35. if (xraydata != nullptr)
  36. {
  37. return engine->ClassifyExpression(part, xraydata);
  38. }
  39. else
  40. {
  41. return false;
  42. }
  43. }
  44. bool COTSClassifyEngineClr::ClassifyBySpectrum(COTSParticleClr^ particle)
  45. {
  46. auto part = particle->GetOTSParticlePtr();
  47. auto xraydata = part->GetXrayInfo();
  48. if (xraydata != nullptr)
  49. {
  50. return engine->ClassifyBySpectrum(part, xraydata);
  51. }
  52. else
  53. {
  54. return false;
  55. }
  56. }
  57. bool COTSClassifyEngineClr::ClassifyByExpressionTemporarySpectrum(COTSParticleClr^ particle)
  58. {
  59. auto part = particle->GetOTSParticlePtr();
  60. auto xraydata = part->GetXrayInfo();
  61. if (xraydata != nullptr)
  62. {
  63. return engine->ClassifyByExpressionTemporarySpectrum(part, xraydata);
  64. }
  65. else
  66. {
  67. return false;
  68. }
  69. }
  70. bool COTSClassifyEngineClr::ClassifyIncA(COTSParticleClr^ particle, int SteelTech)
  71. {
  72. auto part = particle->GetOTSParticlePtr();
  73. auto xraydata = part->GetXrayInfo();
  74. return engine->ClassifyIncA(part, SteelTech, xraydata);
  75. }
  76. double COTSClassifyEngineClr::IfNeedMaxEDS(COTSParticleClr^ particle)
  77. {
  78. auto part = particle->GetOTSParticlePtr();
  79. auto xraydata = part->GetXrayInfo();
  80. double MaxEDSTime;
  81. engine->IfNeedMaxEDS(part, xraydata, MaxEDSTime);
  82. return MaxEDSTime;
  83. }
  84. bool COTSClassifyEngineClr::ZeroElementProcess(COTSParticleClr^ particle)
  85. {
  86. return engine->ZeroElementProcess(particle->GetOTSParticlePtr());
  87. }
  88. }