AI continuous with logger

  1'''
  2AI - AI_continuous_with_logger.py with asynchronous mode.
  3
  4This example demonstrates the process of obtaining AI data in continuous mode with 8 channels from USBDAQF1AOD.
  5Then, save data into CSV file.
  6
  7To begin with, it demonstrates the steps to open the AI and configure the AI parameters.
  8Next, it outlines the procedure for reading and saving the streaming AI data.
  9Finally, it concludes by explaining how to close the AI.
 10
 11-------------------------------------------------------------------------------------
 12Please change correct serial number or IP and port number BEFORE you run example code.
 13
 14For other examples please check:
 15    https://github.com/WPC-Systems-Ltd/WPC_Python_driver_release/tree/main/examples
 16See README.md file to get detailed usage of this example.
 17
 18Copyright (c) 2022-2024 WPC Systems Ltd. All rights reserved.
 19'''
 20
 21## Python
 22import asyncio
 23
 24## WPC
 25
 26from wpcsys import pywpc
 27
 28
 29async def main():
 30    ## Get Python driver version
 31    print(f'{pywpc.PKG_FULL_NAME} - Version {pywpc.__version__}')
 32
 33    ## Create device handle
 34    dev = pywpc.USBDAQF1AOD()
 35
 36    ## Connect to device
 37    try:
 38        dev.connect("default") ## Depend on your device
 39    except Exception as err:
 40        pywpc.printGenericError(err)
 41        ## Release device handle
 42        dev.close()
 43        return
 44
 45    try:
 46        ## Parameters setting
 47        port = 0 ## Depend on your device
 48        mode = 2 ## 0 : On demand, 1 : N-samples, 2 : Continuous.
 49        sampling_rate = 200
 50        read_points = 200
 51        read_delay = 0.2 ## second
 52        channel = 8
 53
 54        ## Get firmware model & version
 55        driver_info = await dev.Sys_getDriverInfo_async()
 56        print("Model name: " + driver_info[0])
 57        print("Firmware version: " + driver_info[-1])
 58
 59        ## Open file with WPC_test.csv
 60        err = dev.Logger_openFile("WPC_test.csv")
 61        print(f"Logger_openFile, status: {err}")
 62
 63        ## Write header into CSV file
 64        err = dev.Logger_writeHeader(["CH0","CH1","CH2","CH3","CH4","CH5","CH6","CH7"])
 65        print(f"Logger_writeHeader, status: {err}")
 66
 67        ## Open AI
 68        err = await dev.AI_open_async(port)
 69        print(f"AI_open_async in port {port}, status: {err}")
 70        
 71        ## Set AI channel
 72        err = await dev.AI_enableChannel_async(port, channel)
 73        print(f"AI_enableChannel_async in port {port}, status: {err}")
 74
 75        ## Set AI acquisition mode to continuous mode (2)
 76        err = await dev.AI_setMode_async(port, mode)
 77        print(f"AI_setMode_async {mode} in port {port}, status: {err}")
 78
 79        ## Set AI sampling rate
 80        err = await dev.AI_setSamplingRate_async(port, sampling_rate)
 81        print(f"AI_setSamplingRate_async {sampling_rate} in port {port}, status: {err}")
 82
 83        ## Open AI streaming
 84        err = await dev.AI_openStreaming_async(port)
 85        print(f"AI_openStreaming_async in port {port}, status: {err}")
 86
 87        ## Start AI streaming
 88        err = await dev.AI_startStreaming_async(port)
 89        print(f"AI_startStreaming_async in port {port}, status: {err}")
 90
 91        ## Wait for acquisition
 92        await asyncio.sleep(1) ## delay [s]
 93
 94        ## Close AI streaming
 95        err = await dev.AI_closeStreaming_async(port)
 96        print(f"AI_closeStreaming_async in port {port}, status: {err}")
 97
 98        data_len = 1
 99        while data_len > 0:
100            ## Read data acquisition
101            ai_2Dlist = await dev.AI_readStreaming_async(port, read_points, read_delay)
102            print(f"number of samples = {len(ai_2Dlist)}" )
103
104            ## Write data into CSV file
105            dev.Logger_write2DList(ai_2Dlist)
106
107            ## Update data len
108            data_len = len(ai_2Dlist)
109
110        ## Close AI
111        err = await dev.AI_close_async(port)
112        print(f"AI_close_async in port {port}, status: {err}")
113    except Exception as err:
114        pywpc.printGenericError(err)
115
116    ## Disconnect device
117    dev.disconnect()
118
119    ## Release device handle
120    dev.close()
121
122    return
123
124def main_for_spyder(*args):
125    if asyncio.get_event_loop().is_running():
126        return asyncio.create_task(main(*args)).result()
127    else:
128        return asyncio.run(main(*args))
129if __name__ == '__main__':
130    asyncio.run(main()) ## Use terminal
131    # await main() ## Use Jupyter or IPython(>=7.0)
132    # main_for_spyder() ## Use Spyder