Automatic-CV


NameAutomatic-CV JSON
Version 1.0.0 PyPI version JSON
download
home_page
SummaryControl the Biologic potentiostat to test CV experiment via Python (combination with OT-2)
upload_time2023-08-29 19:22:51
maintainer
docs_urlNone
authorDanger Lin
requires_python>=3.7
license
keywords biologic
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Automatic CV

A library allowing easy control over EC-BioLogic devices via simple Python code. You can integrate this project with your automated robot (such as the OT-2 robot) to achieve automated electrochemical test tasks. At this stage, only the CV experiment can be tested through this library. Further electrochemical experiments are on the way and will be released in the following update.

> Install with `python -m pip install Automatic-CV`

For details of techniques and parameters, please see: the official development user's guide: [EC-Lab Development Package.pdf](https://github.com/DangerLin/easy-biologic/blob/main/EC-Lab%20Development%20Package.pdf).

### Biologic Program
`Abstract Class`
Represents a program to be run on a device.

#### Methods
+ **BiologicProgram( device, params, channels = None, autoconnect = True, barrier = None, stop_event = None, threaded = False ):** Creates a new program.

+ **channel_state( channels = None ):** Returns the state of the channels.

+ **on_data( callback, index = None ):** Registers a callback function to run when data is collected.

+ **run():** Runs the program.

+ **stop():** Sets the stop event flag.

+ **save_data( file, append = False, by_channel = False ):** Saves data to the given file.

+ **sync():** Waits for barrier, if set.

+ **_connect():** Connects to the device

#### Properties
+ **device:** BiologicDevice. <br>
+ **params:** Passed in parameters. <br>
+ **channels:** Device channels. <br>
+ **autoconnect:** Whether connection to the device should be automatic or + not. <br>
+ **barrier:** A threading.Barrier to use for channel syncronization. [See ProgramRummer] <br>
+ **field_titles:** Column names for saving data. <br>
+ **data:** Data collected during the program. <br>
+ **status:** Status of the program. <br>
+ **fields:** Data fields teh program returns. <br>
+ **technqiues:** List of techniques the program uses.

### Base Programs
This project can be used to scan the `CV` experiment only. Further experiments, including `OCV`, `PEIS`, *etc.*, are on the way and will be released in the following update.
    
#### CV
Performs a `CV` scan.

        Ewe ^
            |        E1
            |        /\
            |       /  \        Ef
            |      /    \      /
            |     /      \    /
            |    /        \  /
            |  Ei          \/
            |              E2
            |
            -----------------------> t
        

##### Params
+ **start:** Initial voltage (Ei). 
[Default: 0]

+ **E1:** Boundary potential that first reaches (E1).

+ **E2:** Boundary potential that reaches later.

+ **Ef:** Potential *vs* reference.
[Default: 0]

+ **step:** Voltage step. 
[Default: 0.001]

+ **rate:** Scan rate in V/s. 
[Default: 0.05]

+ **average:** Average over points. 
[Default: False]


### Find Devices
A convenience script for finding connected devices.

#### Use
From a terminal run `python -m automatic_cv.find_devices`.


### EC Errors
Implements EC errors.

#### Classes
+ **EcError( value = None, code = None, message = None )** 

## Example

A basic example that runs a CV experiment on channel 1.
```python
import logging
import automatic_cv as acv
import automatic_cv.base_programs as abp

logging.basicConfig(level=logging.DEBUG)

# create device
bl = acv.BiologicDevice('169.254.72.33')  #IP address is to be confirmed.

# channels to be used
channels = [0]
by_channel = False

# data saving directory
save_path = f'D:\Data\EC lab\data_output' # file name is to be defined.
if not by_channel:  
    save_path += '.csv'

# create CV program
params_CV = {
	
    'start': 0.9,
    'E1': -0.4,
    'E2': 0.3,
    'Ef': 0.9,
    'vs_initial': False,
    'rate': 0.05,                      #unit: V/s
    'step': 0.001,                     #step = dEN/1000
    'N_Cycles': 0,
    'average_over_dE': False, 
    'begin_measuring_I': 0.5,
    'End_measuring_I': 1.0,
    'I_range' : 'KBIO_IRANGE_AUTO',
    'E_range' : 'KBIO_ERANGE_2_5',
    'bandwidth': 'KBIO_BW_5'
}   

CV = abp.CV(
    bl,
    params_CV,     
    channels = [0]   #channel is to be claimed.
)     

# run program
CV.run( 'data' )
CV.save_data(save_path)
```

            

