COTSXRayParam.cs 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using System.Xml;
  7. using static OTSDataType.otsdataconst;
  8. namespace OTSDataType
  9. {
  10. public class COTSXRayParam : ISlo
  11. {
  12. // x-ray scan mode
  13. const OTS_X_RAY_SCAN_MODE DEFAULE_XRAY_SCAN_MODE = OTS_X_RAY_SCAN_MODE.PointMode;
  14. // search x-ray low counts cut off
  15. const int DEFAULE_XRAY_LOW_COUNT = 800;
  16. // search x-ray speed
  17. const OTS_IMAGE_SCANSPEED_OPTIONS DEFAULE_SEARCH_XRAY_SPEED = OTS_IMAGE_SCANSPEED_OPTIONS.meddium;
  18. // analysis x-ray speed
  19. const OTS_IMAGE_SCANSPEED_OPTIONS DEFAULE_ANALYSIS_XRAY_SPEED = OTS_IMAGE_SCANSPEED_OPTIONS.meddium;
  20. // x-ray expect counts
  21. const int DEFAULE_XRAY_EXP_COUNT = 4500;
  22. // x-ray speed search
  23. const int DEFAULE_XRAY_SEARCH_MID_TIME = 20;
  24. // x-ray speed analysis
  25. const int DEFAULE_XRAY_ANALY_MID_TIME = 1000;
  26. const double DEFAULE_XRAY_QUANTIFY_MINSIZE = 50;
  27. const int DEFAULE_FASTXRAYTIME = 100;
  28. const int Default_Xray_Limit = 50;
  29. private OTS_X_RAY_SCAN_MODE m_nScanMode;
  30. private OTS_IMAGE_SCANSPEED_OPTIONS m_nAnalySpeed;
  31. private int m_nAnalyExpCount;
  32. private int m_nMidSearchAQTime;
  33. private int m_nMidAnalyAQTime;
  34. private double m_nQutantifyMinSize;
  35. private int m_nFastXrayTime;
  36. private bool m_nUsingXray;
  37. private int m_XrayLimit;
  38. private double m_xrayStep;
  39. public double XrayStep { get => m_xrayStep; set => m_xrayStep = value; }
  40. void Init()
  41. {
  42. m_nScanMode = DEFAULE_XRAY_SCAN_MODE;
  43. m_nAnalySpeed = DEFAULE_ANALYSIS_XRAY_SPEED;
  44. m_nAnalyExpCount = DEFAULE_XRAY_EXP_COUNT;
  45. m_nMidSearchAQTime = DEFAULE_XRAY_SEARCH_MID_TIME;
  46. m_nMidAnalyAQTime = DEFAULE_XRAY_ANALY_MID_TIME;
  47. m_nQutantifyMinSize = DEFAULE_XRAY_QUANTIFY_MINSIZE;
  48. m_nFastXrayTime = DEFAULE_FASTXRAYTIME;
  49. m_XrayLimit = Default_Xray_Limit;
  50. m_xrayStep = 0;
  51. }
  52. public COTSXRayParam()
  53. {
  54. Init();
  55. }
  56. // duplication
  57. void Duplicate(COTSXRayParam a_oSource)
  58. {
  59. // copy data over
  60. m_nScanMode = a_oSource.m_nScanMode;
  61. m_nAnalySpeed = a_oSource.m_nAnalySpeed;
  62. m_nAnalyExpCount = a_oSource.m_nAnalyExpCount;
  63. m_nMidSearchAQTime = a_oSource.m_nMidSearchAQTime;
  64. m_nMidAnalyAQTime = a_oSource.m_nMidAnalyAQTime;
  65. m_nQutantifyMinSize = a_oSource.m_nQutantifyMinSize;
  66. m_nFastXrayTime = a_oSource.m_nFastXrayTime;
  67. m_nUsingXray = a_oSource.m_nUsingXray;
  68. m_XrayLimit = a_oSource.m_XrayLimit;
  69. m_xrayStep = a_oSource.m_xrayStep;
  70. }
  71. // copy constructor
  72. public COTSXRayParam(COTSXRayParam a_oSource)
  73. { // copy data over
  74. Duplicate(a_oSource);
  75. }
  76. // ==operator
  77. public bool Equals(COTSXRayParam a_oSource)
  78. {
  79. // return test result
  80. return m_nScanMode == a_oSource.m_nScanMode &&
  81. m_nAnalySpeed == a_oSource.m_nAnalySpeed &&
  82. m_nAnalyExpCount == a_oSource.m_nAnalyExpCount &&
  83. m_nMidSearchAQTime == a_oSource.m_nMidSearchAQTime &&
  84. m_nMidAnalyAQTime == a_oSource.m_nMidAnalyAQTime &&
  85. m_nQutantifyMinSize == a_oSource.m_nQutantifyMinSize &&
  86. m_nFastXrayTime == a_oSource.m_nFastXrayTime &&
  87. m_nUsingXray == a_oSource.m_nUsingXray;
  88. }
  89. public OTS_X_RAY_SCAN_MODE GetScanMode() { return m_nScanMode; }
  90. public void SetScanMode(OTS_X_RAY_SCAN_MODE a_nVal) { m_nScanMode = a_nVal; }
  91. public OTS_IMAGE_SCANSPEED_OPTIONS GetAnalySpeed() { return m_nAnalySpeed; }
  92. public void SetAnalySpeed(OTS_IMAGE_SCANSPEED_OPTIONS a_nVal) { m_nAnalySpeed = a_nVal; }
  93. public int GetAnalyExpCount() { return m_nAnalyExpCount; }
  94. public void SetAnalyExpCount(int a_nVal) { m_nAnalyExpCount = a_nVal; }
  95. public int GetMidSearchAQTime() { return m_nMidSearchAQTime; }
  96. public void SetMidSearchAQTime(int a_nMidSearchAQTime) { m_nMidSearchAQTime = a_nMidSearchAQTime; }
  97. public int GetMidAnalyAQTime() { return m_nMidAnalyAQTime; }
  98. public void SetMidAnalyAQTime(int a_nMidAnalyAQTime) { m_nMidAnalyAQTime = a_nMidAnalyAQTime; }
  99. public double GetFeatureModeMinSize() { return m_nQutantifyMinSize; }
  100. public void SetQuantifyMinSize(double a_nQuantifyMinSize)
  101. {
  102. m_nQutantifyMinSize = a_nQuantifyMinSize;
  103. }
  104. public int GetFastXrayTime() { return m_nFastXrayTime; }
  105. public void SetFastXrayTime(int a_nFastXrayTime)
  106. {
  107. m_nFastXrayTime = a_nFastXrayTime;
  108. }
  109. public int GetXrayLimit() { return m_XrayLimit; }
  110. public void SetXrayLimit(int a_xrayLimit)
  111. {
  112. m_XrayLimit = a_xrayLimit;
  113. }
  114. public bool GetUsingXray() { return m_nUsingXray; }
  115. public void SetUsingXray(bool a_nUsingXray)
  116. {
  117. m_nUsingXray = a_nUsingXray;
  118. }
  119. public override void Serialize(bool isStoring, XmlDocument classDoc, XmlNode rootNode)
  120. {
  121. xString xnScanMode = new xString();
  122. xInt xnAnalyExpCount = new xInt();
  123. xInt xnMidAnalyAQTime = new xInt();
  124. xInt xSmallPartAQTime = new xInt();
  125. xDouble xQuantifyMinSize = new xDouble();
  126. xBool xnUsingXray = new xBool();
  127. xInt xXrayLimit = new xInt();
  128. xDouble xXrayStep = new xDouble();
  129. Slo slo = new Slo();
  130. slo.Register("ScanMode", xnScanMode);
  131. slo.Register("AnalyExpCount", xnAnalyExpCount);
  132. slo.Register("MidAnalyAQTime", xnMidAnalyAQTime);
  133. slo.Register("SmallPartAQTime", xSmallPartAQTime);
  134. slo.Register("QuantifyMinSize", xQuantifyMinSize);
  135. slo.Register("UsingXray", xnUsingXray);
  136. slo.Register("XrayLimit", xXrayLimit);
  137. slo.Register("XrayStep", xXrayStep);
  138. if (isStoring)
  139. {
  140. xnScanMode.AssignValue((int)m_nScanMode+":"+m_nScanMode.ToString());
  141. xnAnalyExpCount.AssignValue(m_nAnalyExpCount);
  142. xnMidAnalyAQTime.AssignValue(m_nMidAnalyAQTime);
  143. xSmallPartAQTime.AssignValue(m_nFastXrayTime);
  144. xQuantifyMinSize.AssignValue(m_nQutantifyMinSize);
  145. xnUsingXray.AssignValue(m_nUsingXray);
  146. xXrayLimit.AssignValue(m_XrayLimit);
  147. xXrayStep.AssignValue(m_xrayStep);
  148. slo.Serialize(true, classDoc, rootNode);
  149. }
  150. else
  151. {
  152. slo.Serialize(false, classDoc, rootNode);
  153. m_nScanMode = (OTS_X_RAY_SCAN_MODE)Convert.ToInt32( xnScanMode.value().Split(':')[0]);
  154. m_nAnalyExpCount = xnAnalyExpCount.value();
  155. m_nMidAnalyAQTime = xnMidAnalyAQTime.value();
  156. m_nFastXrayTime = xSmallPartAQTime.value();
  157. m_nQutantifyMinSize = xQuantifyMinSize.value();
  158. m_nUsingXray = xnUsingXray.value();
  159. m_XrayLimit = xXrayLimit.value();
  160. m_xrayStep = xXrayStep.value();
  161. }
  162. }
  163. }
  164. }