COTSXRayParam.cs 7.2 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 int m_nAnalyExpCount;
  31. private int m_nMidSearchAQTime;
  32. private int m_nMidAnalyAQTime;
  33. private double m_nQutantifyMinSize;
  34. private int m_nFastXrayTime;
  35. private bool m_nUsingXray;
  36. private int m_XrayLimit;
  37. private double m_xrayStep;
  38. public double XrayStep { get => m_xrayStep; set => m_xrayStep = value; }
  39. void Init()
  40. {
  41. m_nScanMode = DEFAULE_XRAY_SCAN_MODE;
  42. m_nAnalyExpCount = DEFAULE_XRAY_EXP_COUNT;
  43. m_nMidSearchAQTime = DEFAULE_XRAY_SEARCH_MID_TIME;
  44. m_nMidAnalyAQTime = DEFAULE_XRAY_ANALY_MID_TIME;
  45. m_nQutantifyMinSize = DEFAULE_XRAY_QUANTIFY_MINSIZE;
  46. m_nFastXrayTime = DEFAULE_FASTXRAYTIME;
  47. m_XrayLimit = Default_Xray_Limit;
  48. m_xrayStep = 0;
  49. }
  50. public COTSXRayParam()
  51. {
  52. Init();
  53. }
  54. // duplication
  55. void Duplicate(COTSXRayParam a_oSource)
  56. {
  57. // copy data over
  58. m_nScanMode = a_oSource.m_nScanMode;
  59. //m_nAnalySpeed = a_oSource.m_nAnalySpeed;
  60. m_nAnalyExpCount = a_oSource.m_nAnalyExpCount;
  61. m_nMidSearchAQTime = a_oSource.m_nMidSearchAQTime;
  62. m_nMidAnalyAQTime = a_oSource.m_nMidAnalyAQTime;
  63. m_nQutantifyMinSize = a_oSource.m_nQutantifyMinSize;
  64. m_nFastXrayTime = a_oSource.m_nFastXrayTime;
  65. m_nUsingXray = a_oSource.m_nUsingXray;
  66. m_XrayLimit = a_oSource.m_XrayLimit;
  67. m_xrayStep = a_oSource.m_xrayStep;
  68. }
  69. // copy constructor
  70. public COTSXRayParam(COTSXRayParam a_oSource)
  71. { // copy data over
  72. Duplicate(a_oSource);
  73. }
  74. // ==operator
  75. public bool Equals(COTSXRayParam a_oSource)
  76. {
  77. // return test result
  78. return m_nScanMode == a_oSource.m_nScanMode &&
  79. //m_nAnalySpeed == a_oSource.m_nAnalySpeed &&
  80. m_nAnalyExpCount == a_oSource.m_nAnalyExpCount &&
  81. m_nMidSearchAQTime == a_oSource.m_nMidSearchAQTime &&
  82. m_nMidAnalyAQTime == a_oSource.m_nMidAnalyAQTime &&
  83. m_nQutantifyMinSize == a_oSource.m_nQutantifyMinSize &&
  84. m_nFastXrayTime == a_oSource.m_nFastXrayTime &&
  85. m_nUsingXray == a_oSource.m_nUsingXray;
  86. }
  87. public OTS_X_RAY_SCAN_MODE GetScanMode() { return m_nScanMode; }
  88. public void SetScanMode(OTS_X_RAY_SCAN_MODE a_nVal) { m_nScanMode = a_nVal; }
  89. public int GetAnalyExpCount() { return m_nAnalyExpCount; }
  90. public void SetAnalyExpCount(int a_nVal) { m_nAnalyExpCount = a_nVal; }
  91. public int GetMidSearchAQTime() { return m_nMidSearchAQTime; }
  92. public void SetMidSearchAQTime(int a_nMidSearchAQTime) { m_nMidSearchAQTime = a_nMidSearchAQTime; }
  93. public int GetMidAnalyAQTime() { return m_nMidAnalyAQTime; }
  94. public void SetMidAnalyAQTime(int a_nMidAnalyAQTime) { m_nMidAnalyAQTime = a_nMidAnalyAQTime; }
  95. public double GetFeatureModeMinSize() { return m_nQutantifyMinSize; }
  96. public void SetQuantifyMinSize(double a_nQuantifyMinSize)
  97. {
  98. m_nQutantifyMinSize = a_nQuantifyMinSize;
  99. }
  100. public int GetFastXrayTime() { return m_nFastXrayTime; }
  101. public void SetFastXrayTime(int a_nFastXrayTime)
  102. {
  103. m_nFastXrayTime = a_nFastXrayTime;
  104. }
  105. public int GetXrayLimit() { return m_XrayLimit; }
  106. public void SetXrayLimit(int a_xrayLimit)
  107. {
  108. m_XrayLimit = a_xrayLimit;
  109. }
  110. public bool GetUsingXray() { return m_nUsingXray; }
  111. public void SetUsingXray(bool a_nUsingXray)
  112. {
  113. m_nUsingXray = a_nUsingXray;
  114. }
  115. public override void Serialize(bool isStoring, XmlDocument classDoc, XmlNode rootNode)
  116. {
  117. xString xnScanMode = new xString();
  118. xInt xnAnalyExpCount = new xInt();
  119. xInt xnMidAnalyAQTime = new xInt();
  120. xInt xSmallPartAQTime = new xInt();
  121. xDouble xQuantifyMinSize = new xDouble();
  122. xBool xnUsingXray = new xBool();
  123. xInt xXrayLimit = new xInt();
  124. //xDouble xXrayStep = new xDouble();
  125. Slo slo = new Slo();
  126. slo.Register("ScanMode", xnScanMode);
  127. slo.Register("AnalyExpCount", xnAnalyExpCount);
  128. slo.Register("MidAnalyAQTime", xnMidAnalyAQTime);
  129. slo.Register("SmallPartAQTime", xSmallPartAQTime);
  130. slo.Register("QuantifyMinSize", xQuantifyMinSize);
  131. slo.Register("UsingXray", xnUsingXray);
  132. slo.Register("XrayLimit", xXrayLimit);
  133. //slo.Register("XrayStep", xXrayStep);
  134. if (isStoring)
  135. {
  136. xnScanMode.AssignValue((int)m_nScanMode+":"+m_nScanMode.ToString());
  137. xnAnalyExpCount.AssignValue(m_nAnalyExpCount);
  138. xnMidAnalyAQTime.AssignValue(m_nMidAnalyAQTime);
  139. xSmallPartAQTime.AssignValue(m_nFastXrayTime);
  140. xQuantifyMinSize.AssignValue(m_nQutantifyMinSize);
  141. xnUsingXray.AssignValue(m_nUsingXray);
  142. xXrayLimit.AssignValue(m_XrayLimit);
  143. //xXrayStep.AssignValue(m_xrayStep);
  144. slo.Serialize(true, classDoc, rootNode);
  145. }
  146. else
  147. {
  148. slo.Serialize(false, classDoc, rootNode);
  149. m_nScanMode = (OTS_X_RAY_SCAN_MODE)Convert.ToInt32( xnScanMode.value().Split(':')[0]);
  150. m_nAnalyExpCount = xnAnalyExpCount.value();
  151. m_nMidAnalyAQTime = xnMidAnalyAQTime.value();
  152. m_nFastXrayTime = xSmallPartAQTime.value();
  153. m_nQutantifyMinSize = xQuantifyMinSize.value();
  154. m_nUsingXray = xnUsingXray.value();
  155. m_XrayLimit = xXrayLimit.value();
  156. //m_xrayStep = xXrayStep.value();
  157. }
  158. }
  159. }
  160. }