Raw data

            {
    "_id": null,
    "home_page": "",
    "name": "Automatic-CV",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.7",
    "maintainer_email": "",
    "keywords": "biologic",
    "author": "Danger Lin",
    "author_email": "dangerlin100@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/80/fd/78b4c10dba6372c673299cc33b95586f60864e11064f23ddd3370e672915/Automatic-CV-1.0.0.tar.gz",
    "platform": null,
    "description": "# Automatic CV\r\n\r\nA library allowing easy control over EC-BioLogic devices via simple Python code. You can integrate this project with your automated robot (such as the OT-2 robot) to achieve automated electrochemical test tasks. At this stage, only the CV experiment can be tested through this library. Further electrochemical experiments are on the way and will be released in the following update.\r\n\r\n> Install with `python -m pip install Automatic-CV`\r\n\r\nFor details of techniques and parameters, please see: the official development user's guide: [EC-Lab Development Package.pdf](https://github.com/DangerLin/easy-biologic/blob/main/EC-Lab%20Development%20Package.pdf).\r\n\r\n### Biologic Program\r\n`Abstract Class`\r\nRepresents a program to be run on a device.\r\n\r\n#### Methods\r\n+ **BiologicProgram( device, params, channels = None, autoconnect = True, barrier = None, stop_event = None, threaded = False ):** Creates a new program.\r\n\r\n+ **channel_state( channels = None ):** Returns the state of the channels.\r\n\r\n+ **on_data( callback, index = None ):** Registers a callback function to run when data is collected.\r\n\r\n+ **run():** Runs the program.\r\n\r\n+ **stop():** Sets the stop event flag.\r\n\r\n+ **save_data( file, append = False, by_channel = False ):** Saves data to the given file.\r\n\r\n+ **sync():** Waits for barrier, if set.\r\n\r\n+ **_connect():** Connects to the device\r\n\r\n#### Properties\r\n+ **device:** BiologicDevice. <br>\r\n+ **params:** Passed in parameters. <br>\r\n+ **channels:** Device channels. <br>\r\n+ **autoconnect:** Whether connection to the device should be automatic or + not. <br>\r\n+ **barrier:** A threading.Barrier to use for channel syncronization. [See ProgramRummer] <br>\r\n+ **field_titles:** Column names for saving data. <br>\r\n+ **data:** Data collected during the program. <br>\r\n+ **status:** Status of the program. <br>\r\n+ **fields:** Data fields teh program returns. <br>\r\n+ **technqiues:** List of techniques the program uses.\r\n\r\n### Base Programs\r\nThis project can be used to scan the `CV` experiment only. Further experiments, including `OCV`, `PEIS`, *etc.*, are on the way and will be released in the following update.\r\n    \r\n#### CV\r\nPerforms a `CV` scan.\r\n\r\n        Ewe ^\r\n            |        E1\r\n            |        /\\\r\n            |       /  \\        Ef\r\n            |      /    \\      /\r\n            |     /      \\    /\r\n            |    /        \\  /\r\n            |  Ei          \\/\r\n            |              E2\r\n            |\r\n            -----------------------> t\r\n        \r\n\r\n##### Params\r\n+ **start:** Initial voltage (Ei). \r\n[Default: 0]\r\n\r\n+ **E1:** Boundary potential that first reaches (E1).\r\n\r\n+ **E2:** Boundary potential that reaches later.\r\n\r\n+ **Ef:** Potential *vs* reference.\r\n[Default: 0]\r\n\r\n+ **step:** Voltage step. \r\n[Default: 0.001]\r\n\r\n+ **rate:** Scan rate in V/s. \r\n[Default: 0.05]\r\n\r\n+ **average:** Average over points. \r\n[Default: False]\r\n\r\n\r\n### Find Devices\r\nA convenience script for finding connected devices.\r\n\r\n#### Use\r\nFrom a terminal run `python -m automatic_cv.find_devices`.\r\n\r\n\r\n### EC Errors\r\nImplements EC errors.\r\n\r\n#### Classes\r\n+ **EcError( value = None, code = None, message = None )** \r\n\r\n## Example\r\n\r\nA basic example that runs a CV experiment on channel 1.\r\n```python\r\nimport logging\r\nimport automatic_cv as acv\r\nimport automatic_cv.base_programs as abp\r\n\r\nlogging.basicConfig(level=logging.DEBUG)\r\n\r\n# create device\r\nbl = acv.BiologicDevice('169.254.72.33')  #IP address is to be confirmed.\r\n\r\n# channels to be used\r\nchannels = [0]\r\nby_channel = False\r\n\r\n# data saving directory\r\nsave_path = f'D:\\Data\\EC lab\\data_output' # file name is to be defined.\r\nif not by_channel:  \r\n    save_path += '.csv'\r\n\r\n# create CV program\r\nparams_CV = {\r\n\t\r\n    'start': 0.9,\r\n    'E1': -0.4,\r\n    'E2': 0.3,\r\n    'Ef': 0.9,\r\n    'vs_initial': False,\r\n    'rate': 0.05,                      #unit: V/s\r\n    'step': 0.001,                     #step = dEN/1000\r\n    'N_Cycles': 0,\r\n    'average_over_dE': False, \r\n    'begin_measuring_I': 0.5,\r\n    'End_measuring_I': 1.0,\r\n    'I_range' : 'KBIO_IRANGE_AUTO',\r\n    'E_range' : 'KBIO_ERANGE_2_5',\r\n    'bandwidth': 'KBIO_BW_5'\r\n}   \r\n\r\nCV = abp.CV(\r\n    bl,\r\n    params_CV,     \r\n    channels = [0]   #channel is to be claimed.\r\n)     \r\n\r\n# run program\r\nCV.run( 'data' )\r\nCV.save_data(save_path)\r\n```\r\n",
    "bugtrack_url": null,
    "license": "",
    "summary": "Control the Biologic potentiostat to test CV experiment via Python (combination with OT-2)",
    "version": "1.0.0",
    "project_urls": {
        "Bug Tracker": "https://github.com/DangerLin/Automatic-CV/issues",
        "Source Code": "https://github.com/DangerLin/Automatic-CV"
    },
    "split_keywords": [
        "biologic"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "ac77d7df84a5d0af5f4f4883affeced6a2822350fa889418a6ebc0787680ab3f",
                "md5": "23660070066dae8e8ae8d22eebdcb8e0",
                "sha256": "6130bc02de6a1d3e6c37093b42d6ed2f460bb286eab4ef24ba8f0a28f16b22d6"
            },
            "downloads": -1,
            "filename": "Automatic_CV-1.0.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "23660070066dae8e8ae8d22eebdcb8e0",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.7",
            "size": 5677078,
            "upload_time": "2023-08-29T19:22:49",
            "upload_time_iso_8601": "2023-08-29T19:22:49.388976Z",
            "url": "https://files.pythonhosted.org/packages/ac/77/d7df84a5d0af5f4f4883affeced6a2822350fa889418a6ebc0787680ab3f/Automatic_CV-1.0.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "80fd78b4c10dba6372c673299cc33b95586f60864e11064f23ddd3370e672915",
                "md5": "c4a279f380ccc2b252e1e34208dc8c96",
                "sha256": "98e1923055397a8c08126896eee226a6107d7d6ebe2dece58d49c0aad11da912"
            },
            "downloads": -1,
            "filename": "Automatic-CV-1.0.0.tar.gz",
            "has_sig": false,
            "md5_digest": "c4a279f380ccc2b252e1e34208dc8c96",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.7",
            "size": 5610089,
            "upload_time": "2023-08-29T19:22:51",
            "upload_time_iso_8601": "2023-08-29T19:22:51.807668Z",
            "url": "https://files.pythonhosted.org/packages/80/fd/78b4c10dba6372c673299cc33b95586f60864e11064f23ddd3370e672915/Automatic-CV-1.0.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-08-29 19:22:51",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "DangerLin",
    "github_project": "Automatic-CV",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "automatic-cv"
}
        
Elapsed time: 0.47918s