Pulse Width Modulation(パルス幅変調)制御 EditToHeaderToFooter

モータードライバ: TA8428K EditToHeaderToFooter

#NameArgFunc
1IN1 i1 制御用入力端子
2IN2 i2
3OUTA o1 〜1.5A
4GND gndGND
5OUTA~o2  
6---- --  
7Vcc vccVCC〜30V
ModeIN1IN2OUTAOUTA~
制動HHLL
正転HLHL
逆転LHLH
停止LLZZ
C[10 uF]水色106
C[ 0.1uF]水色104

ハード EditToHeaderToFooter

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
;pin ctrl.gnd = driver.gnd = 0V
;pin ctrl.vcc = 5V
;pin driver.vcc = 12V
 
;C[10  uF](driver.gnd, driver.vcc)
;C[ 0.1uF](driver.gnd, driver.vcc)
 
;Arduino ctrl
;TA8428K driver
 
;driver.i1 = ctrl.D3
;driver.i2 = ctrl.D11
 
;pin driver.o1;
;pin driver.o2;

ソフト EditToHeaderToFooter

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
void setup() {
  Serial.begin(9600);
  pinMode( 3, OUTPUT);
  pinMode(11, OUTPUT);
}
 
int c1 =  3;
int c2 = 11;
int t = 100;
int d =  50;
int command = 0;
void loop() {
 
  if (Serial.available() > 0) {
    command = Serial.read();
  }
 
  digitalWrite(c1, LOW )
  digitalWrite(c2, HIGH)
  delay(d);
 
  digitalWrite(c1, LOW)
  digitalWrite(c2, LOW)
  delay(t-d);
}

ディーゼル EditToHeaderToFooter

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
int iAna0 =  0;
int pPwm1 =  3;
int pPwm2 = 11;
 
int base = 0;
 
#define avelg 2
#define avesz (1<<avelg)
int avebf[avesz];
int avelc=0;
int ave=0;
 
int Ave(int value) {
  ave -= avebf[avelc];    avebf[avelc] = value >> avelg;
  ave += avebf[avelc];
 
  avelc++;
  if (avelc == avesz) avelc = 0;
 
  return ave;
}
 
void setPwvWidth0311(int r) {
  TCCR2B &= B11111000;
  switch(r) {
    case    1:  TCCR2B |= B00000001;  break;
    case    8:  TCCR2B |= B00000010;  break;
    case   32:  TCCR2B |= B00000011;  break;
    default  : 
    case   64:  TCCR2B |= B00000100;  break;
    case  128:  TCCR2B |= B00000101;  break;
    case  256:  TCCR2B |= B00000110;  break;
    case 1024:  TCCR2B |= B00000111;  break;
  }
}
 
void setup() {
  Serial.begin(9600);
  
  setPwvWidth0311(1024);
 
  pinMode(pPwm1, OUTPUT);
  pinMode(pPwm2, OUTPUT);
  
  pinMode( 8, OUTPUT);
  pinMode( 9,  INPUT);
  pinMode(10, OUTPUT);
  
  analogWrite(pPwm1, 0 );
  analogWrite(pPwm2, 0 );
  
  digitalWrite( 8,  LOW);
  digitalWrite(10, HIGH);
 
  base = analogRead(iAna0)+10;
  Serial.print("base == ");
  Serial.println(base);
  
  for(int i = 0; i<avesz; i++) {
    avebf[i] = 0;
  }
}
 
void loop() {
  int sw    = digitalRead(9);
  int value = analogRead(iAna0);
  int ave = Ave(value);
  int acc   = 0;
  
  
  if (sw == LOW) {
    acc = (1024-ave)/4;
  }
  else {
    acc = (ave - base)/2;
    if (acc <  5) acc =   0;
    if (acc >254) acc = 254;
  }
  if (1) {
    Serial.print(value);
    Serial.print("\t");
    Serial.print(ave);
    Serial.print("\t");
    Serial.println(acc);
  }
  
  analogWrite(pPwm1, 0 );
  analogWrite(pPwm2, acc);
  delay(100);
}

