python wrapper for I2C communications with ORCASEMI devices through FTDI
Project description
PYORCAI2C
INSTALL
pip install pyorcai2c
BASIC USAGE
import pyorcai2c
i2c = pyorcai2c.ftdi(b'SERIAL_NUMBER')
res = i2c.write(slave=ANY_NUMBER, target=ANY_NUMBER, data=ANY_NUMBER)
print(res)
res = i2c.read(slave=ANY_NUMBER, target=ANY_NUMBER)
print(res)
RETRIEVING FTDI BOARD SERIAL NUMBER
If you don't know the serial number of the FTDI board you are using do the following:
import ftd2xx
available_devices = ftd2xx.createDeviceInfoList()
available_devices = ftd2xx.listDevices()
OTHER FEATURES
i2c.write always requires the slave argument as a integer positive number. No other arguments are mandatory.
# ping slave
res = i2c.write(slave=ANY_NUMBER)
print(res)
# i2c command
res = i2c.write(slave=ANY_NUMBER, target=COMMAND_AS_A NUMBER)
print(res)
target argument of i2c.write can eiher be a single integer or a dictionary in the form address_as_integer: data_as_integer. i2c.write will optimize i2c communication by performing the minimum required number of burst write needed to complete the request.
If target argument of i2c.write is a number data argument is also needed. If target argument of i2c.write is an {int: int} dictionary the data argument will be ignored.
A burst read of n bytes can easely be performed through one of the following ways:
# read burts by specifing start address and number of bytes
res = i2c.read(slave=ANY_NUMBER, target=ANY_NUMBER, n=n)
print(res)
# read burst by specifing target as an array
res = i2c.read(slave=ANY_NUMBER, target=[ANY_NUMBER_1, ANY_NUMBER_2, ANY_NUMBER_3])
print(res)
target argument of i2c.read can eiher be a single integer or a list of integers. i2c.read will optimize i2c communication by performing the minimum required number of burst read needed to complete the request.
If target argument of i2c.read is a number n argument is defaulted to 1 if absent. If target argument of i2c.read is a list of integers the n argument will be ignored.
I2C COMMUNICATIONS BASED ON REGISTER MAP USAGE
To import ORCA products register map do the following:
import os
cwd = os.getcwd()
regmap_filepath = os.path.join(cwd, 'regmaps', 'xxx-register-map.json')
regmap = i2c.load_register_map(regmap_filepath)
Loading a register map will allow for both register based and field based communication.
res = i2c.write(slave=ANY_NUMBER, target=VALID_REGISTER_NAME, data=ANY_NUMBER)
print(res)
res = i2c.write(slave=ANY_NUMBER, target=VALID_FIELD_NAME, data=ANY_NUMBER)
print(res)
res = i2c.read(slave=ANY_NUMBER, target=VALID_REGISTER_NAME)
print(res)
res = i2c.read(slave=ANY_NUMBER, target=VALID_FIELD_NAME)
print(res)
UPDATING VERION
pip uninstall pyorcai2c
pip install pyorcai2c
DRYRUN MODE
to write to a local dummy file instead of using a real USB connected FTDI interface fro I2C instantiate the communication object with optional argument dryrun_mode=True (default=False) or use method set_dryrun_mode(True\False, [filepath])
# using custom dummy memory path and location
# 1st option
i2c = ftdi(FTDI_SERIAL_NUMBER, dryrun_mode=True)
# 2nd option
i2c.set_dryrun_mode(True)
# specifying custom dummy memory file
custom_dummy_memory_path = os.path.join(dummy_memory_folder, 'test_dummy_memory.json')
# 1st option
i2c = ftdi(FTDI_SERIAL_NUMBER, dryrun_mode=True, dummy_part_memory=custom_dummy_memory_path)
# 2nd option
i2c.set_dryrun_mode(True, custom_dummy_memory_path)
ADVANCED USAGE:
All of the above ways of communications can be mixed up without much restraint and in a pretty natural way. Mixing up integers, register_names of field_names as the target arguments.
The following strange calls will simply and just work. The module will take care of optimizing the I2C communications by minimizing it through as little burst commands as possible.
The module response structure will reflect the request for the data part of the response while the acks part will be based on starting register address of the burst command.
res = i2c.read(
slave=slave,
target=[
0x04,
0x02,
0x05,
0xA1,
0xA3,
0xA2,
0x06,
'ChargeCtrl1',
'ChargeCtrl2',
'LDO1Mode',
'LDO2Ctrl',
'LDO2Voltage',
'tst_bias_a',
'TstCntrl7',
'LDO1Voltage'
]
)
print(res)
res = i2c.write(
slave=slave,
target={
0x02:0xAA,
0x01:0xEA,
0x10:0xCD,
0x05:0xFE,
0x06:0xBB,
'LDO2Voltage':0x55,
'Buck1Ctrl2':0x33,
'unused_Buck1Ctrl2_b2':1,
'unused_Buck1Ctrl2_b4':1,
'unused_Buck1Ctrl2_b5':0,
'Buck1Ton':255,
'Buck1VRegA':0
}
)
print(res)
additional code examples:
You can find additional examples here: https://github.com/orcasemi/pyorcai2c/blob/main/tests/test.py and here: https://github.com/orcasemi/pyorcai2c/blob/main/tests/debug.py
co-development (ORCA DEVELOPMENT TEAM ONLY)
- clone the repository locally
git clone git@github.com:orcasemi/pyorcai2c.git
if you get an error about not having enough clearance to clone it please follow this tutorial to setup a github ssh-key and contact orcasemi github organization to be added as a member
- setup and activate virtual envinroment
cd pyorcai2c
python -m venv
- if you are on windows and you have never done that before you need to enable powershell to run scripts in order to activate the newly created virtual envinroment
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser
run that from an admin elevated powershell
- activate the virtual envinroment
.\venv\Scripts\activate
- run test
pyhton .\test\test.py
- publish on PyPI
py -m build
py -m twine upload --repository pypi dist/*
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pyorcai2c-0.0.8.tar.gz.
File metadata
- Download URL: pyorcai2c-0.0.8.tar.gz
- Upload date:
- Size: 92.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
70420120ed6243ec78bde444a00f2b37ab2dd7319f004be7a68515cee107bb1a
|
|
| MD5 |
f668e10a3bb3064cb66d566d5b5b9cbd
|
|
| BLAKE2b-256 |
2c0f57903d9cc6c39fe2d6075a676d5a74c566026c0b7b0506aa1056718c3ee5
|
File details
Details for the file pyorcai2c-0.0.8-py3-none-any.whl.
File metadata
- Download URL: pyorcai2c-0.0.8-py3-none-any.whl
- Upload date:
- Size: 10.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e70853d17a9849ad31abee30a5ac55e807f11362a3ea465b916a5fda21f98096
|
|
| MD5 |
43084d5ab257da984cc8365f1d4b80d2
|
|
| BLAKE2b-256 |
fe99c15efea9d37faabb8e65b9dd8b7de8da188858aab509a0a683270fea4922
|