AIConvertHelper.cs 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587
  1. using System;
  2. using System.Collections.Generic;
  3. using Vinno.AI.CommonSDK.Enums;
  4. using Vinno.AI.CommonSDK.Interfaces;
  5. using Vinno.AI.CommonSDK.Models;
  6. using Vinno.AI.CommonSDK.Models.Contours;
  7. using Vinno.AI.CommonSDK.Models.Data;
  8. using Vinno.AI.CommonSDK.Models.Descriptions;
  9. using Vinno.AI.CommonSDK.Models.DetectedObjects;
  10. using Vinno.AI.CommonSDK.Models.Geomtries;
  11. using Vinno.AI.CommonSDK.Models.LabelExtraInfos;
  12. using Vinno.AI.CommonSDK.Models.LabelGroups;
  13. using Vinno.AI.CommonSDK.Models.Labels;
  14. using Vinno.AI.CommonSDK.Models.Measurements;
  15. using Vinno.AI.CommonSDK.Models.MeasureValues;
  16. using Vinno.AI.CommonSDK.Models.ResultDatas;
  17. using Vinno.AI.CommonSDK.Tools;
  18. using Vinno.AI.VetHeartDiagnosisSDK.Models;
  19. namespace Vinno.AI.VetHeartDiagnosisSDK.Tools
  20. {
  21. internal class AIConvertHelper
  22. {
  23. internal static IReadOnlyDictionary<AIImageDataId, IReadOnlyList<IAIResultData>> ConvertTransResultListToAIResultDict(List<TransAIResultInfo> transResultList)
  24. {
  25. if (transResultList == null)
  26. {
  27. return null;
  28. }
  29. Dictionary<AIImageDataId, IReadOnlyList<IAIResultData>> result = new Dictionary<AIImageDataId, IReadOnlyList<IAIResultData>>();
  30. foreach (var item in transResultList)
  31. {
  32. AIImageDataId imageDataId = ConvertTransAIDataIdsToAIImageDataId(item.DataId);
  33. if (imageDataId == null)
  34. {
  35. continue;
  36. }
  37. List<IAIResultData> resultDataList = new List<IAIResultData>();
  38. if (item.ResultDatas != null)
  39. {
  40. foreach (var resultItem in item.ResultDatas)
  41. {
  42. var resultData = ConvertTransAIResultDatasToIAIResultData(resultItem);
  43. if (resultData != null)
  44. {
  45. resultDataList.Add(resultData);
  46. }
  47. }
  48. }
  49. result.Add(imageDataId, resultDataList);
  50. }
  51. return result;
  52. }
  53. private static AIImageDataId ConvertTransAIDataIdsToAIImageDataId(TransAIDataIds item)
  54. {
  55. if (item == null)
  56. {
  57. return null;
  58. }
  59. switch (item.DataIdType)
  60. {
  61. case AIEnumDataIdType.ImageDataId:
  62. return item.ImageDataId;
  63. default:
  64. return null;
  65. }
  66. }
  67. private static IAIResultData ConvertTransAIResultDatasToIAIResultData(TransAIResultDatas transAIResultDatas)
  68. {
  69. if (transAIResultDatas == null)
  70. {
  71. return null;
  72. }
  73. switch (transAIResultDatas.ResultDataType)
  74. {
  75. case AIEnumResultDataType.RecognizedObjectsPerLabelGroup:
  76. var transAIRecognizedObjectsPerLabelGroup = transAIResultDatas.RecognizedObjectsPerLabelGroup;
  77. return ConvertTransAIRecognizedObjectsPerLabelGroupToAIRecognizedObjectsPerLabelGroup(transAIRecognizedObjectsPerLabelGroup);
  78. case AIEnumResultDataType.VetHeartLVArea:
  79. var transAIVetHeartLVArea = transAIResultDatas.VetHeartLVArea;
  80. return ConvertTransAIVetHeartLVAreaToAIVetHeartLVArea(transAIVetHeartLVArea);
  81. case AIEnumResultDataType.VetBRecognizedCardiacCycle:
  82. var transVetBRecognizedCardiacCycle = transAIResultDatas.VetBRecognizedCardiacCycle;
  83. return ConvertTransAIVetBRecognizedCardiacCycleToAIVetBRecognizedCardiacCycle(transVetBRecognizedCardiacCycle);
  84. default:
  85. return null;
  86. }
  87. }
  88. private static AIRecognizedObjectsPerLabelGroup ConvertTransAIRecognizedObjectsPerLabelGroupToAIRecognizedObjectsPerLabelGroup(TransAIRecognizedObjectsPerLabelGroup transAIRecognizedObjectsPerLabelGroup)
  89. {
  90. if (transAIRecognizedObjectsPerLabelGroup == null)
  91. {
  92. return null;
  93. }
  94. var labelGroup = ConvertTransAILabelGroupsToIAILabelGroup(transAIRecognizedObjectsPerLabelGroup.LabelGroup);
  95. IAIDetectedObject[] detectedObjectList;
  96. if (transAIRecognizedObjectsPerLabelGroup.DetectedObjects == null)
  97. {
  98. detectedObjectList = null;
  99. }
  100. else
  101. {
  102. detectedObjectList = new IAIDetectedObject[transAIRecognizedObjectsPerLabelGroup.DetectedObjects.Count];
  103. int index = 0;
  104. foreach (var transDetectedObject in transAIRecognizedObjectsPerLabelGroup.DetectedObjects)
  105. {
  106. var detectedObject = ConvertTransAIDetectedObjectsToIAIDetectedObject(transDetectedObject);
  107. detectedObjectList[index] = detectedObject;
  108. index++;
  109. }
  110. }
  111. return new AIRecognizedObjectsPerLabelGroup(labelGroup, detectedObjectList);
  112. }
  113. private static IAILabelGroup ConvertTransAILabelGroupsToIAILabelGroup(TransAILabelGroups transLabelGroup)
  114. {
  115. if (transLabelGroup == null)
  116. {
  117. return null;
  118. }
  119. switch (transLabelGroup.LabelGroupType)
  120. {
  121. case AIEnumILabelGroupType.LabelGroup:
  122. return ConvertTransAILabelGroupToAILabelGroup(transLabelGroup.LabelGroup);
  123. default:
  124. return null;
  125. }
  126. }
  127. private static AILabelGroup ConvertTransAILabelGroupToAILabelGroup(TransAILabelGroup transLabelGroup)
  128. {
  129. if (transLabelGroup == null)
  130. {
  131. return null;
  132. }
  133. var name = transLabelGroup.Name;
  134. List<IAILabel> labels = new List<IAILabel>();
  135. if (transLabelGroup.Labels != null)
  136. {
  137. labels = new List<IAILabel>();
  138. foreach (var transLabel in transLabelGroup.Labels)
  139. {
  140. var label = ConvertTransAILabelsToIAILabel(transLabel);
  141. if (label != null)
  142. {
  143. labels.Add(label);
  144. }
  145. }
  146. }
  147. List<Type> validLabelExtraInfoTypes;
  148. if (transLabelGroup.ValidLabelExtraInfoTypes == null)
  149. {
  150. validLabelExtraInfoTypes = null;
  151. }
  152. else
  153. {
  154. validLabelExtraInfoTypes = new List<Type>();
  155. foreach (var extraInfoType in transLabelGroup.ValidLabelExtraInfoTypes)
  156. {
  157. switch (extraInfoType)
  158. {
  159. case AIEnumLabelExtraInfoType.LesionMalignantDegreeLabelExtraInfo:
  160. validLabelExtraInfoTypes.Add(typeof(AILesionMalignantDegreeLabelExtraInfo));
  161. break;
  162. case AIEnumLabelExtraInfoType.LesionInvolvedScopeLabelExtraInfo:
  163. validLabelExtraInfoTypes.Add(typeof(AILesionInvolvedScopeLabelExtraInfo));
  164. break;
  165. }
  166. }
  167. }
  168. var labelGroup = new AILabelGroup(name, validLabelExtraInfoTypes);
  169. int index = 0;
  170. foreach (var label in labels)
  171. {
  172. labelGroup.RegistLabel(index, label.Name, label.ExtraInfos);
  173. index++;
  174. }
  175. return labelGroup;
  176. }
  177. private static IAILabel ConvertTransAILabelsToIAILabel(TransAILabels transLabel)
  178. {
  179. if (transLabel == null)
  180. {
  181. return null;
  182. }
  183. switch (transLabel.LabelType)
  184. {
  185. case AIEnumLabelType.Label:
  186. return ConvertTransAILabelToAILabel(transLabel.Label);
  187. }
  188. return null;
  189. }
  190. private static AILabel ConvertTransAILabelToAILabel(TransAILabel transLabel)
  191. {
  192. if (transLabel == null)
  193. {
  194. return null;
  195. }
  196. var name = transLabel.Name;
  197. var groupName = transLabel.GroupName;
  198. var index = transLabel.Index;
  199. List<IAILabelExtraInfo> extraInfos;
  200. if (transLabel.ExtraInfos == null)
  201. {
  202. extraInfos = null;
  203. }
  204. else
  205. {
  206. extraInfos = new List<IAILabelExtraInfo>();
  207. foreach (var transExtraInfo in transLabel.ExtraInfos)
  208. {
  209. var extraInfo = ConvertTransAILabelExtraInfosToIAILabelExtraInfo(transExtraInfo);
  210. if (extraInfo != null)
  211. {
  212. extraInfos.Add(extraInfo);
  213. }
  214. }
  215. }
  216. return new AILabel(name, index, groupName, extraInfos);
  217. }
  218. private static IAILabelExtraInfo ConvertTransAILabelExtraInfosToIAILabelExtraInfo(TransAILabelExtraInfos transExtraInfo)
  219. {
  220. if (transExtraInfo == null)
  221. {
  222. return null;
  223. }
  224. switch (transExtraInfo.LabelExtraInfoType)
  225. {
  226. case AIEnumLabelExtraInfoType.LesionMalignantDegreeLabelExtraInfo:
  227. return transExtraInfo.LesionMalignantDegreeLabelExtraInfo;
  228. case AIEnumLabelExtraInfoType.LesionInvolvedScopeLabelExtraInfo:
  229. return transExtraInfo.LesionInvolvedScopeLabelExtraInfo;
  230. }
  231. return null;
  232. }
  233. private static IAIDetectedObject ConvertTransAIDetectedObjectsToIAIDetectedObject(TransAIDetectedObjects transDetectedObject)
  234. {
  235. if (transDetectedObject == null)
  236. {
  237. return null;
  238. }
  239. switch (transDetectedObject.DetectedObjectType)
  240. {
  241. case AIEnumDetectedObjectType.DetectedObject:
  242. return ConvertTransAIDetectedObjectToAIDetectedObject(transDetectedObject.DetectedObject);
  243. case AIEnumDetectedObjectType.ModuleRecognizedObject:
  244. return ConvertTransAIModuleRecognizedObjectToAIModuleRecognizedObject(transDetectedObject.ModuleRecognizedObject);
  245. case AIEnumDetectedObjectType.ModuleStandardSectionResult:
  246. return ConvertTransAIModuleStandardSectionResultToAIModuleStandardSectionResult(transDetectedObject.ModuleStandardSectionResult);
  247. }
  248. return null;
  249. }
  250. private static AIDetectedObjectV2 ConvertTransAIDetectedObjectToAIDetectedObject(TransAIDetectedObjectV2 transDetectedObject)
  251. {
  252. if (transDetectedObject == null)
  253. {
  254. return null;
  255. }
  256. var iAILabel = ConvertTransAILabelsToIAILabel(transDetectedObject.Label);
  257. var score = transDetectedObject.Score;
  258. var iAIGeomtry = ConvertTransAIGeomtriesToIAIGeometry(transDetectedObject.BoundingBox);
  259. var iAIContour = ConvertTransAIContoursToIAIContour(transDetectedObject.Contour);
  260. var iAIDescription = ConvertTransAIDescriptionsToIAIDescriptions(transDetectedObject.Description);
  261. IAIMeasurement[] iAIMeasurementsArray;
  262. if (transDetectedObject.Measurements == null)
  263. {
  264. iAIMeasurementsArray = null;
  265. }
  266. else
  267. {
  268. iAIMeasurementsArray = new IAIMeasurement[transDetectedObject.Measurements.Length];
  269. for (int i = 0; i < transDetectedObject.Measurements.Length; i++)
  270. {
  271. iAIMeasurementsArray[i] = ConvertTransAIMeasurementsToIAIMeasurement(transDetectedObject.Measurements[i]);
  272. }
  273. }
  274. return new AIDetectedObjectV2(iAILabel, score, iAIGeomtry, iAIContour, iAIDescription, iAIMeasurementsArray);
  275. }
  276. private static IAIGeometry ConvertTransAIGeomtriesToIAIGeometry(TransAIGeomtries transAIGeomtries)
  277. {
  278. if (transAIGeomtries == null)
  279. {
  280. return null;
  281. }
  282. switch (transAIGeomtries.GeometryType)
  283. {
  284. case AIEnumGeometryType.Sector:
  285. return AICommonConvertHelperV2.ConvertTransAISectorToAISector(transAIGeomtries.Sector);
  286. case AIEnumGeometryType.Rectangle:
  287. return AICommonConvertHelperV2.ConvertTransAIRectangleToAIRectangle(transAIGeomtries.Rectangle);
  288. case AIEnumGeometryType.Rect:
  289. return transAIGeomtries.Rect;
  290. case AIEnumGeometryType.RotatedRect:
  291. return AICommonConvertHelperV2.ConvertTransAIRotatedRectToAIRotatedRect(transAIGeomtries.RotatedRect);
  292. case AIEnumGeometryType.Parallelogram:
  293. return AICommonConvertHelperV2.ConvertTransAIParallelogramToAIParallelogram(transAIGeomtries.Parallelogram);
  294. case AIEnumGeometryType.Line:
  295. return AICommonConvertHelperV2.ConvertTransAILineToAILine(transAIGeomtries.Line);
  296. case AIEnumGeometryType.Point:
  297. return AICommonConvertHelperV2.ConvertTransAIPointToAIPoint(transAIGeomtries.Point);
  298. case AIEnumGeometryType.ConvexArrayUltrasoundImageRegion:
  299. return AICommonConvertHelperV2.ConvertTransAIUltrasoundImageRegionToIAIUltrasoundImageRegion(transAIGeomtries.UltrasoundImageRegion);
  300. case AIEnumGeometryType.LinearArrayUltrasoundImageRegion:
  301. return AICommonConvertHelperV2.ConvertTransAIUltrasoundImageRegionToIAIUltrasoundImageRegion(transAIGeomtries.UltrasoundImageRegion);
  302. }
  303. return null;
  304. }
  305. private static IAIContour ConvertTransAIContoursToIAIContour(TransAIContours transAIContours)
  306. {
  307. if (transAIContours == null)
  308. {
  309. return null;
  310. }
  311. switch (transAIContours.ContourType)
  312. {
  313. case AIEnumContourType.SimpleContour:
  314. return AICommonConvertHelperV2.ConvertTransAISimpleContourToAISimpleContour(transAIContours.SimpleContour);
  315. case AIEnumContourType.AnnularContour:
  316. return AICommonConvertHelperV2.ConvertTransAIAnnularContourToAIAnnularContour(transAIContours.AnnularContour);
  317. case AIEnumContourType.MultiHoleContour:
  318. return AICommonConvertHelperV2.ConvertTransAIMultiHoleContourToAIMultiHoleContour(transAIContours.MultiHoleContour);
  319. case AIEnumContourType.MModeEPSSContour:
  320. return ConvertTransAIMModeEPSSContourToAIMModeEPSSContour(transAIContours.MModeEPSSContour);
  321. case AIEnumContourType.VetMModeLVStudyContour:
  322. return ConvertTransAIVetMModeLVStudyContourToAIVetMModeLVStudyContour(transAIContours.VetMModeLVStudyContour);
  323. }
  324. return null;
  325. }
  326. private static AIMModeEPSSContour ConvertTransAIMModeEPSSContourToAIMModeEPSSContour(TransAIMModeEPSSContour mModeEPSSContour)
  327. {
  328. if (mModeEPSSContour == null)
  329. {
  330. return null;
  331. }
  332. return new AIMModeEPSSContour(mModeEPSSContour.IVSDownContour);
  333. }
  334. private static AIVetMModeLVStudyContour ConvertTransAIVetMModeLVStudyContourToAIVetMModeLVStudyContour(TransAIVetMModeLVStudyContour vetMModeLVStudyContour)
  335. {
  336. if (vetMModeLVStudyContour == null)
  337. {
  338. return null;
  339. }
  340. return new AIVetMModeLVStudyContour(vetMModeLVStudyContour.IVSUpContour, vetMModeLVStudyContour.IVSDownContour, vetMModeLVStudyContour.LPWUPContour, vetMModeLVStudyContour.LPWDownContour);
  341. }
  342. private static IAIDescriptionV2 ConvertTransAIDescriptionsToIAIDescriptions(TransAIDescriptions transDescription)
  343. {
  344. if (transDescription == null)
  345. {
  346. return null;
  347. }
  348. return null;
  349. }
  350. private static IAIMeasurement ConvertTransAIMeasurementsToIAIMeasurement(TransAIMeasurements transAIMeasurements)
  351. {
  352. if (transAIMeasurements == null)
  353. {
  354. return null;
  355. }
  356. switch (transAIMeasurements.MeasurementType)
  357. {
  358. case AIEnumMeasurementType.TransverseLongitudinalDiameterMeasurement:
  359. return AICommonConvertHelperV2.ConvertTransAITransverseLongitudinalDiameterMeasurementToAITransverseLongitudinalDiameterMeasurement(transAIMeasurements.TransverseLongitudinalDiameterMeasurement);
  360. case AIEnumMeasurementType.LongAxisLeftVentricleVolumeMeasurement:
  361. return AICommonConvertHelperV2.ConvertTransAILongAxisLeftVentricleVolumeMeasurementToAILongAxisLeftVentricleVolumeMeasurement(transAIMeasurements.LongAxisLeftVentricleVolumeMeasurement);
  362. case AIEnumMeasurementType.VetBModeCalMeasurement:
  363. return ConvertTransAIVetBModeCalMeasurementToAIVetBModeCalMeasurement(transAIMeasurements.VetBModeCalMeasurement);
  364. case AIEnumMeasurementType.VetLVAreaMeasurement:
  365. return ConvertTransAIVetLVAreaMeasurementToAIVetLVAreaMeasurement(transAIMeasurements.VetLVAreaMeasurement);
  366. case AIEnumMeasurementType.VetLAAOMeasurement:
  367. return ConvertTransAIVetLAAOMeasurementToAIVetLAAOMeasurement(transAIMeasurements.VetLAAOMeasurement);
  368. case AIEnumMeasurementType.VetBModeEPSSMeasurement:
  369. return ConvertTransAIVetBModeEPSSMeasurementToAIVetBModeEPSSMeasurement(transAIMeasurements.VetBModeEPSSMeasurement);
  370. case AIEnumMeasurementType.VetLVInnerDiameterMeasurement:
  371. return ConvertTransAIVetLVInnerDiameterMeasurementToAIVetLVInnerDiameterMeasurement(transAIMeasurements.VetLVInnerDiameterMeasurement);
  372. case AIEnumMeasurementType.VetMModeEPSSMeasurement:
  373. return ConvertTransAIVetMModeEPSSMeasurementToAIVetMModeEPSSMeasurement(transAIMeasurements.VetMModeEPSSMeasurement);
  374. case AIEnumMeasurementType.VetMModeLVStudyMeasurement:
  375. return ConvertTransAIVetMModeLVStudyMeasurementToAIVetMModeLVStudyMeasurement(transAIMeasurements.VetMModeLVStudyMeasurement);
  376. }
  377. return null;
  378. }
  379. private static AIVetBModeCalMeasurement ConvertTransAIVetBModeCalMeasurementToAIVetBModeCalMeasurement(TransAIVetBModeCalMeasurement vetBModeCalMeasurement)
  380. {
  381. if (vetBModeCalMeasurement == null)
  382. {
  383. return null;
  384. }
  385. var ivs = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetBModeCalMeasurement.IVSMeasurePosition);
  386. var lv = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetBModeCalMeasurement.LVMeasurePosition);
  387. var lpw = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetBModeCalMeasurement.LPWMeasurePosition);
  388. return new AIVetBModeCalMeasurement(ivs, lv, lpw, vetBModeCalMeasurement.CmPerPixel);
  389. }
  390. private static AIVetLVAreaMeasurement ConvertTransAIVetLVAreaMeasurementToAIVetLVAreaMeasurement(TransAIVetLVAreaMeasurement vetLVAreaMeasurement)
  391. {
  392. if (vetLVAreaMeasurement == null)
  393. {
  394. return null;
  395. }
  396. return new AIVetLVAreaMeasurement(vetLVAreaMeasurement.LVArea, vetLVAreaMeasurement.CmPerPixel, true);
  397. }
  398. private static AIVetLAAOMeasurement ConvertTransAIVetLAAOMeasurementToAIVetLAAOMeasurement(TransAIVetLAAOMeasurement vetLAAOMeasurement)
  399. {
  400. if (vetLAAOMeasurement == null)
  401. {
  402. return null;
  403. }
  404. var la = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetLAAOMeasurement.LAMarkPosition);
  405. var ao = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetLAAOMeasurement.AOMarkPosition);
  406. return new AIVetLAAOMeasurement(la, ao, vetLAAOMeasurement.CmPerPixel);
  407. }
  408. private static AIVetBModeEPSSMeasurement ConvertTransAIVetBModeEPSSMeasurementToAIVetBModeEPSSMeasurement(TransAIVetBModeEPSSMeasurement vetBModeEPSSMeasurement)
  409. {
  410. if (vetBModeEPSSMeasurement == null)
  411. {
  412. return null;
  413. }
  414. var epss = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetBModeEPSSMeasurement.EPSSMarkPosition);
  415. return new AIVetBModeEPSSMeasurement(epss, vetBModeEPSSMeasurement.CmPerPixel);
  416. }
  417. private static AIVetLVInnerDiameterMeasurement ConvertTransAIVetLVInnerDiameterMeasurementToAIVetLVInnerDiameterMeasurement(TransAIVetLVInnerDiameterMeasurement vetLVInnerDiameterMeasurement)
  418. {
  419. if (vetLVInnerDiameterMeasurement == null)
  420. {
  421. return null;
  422. }
  423. var lv = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetLVInnerDiameterMeasurement.LVInnerDiameterMarkPosition);
  424. return new AIVetLVInnerDiameterMeasurement(lv, vetLVInnerDiameterMeasurement.CmPerPixel);
  425. }
  426. private static AIVetMModeEPSSMeasurement ConvertTransAIVetMModeEPSSMeasurementToAIVetMModeEPSSMeasurement(TransAIVetMModeEPSSMeasurement vetMModeEPSSMeasurement)
  427. {
  428. if (vetMModeEPSSMeasurement == null)
  429. {
  430. return null;
  431. }
  432. var epss = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetMModeEPSSMeasurement.EPSSMarkPosition);
  433. return new AIVetMModeEPSSMeasurement(epss, vetMModeEPSSMeasurement.CmPerPixel);
  434. }
  435. private static AIVetMModeLVStudyMeasurement ConvertTransAIVetMModeLVStudyMeasurementToAIVetMModeLVStudyMeasurement(TransAIVetMModeLVStudyMeasurement vetMModeLVStudyMeasurement)
  436. {
  437. if (vetMModeLVStudyMeasurement == null)
  438. {
  439. return null;
  440. }
  441. var isved = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetMModeLVStudyMeasurement.IVSEDMeasurePosition);
  442. var isves = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetMModeLVStudyMeasurement.IVSESMeasurePosition);
  443. var lved = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetMModeLVStudyMeasurement.LVEDMeasurePosition);
  444. var lves = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetMModeLVStudyMeasurement.LVESMeasurePosition);
  445. var lpwed = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetMModeLVStudyMeasurement.LPWEDMeasurePosition);
  446. var lpwes = AICommonConvertHelperV2.ConvertTransAILineToAILine(vetMModeLVStudyMeasurement.LPWESMeasurePosition);
  447. return new AIVetMModeLVStudyMeasurement(isved, isves, lved, lves, lpwed, lpwes, vetMModeLVStudyMeasurement.CmPerPixel);
  448. }
  449. private static AIModuleRecognizedObject ConvertTransAIModuleRecognizedObjectToAIModuleRecognizedObject(TransAIModuleRecognizedObject transModuleRecognizedObject)
  450. {
  451. if (transModuleRecognizedObject == null)
  452. {
  453. return null;
  454. }
  455. var iAILabel = ConvertTransAILabelsToIAILabel(transModuleRecognizedObject.Label);
  456. var score = transModuleRecognizedObject.Score;
  457. var iAIGeomtry = ConvertTransAIGeomtriesToIAIGeometry(transModuleRecognizedObject.BoundingBox);
  458. var iAIContour = ConvertTransAIContoursToIAIContour(transModuleRecognizedObject.Contour);
  459. var iAIDescription = ConvertTransAIDescriptionsToIAIDescriptions(transModuleRecognizedObject.Description);
  460. IAIMeasurement[] iAIMeasurementsArray;
  461. if (transModuleRecognizedObject.Measurements == null)
  462. {
  463. iAIMeasurementsArray = null;
  464. }
  465. else
  466. {
  467. iAIMeasurementsArray = new IAIMeasurement[transModuleRecognizedObject.Measurements.Length];
  468. for (int i = 0; i < transModuleRecognizedObject.Measurements.Length; i++)
  469. {
  470. iAIMeasurementsArray[i] = ConvertTransAIMeasurementsToIAIMeasurement(transModuleRecognizedObject.Measurements[i]);
  471. }
  472. }
  473. return new AIModuleRecognizedObject(iAILabel, score, iAIGeomtry, iAIContour, iAIDescription, iAIMeasurementsArray);
  474. }
  475. private static AIModuleStandardSectionResult ConvertTransAIModuleStandardSectionResultToAIModuleStandardSectionResult(TransAIModuleStandardSectionResult transModuleStandardSectionResult)
  476. {
  477. if (transModuleStandardSectionResult == null)
  478. {
  479. return null;
  480. }
  481. var iAILabel = ConvertTransAILabelsToIAILabel(transModuleStandardSectionResult.Label);
  482. var score = transModuleStandardSectionResult.Score;
  483. IAIMeasurement[] iAIMeasurementsArray;
  484. if (transModuleStandardSectionResult.Measurements == null)
  485. {
  486. iAIMeasurementsArray = null;
  487. }
  488. else
  489. {
  490. iAIMeasurementsArray = new IAIMeasurement[transModuleStandardSectionResult.Measurements.Length];
  491. for (int i = 0; i < transModuleStandardSectionResult.Measurements.Length; i++)
  492. {
  493. iAIMeasurementsArray[i] = ConvertTransAIMeasurementsToIAIMeasurement(transModuleStandardSectionResult.Measurements[i]);
  494. }
  495. }
  496. return new AIModuleStandardSectionResult(iAILabel, score, iAIMeasurementsArray);
  497. }
  498. private static AIVetHeartLVArea ConvertTransAIVetHeartLVAreaToAIVetHeartLVArea(TransAIVetHeartLVArea transAIVetHeartLVArea)
  499. {
  500. if (transAIVetHeartLVArea == null)
  501. {
  502. return null;
  503. }
  504. var dataId = AICommonConvertHelperV2.ConvertTransDataIdToIAIDataId(transAIVetHeartLVArea.FrameId);
  505. return new AIVetHeartLVArea(dataId, transAIVetHeartLVArea.MeasureValue);
  506. }
  507. private static AIVetBRecognizedCardiacCycle ConvertTransAIVetBRecognizedCardiacCycleToAIVetBRecognizedCardiacCycle(TransAIVetBRecognizedCardiacCycle transVetBRecognizedCardiacCycle)
  508. {
  509. if (transVetBRecognizedCardiacCycle == null)
  510. {
  511. return null;
  512. }
  513. var cycleStartFrameId = AICommonConvertHelperV2.ConvertTransDataIdToIAIDataId(transVetBRecognizedCardiacCycle.StartFrameId);
  514. var cycleEndFrameId = AICommonConvertHelperV2.ConvertTransDataIdToIAIDataId(transVetBRecognizedCardiacCycle.EndFrameId);
  515. var endDiastoleFrameId = AICommonConvertHelperV2.ConvertTransDataIdToIAIDataId(transVetBRecognizedCardiacCycle.EndDiastoleFrame);
  516. var endSystoleFrameId = AICommonConvertHelperV2.ConvertTransDataIdToIAIDataId(transVetBRecognizedCardiacCycle.EndSystoleFrame);
  517. var edivsdia = AICommonConvertHelperV2.ConvertTransAIMeasureValuesToIAIMeasureValues(transVetBRecognizedCardiacCycle.EDIvsDia);
  518. var edlpwdia = AICommonConvertHelperV2.ConvertTransAIMeasureValuesToIAIMeasureValues(transVetBRecognizedCardiacCycle.EDLpwDia);
  519. var esivsdia = AICommonConvertHelperV2.ConvertTransAIMeasureValuesToIAIMeasureValues(transVetBRecognizedCardiacCycle.ESIvsDia);
  520. var eslpwdia = AICommonConvertHelperV2.ConvertTransAIMeasureValuesToIAIMeasureValues(transVetBRecognizedCardiacCycle.ESLpwDia);
  521. var score = transVetBRecognizedCardiacCycle.Score;
  522. if (edivsdia is AILengthMeasureValue && edlpwdia is AILengthMeasureValue && esivsdia is AILengthMeasureValue && eslpwdia is AILengthMeasureValue)
  523. {
  524. return new AIVetBRecognizedCardiacCycle(cycleStartFrameId, cycleEndFrameId, endDiastoleFrameId, endSystoleFrameId, (AILengthMeasureValue)edivsdia, (AILengthMeasureValue)edlpwdia, (AILengthMeasureValue)esivsdia, (AILengthMeasureValue)eslpwdia, score);
  525. }
  526. else
  527. {
  528. return null;
  529. }
  530. }
  531. }
  532. }