Compare commits
No commits in common. "1eab463c48d14318857c6ae961ab4b5a0f5fdb1b" and "cfe805a5e7ebe2e6b67405dd050d9026a7914161" have entirely different histories.
1eab463c48
...
cfe805a5e7
|
@ -1 +0,0 @@
|
|||
__pycache__/
|
16
README.md
16
README.md
|
@ -1,16 +0,0 @@
|
|||
# errata
|
||||
|
||||
* In the function 'get_switching_step()', the documentation of the relevant command (Get Step 205_1 on p54) states that the returned array is 6 bytes long in the format
|
||||
* [0] = '205'
|
||||
* [1] = step_index
|
||||
* [2] = swtich_state
|
||||
* [3] = dwell_0
|
||||
* [4] = dwell_1
|
||||
* [5] = dwell_units
|
||||
* This arrangement is incorrect, at least for firmware version 'A3' which is all I have access to. The actual returned array is as follows:
|
||||
* [0] = '205'
|
||||
* [2] = swtich_state
|
||||
* [3] = dwell_0
|
||||
* [4] = dwell_1
|
||||
* [5] = dwell_units
|
||||
* This means that from the returned array alone the relevant step cannot be determined
|
121
SP4T.py
121
SP4T.py
|
@ -2,9 +2,6 @@
|
|||
# Author: George 'Joj' Travers
|
||||
#
|
||||
# Reference: https://www.minicircuits.com/softwaredownload/Prog_Manual-Solid_State_Switch.pdf
|
||||
#
|
||||
# command data is sent and recieved in decimal for some reason, don't ask why idk
|
||||
# ex: command 205_1 refers to the first two bytes sent in the 64-byte transmit array
|
||||
|
||||
def get_device_model(dev):
|
||||
# Returns the Mini-Circuits part number of the connected switch
|
||||
|
@ -105,123 +102,41 @@ def get_num_switching_steps(dev):
|
|||
def set_switching_step(dev, step_index, switch_state, dwell_0, dwell_1, dwell_units):
|
||||
# Configures the state and dwell time of a single step within the pre-defined switching sequence
|
||||
# command 204_1
|
||||
command = [204,1,step_index,switch_state,dwell_0,dwell_1,dwell_units]
|
||||
command = [204,1]
|
||||
|
||||
dev.write(0x01,command)
|
||||
ret_arr = dev.read(0x81,64)
|
||||
|
||||
if ret_arr[0] != 204 :
|
||||
return "Error: Invalid response"
|
||||
return "Switching step configured"
|
||||
|
||||
def get_switching_step(dev, step_index):
|
||||
# Returns the state and dwell time of a single step within the pre-defined switching sequence
|
||||
# command 205_1
|
||||
command = [205,1,step_index]
|
||||
|
||||
dev.write(0x01,command)
|
||||
ret_arr = dev.read(0x81,64)
|
||||
|
||||
if ret_arr[0] != 205 :
|
||||
return "Error: Invalid response"
|
||||
return ret_arr[:5]
|
||||
return f"Number of steps: {ret_arr[1]}"
|
||||
|
||||
def set_switching_direction(dev, direction):
|
||||
# Sets the direction in which the sequence of switch states which will be executed
|
||||
# command 204_2
|
||||
command = [204,2,direction]
|
||||
|
||||
dev.write(0x01,command)
|
||||
ret_arr = dev.read(0x81,64)
|
||||
def get_switching_step(dev):
|
||||
return
|
||||
|
||||
def set_switching_direction(dev):
|
||||
return
|
||||
|
||||
if ret_arr[0] != 204 :
|
||||
return "Error: Invalid response"
|
||||
return "Switching direction configured"
|
||||
|
||||
def get_switching_direction(dev):
|
||||
# Returns the direction in which the sequence of switch states will be executed
|
||||
# command 205_2
|
||||
command = [205,2]
|
||||
|
||||
dev.write(0x01,command)
|
||||
ret_arr = dev.read(0x81,64)
|
||||
|
||||
if ret_arr[0] != 205 :
|
||||
return "Error: Invalid response"
|
||||
|
||||
if ret_arr[1] == 0 :
|
||||
return "Forward"
|
||||
elif ret_arr[1] == 1 :
|
||||
return "Reverse"
|
||||
elif ret_arr[1] == 2 :
|
||||
return "Bi_Directional"
|
||||
else :
|
||||
return "Error: Invalid response"
|
||||
|
||||
def set_num_switching_cycles(dev, cycles_0, cycles_1):
|
||||
# Sets the number of times that the complete switching sequence will be executed
|
||||
# This setting will beignored if the switch sequence has been configured to execute in continuous mode
|
||||
# command 204_4
|
||||
command = [204,4,cycles_0,cycles_1]
|
||||
|
||||
dev.write(0x01,command)
|
||||
ret_arr = dev.read(0x81,64)
|
||||
|
||||
if ret_arr[0] != 204 :
|
||||
return "Error: Invalid response"
|
||||
return "Switching cycles configured"
|
||||
return
|
||||
|
||||
|
||||
def get_num_switching_cycles(dev):
|
||||
# Returns the number of times that the complete switching sequence will be executed
|
||||
# This setting will be ignored if the switch sequence has been configured to execute in continuous mode
|
||||
# command 205_4
|
||||
command = [205,4]
|
||||
def set_num_switching_cycles():
|
||||
return
|
||||
|
||||
dev.write(0x01,command)
|
||||
ret_arr = dev.read(0x81,64)
|
||||
|
||||
if ret_arr[0] != 205 :
|
||||
return "Error: Invalid response"
|
||||
return ret_arr[:3]
|
||||
def get_num_switching_cycles():
|
||||
return
|
||||
|
||||
def set_switching_mode(dev, mode):
|
||||
# Configures whether the switch sequence will be executed continuously or for a pre-defined number of cycles
|
||||
# With continuous mode enabled, the sequence will repeat from the time the sequence is enabled by the user until the time it is disabled by the user; the setting for number of cycles will be ignored
|
||||
# With continuous mode disabled the sequence will repeat according to the setting for number of cycle
|
||||
# command 204_3
|
||||
command = [204,3, mode]
|
||||
|
||||
dev.write(0x01,command)
|
||||
ret_arr = dev.read(0x81,64)
|
||||
def set_switching_mode():
|
||||
return
|
||||
|
||||
if ret_arr[0] != 204 :
|
||||
return "Error: Invalid response"
|
||||
return "Switching mode set"
|
||||
|
||||
def get_switching_mode(dev):
|
||||
# Indicates whether or not the switching sequence is configured to operate in continuous mode
|
||||
# With continuous mode enabled, the sequence will repeat from the time the sequence is enabled by the user until the time it is disabled by the user; the setting for number of cycles will be ignored
|
||||
# With continuous mode disabled the sequence will repeat according to the setting for number of cycles.
|
||||
# command 205_3
|
||||
command = [205,3]
|
||||
def get_switching_mode():
|
||||
return
|
||||
|
||||
dev.write(0x01,command)
|
||||
ret_arr = dev.read(0x81,64)
|
||||
|
||||
if ret_arr[0] != 205 :
|
||||
return "Error: Invalid response"
|
||||
return f"Continuous mode: {ret_arr[1]}"
|
||||
|
||||
def start_stop_switching_mode(dev, mode):
|
||||
# Starts or stops the pre-defined switching sequence
|
||||
# The sequence will not operate unless all required parameters have been configured correctly
|
||||
# command 204_5
|
||||
command = [204,5,mode]
|
||||
|
||||
dev.write(0x01,command)
|
||||
ret_arr = dev.read(0x81,64)
|
||||
|
||||
if ret_arr[0] != 204 :
|
||||
return "Error: Invalid response"
|
||||
return "Switching sequence set"
|
||||
def start_stop_switching_mode():
|
||||
return
|
||||
|
|
|
@ -1,47 +0,0 @@
|
|||
import usb.core, usb.util
|
||||
import sys
|
||||
|
||||
# import bindings from directory above example folder
|
||||
sys.path.append('../')
|
||||
from SP4T import *
|
||||
|
||||
# connect to USB device
|
||||
dev = usb.core.find(idVendor=0x20ce, idProduct=0x0022)
|
||||
|
||||
if dev is None:
|
||||
print("sad")
|
||||
raise ValueError('Device not found')
|
||||
|
||||
|
||||
for configuration in dev:
|
||||
for interface in configuration:
|
||||
ifnum = interface.bInterfaceNumber
|
||||
if not dev.is_kernel_driver_active(ifnum):
|
||||
continue
|
||||
try:
|
||||
dev.detach_kernel_driver(ifnum)
|
||||
except {usb.core.USBError, e}:
|
||||
pass
|
||||
|
||||
#set device config
|
||||
dev.set_configuration()
|
||||
|
||||
|
||||
|
||||
# testing bindings
|
||||
print(get_device_model(dev))
|
||||
|
||||
print(get_device_serial(dev))
|
||||
|
||||
print(get_sp4t_state(dev))
|
||||
print(set_sp4t_state(dev, 4))
|
||||
|
||||
print(get_sp4t_state(dev))
|
||||
print(get_firmware(dev))
|
||||
|
||||
print(get_num_switching_steps(dev))
|
||||
print(set_num_switching_steps(dev, 10))
|
||||
print(get_num_switching_steps(dev))
|
||||
print(set_switching_step(dev, 1, 3, 0, 5, 0))
|
||||
print(get_switching_step(dev, 1)) # returns step 1 switch settings
|
||||
print(get_switching_direction(dev))
|
Loading…
Reference in New Issue