OTSClassifyEngineClr.cpp 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  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::ParticleClassifyEng:
  15. engine = GetParticleEngine(file).get();
  16. break;
  17. case EngineType::InclutionEng:
  18. engine = GetInclutionEngine().get();
  19. break;
  20. case EngineType::CurveCompare:
  21. engine = GetCurveCompareEngine(file).get();
  22. break;
  23. default:
  24. break;
  25. }
  26. }
  27. bool COTSClassifyEngineClr::Classify(COTSParticleClr^ particle)
  28. {
  29. auto part = particle->GetOTSParticlePtr();
  30. auto xraydata = part->GetXrayInfo();
  31. return engine->Classify(part, xraydata);
  32. }
  33. bool COTSClassifyEngineClr::Classify(COTSParticleClr^ particle, int SteelTech)
  34. {
  35. auto part = particle->GetOTSParticlePtr();
  36. auto xraydata = part->GetXrayInfo();
  37. return engine->Classify(part, SteelTech, xraydata);
  38. }
  39. double COTSClassifyEngineClr::IfNeedMaxEDS(COTSParticleClr^ particle)
  40. {
  41. auto part = particle->GetOTSParticlePtr();
  42. auto xraydata = part->GetXrayInfo();
  43. double MaxEDSTime;
  44. engine->IfNeedMaxEDS(part, xraydata, MaxEDSTime);
  45. return MaxEDSTime;
  46. }
  47. }