EditToHeaderToFooter

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
int iAna0 =  1;
int iAna1 =  2;
int pPwm1 =  5;
int pPwm2 =  6;
int pLed1 =  3;
int pLed2 =  9;
 
int base0 = 0;
int base1 = 0;
 
#define avelg 2
#define avesz (1<<avelg)
int avebf[2][avesz];
int avelc[2] = {0,0};
int ave[2] = {0,0};
 
int Ave(int id, int value) {
  if (id > 2) return 0;
  ave[id] -= avebf[id][avelc[id]];    avebf[id][avelc[id]] = value >> avelg;
  ave[id] += avebf[id][avelc[id]];
 
  avelc[id]++;
  if (avelc[id] == avesz) avelc[id] = 0;
 
  return ave[id];
}
 
const int vBaseOffset = 10;
void setup() {
  Serial.begin(9600);
 
  pinMode(pPwm1, OUTPUT);
  pinMode(pPwm2, OUTPUT);
  pinMode(pLed1, OUTPUT);
  pinMode(pLed2, OUTPUT);
 
  analogWrite(pPwm1, 0);
  analogWrite(pPwm2, 0);
 
  base0 = analogRead(iAna0) + vBaseOffset;
  base1 = analogRead(iAna1) + vBaseOffset;
  Serial.print("base == ");
  Serial.print(base0);
  Serial.print(", ");
  Serial.println(base1);
 
  for (int i = 0; i < avesz; i++) {
    avebf[0][i] = 0;
    avebf[1][i] = 0;
  }
}
 
int gSwtchingLock = false;
int gDir = 0;
void loop() {
  int value0 = analogRead(iAna0);
  int value1 = analogRead(iAna1);
  int ave0 = Ave(0, value0);
  int ave1 = Ave(1, value1);
  
 
  int acc = (int)((ave0 - base0) * 0.7);
  if (acc <   5) acc =   0;
  if (acc > 254) acc = 254;
 
  bool sw = (ave1 - base1) > base1;
  if (gSwtchingLock == false && sw == true && acc == 0) {
    gDir = 1 - gDir;
    gSwtchingLock = true;
  }
  
  if (gSwtchingLock == true)
  {
    Serial.print((gDir == 0) ? "200\t100\t" : "100\t200\t");
    Serial.println(gDir);
    if (sw == false) gSwtchingLock = false;
    return;
  }
 
  if (gSwtchingLock) {
    analogWrite(pPwm1, 0);
    analogWrite(pPwm2, 0);
    delay(10);
    return;
  }
 
  if (true) {
    Serial.print(ave0);
    Serial.print("\t");
    Serial.print(ave1);
    Serial.print("\t");
    Serial.println(acc);
  }
 
  if (gDir == 1) {
    analogWrite(pPwm1, 0 );
    analogWrite(pPwm2, acc);
    analogWrite(pLed1, 0 );
    analogWrite(pLed2, acc);
  }
  else {
    analogWrite(pPwm1, acc);
    analogWrite(pPwm2, 0);
    analogWrite(pLed1, acc);
    analogWrite(pLed2, 0);
  }
  delay(100);
}
  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
int iAna0 =  0;
int pPwm1 =  3;
int pPwm2 = 11;
 
int pPower = 7;
int pDir   = 9;
int pPowerDir1 =  5;
int pPowerDir2 = 10;
 
 
const int PUSHED = LOW;
 
int base = 0;
 
#define avelg 2
#define avesz (1<<avelg)
int avebf[avesz];
int avelc=0;
int ave=0;
 
class cStatelessToggleButton
{
  public:
    int vPort;
    bool vState;
    const int PUSHED = LOW;
    void (*vStateChanged)();
  private:
    int vPushed;
  public:
    cStatelessToggleButton(int aPort, void (*aStateChanged)() = NULL)
      : vPort(aPort)
      , vStateChanged(aStateChanged)
    {
      fInit();
    }
 
    void fInit() {
      vState = false;
      vPushed = false;
      pinMode(vPort, INPUT_PULLUP);
    }
    
