COTSXRayParam.cs 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  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 int GetAnalyExpCount() { return m_nAnalyExpCount; }
  92. public void SetAnalyExpCount(int a_nVal) { m_nAnalyExpCount = a_nVal; }
  93. public int GetMidSearchAQTime() { return m_nMidSearchAQTime; }
  94. public void SetMidSearchAQTime(int a_nMidSearchAQTime) { m_nMidSearchAQTime = a_nMidSearchAQTime; }
  95. public int GetMidAnalyAQTime() { return m_nMidAnalyAQTime; }
  96. public void SetMidAnalyAQTime(int a_nMidAnalyAQTime) { m_nMidAnalyAQTime = a_nMidAnalyAQTime; }
  97. public double GetFeatureModeMinSize() { return m_nQutantifyMinSize; }
  98. public void SetQuantifyMinSize(double a_nQuantifyMinSize)
  99. {
  100. m_nQutantifyMinSize = a_nQuantifyMinSize;
  101. }
  102. public int GetFastXrayTime() { return m_nFastXrayTime; }
  103. public void SetFastXrayTime(int a_nFastXrayTime)
  104. {
  105. m_nFastXrayTime = a_nFastXrayTime;
  106. }
  107. public int GetXrayLimit() { return m_XrayLimit; }
  108. public void SetXrayLimit(int a_xrayLimit)
  109. {
  110. m_XrayLimit = a_xrayLimit;
  111. }
  112. public bool GetUsingXray() { return m_nUsingXray; }
  113. public void SetUsingXray(bool a_nUsingXray)
  114. {
  115. m_nUsingXray = a_nUsingXray;
  116. }
  117. public override void Serialize(bool isStoring, XmlDocument classDoc, XmlNode rootNode)
  118. {
  119. xString xnScanMode = new xString();
  120. xInt xnAnalyExpCount = new xInt();
  121. xInt xnMidAnalyAQTime = new xInt();
  122. xInt xSmallPartAQTime = new xInt();
  123. xDouble xQuantifyMinSize = new xDouble();
  124. xBool xnUsingXray = new xBool();
  125. xInt xXrayLimit = new xInt();
  126. xDouble xXrayStep = new xDouble();
  127. Slo slo = new Slo();
  128. slo.Register("ScanMode", xnScanMode);
  129. slo.Register("AnalyExpCount", xnAnalyExpCount);
  130. slo.Register("MidAnalyAQTime", xnMidAnalyAQTime);
  131. slo.Register("SmallPartAQTime", xSmallPartAQTime);
  132. slo.Register("QuantifyMinSize", xQuantifyMinSize);
  133. slo.Register("UsingXray", xnUsingXray);
  134. slo.Register("XrayLimit", xXrayLimit);
  135. slo.Register("XrayStep", xXrayStep);
  136. if (isStoring)
  137. {
  138. xnScanMode.AssignValue((int)m_nScanMode+":"+m_nScanMode.ToString());
  139. xnAnalyExpCount.AssignValue(m_nAnalyExpCount);
  140. xnMidAnalyAQTime.AssignValue(m_nMidAnalyAQTime);
  141. xSmallPartAQTime.AssignValue(m_nFastXrayTime);
  142. xQuantifyMinSize.AssignValue(m_nQutantifyMinSize);
  143. xnUsingXray.AssignValue(m_nUsingXray);
  144. xXrayLimit.AssignValue(m_XrayLimit);
  145. xXrayStep.AssignValue(m_xrayStep);
  146. slo.Serialize(true, classDoc, rootNode);
  147. }
  148. else
  149. {
  150. slo.Serialize(false, classDoc, rootNode);
  151. m_nScanMode = (OTS_X_RAY_SCAN_MODE)Convert.ToInt32( xnScanMode.value().Split(':')[0]);
  152. m_nAnalyExpCount = xnAnalyExpCount.value();
  153. m_nMidAnalyAQTime = xnMidAnalyAQTime.value();
  154. m_nFastXrayTime = xSmallPartAQTime.value();
  155. m_nQutantifyMinSize = xQuantifyMinSize.value();
  156. m_nUsingXray = xnUsingXray.value();
  157. m_XrayLimit = xXrayLimit.value();
  158. m_xrayStep = xXrayStep.value();
  159. }
  160. }
  161. }
  162. }