| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- #include "stdafx.h"
- #include <msclr\marshal_cppstd.h>
- #include "OTSParticleClr.h"
- #include "PosXrayClr.h"
- #include "OTSClassifyEngineClr.h"
- namespace OTSCLRINTERFACE {
- using namespace msclr::interop;
- using namespace OTSCLRINTERFACE;
- COTSClassifyEngineClr::COTSClassifyEngineClr(EngineType engineType, System::String^ libFileName)
- {
- std::string file = marshal_as <std::string>(libFileName);
- switch (engineType)
- {
- case EngineType::ParticleClassifyEng:
- engine = GetParticleEngine(file).get();
- break;
- case EngineType::InclutionEng:
- engine = GetInclutionEngine().get();
- break;
- case EngineType::CurveCompare:
- engine = GetCurveCompareEngine(file).get();
- break;
- default:
- break;
- }
- }
- bool COTSClassifyEngineClr::Classify(COTSParticleClr^ particle)
- {
- auto part = particle->GetOTSParticlePtr();
- auto xraydata = part->GetXrayInfo();
- return engine->Classify(part, xraydata);
-
- }
- bool COTSClassifyEngineClr::Classify(COTSParticleClr^ particle, int SteelTech)
- {
- auto part = particle->GetOTSParticlePtr();
- auto xraydata = part->GetXrayInfo();
- return engine->Classify(part, SteelTech, xraydata);
-
- }
- double COTSClassifyEngineClr::IfNeedMaxEDS(COTSParticleClr^ particle)
- {
- auto part = particle->GetOTSParticlePtr();
- auto xraydata = part->GetXrayInfo();
- double MaxEDSTime;
- engine->IfNeedMaxEDS(part, xraydata, MaxEDSTime);
- return MaxEDSTime;
- }
- }
|