    int fUpdate() {
      if (digitalRead(vPort) == PUSHED) {
        if (vPushed == false) {
          vState = !vState;
          vPushed = true;
          if (vStateChanged != NULL) vStateChanged();
        }
      } else {
        vPushed = false;  
        if (vStateChanged != NULL) vStateChanged();
      }
    }
};
void fCtrlStateChanged();
cStatelessToggleButton vPowerButton(pPower, fCtrlStateChanged);
cStatelessToggleButton vDirButton  (pDir  , fCtrlStateChanged);
void fCtrlStateChanged() {
  analogWrite(pPowerDir1, (vPowerButton.vState &&  vDirButton.vState) ?  50 : 0);
  analogWrite(pPowerDir2, (vPowerButton.vState && !vDirButton.vState) ? 128 : 0);
}
bool neutral = false;
cStatelessToggleButton vNeutralButton  (pDir  , [](){neutral = !neutral;});
 
 
int Ave(int value) {
  ave -= avebf[avelc];    avebf[avelc] = value >> avelg;
  ave += avebf[avelc];
 
  avelc++;
  if (avelc == avesz) avelc = 0;
 
  return ave;
}
 
void setPwvWidth0311(int r) {
  TCCR2B &= B11111000;
  switch(r) {
    case    0:  TCCR2B |= B00000000;  break;
    case    1:  TCCR2B |= B00000001;  break;
    case    8:  TCCR2B |= B00000010;  break;
    case   32:  TCCR2B |= B00000011;  break;
    default  : 
    case   64:  TCCR2B |= B00000100;  break;
    case  128:  TCCR2B |= B00000101;  break;
    case  256:  TCCR2B |= B00000110;  break;
    case 1024:  TCCR2B |= B00000111;  break;
  }
}
void setPwvWidth0506(int r) {
  TCCR0B &= B11111000;
  switch(r) {
    case    0:  TCCR0B |= B00000000;  break;
    case    1:  TCCR0B |= B00000001;  break;
    case    8:  TCCR0B |= B00000010;  break;
    case   64:  TCCR0B |= B00000011;  break;
    default  : 
    case  256:  TCCR0B |= B00000100;  break;
    case 1024:  TCCR0B |= B00000101;  break;
  }
}
 
void setup() {
  Serial.begin(9600);
  setPwvWidth0311(256);
  //setPwvWidth0506(1);
 
  pinMode(pPwm1, OUTPUT);
  pinMode(pPwm2, OUTPUT);
    
  pinMode(pPowerDir1, OUTPUT);
  pinMode(pPowerDir2, OUTPUT);
  
  analogWrite(pPwm1, 0);
  analogWrite(pPwm2, 0);
  
  analogWrite(pPowerDir1,  50);
  analogWrite(pPowerDir2, 128);
 
  base = analogRead(iAna0)+10;
  Serial.print("\nbase == ");
  Serial.println(base);
  
  for(int i = 0; i<avesz; i++) {
    avebf[i] = 0;
  }
}
#define HKS9200
//#define DD51
//#define DD51K
//#define DE15
//#define DF200
//#define KIHA20
//#define KIHA40
//#define KIHA75
//#define KIHA100 //KATO
//#define KIHA120
//#define KIHA181x5
//#define KIHA183
//#define KIHA187x4
//#define KIHA187x6
//#define KTR8000
//#define Renfe592
//#define Sanriku36
 
#ifdef HKS9200
  int vIdleMax = 10; int vIdleAcc = 20; int vAccDiv = 5;  int vIdleDelay = 64;
#endif
#ifdef DD51
  int vIdleMax = 30; int vIdleAcc = 40; int vAccDiv = 4;  int vIdleDelay = 64;
#endif
#ifdef DD51K
  int vIdleMax =  5; int vIdleAcc = 35; int vAccDiv = 3;  int vIdleDelay = 64;
#endif
#ifdef DE15
  int vIdleMax =  5; int vIdleAcc = 20; int vAccDiv = 4;  int vIdleDelay = 64;
#endif
#ifdef DF200
  int vIdleMax =  5; int vIdleAcc = 30; int vAccDiv = 3;  int vIdleDelay = 64;
#endif
#ifdef KIHA20
  int vIdleMax = 10; int vIdleAcc = 20; int vAccDiv = 3;  int vIdleDelay = 64;
