L9110S H-Bridge Driver

Fork of L9110S by Hochschule München

Committer:
HMFK03LST1
Date:
Tue Feb 09 07:46:23 2016 +0000
Revision:
4:d2fb1359716e
Parent:
2:5d4f1e2b27fe
Child:
5:5d8bf5144d8f
Jens

Who changed what in which revision?

UserRevisionLine numberNew contents of line
HMFK03LST1 1:4c6c89e42fa4 1 /* L9110S H-Brigh Driver Interface
HMFK03LST1 0:1a9b998e0ec1 2 *
HMFK03LST1 0:1a9b998e0ec1 3 * By Sebastian Donner
HMFK03LST1 0:1a9b998e0ec1 4 *
HMFK03LST1 0:1a9b998e0ec1 5 * Permission is hereby granted, free of charge, to any person
HMFK03LST1 0:1a9b998e0ec1 6 * obtaining a copy of this software and associated documentation
HMFK03LST1 0:1a9b998e0ec1 7 * files (the "Software"), to deal in the Software without
HMFK03LST1 0:1a9b998e0ec1 8 * restriction, including without limitation the rights to use,
HMFK03LST1 0:1a9b998e0ec1 9 * copy, modify, merge, publish, distribute, sublicense, and/or sell
HMFK03LST1 0:1a9b998e0ec1 10 * copies of the Software, and to permit persons to whom the
HMFK03LST1 0:1a9b998e0ec1 11 * Software is furnished to do so, subject to the following
HMFK03LST1 0:1a9b998e0ec1 12 * conditions:
HMFK03LST1 0:1a9b998e0ec1 13 *
HMFK03LST1 0:1a9b998e0ec1 14 * The above copyright notice and this permission notice shall be
HMFK03LST1 0:1a9b998e0ec1 15 * included in all copies or substantial portions of the Software.
HMFK03LST1 0:1a9b998e0ec1 16 *
HMFK03LST1 0:1a9b998e0ec1 17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
HMFK03LST1 0:1a9b998e0ec1 18 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
HMFK03LST1 0:1a9b998e0ec1 19 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
HMFK03LST1 0:1a9b998e0ec1 20 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
HMFK03LST1 0:1a9b998e0ec1 21 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
HMFK03LST1 0:1a9b998e0ec1 22 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
HMFK03LST1 0:1a9b998e0ec1 23 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
HMFK03LST1 0:1a9b998e0ec1 24 * OTHER DEALINGS IN THE SOFTWARE.
HMFK03LST1 0:1a9b998e0ec1 25 */
HMFK03LST1 0:1a9b998e0ec1 26
HMFK03LST1 0:1a9b998e0ec1 27 #include "L9110S.h"
HMFK03LST1 0:1a9b998e0ec1 28
HMFK03LST1 0:1a9b998e0ec1 29 /** Create a new interface for an L9110S
HMFK03LST1 0:1a9b998e0ec1 30 *
HMFK03LST1 0:1a9b998e0ec1 31 * @param cw_r is the pin for clockwise rotate
HMFK03LST1 0:1a9b998e0ec1 32 * @param ccw_r is the pin for counter clockwise rotate
HMFK03LST1 0:1a9b998e0ec1 33 */
HMFK03LST1 0:1a9b998e0ec1 34 L9110S::L9110S(PinName cw_r, PinName ccw_r):
HMFK03LST1 4:d2fb1359716e 35 cw_min(14), cw_max(70), ccw_min(14), ccw_max(70), _cw(cw_r), _ccw(ccw_r), periode(1000)
HMFK03LST1 0:1a9b998e0ec1 36 {
HMFK03LST1 0:1a9b998e0ec1 37 _cw.period_us( periode);
HMFK03LST1 0:1a9b998e0ec1 38 _ccw.period_us(periode);
HMFK03LST1 0:1a9b998e0ec1 39 _cw.pulsewidth_us( 0);
HMFK03LST1 0:1a9b998e0ec1 40 _ccw.pulsewidth_us(0);
HMFK03LST1 0:1a9b998e0ec1 41 }
HMFK03LST1 0:1a9b998e0ec1 42
HMFK03LST1 2:5d4f1e2b27fe 43 /** sets Pulswidth cw(+) ccw(-)
HMFK03LST1 0:1a9b998e0ec1 44 *
HMFK03LST1 1:4c6c89e42fa4 45 * @param power positiv in clockwise Dir
HMFK03LST1 1:4c6c89e42fa4 46 * @param power negativ in counter clockwise Dir
HMFK03LST1 0:1a9b998e0ec1 47 *
HMFK03LST1 0:1a9b998e0ec1 48 * in % of range from min_(cw/ccw) to max_(cw/ccw)
HMFK03LST1 0:1a9b998e0ec1 49 *
HMFK03LST1 0:1a9b998e0ec1 50 */
HMFK03LST1 0:1a9b998e0ec1 51 void L9110S::drive(int power)
HMFK03LST1 0:1a9b998e0ec1 52 {
HMFK03LST1 4:d2fb1359716e 53
HMFK03LST1 4:d2fb1359716e 54 // Limit PWM -100 to 100
HMFK03LST1 4:d2fb1359716e 55 if (power > 100) power = 100;
HMFK03LST1 4:d2fb1359716e 56 if (power < -100) power = -100;
HMFK03LST1 4:d2fb1359716e 57
HMFK03LST1 0:1a9b998e0ec1 58 // Calc PWM in us
HMFK03LST1 4:d2fb1359716e 59 if (power > 0) {power = ((power * ( cw_max - cw_min)) + ( cw_min * 100)) * periode / 10000;}
HMFK03LST1 4:d2fb1359716e 60 else { if (power < 0) {power = ((power * (ccw_max - ccw_min)) - (ccw_min * 100)) * periode / 10000;}
HMFK03LST1 4:d2fb1359716e 61 else power = 0;}
HMFK03LST1 0:1a9b998e0ec1 62
HMFK03LST1 0:1a9b998e0ec1 63 //cw or ccw Rotate
HMFK03LST1 0:1a9b998e0ec1 64 if (power >= 0){_ccw.pulsewidth_us(0); _cw.pulsewidth_us(power);}
HMFK03LST1 0:1a9b998e0ec1 65 else {_cw.pulsewidth_us(0); _ccw.pulsewidth_us(-power);}
HMFK03LST1 0:1a9b998e0ec1 66 }
HMFK03LST1 0:1a9b998e0ec1 67
HMFK03LST1 2:5d4f1e2b27fe 68 /** sets Pulswidth and Dir
HMFK03LST1 0:1a9b998e0ec1 69 *
HMFK03LST1 1:4c6c89e42fa4 70 * @param dir positiv dir is clockwise direction
HMFK03LST1 1:4c6c89e42fa4 71 * @param dir negativ dir is counter clockwise direction
HMFK03LST1 1:4c6c89e42fa4 72 * @param dir zero is stop
HMFK03LST1 0:1a9b998e0ec1 73 *
HMFK03LST1 1:4c6c89e42fa4 74 * @param power in % of range from min_(cw/ccw) to max_(cw/ccw) allways positiv
HMFK03LST1 0:1a9b998e0ec1 75 *
HMFK03LST1 0:1a9b998e0ec1 76 */
HMFK03LST1 0:1a9b998e0ec1 77 void L9110S::drive(int dir, int power)
HMFK03LST1 0:1a9b998e0ec1 78 {
HMFK03LST1 4:d2fb1359716e 79 // Limit PWM 0 to 100 and Stop
HMFK03LST1 4:d2fb1359716e 80 if ((power > 100) || (power < 0) || (dir == 0)) power = 0;
HMFK03LST1 4:d2fb1359716e 81
HMFK03LST1 0:1a9b998e0ec1 82 // Calc PWM in us
HMFK03LST1 0:1a9b998e0ec1 83 if (dir > 0) {power = ((power * (cw_max - cw_min )) + (cw_min * 100)) * periode / 100000;}
HMFK03LST1 0:1a9b998e0ec1 84 else { if (dir < 0) {power = ((power * (ccw_max- ccw_min)) + (ccw_min * 100)) * periode / 100000;}
HMFK03LST1 0:1a9b998e0ec1 85 else power = 0;}
HMFK03LST1 4:d2fb1359716e 86
HMFK03LST1 0:1a9b998e0ec1 87
HMFK03LST1 0:1a9b998e0ec1 88 //cw or ccw Rotate
HMFK03LST1 0:1a9b998e0ec1 89 if (dir > 0){_ccw.pulsewidth_us(0); _cw.pulsewidth_us(power);}
HMFK03LST1 0:1a9b998e0ec1 90 else {_cw.pulsewidth_us(0); _ccw.pulsewidth_us(power);}
HMFK03LST1 0:1a9b998e0ec1 91 }
HMFK03LST1 0:1a9b998e0ec1 92
HMFK03LST1 0:1a9b998e0ec1 93 /** sets the PWM frequency
HMFK03LST1 0:1a9b998e0ec1 94 *
HMFK03LST1 0:1a9b998e0ec1 95 * @param hz is the PWM frequency (default 2000 Hz)
HMFK03LST1 0:1a9b998e0ec1 96 */
HMFK03LST1 0:1a9b998e0ec1 97 void L9110S::frequency(int hz)
HMFK03LST1 0:1a9b998e0ec1 98 {
HMFK03LST1 0:1a9b998e0ec1 99 periode = 1000000/hz;
HMFK03LST1 0:1a9b998e0ec1 100 }
HMFK03LST1 4:d2fb1359716e 101
HMFK03LST1 4:d2fb1359716e 102 float L9110S::deg_diff(float Soll, float Ist)
HMFK03LST1 4:d2fb1359716e 103 {
HMFK03LST1 4:d2fb1359716e 104 float diff = Soll - Ist;
HMFK03LST1 4:d2fb1359716e 105 if(diff > 180) diff = -360 + diff;
HMFK03LST1 4:d2fb1359716e 106 if(diff < -180) diff = 360 + diff;
HMFK03LST1 4:d2fb1359716e 107 return diff;
HMFK03LST1 4:d2fb1359716e 108 }
HMFK03LST1 4:d2fb1359716e 109
HMFK03LST1 4:d2fb1359716e 110 void L9110S::drive_diff(float Soll, float Ist, int kp ,int i_lim, int trash)
HMFK03LST1 4:d2fb1359716e 111 {
HMFK03LST1 4:d2fb1359716e 112 int p = deg_diff(Soll, Ist) * kp;
HMFK03LST1 4:d2fb1359716e 113
HMFK03LST1 4:d2fb1359716e 114 if (abs(p) < ((kp * trash)/10)) {p = 0;}
HMFK03LST1 4:d2fb1359716e 115 else
HMFK03LST1 4:d2fb1359716e 116 {
HMFK03LST1 4:d2fb1359716e 117 drive_i = drive_i + (p/16);
HMFK03LST1 4:d2fb1359716e 118 if (drive_i > i_lim) drive_i = i_lim;
HMFK03LST1 4:d2fb1359716e 119 if (drive_i < -i_lim) drive_i = -i_lim;
HMFK03LST1 4:d2fb1359716e 120 }
HMFK03LST1 4:d2fb1359716e 121 drive(drive_i/10 + p);
HMFK03LST1 4:d2fb1359716e 122 }
HMFK03LST1 0:1a9b998e0ec1 123
HMFK03LST1 0:1a9b998e0ec1 124