2022-02-17 17:59:09 +00:00
# include "drivers/servo/servo.hpp"
# include "drivers/servo/servo_cluster.hpp"
# include <cstdio>
# define MP_OBJ_TO_PTR2(o, t) ((t *)(uintptr_t)(o))
2022-03-18 12:06:35 +00:00
using namespace pimoroni ;
2022-02-17 17:59:09 +00:00
using namespace servo ;
extern " C " {
# include "servo.h"
# include "py/builtin.h"
2022-02-18 18:15:15 +00:00
/********** Calibration **********/
/***** Variables Struct *****/
typedef struct _Calibration_obj_t {
mp_obj_base_t base ;
Calibration * calibration ;
} _Calibtration_obj_t ;
/***** Print *****/
void Calibration_print ( const mp_print_t * print , mp_obj_t self_in , mp_print_kind_t kind ) {
( void ) kind ; //Unused input parameter
_Calibtration_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Calibtration_obj_t ) ;
Calibration * calib = self - > calibration ;
mp_print_str ( print , " Calibration( " ) ;
uint size = calib - > size ( ) ;
mp_print_str ( print , " size = " ) ;
mp_obj_print_helper ( print , mp_obj_new_int ( size ) , PRINT_REPR ) ;
mp_print_str ( print , " , points = { " ) ;
for ( uint i = 0 ; i < size ; i + + ) {
Calibration : : Point * point = calib - > point_at ( i ) ;
2022-03-08 17:11:35 +00:00
mp_print_str ( print , " { " ) ;
2022-02-18 18:15:15 +00:00
mp_obj_print_helper ( print , mp_obj_new_float ( point - > pulse ) , PRINT_REPR ) ;
mp_print_str ( print , " , " ) ;
mp_obj_print_helper ( print , mp_obj_new_float ( point - > value ) , PRINT_REPR ) ;
mp_print_str ( print , " } " ) ;
if ( i < size - 1 )
mp_print_str ( print , " , " ) ;
}
2022-03-08 16:54:20 +00:00
mp_print_str ( print , " }, limit_lower = " ) ;
2022-03-08 14:26:57 +00:00
mp_obj_print_helper ( print , calib - > has_lower_limit ( ) ? mp_const_true : mp_const_false , PRINT_REPR ) ;
2022-03-08 16:54:20 +00:00
mp_print_str ( print , " , limit_upper = " ) ;
2022-03-08 14:26:57 +00:00
mp_obj_print_helper ( print , calib - > has_upper_limit ( ) ? mp_const_true : mp_const_false , PRINT_REPR ) ;
2022-03-08 15:18:45 +00:00
mp_print_str ( print , " ) " ) ;
2022-02-18 18:15:15 +00:00
}
/***** Constructor *****/
mp_obj_t Calibration_make_new ( const mp_obj_type_t * type , size_t n_args , size_t n_kw , const mp_obj_t * all_args ) {
_Calibtration_obj_t * self = nullptr ;
enum { ARG_type } ;
static const mp_arg_t allowed_args [ ] = {
2022-03-21 23:51:15 +00:00
{ MP_QSTR_type , MP_ARG_OBJ , { . u_obj = mp_const_none } } ,
2022-02-18 18:15:15 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all_kw_array ( n_args , n_kw , all_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
2022-03-21 23:51:15 +00:00
const mp_obj_t object = args [ ARG_type ] . u_obj ;
if ( object ! = mp_const_none ) {
if ( mp_obj_is_int ( object ) ) {
int type = mp_obj_get_int ( object ) ;
if ( type < 0 | | type > = 3 ) {
mp_raise_ValueError ( " type out of range. Expected ANGULAR (0), LINEAR (1) or CONTINUOUS (2) " ) ;
}
servo : : CalibrationType calibration_type = ( servo : : CalibrationType ) type ;
2022-02-18 18:15:15 +00:00
2022-03-21 23:51:15 +00:00
self = m_new_obj_with_finaliser ( _Calibtration_obj_t ) ;
self - > base . type = & Calibration_type ;
self - > calibration = new Calibration ( calibration_type ) ;
}
else {
mp_raise_TypeError ( " cannot convert object to an integer " ) ;
}
}
else {
self = m_new_obj_with_finaliser ( _Calibtration_obj_t ) ;
self - > base . type = & Calibration_type ;
self - > calibration = new Calibration ( ) ;
}
2022-02-18 18:15:15 +00:00
return MP_OBJ_FROM_PTR ( self ) ;
}
2022-03-08 14:26:57 +00:00
/***** Destructor ******/
mp_obj_t Calibration___del__ ( mp_obj_t self_in ) {
_Calibtration_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Calibtration_obj_t ) ;
2022-03-08 17:11:35 +00:00
delete self - > calibration ;
2022-03-08 14:26:57 +00:00
return mp_const_none ;
}
2022-02-18 18:15:15 +00:00
/***** Methods *****/
2022-03-21 23:51:15 +00:00
mp_obj_t Calibration_apply_blank ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-02-18 18:15:15 +00:00
enum { ARG_self , ARG_size } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_size , MP_ARG_REQUIRED | MP_ARG_INT } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
int size = args [ ARG_size ] . u_int ;
if ( size < 0 )
mp_raise_ValueError ( " size out of range. Expected 0 or greater " ) ;
else
2022-03-21 23:51:15 +00:00
self - > calibration - > apply_blank ( ( uint ) size ) ;
2022-02-18 18:15:15 +00:00
return mp_const_none ;
}
2022-03-21 23:51:15 +00:00
mp_obj_t Calibration_apply_two_point ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-02-18 18:15:15 +00:00
enum { ARG_self , ARG_min_pulse , ARG_max_pulse , ARG_min_value , ARG_max_value } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_min_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_max_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_min_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_max_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
float min_pulse = mp_obj_get_float ( args [ ARG_min_pulse ] . u_obj ) ;
float max_pulse = mp_obj_get_float ( args [ ARG_max_pulse ] . u_obj ) ;
float min_value = mp_obj_get_float ( args [ ARG_min_value ] . u_obj ) ;
float max_value = mp_obj_get_float ( args [ ARG_max_value ] . u_obj ) ;
2022-03-21 23:51:15 +00:00
self - > calibration - > apply_two_point ( min_pulse , max_pulse , min_value , max_value ) ;
2022-02-18 18:15:15 +00:00
return mp_const_none ;
}
2022-03-21 23:51:15 +00:00
mp_obj_t Calibration_apply_three_point ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-02-18 18:15:15 +00:00
enum { ARG_self , ARG_min_pulse , ARG_mid_pulse , ARG_max_pulse , ARG_min_value , ARG_mid_value , ARG_max_value } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_min_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_mid_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_max_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_min_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_mid_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_max_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
float min_pulse = mp_obj_get_float ( args [ ARG_min_pulse ] . u_obj ) ;
float mid_pulse = mp_obj_get_float ( args [ ARG_mid_pulse ] . u_obj ) ;
float max_pulse = mp_obj_get_float ( args [ ARG_max_pulse ] . u_obj ) ;
float min_value = mp_obj_get_float ( args [ ARG_min_value ] . u_obj ) ;
float mid_value = mp_obj_get_float ( args [ ARG_mid_value ] . u_obj ) ;
float max_value = mp_obj_get_float ( args [ ARG_max_value ] . u_obj ) ;
2022-03-21 23:51:15 +00:00
self - > calibration - > apply_three_point ( min_pulse , mid_pulse , max_pulse , min_value , mid_value , max_value ) ;
2022-02-18 18:15:15 +00:00
return mp_const_none ;
}
2022-03-21 23:51:15 +00:00
mp_obj_t Calibration_apply_uniform ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-02-18 18:15:15 +00:00
enum { ARG_self , ARG_size , ARG_min_pulse , ARG_max_pulse , ARG_min_value , ARG_max_value } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_size , MP_ARG_REQUIRED | MP_ARG_INT } ,
{ MP_QSTR_min_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_max_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_min_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_max_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
int size = args [ ARG_size ] . u_int ;
if ( size < 0 )
mp_raise_ValueError ( " size out of range. Expected 0 or greater " ) ;
else {
float min_pulse = mp_obj_get_float ( args [ ARG_min_pulse ] . u_obj ) ;
float max_pulse = mp_obj_get_float ( args [ ARG_max_pulse ] . u_obj ) ;
float min_value = mp_obj_get_float ( args [ ARG_min_value ] . u_obj ) ;
float max_value = mp_obj_get_float ( args [ ARG_max_value ] . u_obj ) ;
2022-03-21 23:51:15 +00:00
self - > calibration - > apply_uniform ( ( uint ) size , min_pulse , max_pulse , min_value , max_value ) ;
2022-02-18 18:15:15 +00:00
}
return mp_const_none ;
}
2022-03-21 23:51:15 +00:00
mp_obj_t Calibration_apply_default ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-02-18 18:15:15 +00:00
enum { ARG_self , ARG_type } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_type , MP_ARG_REQUIRED | MP_ARG_INT } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
2022-03-21 23:51:15 +00:00
int type = args [ ARG_type ] . u_int ;
if ( type < 0 | | type > = 3 ) {
mp_raise_ValueError ( " type out of range. Expected ANGULAR (0), LINEAR (1) or CONTINUOUS (2) " ) ;
}
servo : : CalibrationType calibration_type = ( servo : : CalibrationType ) type ;
self - > calibration - > apply_default ( calibration_type ) ;
2022-02-18 18:15:15 +00:00
return mp_const_none ;
}
mp_obj_t Calibration_size ( mp_obj_t self_in ) {
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Calibration_obj_t ) ;
return mp_obj_new_int ( self - > calibration - > size ( ) ) ;
}
mp_obj_t Calibration_point_at ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 2 ) {
enum { ARG_self , ARG_index } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_index , MP_ARG_REQUIRED | MP_ARG_INT } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
int index = args [ ARG_index ] . u_int ;
2022-03-08 14:26:57 +00:00
int calibration_size = ( int ) self - > calibration - > size ( ) ;
if ( calibration_size = = 0 )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
if ( index < 0 | | index > = calibration_size )
2022-03-10 17:09:06 +00:00
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " index out of range. Expected 0 to %d " ) , calibration_size - 1 ) ;
2022-02-18 18:15:15 +00:00
else {
Calibration : : Point * point = self - > calibration - > point_at ( ( uint ) index ) ;
2022-03-21 23:51:15 +00:00
mp_obj_t list = mp_obj_new_list ( 0 , NULL ) ;
mp_obj_list_append ( list , mp_obj_new_float ( point - > pulse ) ) ;
mp_obj_list_append ( list , mp_obj_new_float ( point - > value ) ) ;
return list ;
2022-02-18 18:15:15 +00:00
}
}
else {
enum { ARG_self , ARG_index , ARG_point } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_index , MP_ARG_REQUIRED | MP_ARG_INT } ,
{ MP_QSTR_point , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
int index = args [ ARG_index ] . u_int ;
2022-03-08 14:26:57 +00:00
int calibration_size = ( int ) self - > calibration - > size ( ) ;
if ( calibration_size = = 0 )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
if ( index < 0 | | index > = calibration_size )
2022-03-10 17:09:06 +00:00
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " index out of range. Expected 0 to %d " ) , calibration_size - 1 ) ;
2022-02-18 18:15:15 +00:00
else {
Calibration : : Point * point = self - > calibration - > point_at ( ( uint ) index ) ;
const mp_obj_t object = args [ ARG_point ] . u_obj ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
if ( list - > len = = 2 ) {
point - > pulse = mp_obj_get_float ( list - > items [ 0 ] ) ;
point - > value = mp_obj_get_float ( list - > items [ 1 ] ) ;
}
else {
mp_raise_ValueError ( " list must contain two numbers " ) ;
}
}
2022-03-21 23:51:15 +00:00
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
2022-02-18 18:15:15 +00:00
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
if ( tuple - > len = = 2 ) {
point - > pulse = mp_obj_get_float ( tuple - > items [ 0 ] ) ;
point - > value = mp_obj_get_float ( tuple - > items [ 1 ] ) ;
}
else {
mp_raise_ValueError ( " tuple must contain two numbers " ) ;
}
}
else {
mp_raise_TypeError ( " can't convert object to list or tuple " ) ;
}
}
}
2022-03-08 14:26:57 +00:00
return mp_const_none ;
2022-02-18 18:15:15 +00:00
}
2022-03-21 23:51:15 +00:00
mp_obj_t Calibration_pulse_at ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 2 ) {
enum { ARG_self , ARG_index } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_index , MP_ARG_REQUIRED | MP_ARG_INT } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
int index = args [ ARG_index ] . u_int ;
int calibration_size = ( int ) self - > calibration - > size ( ) ;
if ( calibration_size = = 0 )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
if ( index < 0 | | index > = calibration_size )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " index out of range. Expected 0 to %d " ) , calibration_size - 1 ) ;
else {
Calibration : : Point * point = self - > calibration - > point_at ( ( uint ) index ) ;
return mp_obj_new_float ( point - > pulse ) ;
}
}
else {
enum { ARG_self , ARG_index , ARG_pulse } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_index , MP_ARG_REQUIRED | MP_ARG_INT } ,
{ MP_QSTR_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
int index = args [ ARG_index ] . u_int ;
int calibration_size = ( int ) self - > calibration - > size ( ) ;
if ( calibration_size = = 0 )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
if ( index < 0 | | index > = calibration_size )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " index out of range. Expected 0 to %d " ) , calibration_size - 1 ) ;
else {
Calibration : : Point * point = self - > calibration - > point_at ( ( uint ) index ) ;
point - > pulse = mp_obj_get_float ( args [ ARG_pulse ] . u_obj ) ;
}
}
return mp_const_none ;
}
mp_obj_t Calibration_value_at ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 2 ) {
enum { ARG_self , ARG_index } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_index , MP_ARG_REQUIRED | MP_ARG_INT } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
int index = args [ ARG_index ] . u_int ;
int calibration_size = ( int ) self - > calibration - > size ( ) ;
if ( calibration_size = = 0 )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
if ( index < 0 | | index > = calibration_size )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " index out of range. Expected 0 to %d " ) , calibration_size - 1 ) ;
else {
Calibration : : Point * point = self - > calibration - > point_at ( ( uint ) index ) ;
return mp_obj_new_float ( point - > value ) ;
}
}
else {
enum { ARG_self , ARG_index , ARG_value } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_index , MP_ARG_REQUIRED | MP_ARG_INT } ,
{ MP_QSTR_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
int index = args [ ARG_index ] . u_int ;
int calibration_size = ( int ) self - > calibration - > size ( ) ;
if ( calibration_size = = 0 )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
if ( index < 0 | | index > = calibration_size )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " index out of range. Expected 0 to %d " ) , calibration_size - 1 ) ;
else {
Calibration : : Point * point = self - > calibration - > point_at ( ( uint ) index ) ;
point - > value = mp_obj_get_float ( args [ ARG_value ] . u_obj ) ;
}
}
return mp_const_none ;
}
2022-02-18 18:15:15 +00:00
mp_obj_t Calibration_first_point ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 1 ) {
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
Calibration : : Point * point = self - > calibration - > first_point ( ) ;
2022-03-08 14:26:57 +00:00
if ( point = = nullptr )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
else {
2022-03-21 23:51:15 +00:00
mp_obj_t list = mp_obj_new_list ( 0 , NULL ) ;
mp_obj_list_append ( list , mp_obj_new_float ( point - > pulse ) ) ;
mp_obj_list_append ( list , mp_obj_new_float ( point - > value ) ) ;
return list ;
2022-03-08 14:26:57 +00:00
}
2022-02-18 18:15:15 +00:00
}
else {
enum { ARG_self , ARG_point } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_point , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
Calibration : : Point * point = self - > calibration - > first_point ( ) ;
2022-03-08 14:26:57 +00:00
if ( point = = nullptr )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
else {
const mp_obj_t object = args [ ARG_point ] . u_obj ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
if ( list - > len = = 2 ) {
point - > pulse = mp_obj_get_float ( list - > items [ 0 ] ) ;
point - > value = mp_obj_get_float ( list - > items [ 1 ] ) ;
}
else {
mp_raise_ValueError ( " list must contain two numbers " ) ;
}
2022-02-18 18:15:15 +00:00
}
2022-03-21 23:51:15 +00:00
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
2022-03-08 14:26:57 +00:00
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
if ( tuple - > len = = 2 ) {
point - > pulse = mp_obj_get_float ( tuple - > items [ 0 ] ) ;
point - > value = mp_obj_get_float ( tuple - > items [ 1 ] ) ;
}
else {
mp_raise_ValueError ( " tuple must contain two numbers " ) ;
}
2022-02-18 18:15:15 +00:00
}
else {
2022-03-08 14:26:57 +00:00
mp_raise_TypeError ( " can't convert object to list or tuple " ) ;
2022-02-18 18:15:15 +00:00
}
}
}
2022-03-08 14:26:57 +00:00
return mp_const_none ;
2022-02-18 18:15:15 +00:00
}
2022-03-21 23:51:15 +00:00
mp_obj_t Calibration_first_pulse ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 1 ) {
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
Calibration : : Point * point = self - > calibration - > first_point ( ) ;
if ( point = = nullptr )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
else {
return mp_obj_new_float ( point - > pulse ) ;
}
}
else {
enum { ARG_self , ARG_pulse } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
Calibration : : Point * point = self - > calibration - > first_point ( ) ;
if ( point = = nullptr )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
else {
point - > pulse = mp_obj_get_float ( args [ ARG_pulse ] . u_obj ) ;
}
}
return mp_const_none ;
}
mp_obj_t Calibration_first_value ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 1 ) {
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
Calibration : : Point * point = self - > calibration - > first_point ( ) ;
if ( point = = nullptr )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
else {
return mp_obj_new_float ( point - > value ) ;
}
}
else {
enum { ARG_self , ARG_value } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
Calibration : : Point * point = self - > calibration - > first_point ( ) ;
if ( point = = nullptr )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
else {
point - > value = mp_obj_get_float ( args [ ARG_value ] . u_obj ) ;
}
}
return mp_const_none ;
}
2022-02-18 18:15:15 +00:00
mp_obj_t Calibration_last_point ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 1 ) {
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
Calibration : : Point * point = self - > calibration - > last_point ( ) ;
2022-03-08 14:26:57 +00:00
if ( point = = nullptr )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
else {
2022-03-21 23:51:15 +00:00
mp_obj_t list = mp_obj_new_list ( 0 , NULL ) ;
mp_obj_list_append ( list , mp_obj_new_float ( point - > pulse ) ) ;
mp_obj_list_append ( list , mp_obj_new_float ( point - > value ) ) ;
return list ;
2022-03-08 14:26:57 +00:00
}
2022-02-18 18:15:15 +00:00
}
else {
enum { ARG_self , ARG_point } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_point , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
Calibration : : Point * point = self - > calibration - > last_point ( ) ;
2022-03-08 14:26:57 +00:00
if ( point = = nullptr )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
else {
const mp_obj_t object = args [ ARG_point ] . u_obj ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
if ( list - > len = = 2 ) {
point - > pulse = mp_obj_get_float ( list - > items [ 0 ] ) ;
point - > value = mp_obj_get_float ( list - > items [ 1 ] ) ;
}
else {
mp_raise_ValueError ( " list must contain two numbers " ) ;
}
2022-02-18 18:15:15 +00:00
}
2022-03-21 23:51:15 +00:00
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
2022-03-08 14:26:57 +00:00
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
if ( tuple - > len = = 2 ) {
point - > pulse = mp_obj_get_float ( tuple - > items [ 0 ] ) ;
point - > value = mp_obj_get_float ( tuple - > items [ 1 ] ) ;
}
else {
mp_raise_ValueError ( " tuple must contain two numbers " ) ;
}
2022-02-18 18:15:15 +00:00
}
else {
2022-03-08 14:26:57 +00:00
mp_raise_TypeError ( " can't convert object to list or tuple " ) ;
2022-02-18 18:15:15 +00:00
}
}
}
2022-03-08 14:26:57 +00:00
return mp_const_none ;
}
2022-03-21 23:51:15 +00:00
mp_obj_t Calibration_last_pulse ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 1 ) {
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
Calibration : : Point * point = self - > calibration - > last_point ( ) ;
if ( point = = nullptr )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
else {
return mp_obj_new_float ( point - > pulse ) ;
}
}
else {
enum { ARG_self , ARG_pulse } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
Calibration : : Point * point = self - > calibration - > last_point ( ) ;
if ( point = = nullptr )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
else {
point - > pulse = mp_obj_get_float ( args [ ARG_pulse ] . u_obj ) ;
}
}
return mp_const_none ;
}
mp_obj_t Calibration_last_value ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 1 ) {
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
Calibration : : Point * point = self - > calibration - > last_point ( ) ;
if ( point = = nullptr )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
else {
return mp_obj_new_float ( point - > value ) ;
}
}
else {
enum { ARG_self , ARG_value } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
Calibration : : Point * point = self - > calibration - > last_point ( ) ;
if ( point = = nullptr )
mp_raise_ValueError ( " this calibration does not have any points " ) ;
else {
point - > value = mp_obj_get_float ( args [ ARG_value ] . u_obj ) ;
}
}
return mp_const_none ;
}
2022-03-08 14:26:57 +00:00
mp_obj_t Calibration_has_lower_limit ( mp_obj_t self_in ) {
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Calibration_obj_t ) ;
return self - > calibration - > has_lower_limit ( ) ? mp_const_true : mp_const_false ;
}
mp_obj_t Calibration_has_upper_limit ( mp_obj_t self_in ) {
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Calibration_obj_t ) ;
return self - > calibration - > has_upper_limit ( ) ? mp_const_true : mp_const_false ;
2022-02-18 18:15:15 +00:00
}
mp_obj_t Calibration_limit_to_calibration ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
enum { ARG_self , ARG_lower , ARG_upper } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_lower , MP_ARG_REQUIRED | MP_ARG_BOOL } ,
{ MP_QSTR_upper , MP_ARG_REQUIRED | MP_ARG_BOOL } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
bool lower = args [ ARG_lower ] . u_bool ;
bool upper = args [ ARG_upper ] . u_bool ;
self - > calibration - > limit_to_calibration ( lower , upper ) ;
return mp_const_none ;
}
mp_obj_t Calibration_value_to_pulse ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
enum { ARG_self , ARG_value } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
float value = mp_obj_get_float ( args [ ARG_value ] . u_obj ) ;
2022-02-19 19:25:15 +00:00
float pulse_out , value_out ;
if ( self - > calibration - > value_to_pulse ( value , pulse_out , value_out ) ) {
mp_obj_t tuple [ 2 ] ;
tuple [ 0 ] = mp_obj_new_float ( pulse_out ) ;
tuple [ 1 ] = mp_obj_new_float ( value_out ) ;
return mp_obj_new_tuple ( 2 , tuple ) ;
}
else {
2022-03-08 14:26:57 +00:00
mp_raise_msg ( & mp_type_RuntimeError , " Unable to convert value to pulse. Calibration needs at least 2 points " ) ;
2022-02-19 19:25:15 +00:00
}
return mp_const_none ;
2022-02-18 18:15:15 +00:00
}
2022-02-19 20:13:18 +00:00
mp_obj_t Calibration_pulse_to_value ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-02-18 18:15:15 +00:00
enum { ARG_self , ARG_pulse } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Calibration_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Calibration_obj_t ) ;
float pulse = mp_obj_get_float ( args [ ARG_pulse ] . u_obj ) ;
2022-02-19 19:25:15 +00:00
float value_out , pulse_out ;
2022-02-19 20:13:18 +00:00
if ( self - > calibration - > pulse_to_value ( pulse , value_out , pulse_out ) ) {
2022-02-19 19:25:15 +00:00
mp_obj_t tuple [ 2 ] ;
tuple [ 0 ] = mp_obj_new_float ( pulse_out ) ;
tuple [ 1 ] = mp_obj_new_float ( value_out ) ;
return mp_obj_new_tuple ( 2 , tuple ) ;
}
else {
2022-03-08 14:26:57 +00:00
mp_raise_msg ( & mp_type_RuntimeError , " Unable to convert pulse to value. Calibration needs at least 2 points " ) ;
2022-02-19 19:25:15 +00:00
}
return mp_const_none ;
2022-02-18 18:15:15 +00:00
}
2022-02-17 17:59:09 +00:00
/********** Servo **********/
/***** Variables Struct *****/
typedef struct _Servo_obj_t {
mp_obj_base_t base ;
Servo * servo ;
} _Servo_obj_t ;
/***** Print *****/
void Servo_print ( const mp_print_t * print , mp_obj_t self_in , mp_print_kind_t kind ) {
( void ) kind ; //Unused input parameter
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Servo_obj_t ) ;
mp_print_str ( print , " Servo( " ) ;
mp_print_str ( print , " pin = " ) ;
mp_obj_print_helper ( print , mp_obj_new_int ( self - > servo - > get_pin ( ) ) , PRINT_REPR ) ;
2022-02-19 01:07:19 +00:00
mp_print_str ( print , " , enabled = " ) ;
mp_obj_print_helper ( print , self - > servo - > is_enabled ( ) ? mp_const_true : mp_const_false , PRINT_REPR ) ;
2022-02-17 17:59:09 +00:00
mp_print_str ( print , " , pulse = " ) ;
mp_obj_print_helper ( print , mp_obj_new_float ( self - > servo - > get_pulse ( ) ) , PRINT_REPR ) ;
2022-02-18 18:15:15 +00:00
mp_print_str ( print , " , value = " ) ;
mp_obj_print_helper ( print , mp_obj_new_float ( self - > servo - > get_value ( ) ) , PRINT_REPR ) ;
2022-02-19 01:07:19 +00:00
mp_print_str ( print , " , freq = " ) ;
mp_obj_print_helper ( print , mp_obj_new_float ( self - > servo - > get_frequency ( ) ) , PRINT_REPR ) ;
2022-02-17 17:59:09 +00:00
mp_print_str ( print , " ) " ) ;
}
/***** Constructor *****/
mp_obj_t Servo_make_new ( const mp_obj_type_t * type , size_t n_args , size_t n_kw , const mp_obj_t * all_args ) {
_Servo_obj_t * self = nullptr ;
2022-03-21 23:51:15 +00:00
enum { ARG_pin , ARG_calibration , ARG_freq } ;
2022-02-17 17:59:09 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_pin , MP_ARG_REQUIRED | MP_ARG_INT } ,
2022-03-21 23:51:15 +00:00
{ MP_QSTR_calibration , MP_ARG_OBJ , { . u_obj = mp_const_none } } ,
2022-03-02 18:59:17 +00:00
{ MP_QSTR_freq , MP_ARG_OBJ , { . u_obj = mp_const_none } } ,
2022-02-17 17:59:09 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all_kw_array ( n_args , n_kw , all_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
int pin = args [ ARG_pin ] . u_int ;
2022-03-21 23:51:15 +00:00
servo : : Calibration * calib = nullptr ;
servo : : CalibrationType calibration_type = servo : : CalibrationType : : ANGULAR ;
const mp_obj_t calib_object = args [ ARG_calibration ] . u_obj ;
if ( calib_object ! = mp_const_none ) {
if ( mp_obj_is_int ( calib_object ) ) {
int type = mp_obj_get_int ( calib_object ) ;
if ( type < 0 | | type > = 3 ) {
mp_raise_ValueError ( " type out of range. Expected ANGULAR (0), LINEAR (1) or CONTINUOUS (2) " ) ;
}
calibration_type = ( servo : : CalibrationType ) type ;
}
else if ( mp_obj_is_type ( calib_object , & Calibration_type ) ) {
calib = ( MP_OBJ_TO_PTR2 ( calib_object , _Calibration_obj_t ) - > calibration ) ;
}
else {
mp_raise_TypeError ( " cannot convert object to an integer or a Calibration class instance " ) ;
}
}
2022-02-17 17:59:09 +00:00
2022-03-02 18:59:17 +00:00
float freq = servo : : ServoState : : DEFAULT_FREQUENCY ;
if ( args [ ARG_freq ] . u_obj ! = mp_const_none ) {
freq = mp_obj_get_float ( args [ ARG_freq ] . u_obj ) ;
}
2022-02-17 17:59:09 +00:00
self = m_new_obj_with_finaliser ( _Servo_obj_t ) ;
self - > base . type = & Servo_type ;
2022-03-21 23:51:15 +00:00
if ( calib ! = nullptr )
self - > servo = new Servo ( pin , * calib , freq ) ;
else
self - > servo = new Servo ( pin , calibration_type , freq ) ;
2022-02-17 17:59:09 +00:00
self - > servo - > init ( ) ;
return MP_OBJ_FROM_PTR ( self ) ;
}
2022-03-08 14:26:57 +00:00
/***** Destructor ******/
mp_obj_t Servo___del__ ( mp_obj_t self_in ) {
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Servo_obj_t ) ;
delete self - > servo ;
return mp_const_none ;
}
2022-02-18 18:15:15 +00:00
/***** Methods *****/
extern mp_obj_t Servo_pin ( mp_obj_t self_in ) {
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Servo_obj_t ) ;
return mp_obj_new_int ( self - > servo - > get_pin ( ) ) ;
}
2022-02-17 17:59:09 +00:00
extern mp_obj_t Servo_enable ( mp_obj_t self_in ) {
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Servo_obj_t ) ;
self - > servo - > enable ( ) ;
return mp_const_none ;
}
extern mp_obj_t Servo_disable ( mp_obj_t self_in ) {
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Servo_obj_t ) ;
self - > servo - > disable ( ) ;
return mp_const_none ;
}
extern mp_obj_t Servo_is_enabled ( mp_obj_t self_in ) {
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Servo_obj_t ) ;
return self - > servo - > is_enabled ( ) ? mp_const_true : mp_const_false ;
}
2022-03-08 14:26:57 +00:00
extern mp_obj_t Servo_pulse ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-02-17 17:59:09 +00:00
if ( n_args < = 1 ) {
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Servo_obj_t ) ;
2022-03-08 14:26:57 +00:00
return mp_obj_new_float ( self - > servo - > get_pulse ( ) ) ;
2022-02-17 17:59:09 +00:00
}
else {
2022-03-08 14:26:57 +00:00
enum { ARG_self , ARG_pulse } ;
2022-02-17 17:59:09 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-08 14:26:57 +00:00
{ MP_QSTR_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-02-17 17:59:09 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Servo_obj_t ) ;
2022-03-08 14:26:57 +00:00
float pulse = mp_obj_get_float ( args [ ARG_pulse ] . u_obj ) ;
2022-02-17 17:59:09 +00:00
2022-03-08 14:26:57 +00:00
self - > servo - > set_pulse ( pulse ) ;
2022-02-17 17:59:09 +00:00
return mp_const_none ;
}
}
2022-03-08 14:26:57 +00:00
extern mp_obj_t Servo_value ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-02-17 17:59:09 +00:00
if ( n_args < = 1 ) {
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Servo_obj_t ) ;
2022-03-08 14:26:57 +00:00
return mp_obj_new_float ( self - > servo - > get_value ( ) ) ;
2022-02-17 17:59:09 +00:00
}
else {
2022-03-08 14:26:57 +00:00
enum { ARG_self , ARG_value } ;
2022-02-17 17:59:09 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-08 14:26:57 +00:00
{ MP_QSTR_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-02-17 17:59:09 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Servo_obj_t ) ;
2022-03-08 14:26:57 +00:00
float value = mp_obj_get_float ( args [ ARG_value ] . u_obj ) ;
2022-02-17 17:59:09 +00:00
2022-03-08 14:26:57 +00:00
self - > servo - > set_value ( value ) ;
2022-02-17 17:59:09 +00:00
return mp_const_none ;
}
}
2022-02-19 01:07:19 +00:00
extern mp_obj_t Servo_frequency ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 1 ) {
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Servo_obj_t ) ;
return mp_obj_new_float ( self - > servo - > get_frequency ( ) ) ;
}
else {
enum { ARG_self , ARG_freq } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_freq , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Servo_obj_t ) ;
float freq = mp_obj_get_float ( args [ ARG_freq ] . u_obj ) ;
2022-03-08 14:26:57 +00:00
if ( ! self - > servo - > set_frequency ( freq ) ) {
2022-02-19 18:16:37 +00:00
mp_raise_ValueError ( " freq out of range. Expected 10Hz to 350Hz " ) ;
2022-03-08 14:26:57 +00:00
}
return mp_const_none ;
2022-02-19 01:07:19 +00:00
}
}
2022-02-18 18:15:15 +00:00
extern mp_obj_t Servo_min_value ( mp_obj_t self_in ) {
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Servo_obj_t ) ;
return mp_obj_new_float ( self - > servo - > get_min_value ( ) ) ;
}
extern mp_obj_t Servo_mid_value ( mp_obj_t self_in ) {
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Servo_obj_t ) ;
return mp_obj_new_float ( self - > servo - > get_mid_value ( ) ) ;
}
extern mp_obj_t Servo_max_value ( mp_obj_t self_in ) {
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Servo_obj_t ) ;
return mp_obj_new_float ( self - > servo - > get_max_value ( ) ) ;
}
2022-02-17 17:59:09 +00:00
extern mp_obj_t Servo_to_min ( mp_obj_t self_in ) {
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Servo_obj_t ) ;
self - > servo - > to_min ( ) ;
return mp_const_none ;
}
extern mp_obj_t Servo_to_mid ( mp_obj_t self_in ) {
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Servo_obj_t ) ;
self - > servo - > to_mid ( ) ;
return mp_const_none ;
}
extern mp_obj_t Servo_to_max ( mp_obj_t self_in ) {
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _Servo_obj_t ) ;
self - > servo - > to_max ( ) ;
return mp_const_none ;
}
extern mp_obj_t Servo_to_percent ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 2 ) {
enum { ARG_self , ARG_in } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Servo_obj_t ) ;
float in = mp_obj_get_float ( args [ ARG_in ] . u_obj ) ;
self - > servo - > to_percent ( in ) ;
}
else if ( n_args < = 4 ) {
enum { ARG_self , ARG_in , ARG_in_min , ARG_in_max } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in_min , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in_max , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Servo_obj_t ) ;
float in = mp_obj_get_float ( args [ ARG_in ] . u_obj ) ;
float in_min = mp_obj_get_float ( args [ ARG_in_min ] . u_obj ) ;
float in_max = mp_obj_get_float ( args [ ARG_in_max ] . u_obj ) ;
self - > servo - > to_percent ( in , in_min , in_max ) ;
}
else {
enum { ARG_self , ARG_in , ARG_in_min , ARG_in_max , ARG_value_min , ARG_value_max } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in_min , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in_max , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_value_min , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_value_max , MP_ARG_REQUIRED | MP_ARG_OBJ }
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Servo_obj_t ) ;
float in = mp_obj_get_float ( args [ ARG_in ] . u_obj ) ;
float in_min = mp_obj_get_float ( args [ ARG_in_min ] . u_obj ) ;
float in_max = mp_obj_get_float ( args [ ARG_in_max ] . u_obj ) ;
float value_min = mp_obj_get_float ( args [ ARG_value_min ] . u_obj ) ;
float value_max = mp_obj_get_float ( args [ ARG_value_max ] . u_obj ) ;
self - > servo - > to_percent ( in , in_min , in_max , value_min , value_max ) ;
}
2022-03-08 14:26:57 +00:00
2022-02-17 17:59:09 +00:00
return mp_const_none ;
}
2022-03-08 16:54:20 +00:00
extern mp_obj_t Servo_calibration ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 1 ) {
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Servo_obj_t ) ;
2022-02-18 18:15:15 +00:00
2022-03-08 17:11:35 +00:00
// Create a new MP Calibration instance and assign a copy of the servo's calibration to it
2022-03-08 16:54:20 +00:00
_Calibration_obj_t * calib = m_new_obj_with_finaliser ( _Calibration_obj_t ) ;
calib - > base . type = & Calibration_type ;
2022-03-08 17:11:35 +00:00
calib - > calibration = new Calibration ( self - > servo - > calibration ( ) ) ;
2022-03-08 16:54:20 +00:00
return MP_OBJ_FROM_PTR ( calib ) ;
}
else {
enum { ARG_self , ARG_calibration } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_calibration , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_Servo_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _Servo_obj_t ) ;
const mp_obj_t object = args [ ARG_calibration ] . u_obj ;
if ( mp_obj_is_type ( object , & Calibration_type ) ) {
_Calibration_obj_t * calib = MP_OBJ_TO_PTR2 ( object , _Calibration_obj_t ) ;
self - > servo - > calibration ( ) = * ( calib - > calibration ) ;
}
else {
mp_raise_TypeError ( " cannot convert object to a Calibration class instance " ) ;
}
}
return mp_const_none ;
2022-02-18 18:15:15 +00:00
}
2022-02-17 17:59:09 +00:00
/********** ServoCluster **********/
/***** Variables Struct *****/
typedef struct _ServoCluster_obj_t {
mp_obj_base_t base ;
ServoCluster * cluster ;
2022-03-18 12:06:35 +00:00
PWMCluster : : Sequence * seq_buf ;
PWMCluster : : TransitionData * dat_buf ;
2022-02-17 17:59:09 +00:00
} _ServoCluster_obj_t ;
/***** Print *****/
void ServoCluster_print ( const mp_print_t * print , mp_obj_t self_in , mp_print_kind_t kind ) {
( void ) kind ; //Unused input parameter
2022-02-21 00:04:36 +00:00
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _ServoCluster_obj_t ) ;
2022-02-17 17:59:09 +00:00
mp_print_str ( print , " ServoCluster( " ) ;
2022-03-08 14:26:57 +00:00
mp_print_str ( print , " servos = { " ) ;
2022-03-07 22:27:43 +00:00
uint8_t servo_count = self - > cluster - > get_count ( ) ;
for ( uint8_t servo = 0 ; servo < servo_count ; servo + + ) {
2022-03-08 15:18:45 +00:00
mp_print_str ( print , " \n \t {pin = " ) ;
2022-03-08 14:26:57 +00:00
mp_obj_print_helper ( print , mp_obj_new_int ( self - > cluster - > get_pin ( servo ) ) , PRINT_REPR ) ;
mp_print_str ( print , " , enabled = " ) ;
mp_obj_print_helper ( print , self - > cluster - > is_enabled ( servo ) ? mp_const_true : mp_const_false , PRINT_REPR ) ;
mp_print_str ( print , " , pulse = " ) ;
mp_obj_print_helper ( print , mp_obj_new_float ( self - > cluster - > get_pulse ( servo ) ) , PRINT_REPR ) ;
mp_print_str ( print , " , value = " ) ;
mp_obj_print_helper ( print , mp_obj_new_float ( self - > cluster - > get_value ( servo ) ) , PRINT_REPR ) ;
mp_print_str ( print , " , phase = " ) ;
mp_obj_print_helper ( print , mp_obj_new_float ( self - > cluster - > get_phase ( servo ) ) , PRINT_REPR ) ;
mp_print_str ( print , " } " ) ;
2022-03-08 15:18:45 +00:00
if ( servo < servo_count - 1 )
mp_print_str ( print , " , " ) ;
}
if ( servo_count > 0 ) {
mp_print_str ( print , " \n " ) ;
2022-02-21 00:04:36 +00:00
}
2022-03-02 18:59:17 +00:00
mp_print_str ( print , " }, freq = " ) ;
mp_obj_print_helper ( print , mp_obj_new_float ( self - > cluster - > get_frequency ( ) ) , PRINT_REPR ) ;
2022-02-17 17:59:09 +00:00
2022-03-02 18:59:17 +00:00
mp_print_str ( print , " ) " ) ;
2022-02-17 17:59:09 +00:00
}
/***** Constructor *****/
mp_obj_t ServoCluster_make_new ( const mp_obj_type_t * type , size_t n_args , size_t n_kw , const mp_obj_t * all_args ) {
_ServoCluster_obj_t * self = nullptr ;
2022-03-21 23:51:15 +00:00
enum { ARG_pio , ARG_sm , ARG_pins , ARG_calibration , ARG_freq , ARG_auto_phase } ;
2022-02-17 17:59:09 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_pio , MP_ARG_REQUIRED | MP_ARG_INT } ,
{ MP_QSTR_sm , MP_ARG_REQUIRED | MP_ARG_INT } ,
2022-03-08 14:26:57 +00:00
{ MP_QSTR_pins , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-21 23:51:15 +00:00
{ MP_QSTR_calibration , MP_ARG_OBJ , { . u_obj = mp_const_none } } ,
2022-03-02 18:59:17 +00:00
{ MP_QSTR_freq , MP_ARG_OBJ , { . u_obj = mp_const_none } } ,
2022-03-08 14:26:57 +00:00
{ MP_QSTR_auto_phase , MP_ARG_BOOL , { . u_bool = true } } ,
2022-02-17 17:59:09 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all_kw_array ( n_args , n_kw , all_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
PIO pio = args [ ARG_pio ] . u_int = = 0 ? pio0 : pio1 ;
int sm = args [ ARG_sm ] . u_int ;
2022-03-08 14:26:57 +00:00
uint pin_mask = 0 ;
bool mask_provided = true ;
uint32_t pin_count = 0 ;
uint8_t * pins = nullptr ;
// Determine what pins this cluster will use
const mp_obj_t object = args [ ARG_pins ] . u_obj ;
2022-03-08 15:18:45 +00:00
if ( mp_obj_is_int ( object ) ) {
2022-03-08 14:26:57 +00:00
pin_mask = ( uint ) mp_obj_get_int ( object ) ;
}
2022-03-10 17:09:06 +00:00
else {
mp_obj_t * items = nullptr ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
pin_count = list - > len ;
items = list - > items ;
2022-03-08 14:26:57 +00:00
}
2022-03-10 17:09:06 +00:00
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
pin_count = tuple - > len ;
items = tuple - > items ;
}
if ( items = = nullptr )
mp_raise_TypeError ( " cannot convert object to a list or tuple of pins, or a pin mask integer " ) ;
else if ( pin_count = = 0 )
mp_raise_TypeError ( " list or tuple must contain at least one integer " ) ;
else {
2022-03-08 14:26:57 +00:00
// Create and populate a local array of pins
2022-03-10 18:17:42 +00:00
pins = new uint8_t [ pin_count ] ;
2022-03-10 17:09:06 +00:00
for ( size_t i = 0 ; i < pin_count ; i + + ) {
int pin = mp_obj_get_int ( items [ i ] ) ;
if ( pin < 0 | | pin > = ( int ) NUM_BANK0_GPIOS ) {
delete [ ] pins ;
mp_raise_ValueError ( " a pin in the list or tuple is out of range. Expected 0 to 29 " ) ;
2022-03-08 14:26:57 +00:00
}
else {
2022-03-10 17:09:06 +00:00
pins [ i ] = ( uint8_t ) pin ;
2022-03-08 14:26:57 +00:00
}
}
mask_provided = false ;
}
}
2022-03-21 23:51:15 +00:00
servo : : Calibration * calib = nullptr ;
servo : : CalibrationType calibration_type = servo : : CalibrationType : : ANGULAR ;
const mp_obj_t calib_object = args [ ARG_calibration ] . u_obj ;
if ( calib_object ! = mp_const_none ) {
if ( mp_obj_is_int ( calib_object ) ) {
int type = mp_obj_get_int ( calib_object ) ;
if ( type < 0 | | type > = 3 ) {
mp_raise_ValueError ( " type out of range. Expected ANGULAR (0), LINEAR (1) or CONTINUOUS (2) " ) ;
}
calibration_type = ( servo : : CalibrationType ) mp_obj_get_int ( calib_object ) ;
}
else if ( mp_obj_is_type ( calib_object , & Calibration_type ) ) {
calib = ( MP_OBJ_TO_PTR2 ( calib_object , _Calibration_obj_t ) - > calibration ) ;
}
else {
mp_raise_TypeError ( " cannot convert object to an integer or a Calibration class instance " ) ;
}
}
2022-03-02 18:59:17 +00:00
float freq = servo : : ServoState : : DEFAULT_FREQUENCY ;
if ( args [ ARG_freq ] . u_obj ! = mp_const_none ) {
freq = mp_obj_get_float ( args [ ARG_freq ] . u_obj ) ;
}
2022-02-17 17:59:09 +00:00
2022-03-08 14:26:57 +00:00
bool auto_phase = args [ ARG_auto_phase ] . u_bool ;
2022-03-18 12:06:35 +00:00
ServoCluster * cluster ;
PWMCluster : : Sequence * seq_buffer = m_new ( PWMCluster : : Sequence , PWMCluster : : NUM_BUFFERS * 2 ) ;
PWMCluster : : TransitionData * dat_buffer = m_new ( PWMCluster : : TransitionData , PWMCluster : : BUFFER_SIZE * 2 ) ;
2022-03-21 23:51:15 +00:00
if ( mask_provided ) {
if ( calib ! = nullptr )
cluster = new ServoCluster ( pio , sm , pin_mask , * calib , freq , auto_phase , seq_buffer , dat_buffer ) ;
else
cluster = new ServoCluster ( pio , sm , pin_mask , calibration_type , freq , auto_phase , seq_buffer , dat_buffer ) ;
}
else {
if ( calib ! = nullptr )
cluster = new ServoCluster ( pio , sm , pins , pin_count , * calib , freq , auto_phase , seq_buffer , dat_buffer ) ;
else
cluster = new ServoCluster ( pio , sm , pins , pin_count , calibration_type , freq , auto_phase , seq_buffer , dat_buffer ) ;
}
2022-02-17 17:59:09 +00:00
2022-03-08 14:26:57 +00:00
// Cleanup the pins array
if ( pins ! = nullptr )
delete [ ] pins ;
2022-03-18 12:06:35 +00:00
if ( ! cluster - > init ( ) ) {
delete cluster ;
m_del ( PWMCluster : : Sequence , seq_buffer , PWMCluster : : NUM_BUFFERS * 2 ) ;
m_del ( PWMCluster : : TransitionData , dat_buffer , PWMCluster : : BUFFER_SIZE * 2 ) ;
2022-03-18 16:33:24 +00:00
mp_raise_msg ( & mp_type_RuntimeError , " unable to allocate the hardware resources needed to initialise this ServoCluster " ) ; //. Try running `import gc` followed by `gc.collect()`, then create this ServoCluster");
2022-03-18 12:06:35 +00:00
}
self = m_new_obj_with_finaliser ( _ServoCluster_obj_t ) ;
self - > base . type = & ServoCluster_type ;
self - > cluster = cluster ;
self - > seq_buf = seq_buffer ;
self - > dat_buf = dat_buffer ;
2022-02-17 17:59:09 +00:00
return MP_OBJ_FROM_PTR ( self ) ;
}
2022-03-08 14:26:57 +00:00
/***** Destructor ******/
mp_obj_t ServoCluster___del__ ( mp_obj_t self_in ) {
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _ServoCluster_obj_t ) ;
delete self - > cluster ;
return mp_const_none ;
}
2022-02-18 18:15:15 +00:00
/***** Methods *****/
2022-03-08 14:26:57 +00:00
extern mp_obj_t ServoCluster_count ( mp_obj_t self_in ) {
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _ServoCluster_obj_t ) ;
return mp_obj_new_int ( self - > cluster - > get_count ( ) ) ;
}
extern mp_obj_t ServoCluster_pin ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-02-18 18:15:15 +00:00
enum { ARG_self , ARG_servo } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servo , MP_ARG_REQUIRED | MP_ARG_INT } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo = args [ ARG_servo ] . u_int ;
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else if ( servo < 0 | | servo > = servo_count )
2022-03-10 17:09:06 +00:00
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
2022-02-18 18:15:15 +00:00
else
2022-03-08 14:26:57 +00:00
return mp_obj_new_int ( self - > cluster - > get_pin ( ( uint ) servo ) ) ;
return mp_const_none ;
}
extern mp_obj_t ServoCluster_enable ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-03-10 17:09:06 +00:00
enum { ARG_self , ARG_servos , ARG_load } ;
2022-03-08 14:26:57 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-10 17:09:06 +00:00
{ MP_QSTR_servos , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-08 14:26:57 +00:00
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
2022-03-10 17:09:06 +00:00
else {
// Determine what servo(s) to enable
const mp_obj_t object = args [ ARG_servos ] . u_obj ;
if ( mp_obj_is_int ( object ) ) {
int servo = mp_obj_get_int ( object ) ;
if ( servo < 0 | | servo > = servo_count )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
else
self - > cluster - > enable ( ( uint ) servo , args [ ARG_load ] . u_bool ) ;
}
else {
size_t length = 0 ;
mp_obj_t * items = nullptr ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
length = list - > len ;
items = list - > items ;
}
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
length = tuple - > len ;
items = tuple - > items ;
}
if ( items = = nullptr )
mp_raise_TypeError ( " cannot convert object to a list or tuple of integers, or a single integer " ) ;
else if ( length = = 0 )
mp_raise_TypeError ( " list or tuple must contain at least one integer " ) ;
else {
// Create and populate a local array of servo indices
uint8_t * servos = new uint8_t [ length ] ;
for ( size_t i = 0 ; i < length ; i + + ) {
int servo = mp_obj_get_int ( items [ i ] ) ;
if ( servo < 0 | | servo > = servo_count ) {
delete [ ] servos ;
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " a servo in the list or tuple is out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
}
else {
servos [ i ] = ( uint8_t ) servo ;
}
}
self - > cluster - > enable ( servos , length , args [ ARG_load ] . u_bool ) ;
delete [ ] servos ;
}
}
}
return mp_const_none ;
}
extern mp_obj_t ServoCluster_enable_all ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
enum { ARG_self , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
self - > cluster - > enable_all ( args [ ARG_load ] . u_bool ) ;
2022-03-07 22:27:43 +00:00
2022-02-17 17:59:09 +00:00
return mp_const_none ;
}
2022-02-18 18:15:15 +00:00
extern mp_obj_t ServoCluster_disable ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-03-10 17:09:06 +00:00
enum { ARG_self , ARG_servos , ARG_load } ;
2022-02-17 17:59:09 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-10 17:09:06 +00:00
{ MP_QSTR_servos , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-08 14:26:57 +00:00
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
2022-02-17 17:59:09 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
2022-03-10 17:09:06 +00:00
else {
// Determine what servo(s) to disable
const mp_obj_t object = args [ ARG_servos ] . u_obj ;
if ( mp_obj_is_int ( object ) ) {
int servo = mp_obj_get_int ( object ) ;
if ( servo < 0 | | servo > = servo_count )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
else
self - > cluster - > disable ( ( uint ) servo , args [ ARG_load ] . u_bool ) ;
}
else {
size_t length = 0 ;
mp_obj_t * items = nullptr ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
length = list - > len ;
items = list - > items ;
}
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
length = tuple - > len ;
items = tuple - > items ;
}
if ( items = = nullptr )
mp_raise_TypeError ( " cannot convert object to a list or tuple of integers, or a single integer " ) ;
else if ( length = = 0 )
mp_raise_TypeError ( " list or tuple must contain at least one integer " ) ;
else {
// Create and populate a local array of servo indices
uint8_t * servos = new uint8_t [ length ] ;
for ( size_t i = 0 ; i < length ; i + + ) {
int servo = mp_obj_get_int ( items [ i ] ) ;
if ( servo < 0 | | servo > = servo_count ) {
delete [ ] servos ;
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " a servo in the list or tuple is out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
}
else {
servos [ i ] = ( uint8_t ) servo ;
}
}
self - > cluster - > disable ( servos , length , args [ ARG_load ] . u_bool ) ;
delete [ ] servos ;
}
}
}
return mp_const_none ;
}
extern mp_obj_t ServoCluster_disable_all ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
enum { ARG_self , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
self - > cluster - > disable_all ( args [ ARG_load ] . u_bool ) ;
2022-03-07 22:27:43 +00:00
2022-02-17 17:59:09 +00:00
return mp_const_none ;
}
2022-02-18 18:15:15 +00:00
extern mp_obj_t ServoCluster_is_enabled ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
enum { ARG_self , ARG_servo } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servo , MP_ARG_REQUIRED | MP_ARG_INT } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo = args [ ARG_servo ] . u_int ;
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else if ( servo < 0 | | servo > = servo_count )
2022-03-10 17:09:06 +00:00
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
2022-02-18 18:15:15 +00:00
else
return self - > cluster - > is_enabled ( ( uint ) servo ) ? mp_const_true : mp_const_false ;
2022-03-07 22:27:43 +00:00
return mp_const_none ;
2022-02-18 18:15:15 +00:00
}
2022-03-08 14:26:57 +00:00
extern mp_obj_t ServoCluster_pulse ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 2 ) {
enum { ARG_self , ARG_servo } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servo , MP_ARG_REQUIRED | MP_ARG_INT } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo = args [ ARG_servo ] . u_int ;
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else if ( servo < 0 | | servo > = servo_count )
2022-03-10 17:09:06 +00:00
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
2022-03-08 14:26:57 +00:00
else
return mp_obj_new_float ( self - > cluster - > get_pulse ( ( uint ) servo ) ) ;
}
else {
2022-03-10 20:34:59 +00:00
enum { ARG_self , ARG_servos , ARG_pulse , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servos , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
// Determine what servo(s) to enable
const mp_obj_t object = args [ ARG_servos ] . u_obj ;
if ( mp_obj_is_int ( object ) ) {
int servo = mp_obj_get_int ( object ) ;
if ( servo < 0 | | servo > = servo_count )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
else {
float pulse = mp_obj_get_float ( args [ ARG_pulse ] . u_obj ) ;
self - > cluster - > set_pulse ( ( uint ) servo , pulse , args [ ARG_load ] . u_bool ) ;
}
}
else {
size_t length = 0 ;
mp_obj_t * items = nullptr ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
length = list - > len ;
items = list - > items ;
}
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
length = tuple - > len ;
items = tuple - > items ;
}
if ( items = = nullptr )
mp_raise_TypeError ( " cannot convert object to a list or tuple of integers, or a single integer " ) ;
else if ( length = = 0 )
mp_raise_TypeError ( " list or tuple must contain at least one integer " ) ;
else {
// Create and populate a local array of servo indices
uint8_t * servos = new uint8_t [ length ] ;
for ( size_t i = 0 ; i < length ; i + + ) {
int servo = mp_obj_get_int ( items [ i ] ) ;
if ( servo < 0 | | servo > = servo_count ) {
delete [ ] servos ;
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " a servo in the list or tuple is out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
}
else {
servos [ i ] = ( uint8_t ) servo ;
}
}
float pulse = mp_obj_get_float ( args [ ARG_pulse ] . u_obj ) ;
self - > cluster - > set_pulse ( servos , length , pulse , args [ ARG_load ] . u_bool ) ;
delete [ ] servos ;
}
}
}
}
return mp_const_none ;
}
2022-03-18 16:33:24 +00:00
extern mp_obj_t ServoCluster_all_to_pulse ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
/*if(n_args <= 1) {
2022-03-10 20:34:59 +00:00
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
uint servo_count = self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( mp_obj_new_tuple ( servo_count , NULL ) , mp_obj_tuple_t ) ;
for ( uint servo = 0 ; servo < servo_count ; servo + + ) {
tuple - > items [ servo ] = mp_obj_new_float ( self - > cluster - > get_pulse ( servo ) ) ;
}
return MP_OBJ_FROM_PTR ( tuple ) ;
}
}
2022-03-18 16:33:24 +00:00
else { */
enum { ARG_self , ARG_pulse , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_pulse , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
2022-03-08 14:26:57 +00:00
2022-03-18 16:33:24 +00:00
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
2022-03-08 14:26:57 +00:00
2022-03-18 16:33:24 +00:00
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
2022-03-08 14:26:57 +00:00
2022-03-18 16:33:24 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
float pulse = mp_obj_get_float ( args [ ARG_pulse ] . u_obj ) ;
self - > cluster - > set_all_pulses ( pulse , args [ ARG_load ] . u_bool ) ;
2022-03-08 14:26:57 +00:00
}
2022-03-18 16:33:24 +00:00
//}
2022-03-08 14:26:57 +00:00
return mp_const_none ;
}
2022-02-18 18:15:15 +00:00
extern mp_obj_t ServoCluster_value ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 2 ) {
enum { ARG_self , ARG_servo } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servo , MP_ARG_REQUIRED | MP_ARG_INT } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo = args [ ARG_servo ] . u_int ;
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else if ( servo < 0 | | servo > = servo_count )
2022-03-10 17:09:06 +00:00
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
2022-02-18 18:15:15 +00:00
else
return mp_obj_new_float ( self - > cluster - > get_value ( ( uint ) servo ) ) ;
}
else {
2022-03-10 20:34:59 +00:00
enum { ARG_self , ARG_servos , ARG_value , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servos , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
// Determine what servo(s) to enable
const mp_obj_t object = args [ ARG_servos ] . u_obj ;
if ( mp_obj_is_int ( object ) ) {
int servo = mp_obj_get_int ( object ) ;
if ( servo < 0 | | servo > = servo_count )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
else {
float value = mp_obj_get_float ( args [ ARG_value ] . u_obj ) ;
self - > cluster - > set_value ( ( uint ) servo , value , args [ ARG_load ] . u_bool ) ;
}
}
else {
size_t length = 0 ;
mp_obj_t * items = nullptr ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
length = list - > len ;
items = list - > items ;
}
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
length = tuple - > len ;
items = tuple - > items ;
}
if ( items = = nullptr )
mp_raise_TypeError ( " cannot convert object to a list or tuple of integers, or a single integer " ) ;
else if ( length = = 0 )
mp_raise_TypeError ( " list or tuple must contain at least one integer " ) ;
else {
// Create and populate a local array of servo indices
uint8_t * servos = new uint8_t [ length ] ;
for ( size_t i = 0 ; i < length ; i + + ) {
int servo = mp_obj_get_int ( items [ i ] ) ;
if ( servo < 0 | | servo > = servo_count ) {
delete [ ] servos ;
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " a servo in the list or tuple is out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
}
else {
servos [ i ] = ( uint8_t ) servo ;
}
}
float value = mp_obj_get_float ( args [ ARG_value ] . u_obj ) ;
self - > cluster - > set_value ( servos , length , value , args [ ARG_load ] . u_bool ) ;
delete [ ] servos ;
}
}
}
}
return mp_const_none ;
}
2022-03-18 16:33:24 +00:00
extern mp_obj_t ServoCluster_all_to_value ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
/*if(n_args <= 1) {
2022-03-10 20:34:59 +00:00
enum { ARG_self , ARG_servo } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
uint servo_count = self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( mp_obj_new_tuple ( servo_count , NULL ) , mp_obj_tuple_t ) ;
for ( uint servo = 0 ; servo < servo_count ; servo + + ) {
tuple - > items [ servo ] = mp_obj_new_float ( self - > cluster - > get_value ( servo ) ) ;
}
return MP_OBJ_FROM_PTR ( tuple ) ;
}
}
2022-03-18 16:33:24 +00:00
else { */
enum { ARG_self , ARG_value , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_value , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
2022-02-18 18:15:15 +00:00
2022-03-18 16:33:24 +00:00
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
2022-02-18 18:15:15 +00:00
2022-03-18 16:33:24 +00:00
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
2022-02-18 18:15:15 +00:00
2022-03-18 16:33:24 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
float value = mp_obj_get_float ( args [ ARG_value ] . u_obj ) ;
self - > cluster - > set_all_values ( value , args [ ARG_load ] . u_bool ) ;
2022-02-18 18:15:15 +00:00
}
2022-03-18 16:33:24 +00:00
//}
2022-03-07 22:27:43 +00:00
return mp_const_none ;
2022-02-18 18:15:15 +00:00
}
2022-03-08 14:26:57 +00:00
extern mp_obj_t ServoCluster_phase ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-02-18 18:15:15 +00:00
if ( n_args < = 2 ) {
enum { ARG_self , ARG_servo } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servo , MP_ARG_REQUIRED | MP_ARG_INT } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo = args [ ARG_servo ] . u_int ;
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else if ( servo < 0 | | servo > = servo_count )
2022-03-10 17:09:06 +00:00
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
2022-02-18 18:15:15 +00:00
else
2022-03-08 14:26:57 +00:00
return mp_obj_new_float ( self - > cluster - > get_phase ( ( uint ) servo ) ) ;
2022-02-18 18:15:15 +00:00
}
else {
2022-03-10 20:34:59 +00:00
enum { ARG_self , ARG_servos , ARG_phase , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servos , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_phase , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
// Determine what servo(s) to enable
const mp_obj_t object = args [ ARG_servos ] . u_obj ;
if ( mp_obj_is_int ( object ) ) {
int servo = mp_obj_get_int ( object ) ;
if ( servo < 0 | | servo > = servo_count )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
else {
float phase = mp_obj_get_float ( args [ ARG_phase ] . u_obj ) ;
self - > cluster - > set_phase ( ( uint ) servo , phase , args [ ARG_load ] . u_bool ) ;
}
}
else {
size_t length = 0 ;
mp_obj_t * items = nullptr ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
length = list - > len ;
items = list - > items ;
}
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
length = tuple - > len ;
items = tuple - > items ;
}
if ( items = = nullptr )
mp_raise_TypeError ( " cannot convert object to a list or tuple of integers, or a single integer " ) ;
else if ( length = = 0 )
mp_raise_TypeError ( " list or tuple must contain at least one integer " ) ;
else {
// Create and populate a local array of servo indices
uint8_t * servos = new uint8_t [ length ] ;
for ( size_t i = 0 ; i < length ; i + + ) {
int servo = mp_obj_get_int ( items [ i ] ) ;
if ( servo < 0 | | servo > = servo_count ) {
delete [ ] servos ;
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " a servo in the list or tuple is out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
}
else {
servos [ i ] = ( uint8_t ) servo ;
}
}
float phase = mp_obj_get_float ( args [ ARG_phase ] . u_obj ) ;
self - > cluster - > set_phase ( servos , length , phase , args [ ARG_load ] . u_bool ) ;
delete [ ] servos ;
}
}
}
}
return mp_const_none ;
}
2022-03-18 16:33:24 +00:00
extern mp_obj_t ServoCluster_all_to_phase ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
/*if(n_args <= 1) {
2022-03-10 20:34:59 +00:00
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
uint servo_count = self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( mp_obj_new_tuple ( servo_count , NULL ) , mp_obj_tuple_t ) ;
for ( uint servo = 0 ; servo < servo_count ; servo + + ) {
tuple - > items [ servo ] = mp_obj_new_float ( self - > cluster - > get_phase ( servo ) ) ;
}
return MP_OBJ_FROM_PTR ( tuple ) ;
}
}
2022-03-18 16:33:24 +00:00
else { */
enum { ARG_self , ARG_phase , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_phase , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
2022-02-18 18:15:15 +00:00
2022-03-18 16:33:24 +00:00
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
2022-02-18 18:15:15 +00:00
2022-03-18 16:33:24 +00:00
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
2022-02-18 18:15:15 +00:00
2022-03-18 16:33:24 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
float phase = mp_obj_get_float ( args [ ARG_phase ] . u_obj ) ;
self - > cluster - > set_all_phases ( phase , args [ ARG_load ] . u_bool ) ;
2022-02-18 18:15:15 +00:00
}
2022-03-18 16:33:24 +00:00
//}
2022-03-07 22:27:43 +00:00
return mp_const_none ;
2022-02-18 18:15:15 +00:00
}
2022-02-20 15:12:02 +00:00
extern mp_obj_t ServoCluster_frequency ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 1 ) {
enum { ARG_self } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
return mp_obj_new_float ( self - > cluster - > get_frequency ( ) ) ;
}
else {
enum { ARG_self , ARG_freq } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_freq , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
float freq = mp_obj_get_float ( args [ ARG_freq ] . u_obj ) ;
if ( ! self - > cluster - > set_frequency ( freq ) )
mp_raise_ValueError ( " freq out of range. Expected 10Hz to 350Hz " ) ;
else
return mp_const_none ;
}
}
2022-02-18 18:15:15 +00:00
extern mp_obj_t ServoCluster_min_value ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
enum { ARG_self , ARG_servo } ;
2022-02-17 17:59:09 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-02-18 18:15:15 +00:00
{ MP_QSTR_servo , MP_ARG_REQUIRED | MP_ARG_INT } ,
2022-02-17 17:59:09 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
2022-02-18 18:15:15 +00:00
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo = args [ ARG_servo ] . u_int ;
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else if ( servo < 0 | | servo > = servo_count )
2022-03-10 17:09:06 +00:00
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
2022-02-18 18:15:15 +00:00
else
return mp_obj_new_float ( self - > cluster - > get_min_value ( ( uint ) servo ) ) ;
2022-03-07 22:27:43 +00:00
return mp_const_none ;
2022-02-18 18:15:15 +00:00
}
extern mp_obj_t ServoCluster_mid_value ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
enum { ARG_self , ARG_servo } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servo , MP_ARG_REQUIRED | MP_ARG_INT } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
2022-02-17 17:59:09 +00:00
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
2022-02-18 18:15:15 +00:00
int servo = args [ ARG_servo ] . u_int ;
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else if ( servo < 0 | | servo > = servo_count )
2022-03-10 17:09:06 +00:00
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
2022-02-18 18:15:15 +00:00
else
return mp_obj_new_float ( self - > cluster - > get_mid_value ( ( uint ) servo ) ) ;
2022-03-07 22:27:43 +00:00
return mp_const_none ;
2022-02-17 17:59:09 +00:00
}
2022-02-18 18:15:15 +00:00
extern mp_obj_t ServoCluster_max_value ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
enum { ARG_self , ARG_servo } ;
2022-02-17 17:59:09 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-02-18 18:15:15 +00:00
{ MP_QSTR_servo , MP_ARG_REQUIRED | MP_ARG_INT } ,
2022-02-17 17:59:09 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
2022-02-18 18:15:15 +00:00
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo = args [ ARG_servo ] . u_int ;
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else if ( servo < 0 | | servo > = servo_count )
2022-03-10 17:09:06 +00:00
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
2022-02-18 18:15:15 +00:00
else
return mp_obj_new_float ( self - > cluster - > get_max_value ( ( uint ) servo ) ) ;
2022-03-07 22:27:43 +00:00
return mp_const_none ;
2022-02-18 18:15:15 +00:00
}
extern mp_obj_t ServoCluster_to_min ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-03-10 20:34:59 +00:00
enum { ARG_self , ARG_servos , ARG_load } ;
2022-02-18 18:15:15 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-10 20:34:59 +00:00
{ MP_QSTR_servos , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-08 14:26:57 +00:00
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
2022-02-18 18:15:15 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
2022-02-17 17:59:09 +00:00
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
2022-02-18 18:15:15 +00:00
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
2022-03-10 20:34:59 +00:00
else {
// Determine what servo(s) to enable
const mp_obj_t object = args [ ARG_servos ] . u_obj ;
if ( mp_obj_is_int ( object ) ) {
int servo = mp_obj_get_int ( object ) ;
if ( servo < 0 | | servo > = servo_count )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
else
self - > cluster - > to_min ( ( uint ) servo , args [ ARG_load ] . u_bool ) ;
}
else {
size_t length = 0 ;
mp_obj_t * items = nullptr ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
length = list - > len ;
items = list - > items ;
}
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
length = tuple - > len ;
items = tuple - > items ;
}
if ( items = = nullptr )
mp_raise_TypeError ( " cannot convert object to a list or tuple of integers, or a single integer " ) ;
else if ( length = = 0 )
mp_raise_TypeError ( " list or tuple must contain at least one integer " ) ;
else {
// Create and populate a local array of servo indices
uint8_t * servos = new uint8_t [ length ] ;
for ( size_t i = 0 ; i < length ; i + + ) {
int servo = mp_obj_get_int ( items [ i ] ) ;
if ( servo < 0 | | servo > = servo_count ) {
delete [ ] servos ;
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " a servo in the list or tuple is out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
}
else {
servos [ i ] = ( uint8_t ) servo ;
}
}
self - > cluster - > to_min ( servos , length , args [ ARG_load ] . u_bool ) ;
delete [ ] servos ;
}
}
}
return mp_const_none ;
}
extern mp_obj_t ServoCluster_all_to_min ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
enum { ARG_self , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
2022-02-17 17:59:09 +00:00
2022-03-10 20:34:59 +00:00
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
self - > cluster - > all_to_min ( args [ ARG_load ] . u_bool ) ;
}
2022-02-17 17:59:09 +00:00
return mp_const_none ;
}
2022-02-18 18:15:15 +00:00
extern mp_obj_t ServoCluster_to_mid ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-03-10 20:34:59 +00:00
enum { ARG_self , ARG_servos , ARG_load } ;
2022-02-17 17:59:09 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-10 20:34:59 +00:00
{ MP_QSTR_servos , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-08 14:26:57 +00:00
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
2022-02-17 17:59:09 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
2022-02-18 18:15:15 +00:00
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
2022-03-10 20:34:59 +00:00
else {
// Determine what servo(s) to enable
const mp_obj_t object = args [ ARG_servos ] . u_obj ;
if ( mp_obj_is_int ( object ) ) {
int servo = mp_obj_get_int ( object ) ;
if ( servo < 0 | | servo > = servo_count )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
else
self - > cluster - > to_mid ( ( uint ) servo , args [ ARG_load ] . u_bool ) ;
}
else {
size_t length = 0 ;
mp_obj_t * items = nullptr ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
length = list - > len ;
items = list - > items ;
}
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
length = tuple - > len ;
items = tuple - > items ;
}
2022-02-17 17:59:09 +00:00
2022-03-10 20:34:59 +00:00
if ( items = = nullptr )
mp_raise_TypeError ( " cannot convert object to a list or tuple of integers, or a single integer " ) ;
else if ( length = = 0 )
mp_raise_TypeError ( " list or tuple must contain at least one integer " ) ;
else {
// Create and populate a local array of servo indices
uint8_t * servos = new uint8_t [ length ] ;
for ( size_t i = 0 ; i < length ; i + + ) {
int servo = mp_obj_get_int ( items [ i ] ) ;
if ( servo < 0 | | servo > = servo_count ) {
delete [ ] servos ;
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " a servo in the list or tuple is out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
}
else {
servos [ i ] = ( uint8_t ) servo ;
}
}
self - > cluster - > to_mid ( servos , length , args [ ARG_load ] . u_bool ) ;
delete [ ] servos ;
}
}
}
return mp_const_none ;
}
extern mp_obj_t ServoCluster_all_to_mid ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
enum { ARG_self , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
self - > cluster - > all_to_mid ( args [ ARG_load ] . u_bool ) ;
}
2022-02-17 17:59:09 +00:00
return mp_const_none ;
}
2022-02-18 18:15:15 +00:00
extern mp_obj_t ServoCluster_to_max ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-03-10 20:34:59 +00:00
enum { ARG_self , ARG_servos , ARG_load } ;
2022-02-17 17:59:09 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-10 20:34:59 +00:00
{ MP_QSTR_servos , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-08 14:26:57 +00:00
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
2022-02-17 17:59:09 +00:00
} ;
2022-02-18 18:15:15 +00:00
// Parse args.
2022-02-17 17:59:09 +00:00
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
2022-02-18 18:15:15 +00:00
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
2022-03-10 20:34:59 +00:00
else {
// Determine what servo(s) to enable
const mp_obj_t object = args [ ARG_servos ] . u_obj ;
if ( mp_obj_is_int ( object ) ) {
int servo = mp_obj_get_int ( object ) ;
if ( servo < 0 | | servo > = servo_count )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
else
self - > cluster - > to_max ( ( uint ) servo , args [ ARG_load ] . u_bool ) ;
}
else {
size_t length = 0 ;
mp_obj_t * items = nullptr ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
length = list - > len ;
items = list - > items ;
}
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
length = tuple - > len ;
items = tuple - > items ;
}
2022-02-18 18:15:15 +00:00
2022-03-10 20:34:59 +00:00
if ( items = = nullptr )
mp_raise_TypeError ( " cannot convert object to a list or tuple of integers, or a single integer " ) ;
else if ( length = = 0 )
mp_raise_TypeError ( " list or tuple must contain at least one integer " ) ;
else {
// Create and populate a local array of servo indices
uint8_t * servos = new uint8_t [ length ] ;
for ( size_t i = 0 ; i < length ; i + + ) {
int servo = mp_obj_get_int ( items [ i ] ) ;
if ( servo < 0 | | servo > = servo_count ) {
delete [ ] servos ;
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " a servo in the list or tuple is out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
}
else {
servos [ i ] = ( uint8_t ) servo ;
}
}
self - > cluster - > to_max ( servos , length , args [ ARG_load ] . u_bool ) ;
delete [ ] servos ;
}
}
}
return mp_const_none ;
}
extern mp_obj_t ServoCluster_all_to_max ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
enum { ARG_self , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
self - > cluster - > all_to_max ( args [ ARG_load ] . u_bool ) ;
}
2022-02-18 18:15:15 +00:00
return mp_const_none ;
}
extern mp_obj_t ServoCluster_to_percent ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-03-08 14:26:57 +00:00
if ( n_args < = 4 ) {
2022-03-10 20:34:59 +00:00
enum { ARG_self , ARG_servos , ARG_in , ARG_load } ;
2022-02-18 18:15:15 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-10 20:34:59 +00:00
{ MP_QSTR_servos , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-02-18 18:15:15 +00:00
{ MP_QSTR_in , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-08 14:26:57 +00:00
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
2022-02-18 18:15:15 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
2022-02-18 18:15:15 +00:00
else {
2022-03-10 20:34:59 +00:00
// Determine what servo(s) to enable
const mp_obj_t object = args [ ARG_servos ] . u_obj ;
if ( mp_obj_is_int ( object ) ) {
int servo = mp_obj_get_int ( object ) ;
if ( servo < 0 | | servo > = servo_count )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
else {
float in = mp_obj_get_float ( args [ ARG_in ] . u_obj ) ;
self - > cluster - > to_percent ( ( uint ) servo , in , args [ ARG_load ] . u_bool ) ;
}
}
else {
size_t length = 0 ;
mp_obj_t * items = nullptr ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
length = list - > len ;
items = list - > items ;
}
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
length = tuple - > len ;
items = tuple - > items ;
}
if ( items = = nullptr )
mp_raise_TypeError ( " cannot convert object to a list or tuple of integers, or a single integer " ) ;
else if ( length = = 0 )
mp_raise_TypeError ( " list or tuple must contain at least one integer " ) ;
else {
// Create and populate a local array of servo indices
uint8_t * servos = new uint8_t [ length ] ;
for ( size_t i = 0 ; i < length ; i + + ) {
int servo = mp_obj_get_int ( items [ i ] ) ;
if ( servo < 0 | | servo > = servo_count ) {
delete [ ] servos ;
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " a servo in the list or tuple is out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
}
else {
servos [ i ] = ( uint8_t ) servo ;
}
}
float in = mp_obj_get_float ( args [ ARG_in ] . u_obj ) ;
self - > cluster - > to_percent ( servos , length , in , args [ ARG_load ] . u_bool ) ;
delete [ ] servos ;
}
}
2022-02-18 18:15:15 +00:00
}
}
2022-03-08 14:26:57 +00:00
else if ( n_args < = 6 ) {
2022-03-10 20:34:59 +00:00
enum { ARG_self , ARG_servos , ARG_in , ARG_in_min , ARG_in_max , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servos , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in_min , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in_max , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
// Determine what servo(s) to enable
const mp_obj_t object = args [ ARG_servos ] . u_obj ;
if ( mp_obj_is_int ( object ) ) {
int servo = mp_obj_get_int ( object ) ;
if ( servo < 0 | | servo > = servo_count )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
else {
float in = mp_obj_get_float ( args [ ARG_in ] . u_obj ) ;
float in_min = mp_obj_get_float ( args [ ARG_in_min ] . u_obj ) ;
float in_max = mp_obj_get_float ( args [ ARG_in_max ] . u_obj ) ;
self - > cluster - > to_percent ( ( uint ) servo , in , in_min , in_max , args [ ARG_load ] . u_bool ) ;
}
}
else {
size_t length = 0 ;
mp_obj_t * items = nullptr ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
length = list - > len ;
items = list - > items ;
}
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
length = tuple - > len ;
items = tuple - > items ;
}
if ( items = = nullptr )
mp_raise_TypeError ( " cannot convert object to a list or tuple of integers, or a single integer " ) ;
else if ( length = = 0 )
mp_raise_TypeError ( " list or tuple must contain at least one integer " ) ;
else {
// Create and populate a local array of servo indices
uint8_t * servos = new uint8_t [ length ] ;
for ( size_t i = 0 ; i < length ; i + + ) {
int servo = mp_obj_get_int ( items [ i ] ) ;
if ( servo < 0 | | servo > = servo_count ) {
delete [ ] servos ;
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " a servo in the list or tuple is out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
}
else {
servos [ i ] = ( uint8_t ) servo ;
}
}
float in = mp_obj_get_float ( args [ ARG_in ] . u_obj ) ;
float in_min = mp_obj_get_float ( args [ ARG_in_min ] . u_obj ) ;
float in_max = mp_obj_get_float ( args [ ARG_in_max ] . u_obj ) ;
self - > cluster - > to_percent ( servos , length , in , in_min , in_max , args [ ARG_load ] . u_bool ) ;
delete [ ] servos ;
}
}
}
}
else {
enum { ARG_self , ARG_servos , ARG_in , ARG_in_min , ARG_in_max , ARG_value_min , ARG_value_max , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servos , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in_min , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in_max , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_value_min , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_value_max , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
// Determine what servo(s) to enable
const mp_obj_t object = args [ ARG_servos ] . u_obj ;
if ( mp_obj_is_int ( object ) ) {
int servo = mp_obj_get_int ( object ) ;
if ( servo < 0 | | servo > = servo_count )
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
else {
float in = mp_obj_get_float ( args [ ARG_in ] . u_obj ) ;
float in_min = mp_obj_get_float ( args [ ARG_in_min ] . u_obj ) ;
float in_max = mp_obj_get_float ( args [ ARG_in_max ] . u_obj ) ;
float value_min = mp_obj_get_float ( args [ ARG_value_min ] . u_obj ) ;
float value_max = mp_obj_get_float ( args [ ARG_value_max ] . u_obj ) ;
self - > cluster - > to_percent ( ( uint ) servo , in , in_min , in_max , value_min , value_max , args [ ARG_load ] . u_bool ) ;
}
}
else {
size_t length = 0 ;
mp_obj_t * items = nullptr ;
if ( mp_obj_is_type ( object , & mp_type_list ) ) {
mp_obj_list_t * list = MP_OBJ_TO_PTR2 ( object , mp_obj_list_t ) ;
length = list - > len ;
items = list - > items ;
}
else if ( mp_obj_is_type ( object , & mp_type_tuple ) ) {
mp_obj_tuple_t * tuple = MP_OBJ_TO_PTR2 ( object , mp_obj_tuple_t ) ;
length = tuple - > len ;
items = tuple - > items ;
}
if ( items = = nullptr )
mp_raise_TypeError ( " cannot convert object to a list or tuple of integers, or a single integer " ) ;
else if ( length = = 0 )
mp_raise_TypeError ( " list or tuple must contain at least one integer " ) ;
else {
// Create and populate a local array of servo indices
uint8_t * servos = new uint8_t [ length ] ;
for ( size_t i = 0 ; i < length ; i + + ) {
int servo = mp_obj_get_int ( items [ i ] ) ;
if ( servo < 0 | | servo > = servo_count ) {
delete [ ] servos ;
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " a servo in the list or tuple is out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
}
else {
servos [ i ] = ( uint8_t ) servo ;
}
}
float in = mp_obj_get_float ( args [ ARG_in ] . u_obj ) ;
float in_min = mp_obj_get_float ( args [ ARG_in_min ] . u_obj ) ;
float in_max = mp_obj_get_float ( args [ ARG_in_max ] . u_obj ) ;
float value_min = mp_obj_get_float ( args [ ARG_value_min ] . u_obj ) ;
float value_max = mp_obj_get_float ( args [ ARG_value_max ] . u_obj ) ;
self - > cluster - > to_percent ( servos , length , in , in_min , in_max , value_min , value_max , args [ ARG_load ] . u_bool ) ;
delete [ ] servos ;
}
}
}
}
return mp_const_none ;
}
extern mp_obj_t ServoCluster_all_to_percent ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
if ( n_args < = 3 ) {
enum { ARG_self , ARG_in , ARG_load } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else {
float in = mp_obj_get_float ( args [ ARG_in ] . u_obj ) ;
self - > cluster - > all_to_percent ( in , args [ ARG_load ] . u_bool ) ;
}
}
else if ( n_args < = 5 ) {
enum { ARG_self , ARG_in , ARG_in_min , ARG_in_max , ARG_load } ;
2022-02-18 18:15:15 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in_min , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in_max , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-08 14:26:57 +00:00
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
2022-02-18 18:15:15 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
2022-02-18 18:15:15 +00:00
else {
float in = mp_obj_get_float ( args [ ARG_in ] . u_obj ) ;
float in_min = mp_obj_get_float ( args [ ARG_in_min ] . u_obj ) ;
float in_max = mp_obj_get_float ( args [ ARG_in_max ] . u_obj ) ;
2022-03-10 20:34:59 +00:00
self - > cluster - > all_to_percent ( in , in_min , in_max , args [ ARG_load ] . u_bool ) ;
2022-02-18 18:15:15 +00:00
}
}
else {
2022-03-10 20:34:59 +00:00
enum { ARG_self , ARG_in , ARG_in_min , ARG_in_max , ARG_value_min , ARG_value_max , ARG_load } ;
2022-02-18 18:15:15 +00:00
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in_min , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_in_max , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_value_min , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
2022-03-08 14:26:57 +00:00
{ MP_QSTR_value_max , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_load , MP_ARG_BOOL , { . u_bool = true } } ,
2022-02-18 18:15:15 +00:00
} ;
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
2022-03-07 22:27:43 +00:00
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
2022-02-18 18:15:15 +00:00
else {
float in = mp_obj_get_float ( args [ ARG_in ] . u_obj ) ;
float in_min = mp_obj_get_float ( args [ ARG_in_min ] . u_obj ) ;
float in_max = mp_obj_get_float ( args [ ARG_in_max ] . u_obj ) ;
float value_min = mp_obj_get_float ( args [ ARG_value_min ] . u_obj ) ;
float value_max = mp_obj_get_float ( args [ ARG_value_max ] . u_obj ) ;
2022-03-10 20:34:59 +00:00
self - > cluster - > all_to_percent ( in , in_min , in_max , value_min , value_max , args [ ARG_load ] . u_bool ) ;
2022-02-18 18:15:15 +00:00
}
}
return mp_const_none ;
}
extern mp_obj_t ServoCluster_calibration ( size_t n_args , const mp_obj_t * pos_args , mp_map_t * kw_args ) {
2022-03-08 16:54:20 +00:00
if ( n_args < = 2 ) {
enum { ARG_self , ARG_servo } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servo , MP_ARG_REQUIRED | MP_ARG_INT } ,
} ;
2022-02-18 18:15:15 +00:00
2022-03-08 16:54:20 +00:00
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
2022-02-17 17:59:09 +00:00
2022-03-08 16:54:20 +00:00
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
2022-02-17 17:59:09 +00:00
2022-03-08 16:54:20 +00:00
int servo = args [ ARG_servo ] . u_int ;
int servo_count = ( int ) self - > cluster - > get_count ( ) ;
if ( servo_count = = 0 )
mp_raise_ValueError ( " this cluster does not have any servos " ) ;
else if ( servo < 0 | | servo > = servo_count )
2022-03-10 17:09:06 +00:00
mp_raise_msg_varg ( & mp_type_ValueError , MP_ERROR_TEXT ( " servo out of range. Expected 0 to %d " ) , servo_count - 1 ) ;
2022-03-08 16:54:20 +00:00
else {
2022-03-08 17:11:35 +00:00
// Create a new MP Calibration instance and assign a copy of the servo's calibration to it
2022-03-08 16:54:20 +00:00
_Calibration_obj_t * calib = m_new_obj_with_finaliser ( _Calibration_obj_t ) ;
calib - > base . type = & Calibration_type ;
2022-03-08 17:11:35 +00:00
calib - > calibration = new Calibration ( self - > cluster - > calibration ( ( uint ) servo ) ) ;
2022-03-08 16:54:20 +00:00
return MP_OBJ_FROM_PTR ( calib ) ;
}
}
2022-02-18 18:15:15 +00:00
else {
2022-03-08 16:54:20 +00:00
enum { ARG_self , ARG_servo , ARG_calibration } ;
static const mp_arg_t allowed_args [ ] = {
{ MP_QSTR_ , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
{ MP_QSTR_servo , MP_ARG_REQUIRED | MP_ARG_INT } ,
{ MP_QSTR_calibration , MP_ARG_REQUIRED | MP_ARG_OBJ } ,
} ;
2022-02-18 18:15:15 +00:00
2022-03-08 16:54:20 +00:00
// Parse args.
mp_arg_val_t args [ MP_ARRAY_SIZE ( allowed_args ) ] ;
mp_arg_parse_all ( n_args , pos_args , kw_args , MP_ARRAY_SIZE ( allowed_args ) , allowed_args , args ) ;
2022-02-18 18:15:15 +00:00
2022-03-08 16:54:20 +00:00
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( args [ ARG_self ] . u_obj , _ServoCluster_obj_t ) ;
int servo = args [ ARG_servo ] . u_int ;
const mp_obj_t object = args [ ARG_calibration ] . u_obj ;
if ( mp_obj_is_type ( object , & Calibration_type ) ) {
_Calibration_obj_t * calib = MP_OBJ_TO_PTR2 ( object , _Calibration_obj_t ) ;
self - > cluster - > calibration ( ( uint ) servo ) = * ( calib - > calibration ) ;
}
else {
mp_raise_TypeError ( " cannot convert object to a Calibration class instance " ) ;
}
2022-02-18 18:15:15 +00:00
}
return mp_const_none ;
2022-02-17 17:59:09 +00:00
}
2022-03-08 18:15:59 +00:00
extern mp_obj_t ServoCluster_load ( mp_obj_t self_in ) {
_ServoCluster_obj_t * self = MP_OBJ_TO_PTR2 ( self_in , _ServoCluster_obj_t ) ;
self - > cluster - > load ( ) ;
return mp_const_none ;
}
2022-02-17 17:59:09 +00:00
}