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