reads a quadrature (incremental) encoder that is connected to a Byte Sized Encoder Decoder board connected over I2C to the main controller  
 More...
#include <JEncoderBSED.h>
|  | 
|  | JEncoderBSED (ByteSizedEncoderDecoder &_bsed, byte _encoderChannel, bool _reverse=false, float _distPerCountFactor=1.0, int16_t _slowestIntervalMicros=0, int16_t _encoderEnoughCounts=0) | 
|  | constructor, sets pins and settings 
 | 
|  | 
| long | zeroCounter () | 
|  | reset the counter of how far the encoder has turned 
 | 
|  | 
| float | getVel () | 
|  | calculates velocity in distance per second where distance was set by setdistPerCountFactor() 
 | 
|  | 
| long | getCounter () | 
|  | returns how far the encoder has turned from the zero position 
 | 
|  | 
| float | getPos () | 
|  | returns how far the encoder has turned from the zero position converted to distance 
 | 
|  | 
| float | getDistPerCountFactor () | 
|  | returns a conversion factor between encoder ticks and distance that can be set for the encoder 
 | 
|  | 
| void | setDistPerCountFactor (float _factor) | 
|  | set the conversion factor between encoder ticks and distance 
 | 
|  | 
| void | setReverse (bool _reverse) | 
|  | reverse readings of encoder 
 | 
|  | 
| bool | hasDirection () | 
|  | can this encoder measure direction or just speed 
 | 
|  | 
| bool | isVelNew () | 
|  | could be useful for only recalculating a control loop if there's new velocity data 
 | 
|  | 
| void | run () | 
|  | if an encoder needs to have some code called each loop (like absolute encoder polling encoder and calculating amount turned) 
 | 
|  | 
| virtual void | setRev (bool _rev) | 
|  | empty function for directionless encoders to override 
 | 
|  | 
reads a quadrature (incremental) encoder that is connected to a Byte Sized Encoder Decoder board connected over I2C to the main controller 
◆ JEncoderBSED()
  
  | 
        
          | JEncoderBSED::JEncoderBSED | ( | ByteSizedEncoderDecoder & | _bsed, |  
          |  |  | byte | _encoderChannel, |  
          |  |  | bool | _reverse = false, |  
          |  |  | float | _distPerCountFactor = 1.0, |  
          |  |  | int16_t | _slowestIntervalMicros = 0, |  
          |  |  | int16_t | _encoderEnoughCounts = 0 |  
          |  | ) |  |  |  | inline | 
 
constructor, sets pins and settings 
- Note
- Parameters
- 
  
    | _bsed | instance of BSED class |  | _encoderChannel | channel of encoder on BSED (1-8) |  | _reverse | false(default) |  | _distPerCountFactor | conversion factor for getting distance in an actual unit |  | _slowestIntervalMicros | after this many microseconds without an encoder tick velocity is set to zero. |  | _encoderEnoughCounts | enough counts to calculate velocity from |  
 
 
 
◆ getCounter()
  
  | 
        
          | long JEncoderBSED::getCounter | ( |  | ) |  |  | inlinevirtual | 
 
returns how far the encoder has turned from the zero position 
- Note
- remember that variables overflow 
- Return values
- 
  
  
Reimplemented from JEncoder.
 
 
◆ getDistPerCountFactor()
  
  | 
        
          | float JEncoderBSED::getDistPerCountFactor | ( |  | ) |  |  | inlinevirtual | 
 
returns a conversion factor between encoder ticks and distance that can be set for the encoder 
- Note
- default is 1.0 
- Return values
- 
  
    | (float) | distPerCountFactor |  
 
Reimplemented from JEncoder.
 
 
◆ getPos()
  
  | 
        
          | float JEncoderBSED::getPos | ( |  | ) |  |  | inlinevirtual | 
 
returns how far the encoder has turned from the zero position converted to distance 
- Note
- remember that variables overflow (counter) and that floats have limited precision 
- Return values
- 
  
    | (float) | encoder ticks converted to distance |  
 
Reimplemented from JEncoder.
 
 
◆ getVel()
  
  | 
        
          | float JEncoderBSED::getVel | ( |  | ) |  |  | inlinevirtual | 
 
calculates velocity in distance per second where distance was set by setdistPerCountFactor() 
- Return values
- 
  
  
Reimplemented from JEncoder.
 
 
◆ hasDirection()
  
  | 
        
          | bool JEncoderBSED::hasDirection | ( |  | ) |  |  | inlinevirtual | 
 
can this encoder measure direction or just speed 
- Return values
- 
  
    | (bool) | true = can measure direction |  
 
Reimplemented from JEncoder.
 
 
◆ isVelNew()
  
  | 
        
          | bool JEncoderBSED::isVelNew | ( |  | ) |  |  | inlinevirtual | 
 
could be useful for only recalculating a control loop if there's new velocity data 
- Return values
- 
  
    | (bool) | true if velocity has changed since this function was last called |  
 
Reimplemented from JEncoder.
 
 
◆ run()
  
  | 
        
          | void JEncoderBSED::run | ( |  | ) |  |  | inlinevirtual | 
 
if an encoder needs to have some code called each loop (like absolute encoder polling encoder and calculating amount turned) 
- Note
- interrupt based encoders don't need this to do anything and can define an empty function 
Reimplemented from JEncoder.
 
 
◆ setDistPerCountFactor()
  
  | 
        
          | void JEncoderBSED::setDistPerCountFactor | ( | float | _factor | ) |  |  | inlinevirtual | 
 
set the conversion factor between encoder ticks and distance 
- Parameters
- 
  
  
Reimplemented from JEncoder.
 
 
◆ setReverse()
  
  | 
        
          | void JEncoderBSED::setReverse | ( | bool | _reverse | ) |  |  | inline | 
 
reverse readings of encoder 
- Parameters
- 
  
    | _reverse | whether to invert sign of readings |  
 
- Return values
- 
  
  
 
 
◆ zeroCounter()
  
  | 
        
          | long JEncoderBSED::zeroCounter | ( |  | ) |  |  | inlinevirtual | 
 
reset the counter of how far the encoder has turned 
- Return values
- 
  
    | (long) | returns value of counter before it is reset |  
 
Reimplemented from JEncoder.
 
 
◆ bsed
  
  | 
        
          | ByteSizedEncoderDecoder& JEncoderBSED::bsed |  | protected | 
 
 
◆ distPerCountFactor
  
  | 
        
          | float JEncoderBSED::distPerCountFactor |  | protected | 
 
 
◆ encoderChannel
  
  | 
        
          | byte JEncoderBSED::encoderChannel |  | protected | 
 
 
◆ reverse
  
  | 
        
          | int8_t JEncoderBSED::reverse |  | protected | 
 
 
◆ zeroVal
  
  | 
        
          | int32_t JEncoderBSED::zeroVal |  | protected | 
 
 
The documentation for this class was generated from the following file: