AIO all channels loopback

  1'''
  2AIO - AIO_all_channels_loopback.py with asynchronous mode.
  3
  4This example demonstrates the process of AIO loopback across all channels of USBDAQF1AOD.
  5It involves using AO pins to send signals and AI pins to receive signals on a single device, commonly referred to as "loopback".
  6The AI and AO pins are connected using a wire.
  7
  8Initially, the example demonstrates the steps required to open the AI and AO.
  9Next, it reads AI data and displays its corresponding values.
 10Following that, it writes digital signals to the AO pins and reads AI on-demand data once again.
 11Lastly, it closes the AO and AI ports.
 12
 13-------------------------------------------------------------------------------------
 14Please change correct serial number or IP and port number BEFORE you run example code.
 15
 16For other examples please check:
 17    https://github.com/WPC-Systems-Ltd/WPC_Python_driver_release/tree/main/examples
 18See README.md file to get detailed usage of this example.
 19
 20Copyright (c) 2022-2025 WPC Systems Ltd. All rights reserved.
 21'''
 22
 23## WPC
 24from wpcsys import pywpc
 25
 26## Python
 27import asyncio
 28import sys
 29sys.path.insert(0, 'src/')
 30
 31
 32async def main():
 33    ## Get Python driver version
 34    print(f'{pywpc.PKG_FULL_NAME} - Version {pywpc.__version__}')
 35
 36    ## Create device handle
 37    dev = pywpc.USBDAQF1AOD()
 38
 39    ## Connect to device
 40    try:
 41        dev.connect("default")  ## Depend on your device
 42    except Exception as err:
 43        pywpc.printGenericError(err)
 44        ## Release device handle
 45        dev.close()
 46        return
 47
 48    try:
 49        ## Parameters setting
 50        port = 0  ## Depend on your device
 51        ao_value_list = [0, 0.5, 1, 1.5, 2, 2.5, 3, 3.5]
 52        channel = 8
 53
 54        ## Get firmware model & version
 55        driver_info = await dev.Sys_getDriverInfo_async()
 56        print(f"Model name: {driver_info[0]}, Firmware version: {driver_info[-1]} ")
 57
 58        ## Open AI
 59        err = await dev.AI_open_async(port)
 60        print(f"AI_open_async in port {port}, status: {err}")
 61        
 62        ## Set AI channel
 63        err = await dev.AI_enableChannel_async(port, channel)
 64        print(f"AI_enableChannel_async in port {port}, status: {err}")
 65
 66        ## Open AO
 67        err = await dev.AO_open_async(port)
 68        print(f"AO_open_async in port {port}, status: {err}")
 69
 70        ## Read data acquisition
 71        ai_list = await dev.AI_readOnDemand_async(port)
 72        print(f"AI data in port {port}: {ai_list}")
 73
 74        ## Write AO value simultaneously
 75        err = await dev.AO_writeAllChannels_async(port, ao_value_list)
 76        print(f"In port {port} the AO value is {ao_value_list}, status: {err}")
 77
 78        ## Read data acquisition
 79        ai_list = await dev.AI_readOnDemand_async(port)
 80        print(f"AI data in port {port}: {ai_list}")
 81
 82        ## Close AI
 83        err = await dev.AI_close_async(port)
 84        print(f"AI_close_async in port {port}, status: {err}")
 85
 86        ## Close AO
 87        err = await dev.AO_close_async(port)
 88        print(f"AO_close_async in port {port}, status: {err}")
 89    except Exception as err:
 90        pywpc.printGenericError(err)
 91
 92    finally:
 93        ## Disconnect device
 94        dev.disconnect()
 95
 96        ## Release device handle
 97        dev.close()
 98
 99
100def main_for_spyder(*args):
101    if asyncio.get_event_loop().is_running():
102        return asyncio.create_task(main(*args)).result()
103    else:
104        return asyncio.run(main(*args))
105
106
107if __name__ == '__main__':
108    asyncio.run(main())  ## Use terminal
109    # await main()  ## Use Jupyter or IPython(>=7.0)
110    # main_for_spyder()  ## Use Spyder