Controlor for Humanoid. Walking trajectory generator, sensor reflection etc.

Dependencies:   Adafruit-PWM-Servo-Driver MPU6050 RS300 mbed

Committer:
syundo0730
Date:
Thu Aug 30 12:41:50 2012 +0000
Revision:
3:84e5335fab91
Parent:
2:8a40834788ba
Child:
5:0ca9f1bc1fb0
base

Who changed what in which revision?

UserRevisionLine numberNew contents of line
syundo0730 0:d114194bff43 1 #ifndef PWM_H_2012_08_28_
syundo0730 0:d114194bff43 2 #define PWM_H_2012_08_28_
syundo0730 0:d114194bff43 3
syundo0730 0:d114194bff43 4 #include "LPC17xx.h"
syundo0730 0:d114194bff43 5 #include "mbed.h"
syundo0730 0:d114194bff43 6
syundo0730 2:8a40834788ba 7 const uint32_t SRV_PERIOD = 2500 - 1;//���/8
syundo0730 2:8a40834788ba 8 const uint32_t SRV_MAX_DUTY = 2100 - 1;//�f���[�e�B�[�ő�l
syundo0730 2:8a40834788ba 9 const uint32_t SRV_MIN_DUTY = 900 - 1;//�f���[�e�B�[�ŏ��l
syundo0730 2:8a40834788ba 10
syundo0730 2:8a40834788ba 11 const uint8_t SRV_IDX_SHIFT = 3;//74HC238�C���f�b�N�X�̓�͒[�q��(A,B,C)
syundo0730 2:8a40834788ba 12 const uint8_t SRV_IDX_NUM = 1 << SRV_IDX_SHIFT;//&#65533;C&#65533;&#65533;&#65533;f&#65533;b&#65533;N&#65533;X&#65533;&#784;&#65533;(8)
syundo0730 2:8a40834788ba 13 const uint8_t SRV_IDX_MASK = SRV_IDX_NUM - 1;//&#65533;w&#65533;&#65533;ch&#65533;&#777;&#65533;3bit&#65533;&#65533;&#65533;&#65533;}&#65533;X&#65533;N&#65533;&#65533;&#65533;&#37053;&#65533;&#1986;&#770;&#65533;&#65533;
syundo0730 2:8a40834788ba 14 const uint8_t SRV_BANK_NUM = 3;//PWM&#65533;&#65533;&#65533;&#790;{&#65533;&#65533;
syundo0730 2:8a40834788ba 15 const uint8_t SRV_CH_NUM = SRV_IDX_NUM * SRV_BANK_NUM;//&#65533;&#65533;&#65533;&#65533;&#148;\&#65533;&#515;T&#65533;[&#65533;{&#65533;&#65533;&#65533;[&#65533;^&#65533;&#65533;
syundo0730 0:d114194bff43 16
syundo0730 2:8a40834788ba 17 volatile uint8_t SRV_Idx = 0;//&#65533;T&#65533;[&#65533;{&#65533;&#1538;&#65533;&#1410;&#65533;&#65533;p&#65533;&#771;J&#65533;E&#65533;&#65533;&#65533;^
syundo0730 2:8a40834788ba 18 volatile uint32_t SRV_dutyTable[SRV_BANK_NUM][SRV_IDX_NUM];//&#65533;f&#65533;&#65533;&#65533;[&#65533;e&#65533;B&#65533;[&#65533;l
syundo0730 0:d114194bff43 19
syundo0730 2:8a40834788ba 20 const uint32_t SRV_PWMTable[SRV_BANK_NUM][SRV_IDX_NUM]={
syundo0730 3:84e5335fab91 21 {0,SRV_PERIOD,0,SRV_PERIOD,0,SRV_PERIOD,0,SRV_PERIOD},
syundo0730 3:84e5335fab91 22 {0,0,SRV_PERIOD,SRV_PERIOD,0,0,SRV_PERIOD,SRV_PERIOD},
syundo0730 3:84e5335fab91 23 {0,0,0,0,SRV_PERIOD,SRV_PERIOD,SRV_PERIOD,SRV_PERIOD}
syundo0730 1:5c2e40445778 24 };
syundo0730 1:5c2e40445778 25
syundo0730 0:d114194bff43 26 void Init_PWM(void);
syundo0730 2:8a40834788ba 27 void SetDuty(uint8_t ch, uint32_t duty);
syundo0730 0:d114194bff43 28
syundo0730 0:d114194bff43 29 #endif //PWM_H_2012_08_28_
syundo0730 0:d114194bff43 30
syundo0730 0:d114194bff43 31 #ifdef __cplusplus
syundo0730 0:d114194bff43 32 extern "C" {
syundo0730 0:d114194bff43 33 void PWM1_IRQHandler();
syundo0730 0:d114194bff43 34 }
syundo0730 0:d114194bff43 35 #endif
syundo0730 0:d114194bff43 36
syundo0730 0:d114194bff43 37 int main(void) {
syundo0730 0:d114194bff43 38
syundo0730 0:d114194bff43 39 for(int i = 0; i < SRV_CH_NUM; i++)
syundo0730 0:d114194bff43 40 {
syundo0730 0:d114194bff43 41 SetDuty(i, (SRV_MAX_DUTY + SRV_MIN_DUTY) / 2);
syundo0730 0:d114194bff43 42 }
syundo0730 0:d114194bff43 43
syundo0730 1:5c2e40445778 44 Init_PWM();
syundo0730 1:5c2e40445778 45
syundo0730 0:d114194bff43 46 while (1);
syundo0730 0:d114194bff43 47 }
syundo0730 0:d114194bff43 48
syundo0730 0:d114194bff43 49 void PWM1_IRQHandler (void) {
syundo0730 1:5c2e40445778 50
syundo0730 3:84e5335fab91 51 LPC_PWM1->MR1 = SRV_PWMTable[0][SRV_Idx];
syundo0730 1:5c2e40445778 52 LPC_PWM1->MR2 = SRV_PWMTable[1][SRV_Idx];
syundo0730 1:5c2e40445778 53 LPC_PWM1->MR3 = SRV_PWMTable[2][SRV_Idx];
syundo0730 0:d114194bff43 54 LPC_PWM1->MR4 = SRV_dutyTable[0][SRV_Idx];
syundo0730 0:d114194bff43 55 LPC_PWM1->MR5 = SRV_dutyTable[1][SRV_Idx];
syundo0730 0:d114194bff43 56 LPC_PWM1->MR6 = SRV_dutyTable[2][SRV_Idx];
syundo0730 1:5c2e40445778 57
syundo0730 3:84e5335fab91 58 LPC_PWM1->LER |= 0x7E;
syundo0730 3:84e5335fab91 59
syundo0730 0:d114194bff43 60 LPC_PWM1->IR |= (1<<0); // reset PWMMR0 flag
syundo0730 0:d114194bff43 61
syundo0730 0:d114194bff43 62 SRV_Idx++;
syundo0730 0:d114194bff43 63
syundo0730 0:d114194bff43 64 if(SRV_Idx >= SRV_IDX_NUM){
syundo0730 0:d114194bff43 65 SRV_Idx = 0;
syundo0730 0:d114194bff43 66 }
syundo0730 0:d114194bff43 67 }
syundo0730 0:d114194bff43 68
syundo0730 0:d114194bff43 69 void Init_PWM(void) {
syundo0730 0:d114194bff43 70 LPC_PINCON->PINSEL3 &= ~(3 << 4); // GPIO (00)
syundo0730 0:d114194bff43 71 LPC_GPIO1->FIODIR |= (1 << 18); // output
syundo0730 0:d114194bff43 72
syundo0730 0:d114194bff43 73 LPC_PINCON->PINSEL4 |= 0x555; // GPIO (00)
syundo0730 0:d114194bff43 74 LPC_GPIO2->FIODIR |= 0x3F; // output
syundo0730 0:d114194bff43 75
syundo0730 0:d114194bff43 76 LPC_SC->PCLKSEL0 &= ~(3 << 12); // PCLK_TIMER0 ck/4 (00)
syundo0730 0:d114194bff43 77 LPC_SC->PCONP |= (1 << 6); // PCPWM1
syundo0730 0:d114194bff43 78 LPC_PWM1->TCR = (1 << 1);//reset
syundo0730 0:d114194bff43 79 LPC_PWM1->PR = SystemCoreClock / 4 / 1000000 - 1; // prescale 1000kHz(1us&#65533;&#65533;&#65533;&#65533;)&#65533;&#65533;&#65533;&#65533;&#65533;&#273538;&#386;&#579;^&#65533;C&#65533;}&#65533;J&#65533;E&#65533;&#65533;&#65533;^&#65533;&#65533;J&#65533;E&#65533;&#65533;&#65533;g&#65533;A&#65533;b&#65533;v&#65533;&#65533;&#65533;&#37033;&#65533;&#386;&#65533;&#65533;&#65533;&#65533;&#1874;&#65533;
syundo0730 0:d114194bff43 80 LPC_PWM1->CTCR = 0;
syundo0730 0:d114194bff43 81 LPC_PWM1->MCR |= (1 << 1)|(1 << 0); // MR0R, MR0
syundo0730 0:d114194bff43 82
syundo0730 0:d114194bff43 83 LPC_PWM1->MR0 = SRV_PERIOD; // PWM(74HC238&#65533;&#65533;G1)&#65533;&#65533;&#65533;2500us
syundo0730 1:5c2e40445778 84 //LPC_PWM1->MR1 = SRV_MAX_DUTY;//SRV_PERIOD; // &#65533;&#1538;&#65533;&#1410;&#65533;&#65533;&#65533;&#65533;(74HC238&#65533;&#65533;A)1
syundo0730 1:5c2e40445778 85 //LPC_PWM1->MR2 = SRV_MAX_DUTY;//SRV_PERIOD; // &#65533;&#1538;&#65533;&#1410;&#65533;&#65533;&#65533;&#65533;(74HC238&#65533;&#65533;B)
syundo0730 1:5c2e40445778 86 //LPC_PWM1->MR3 = SRV_MAX_DUTY;//SRV_PERIOD; // &#65533;&#1538;&#65533;&#1410;&#65533;&#65533;&#65533;&#65533;(74HC238&#65533;&#65533;C)
syundo0730 1:5c2e40445778 87 //LPC_PWM1->MR4 = SRV_MAX_DUTY;//(SRV_MAX_DUTY + SRV_MIN_DUTY) / 2; //PWM(74HC238&#65533;&#65533;G1)&#65533;f&#65533;&#65533;&#65533;[&#65533;e&#65533;B&#65533;[(&#65533;j&#65533;&#65533;&#65533;[&#65533;g&#65533;&#65533;&#65533;&#65533;)
syundo0730 1:5c2e40445778 88 //LPC_PWM1->MR5 = SRV_MAX_DUTY;//(SRV_MAX_DUTY + SRV_MIN_DUTY) / 2;
syundo0730 1:5c2e40445778 89 //LPC_PWM1->MR6 = SRV_MAX_DUTY;//(SRV_MAX_DUTY + SRV_MIN_DUTY) / 2;
syundo0730 0:d114194bff43 90
syundo0730 0:d114194bff43 91 LPC_PWM1->IR |= (1<<0);//reset PWMMR0 flag
syundo0730 0:d114194bff43 92
syundo0730 0:d114194bff43 93 NVIC_EnableIRQ(PWM1_IRQn);//enable
syundo0730 0:d114194bff43 94
syundo0730 0:d114194bff43 95 LPC_PWM1->TCR = (1 << 0)|(1 << 3); // enable
syundo0730 0:d114194bff43 96 LPC_PWM1->PCR |= (0x3F << 9);//1-6 pwm
syundo0730 0:d114194bff43 97
syundo0730 0:d114194bff43 98 __enable_irq();
syundo0730 0:d114194bff43 99 }
syundo0730 0:d114194bff43 100
syundo0730 2:8a40834788ba 101 void SetDuty(uint8_t ch, uint32_t duty){
syundo0730 0:d114194bff43 102 if(ch >= SRV_CH_NUM){
syundo0730 0:d114194bff43 103 return;
syundo0730 0:d114194bff43 104 }else if(duty < SRV_MIN_DUTY){
syundo0730 0:d114194bff43 105 duty = SRV_MIN_DUTY;
syundo0730 0:d114194bff43 106 }else if(duty > SRV_MAX_DUTY){
syundo0730 0:d114194bff43 107 duty = SRV_MAX_DUTY;
syundo0730 0:d114194bff43 108 }
syundo0730 0:d114194bff43 109 SRV_dutyTable[ch >> SRV_IDX_SHIFT][ch & SRV_IDX_MASK] = duty;
syundo0730 0:d114194bff43 110 }