#endif
#ifdef KIHA40
  int vIdleMax = 10; int vIdleAcc = 12; int vAccDiv = 9;  int vIdleDelay = 14;
#endif
#ifdef KIHA75
  int vIdleMax =  8; int vIdleAcc = 30; int vAccDiv = 3;  int vIdleDelay = 64;
#endif
#ifdef KIHA100
  int vIdleMax =  5; int vIdleAcc = 15; int vAccDiv = 4;  int vIdleDelay = 64;
#endif
#ifdef KIHA120
  int vIdleMax = 10; int vIdleAcc = 20; int vAccDiv = 5;  int vIdleDelay = 64;
#endif
#ifdef KIHA181
  int vIdleMax = 30; int vIdleAcc = 10; int vAccDiv = 3;  int vIdleDelay = 64;
#endif
#ifdef KIHA183
  int vIdleMax =  5; int vIdleAcc = 20; int vAccDiv = 3;  int vIdleDelay = 64;
#endif
#ifdef KIHA181x5
  int vIdleMax = 10; int vIdleAcc = 35; int vAccDiv = 3;  int vIdleDelay = 64;
#endif
#ifdef KIHA187x4
  int vIdleMax =  8; int vIdleAcc = 30; int vAccDiv = 4;  int vIdleDelay = 64;
#endif
#ifdef KIHA187x6
  int vIdleMax =  8; int vIdleAcc = 30; int vAccDiv = 2;  int vIdleDelay = 64;
#endif
#ifdef KTR8000
  int vIdleMax =  8; int vIdleAcc = 12; int vAccDiv = 6;  int vIdleDelay = 64;
#endif
#ifdef Renfe592
  int vIdleMax =  5; int vIdleAcc = 20; int vAccDiv = 3;  int vIdleDelay = 64;
#endif
#ifdef Sanriku36
  int vIdleMax = 5; int vIdleAcc = 20; int vAccDiv = 5;  int vIdleDelay = 64;
#endif
 
class DCar {
  bool idlingState;
 
  DCar() {
    idlingState = true;
  }
 
  void update() {
    
  }
};
 
bool idlingState = true;
bool enginePower = true;
void loop() {
  int value = analogRead(iAna0);
  int ave = Ave(value);
  int acc   = 0;
 
  vPowerButton.fUpdate();
  vDirButton  .fUpdate();
 
  acc = (ave - base) / vAccDiv;
  if (acc > 254) acc = 254;
 
  if (1) {
    Serial.print(value);
    Serial.print("\t");
    Serial.print(acc);
    Serial.print("\t");
    Serial.println(vPowerButton.vState);
  }
 
  if (vPowerButton.vState) {
    if (!enginePower) {
      enginePower = true;
      setPwvWidth0311(1024);
    }
  }
  else {
    if (enginePower) {
      enginePower = false;
      setPwvWidth0311(256);
    }
  }
  if (enginePower) {
    if (acc < vIdleMax) { //反転振動
      if (idlingState) {
        analogWrite(pPwm1, vIdleAcc);
        analogWrite(pPwm2, 0      );
      } else {
        analogWrite(pPwm2, vIdleAcc);
        analogWrite(pPwm1, 0      );
      }
      idlingState = !idlingState;
    }
    else {
      if (vDirButton.vState) {
        analogWrite(pPwm1, 0      );
        analogWrite(pPwm2, acc);
      } else {
        analogWrite(pPwm2, 0      );
        analogWrite(pPwm1, acc);
      }
    }
  }
  else 
  {
    if (acc < vIdleMax) {
        analogWrite(pPwm1, 0);
        analogWrite(pPwm2, 0);
    }
    else {
      if (vDirButton.vState) {
        analogWrite(pPwm1, 0      );
        analogWrite(pPwm2, acc * 6/5);
      } else {
        analogWrite(pPwm2, 0      );
        analogWrite(pPwm1, acc * 6/5);
      }
    }
  }
  delay(vIdleDelay);
}
リロード   新規 編集 凍結 差分 添付 複製 改名   技術 一覧 検索 最新 バックアップ リンク元   ヘルプ   最終更新のRSS
Last-modified: 2018.1015 (月) 0559.5400 (2019d)