123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- #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::ExpressionClassifyEng:
- engine = GetParticleEngine(file).get();
- break;
- case EngineType::InclutionEng:
- engine = GetInclutionEngine().get();
- break;
- case EngineType::SpectrumCompare:
- engine = GetCurveCompareEngine(file).get();
- break;
- default:
- break;
- }
- if (engine == NULL)
- {
- AfxMessageBox(_T("The ClassifyEng load failed!"));
- exit(1);
- }
- }
- bool COTSClassifyEngineClr::ReloadEngineDB()
- {
- return engine->Init();
-
- }
- bool COTSClassifyEngineClr::ClassifyByExpression(COTSParticleClr^ particle)
- {
- auto part = particle->GetOTSParticlePtr();
- auto xraydata = part->GetXrayInfo();
- if (xraydata != nullptr)
- {
- return engine->ClassifyExpression(part, xraydata);
- }
- else
- {
- return false;
- }
- }
- bool COTSClassifyEngineClr::ClassifyBySpectrum(COTSParticleClr^ particle)
- {
- auto part = particle->GetOTSParticlePtr();
- auto xraydata = part->GetXrayInfo();
- if (xraydata != nullptr)
- {
- return engine->ClassifyBySpectrum(part, xraydata);
- }
- else
- {
- return false;
- }
- }
- bool COTSClassifyEngineClr::ClassifyByExpressionTemporarySpectrum(COTSParticleClr^ particle)
- {
- auto part = particle->GetOTSParticlePtr();
- auto xraydata = part->GetXrayInfo();
- if (xraydata != nullptr)
- {
- return engine->ClassifyByExpressionTemporarySpectrum(part, xraydata);
- }
- else
- {
- return false;
- }
- }
- bool COTSClassifyEngineClr::ClassifyIncA(COTSParticleClr^ particle, int SteelTech)
- {
- auto part = particle->GetOTSParticlePtr();
-
- auto xraydata = part->GetXrayInfo();
-
- return engine->ClassifyIncA(part, SteelTech, xraydata);
-
- }
- bool COTSClassifyEngineClr::IfNeedMaxEDS(COTSParticleClr^ particle,double% maxedstime)
- {
- auto part = particle->GetOTSParticlePtr();
- auto xraydata = part->GetXrayInfo();
- double MaxEDSTime=0;
- bool rst= engine->IfNeedMaxEDS(part, xraydata, MaxEDSTime);
- if (rst)
- {
- maxedstime = MaxEDSTime;
- }
- return rst;
- }
- bool COTSClassifyEngineClr::ZeroElementProcess(COTSParticleClr^ particle)
- {
- return engine->ZeroElementProcess(particle->GetOTSParticlePtr());
-
- }
- }
|