AcqUnitLogicEx.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414
  1. #pragma once
  2. #include"LogicDevice.h"
  3. #include "ResDataObject.h"
  4. #include "ShareMemory_Circle.h"
  5. #include "Detector_Model_Def.h"
  6. #include"DIOSLogicDeviceStructure.h"
  7. #ifndef ACQUNITLOGICEX_EXPORTS
  8. #ifdef _WIN64
  9. #ifdef _DEBUG
  10. #pragma comment(lib, "AcqUnitLogicExX64D.lib")
  11. #else
  12. #pragma comment(lib, "AcqUnitLogicExX64.lib")
  13. #endif
  14. #else
  15. #ifdef _DEBUG
  16. #pragma comment(lib, "AcqUnitLogicExD.lib")
  17. #else
  18. #pragma comment(lib, "AcqUnitLogicEx.lib")
  19. #endif
  20. #endif
  21. #endif
  22. #ifdef ACQUNITLOGICEX_EXPORTS
  23. #define ACQUNITLOGICEX_API __declspec(dllexport)
  24. #define ACQUNITLOGICEX_C_API extern "C" __declspec(dllexport)
  25. #else
  26. #define ACQUNITLOGICEX_API __declspec(dllimport)
  27. #define ACQUNITLOGICEX_C_API extern "C" __declspec(dllimport)
  28. #endif
  29. //------------------------ABC相关----------------------------------------------------BEGIN
  30. #define ABCO_KEY ("ABCOUTPUT")
  31. #define ABCO_ROICENTERX ("ROICENTERX")
  32. #define ABCO_ROICENTERY ("ROICENTERY")
  33. //not include centerposition.
  34. //so that the size get's (1x1) even the height and width is zero.
  35. //actual size is (width*2+1,height*2+1)
  36. #define ABCO_ROIHEIGHT ("ROIHEIGHT")
  37. #define ABCO_ROIWIDTH ("ROIWIDTH")
  38. #define ABCO_ROISHAPE ("ROISHAPE")
  39. #define ABCO_ACTIVE ("ABCO_ACTIVE")
  40. #define ABCO_HARDWARE ("ABCO_HARDWARE")
  41. #define ABCO_EXI_DEF_THRESHOLD (1000)
  42. #define ABCO_EXI_THRESHOLD ("ABCO_EXI_THRESHOLD")
  43. #define ABCO_EXI_DEF_FITWIDTH (50)
  44. #define ABCO_EXI_FITWIDTH ("ABCO_EXI_FITWIDTH")
  45. #define ABCO_EXI_DEF_MIN (0)
  46. #define ABCO_EXI_MIN ("ABCO_EXI_MIN")
  47. #define ABCO_EXI_CUR ("ABCO_EXI_CUR")
  48. #define ABCO_EXI_DEF_MAX (4096)
  49. #define ABCO_EXI_MAX ("ABCO_EXI_MAX")
  50. //voltage step is 0.1v.
  51. //and certain MCU does not support floating calculation.
  52. //so we use DWORD type val,1v => 100
  53. #define ABCO_VOLT_DEF_MAX (1200)
  54. #define ABCO_VOLT_MAX ("ABCO_VOLT_MAX")
  55. #define ABCO_VOLT_CUR ("ABCO_VOLT_CUR")
  56. #define ABCO_VOLT_DEF_MIN (0)
  57. #define ABCO_VOLT_MIN ("ABCO_VOLT_MIN")
  58. //Ratio 1 = 1000,if we wanna change output voltage from 12v to 5v,then Ratio is (5/12 => 417)
  59. #define ABCO_VOLT_DEF_RATIO (1000)
  60. #define ABCO_VOLT_RATIO ("ABCO_VOLT_RATIO")
  61. //Auto Bright Control Output
  62. //ABCInput我们会在发生器端设计
  63. //内嵌一个ROI,没必要定义多个ROI
  64. //详细参照文档【动态探测器定义.xlsx】
  65. //ABC应该作为单一的单元存在,要检讨!!!!
  66. class ACQUNITLOGICEX_API AutoBrightControl_Output
  67. {
  68. string *m_pKey;
  69. string *m_ValString;
  70. ResDataObject * m_pTargetObject;
  71. //ROI 部分
  72. //基于当前mode,取ROI区域并计算Exi
  73. //BaseJsonDataObject<DWORD> m_RoiCenterX;
  74. //BaseJsonDataObject<DWORD> m_RoiCenterY;
  75. //BaseJsonDataObject<DWORD> m_RoiHeight;
  76. //BaseJsonDataObject<DWORD> m_RoiWidth;
  77. //BaseJsonDataObject<DWORD> m_RoiShape;//1:elliptic 0:rectangular
  78. //ABC 部分
  79. //Abc开关
  80. //BaseJsonDataObject<bool> m_Active;
  81. //output by hw
  82. //看起来有2根Analog信号输出(一正一负)
  83. //Unactive情况下,两个Analog信号为0,发生器端不应该有输出剂量的变更.
  84. //至于信号值X轴对称(0->12v,0->-12v),还是偏移对称(0->12v,-12v->0),assert-check
  85. //这里要检讨:偏移对称的话,根据硬件信号就能判断是否UnActive.
  86. //据王磊讲述,没有用过负的...
  87. //Active情况下,输出为最后一张图像的ROI的模拟量(CurrentExi)
  88. //至于停止ABC控制,Analog信号输出改为0即可.
  89. //BaseJsonDataObject<bool> m_HardwareOutput;
  90. //预期想得到的Exi阈值
  91. //10 - 2^(8*sizeof(WORD))
  92. //BaseJsonDataObject<DWORD> m_ExiThreshold;
  93. //fit exi area.如果下列公式满足的话,认为ABC已经达到预期.输出Analog信号为0.
  94. //ABS(CurrentExi - ExiThreshold) < ExiFitWidth
  95. //BaseJsonDataObject<DWORD> m_ExiFitWidth;
  96. //无特殊情况下,缺省值应该为0.
  97. //为了将来考虑,先保留ExiMin.
  98. //BaseJsonDataObject<DWORD> m_ExiMin;
  99. //为预期Exi计算出来的MaxExi
  100. //BaseJsonDataObject<DWORD> m_ExiMax;
  101. //BaseJsonDataObject<DWORD> m_CurrentExi;//current exi val.
  102. //电压的上下限,如果2个Analog信号都有效的话,根据情况(X轴对称,偏移对称)设计
  103. //BaseJsonDataObject<DWORD> m_VoltageOutputMax;//normally it's 12v,min step is 0.1v
  104. //BaseJsonDataObject<DWORD> m_VoltageOutputMin;//normally it's 0v,min step is 0.1v
  105. //输出电压的增益量
  106. //BaseJsonDataObject<DWORD> m_VoltageOutputRatio;//normally it's 1.
  107. //final output analog signal
  108. //如果当前值是3V,真正的Analog输出为3V*VoltageOutputRatio
  109. //BaseJsonDataObject<DWORD> m_CurrentVoltageOutput;
  110. public:
  111. AutoBrightControl_Output();
  112. virtual ~AutoBrightControl_Output();
  113. AutoBrightControl_Output(const AutoBrightControl_Output &tValue);
  114. //base
  115. void SetKey(const char *pKey);
  116. const char *GetKey();
  117. //基于对象
  118. virtual void GetResDataObject(ResDataObject &obj);
  119. virtual bool SetResDataObject(ResDataObject &obj);
  120. //基于字符串
  121. //virtual const char *GetVal();
  122. //virtual bool SetVal(const char* pValString);
  123. //基于下标读取
  124. const ResDataObject &operator [](const char *pKey);
  125. //行为
  126. //设置和读取ROI
  127. //ABC开关
  128. //Exi参数设置
  129. //Voltage参数设置
  130. //硬件输出开关
  131. //Current Exi&Voltage Notify(Exi其实没必要通知)
  132. };
  133. //------------------------ABC相关----------------------------------------------------END
  134. //------------------------IMAGE相关----------------------------------------------------BEGIN
  135. /*
  136. 关于 Fetch行为的解释
  137. 1.必须明确怎么传递图像.
  138. 图像直接Notify?还是Fetch后反馈Notify?
  139. ImageFetchFlag为0,意味着不需要Fetch,下层图像Ready了自动发Notify.
  140. 反之,就需要明确的调用Fetch命令.
  141. 明确调用Fetch命令的前提是,ImageReady为真.
  142. Fetch(Type,FrameId),Request
  143. Type:Full?Prev,
  144. FrameId:
  145. 0< FrameId <= FrameCount,反馈明确的图像,Notify为P2P形式
  146. FrameId == 0 情况,Fetch行为反馈最后图像的Prev&Full
  147. 当ImageReady为假,Fetch命令马上返回失败.
  148. 用例:
  149. 连续采集模式下,ImageFetchFlag为假
  150. Frame将会保存最后一张图像,
  151. 2.Fetch在任何情况下都要存在.
  152. 2.1 OfflineMode下的Image的获取.
  153. 2.2 意外掉线后的LastImage的获取.
  154. */
  155. #define FetchImagePool ("IMAGEFETCHPOOL")
  156. #define MaxFrameLimits ("MAXFRAMELIMITS")
  157. #define ImageLeftCount ("IMAGERLEFTCOUNT")
  158. #define TotalFrameCount ("TOTALFRAMECOUNT")
  159. #define CurrentImageIndex ("CURRENTIMAGEINDEX")
  160. typedef enum _CurFramePos {
  161. FRAME_POS_CUR,
  162. FRAME_POS_FIRST,
  163. FRAME_POS_LAST,
  164. FRAME_POS_INCREASE,
  165. FRAME_POS_DECREASE,
  166. FRAME_POS_MAX
  167. }CURFRAMEPOS;
  168. typedef enum _BINNING_Mode {
  169. BINNING_ORIG,
  170. BINNING_2_2,
  171. BINNING_3_3,
  172. BINNING_4_4
  173. }BINNING_MODE;
  174. class ACQUNITLOGICEX_API ImageFetchPoolEx : public ExJsonDataObject,public DiosLock
  175. {
  176. //共有属性
  177. //FrameCountLimit
  178. //TotalFrameCount
  179. //LeftFrameCount
  180. //类似于Private属性,没有必要对外公开
  181. //FirstFrameIndex
  182. //LastFrameIndex
  183. //CurrentFrameIndex
  184. //FullImageQueue Of ShareMemObject
  185. PVOID m_pFullImageQueue;
  186. //PrevImageQueue Of ShareMemObject
  187. PVOID m_pPrevImageData;
  188. //
  189. public:
  190. ImageFetchPoolEx();
  191. virtual ~ImageFetchPoolEx();
  192. bool SetMaxBlockSize(const char *pQueName, DWORD BlockSize, DWORD FulBlockCount, DWORD PrevBlockCount);
  193. bool SetFulImageInfo(DWORD Height, DWORD Width, DWORD Bits);
  194. //void SetFulImageTrimInfo(DWORD LeftTrim, DWORD RightTrim, DWORD TopTrim, DWORD BottomTrim);
  195. //Bits:follow fullImageInfo setting
  196. //bool SetPrevImageInfo(bool Support, DWORD Height, DWORD Width, bool FetchFlag);
  197. ShareMemoryBlockID AddFrame(IMAGE_VIEW_TYPE Type, ShareMemoryBlockID ImageSmId);
  198. ShareMemoryBlockID AddFrame(IMAGE_VIEW_TYPE Type, WORD* pFrameBuff, DWORD FrameSize);
  199. ShareMemoryBlockID AddRawFrame(IMAGE_VIEW_TYPE Type,DWORD Width,DWORD Height,DWORD Bit, WORD* pImageBuff, DWORD BuffSize);
  200. ShareMemoryBlockID AddFrameWithHead(IMAGE_VIEW_TYPE Type, IMAGE imageHead,WORD* pFrameBuff, DWORD FrameSize);
  201. //先拿图,后设置位置
  202. RET_STATUS DATA_ACTION FetchFrame(IMAGE_VIEW_TYPE Type, CURFRAMEPOS position, ShareMemoryBlockID &ImageSmId);
  203. //设置位置
  204. RET_STATUS DATA_ACTION SetCurrentFramePosition(IMAGE_VIEW_TYPE Type, CURFRAMEPOS position);
  205. void ClearPool();
  206. virtual ResDataObject &GetResDataObject();
  207. virtual ResDataObject &operator [](const char *pKey);
  208. };
  209. //------------------------IMAGE相关----------------------------------------------------END
  210. class ACQUNITLOGICEX_API AcqUnitLogicEx :public LogicDevice
  211. {
  212. ImgDataInfo* m_ImgDataInfo;
  213. GainInfoEx *m_pGainInfo;
  214. //Zoom
  215. /*
  216. 2121探测器,缺省21CM*21CM,so...Zoom X Y 应该为(21,21)
  217. 同理,4343情况就是 (43,43)
  218. 如果ZOOM切换到20*20,则此值应变为(20,20)
  219. */
  220. ZoomInfoEx *m_pZoomInfo;
  221. //Binning
  222. /*
  223. 通常有1*1,2*2,3*3模式
  224. 极端有1*2,2*3,1*3等
  225. */
  226. BinningInfoEx *m_pBinningInfo;
  227. //图像信息
  228. ImageInfoEx *m_pFullImageInfo;
  229. ImageInfoEx *m_pPrevImageInfo;
  230. //探测器曝光状态信息
  231. ResDataObject *m_pECOMFPDState;
  232. ImageFetchPoolEx *m_pFetchPool;
  233. bool DoAddFrameNotify(IMAGE_VIEW_TYPE Type, ShareMemoryBlockID ImageSmId, bool Clear);
  234. protected:
  235. public:
  236. AcqUnitLogicEx(void);
  237. virtual ~AcqUnitLogicEx(void);
  238. //Request参数
  239. //FrameIndex:
  240. //FrameIndex > 0情况: 0<= FrameIndex < FrameCount
  241. //Response参数
  242. //反馈内容为真实的FrameId&SeqId
  243. //Notify内容
  244. //Response成功时,会反馈图像数据的Notify.
  245. //Fetch is based on current idx
  246. RET_STATUS DATA_ACTION FetchFrame(IMAGE_VIEW_TYPE Type, CURFRAMEPOS position, ShareMemoryBlockID &ImageSmId);
  247. RET_STATUS DATA_ACTION SetCurrentFramePosition(IMAGE_VIEW_TYPE Type, CURFRAMEPOS position);
  248. //Fetch is based on framecount
  249. //RET_STATUS DATA_ACTION FetchValidFrame(IMAGE_VIEW_TYPE Type, DWORD FrameIdx, UINT64 &ImageSmId);//
  250. RET_STATUS DATA_ACTION GetImageInfo(IMAGE_VIEW_TYPE Type, ImageInfoEx &Info);
  251. RET_STATUS DATA_ACTION GetGain(float &Gain);//
  252. RET_STATUS DATA_ACTION GetZoom(ZoomInfoEx &zoomInfo);//
  253. RET_STATUS DATA_ACTION GetBinning(BinningInfoEx &binningInfo);//
  254. //状态机相关
  255. virtual RET_STATUS DATA_ACTION FramePrep();
  256. virtual RET_STATUS DATA_ACTION FramePost();
  257. virtual RET_STATUS DATA_ACTION FrameOut();
  258. virtual bool DEVICE_SUPPORT Support_FramePrep();
  259. virtual bool DEVICE_SUPPORT Support_FramePost();
  260. virtual bool DEVICE_SUPPORT Support_FrameOut();
  261. virtual RET_STATUS DATA_ACTION GetSEQResource(ResDataObject*res);
  262. virtual RET_STATUS DATA_ACTION SetAcqImageType(XRAY_IMAGE_TYPE ImageType);
  263. //get device type
  264. virtual bool SYSTEM_CALL GetDeviceType(GUID &DevType);
  265. //get device resource
  266. virtual RET_STATUS SYSTEM_CALL GetDeviceResource(ResDataObject PARAM_OUT *pDeviceResource);
  267. //ResourceCommand Request In and Response Out
  268. virtual RET_STATUS SYSTEM_CALL Request(ResDataObject PARAM_IN *pRequest, ResDataObject PARAM_OUT *pResponse);
  269. //notify to lower layer
  270. virtual RET_STATUS SYSTEM_CALL CmdToLogicDev(ResDataObject PARAM_IN *pCmd);
  271. //对内接口
  272. ShareMemoryBlockID OEM_IF AddFrame(IMAGE_VIEW_TYPE Type, ShareMemoryBlockID ImageSmId);
  273. ShareMemoryBlockID OEM_IF AddFrame(IMAGE_VIEW_TYPE Type, WORD* pImageBuff, DWORD BuffSize);
  274. ShareMemoryBlockID OEM_IF AddRawFrame(IMAGE_VIEW_TYPE Type, WORD* pImageBuff, DWORD BuffSize);
  275. ShareMemoryBlockID OEM_IF AddFrameWithRawHead(IMAGE_VIEW_TYPE Type, IMAGE imageHead, WORD* pFrameBuff, DWORD FrameSize);
  276. bool OEM_IF SetFulImageInfo(DWORD Height, DWORD Width, DWORD Bits, bool FetchFlag);
  277. bool OEM_IF SetPrevImageInfo(bool Support, DWORD Height, DWORD Width, bool FetchFlag);
  278. void OEM_IF ClearPool();
  279. void OEM_IF SetGain(float Gain);
  280. void OEM_IF SetZoom(DWORD &ZoomX, DWORD &ZoomY);//
  281. void OEM_IF SetBinning(DWORD &BinningX, DWORD &BinningY);//
  282. bool SetFulImageInfoEX(const char* fCoef, const char* fTargetEXI);
  283. bool OEM_IF SendImageInfo(IMAGE_VIEW_TYPE eType, ShareMemoryBlockID dwShareMemId, unsigned long long nImageId);
  284. bool OEM_IF SetMaxBlockSize(const char *pQueName, DWORD BlockSize, DWORD FulBlockCount, DWORD PrevBlockCount);
  285. virtual RET_STATUS SYSTEM_CALL SetSyncMode(int nSyncMode);
  286. virtual RET_STATUS SYSTEM_CALL SetGainMode(unsigned int GainMode);
  287. virtual RET_STATUS SYSTEM_CALL SetBinningMode(unsigned int BinningMode);
  288. virtual bool DEVICE_SUPPORT Support_SetLSBCheckEnable();
  289. virtual bool DEVICE_SUPPORT Support_SetLSBCheckROI();
  290. virtual bool DEVICE_SUPPORT Support_SetSensitivity();
  291. virtual RET_STATUS SYSTEM_CALL SetLSBCheckEnable(unsigned int Enable);
  292. virtual RET_STATUS SYSTEM_CALL SetLSBCheckROI(unsigned int X1, unsigned int Y1, unsigned int X2, unsigned int Y2);
  293. virtual RET_STATUS SYSTEM_CALL SetSensitivity(DWORD Sensitivity);//unit LSB/uGy
  294. virtual bool DEVICE_SUPPORT Support_SetExamMode();
  295. virtual RET_STATUS DATA_ACTION SetExamMode(int nExamMode);
  296. virtual bool DEVICE_SUPPORT Support_SetXWindowTime();
  297. virtual RET_STATUS DATA_ACTION SetXWindowTime(int nXWindowTime);
  298. bool OEM_IF SetEcomFPDState(ECOM_FPD_STATE state);
  299. };