Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
main.cpp@10:2088b1935a93, 2018-06-07 (annotated)
- Committer:
- carlosperales95
- Date:
- Thu Jun 07 10:22:01 2018 +0000
- Revision:
- 10:2088b1935a93
- Parent:
- 7:e2b8461d4f05
- Child:
- 11:021210c59a95
Declarations Uptodate
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
mglmx | 0:4d06a6a8e785 | 1 | #include "mbed.h" |
mglmx | 3:fe7010b693a0 | 2 | #include "TextLCD.h" |
mglmx | 1:0ab26889af9b | 3 | //mbed DCC Model Train Demo |
mglmx | 1:0ab26889af9b | 4 | |
carlosperales95 | 7:e2b8461d4f05 | 5 | /******PINS AND DECLARATIONS*******/ |
carlosperales95 | 7:e2b8461d4f05 | 6 | |
carlosperales95 | 7:e2b8461d4f05 | 7 | ///p5 |
carlosperales95 | 7:e2b8461d4f05 | 8 | ///p6 |
carlosperales95 | 7:e2b8461d4f05 | 9 | ///p7 |
carlosperales95 | 7:e2b8461d4f05 | 10 | ///p8 |
carlosperales95 | 7:e2b8461d4f05 | 11 | |
carlosperales95 | 10:2088b1935a93 | 12 | //RAIL SENSORS - INT0,INT1 |
carlosperales95 | 7:e2b8461d4f05 | 13 | //INT0 - p9 |
carlosperales95 | 10:2088b1935a93 | 14 | InterruptIn sensors0(p9); |
carlosperales95 | 7:e2b8461d4f05 | 15 | //INT1 - p10 |
carlosperales95 | 10:2088b1935a93 | 16 | InterruptIn sensors1(p10); |
carlosperales95 | 7:e2b8461d4f05 | 17 | |
carlosperales95 | 7:e2b8461d4f05 | 18 | ///p11 |
carlosperales95 | 7:e2b8461d4f05 | 19 | ///p12 |
carlosperales95 | 7:e2b8461d4f05 | 20 | //M0 - p13 |
carlosperales95 | 7:e2b8461d4f05 | 21 | DigitalIn d21(p13); |
carlosperales95 | 7:e2b8461d4f05 | 22 | //M1 - p14 |
carlosperales95 | 7:e2b8461d4f05 | 23 | DigitalIn d22(p14); |
carlosperales95 | 7:e2b8461d4f05 | 24 | //M2 - p15 |
carlosperales95 | 7:e2b8461d4f05 | 25 | DigitalIn d23(p15); |
carlosperales95 | 7:e2b8461d4f05 | 26 | //p16 |
carlosperales95 | 7:e2b8461d4f05 | 27 | ///p17 |
carlosperales95 | 7:e2b8461d4f05 | 28 | ///p18 |
carlosperales95 | 7:e2b8461d4f05 | 29 | |
carlosperales95 | 7:e2b8461d4f05 | 30 | //POTENTIOMETER - p19 |
carlosperales95 | 7:e2b8461d4f05 | 31 | AnalogIn pot(p19); |
carlosperales95 | 7:e2b8461d4f05 | 32 | |
carlosperales95 | 7:e2b8461d4f05 | 33 | //DAT - p20 |
mglmx | 3:fe7010b693a0 | 34 | DigitalOut Track(p20); //Digital output bit used to drive track power via H-bridge |
carlosperales95 | 7:e2b8461d4f05 | 35 | |
carlosperales95 | 7:e2b8461d4f05 | 36 | //LCD SCREEN - p21, p22, p23, p24, p25, p26 |
carlosperales95 | 7:e2b8461d4f05 | 37 | TextLCD lcd(p22,p21,p23,p24,p25,p26); // RS, E, A4, A5, A6, A7 |
carlosperales95 | 7:e2b8461d4f05 | 38 | |
carlosperales95 | 7:e2b8461d4f05 | 39 | ///p27 |
carlosperales95 | 7:e2b8461d4f05 | 40 | ///p28 |
carlosperales95 | 7:e2b8461d4f05 | 41 | |
carlosperales95 | 7:e2b8461d4f05 | 42 | //LED1 - p29 |
mglmx | 3:fe7010b693a0 | 43 | DigitalOut redled(p29); |
carlosperales95 | 7:e2b8461d4f05 | 44 | //LED2 - p30 |
mglmx | 3:fe7010b693a0 | 45 | DigitalOut greenled(p30); |
carlosperales95 | 7:e2b8461d4f05 | 46 | |
mglmx | 5:ce0f66ea12c5 | 47 | |
carlosperales95 | 10:2088b1935a93 | 48 | |
mglmx | 5:ce0f66ea12c5 | 49 | |
mglmx | 5:ce0f66ea12c5 | 50 | void interrupted(){ |
mglmx | 5:ce0f66ea12c5 | 51 | |
mglmx | 5:ce0f66ea12c5 | 52 | } |
mglmx | 1:0ab26889af9b | 53 | |
mglmx | 1:0ab26889af9b | 54 | void DCC_send_command(unsigned int address, unsigned int inst, unsigned int repeat_count) |
mglmx | 1:0ab26889af9b | 55 | { |
mglmx | 1:0ab26889af9b | 56 | unsigned __int64 command = 0x0000000000000000; // __int64 is the 64-bit integer type |
mglmx | 1:0ab26889af9b | 57 | unsigned __int64 temp_command = 0x0000000000000000; |
mglmx | 1:0ab26889af9b | 58 | unsigned __int64 prefix = 0x3FFF; // 14 "1" bits needed at start |
mglmx | 1:0ab26889af9b | 59 | unsigned int error = 0x00; //error byte |
mglmx | 1:0ab26889af9b | 60 | //calculate error detection byte with xor |
mglmx | 1:0ab26889af9b | 61 | error = address ^ inst; |
mglmx | 1:0ab26889af9b | 62 | //combine packet bits in basic DCC format |
mglmx | 1:0ab26889af9b | 63 | command = (prefix<<28)|(address<<19)|(inst<<10)|((error)<<1)|0x01; |
mglmx | 1:0ab26889af9b | 64 | //printf("\n\r %llx \n\r",command); |
mglmx | 1:0ab26889af9b | 65 | int i=0; |
mglmx | 1:0ab26889af9b | 66 | //repeat DCC command lots of times |
mglmx | 1:0ab26889af9b | 67 | while(i < repeat_count) { |
mglmx | 1:0ab26889af9b | 68 | temp_command = command; |
mglmx | 1:0ab26889af9b | 69 | //loops through packet bits encoding and sending out digital pulses for a DCC command |
mglmx | 1:0ab26889af9b | 70 | for (int j=0; j<64; j++) { |
mglmx | 1:0ab26889af9b | 71 | if((temp_command&0x8000000000000000)==0) { //test packet bit |
mglmx | 1:0ab26889af9b | 72 | //send data for a "0" bit |
mglmx | 1:0ab26889af9b | 73 | Track=0; |
mglmx | 1:0ab26889af9b | 74 | wait_us(100); |
mglmx | 1:0ab26889af9b | 75 | Track=1; |
mglmx | 1:0ab26889af9b | 76 | wait_us(100); |
mglmx | 1:0ab26889af9b | 77 | //printf("0011"); |
mglmx | 1:0ab26889af9b | 78 | } else { |
mglmx | 1:0ab26889af9b | 79 | //send data for a "1"bit |
mglmx | 1:0ab26889af9b | 80 | Track=0; |
mglmx | 1:0ab26889af9b | 81 | wait_us(58); |
mglmx | 1:0ab26889af9b | 82 | Track=1; |
mglmx | 1:0ab26889af9b | 83 | wait_us(58); |
mglmx | 1:0ab26889af9b | 84 | //printf("01"); |
mglmx | 1:0ab26889af9b | 85 | } |
mglmx | 1:0ab26889af9b | 86 | // next bit in packet |
mglmx | 1:0ab26889af9b | 87 | temp_command = temp_command<<1; |
mglmx | 1:0ab26889af9b | 88 | } |
mglmx | 1:0ab26889af9b | 89 | i++; |
mglmx | 0:4d06a6a8e785 | 90 | } |
mglmx | 0:4d06a6a8e785 | 91 | } |
mglmx | 1:0ab26889af9b | 92 | //DCC train demo turns on headlight, dims headlight, and moves back and forth at half speed forever |
mglmx | 1:0ab26889af9b | 93 | int main() |
mglmx | 1:0ab26889af9b | 94 | { |
mglmx | 2:f580707c44fa | 95 | led1 = 1; |
mglmx | 2:f580707c44fa | 96 | wait(0.5); |
mglmx | 2:f580707c44fa | 97 | led1 = 0; |
mglmx | 2:f580707c44fa | 98 | wait(0.5); |
mglmx | 2:f580707c44fa | 99 | led1 = 1; |
mglmx | 1:0ab26889af9b | 100 | //typical out of box default engine DCC address is 3 (at least for Bachmann trains) |
mglmx | 1:0ab26889af9b | 101 | //Note: A DCC controller can reprogram the address whenever needed |
mglmx | 1:0ab26889af9b | 102 | unsigned int DCCaddress = 0x01; |
mglmx | 1:0ab26889af9b | 103 | //see http://www.nmra.org/standards/DCC/standards_rps/RP-921%202006%20Aug%2021.pdf |
mglmx | 1:0ab26889af9b | 104 | //01DCSSSS for speed, D is direction (fwd=1 and rev=0), C is speed(SSSSC) LSB |
mglmx | 1:0ab26889af9b | 105 | unsigned int DCCinst_forward = 0x68; //forward half speed |
mglmx | 1:0ab26889af9b | 106 | unsigned int DCCinst_reverse = 0x48; //reverse half speed |
mglmx | 4:50879dfb82d5 | 107 | unsigned int DCCinst_stop = 0x50; |
mglmx | 1:0ab26889af9b | 108 | //100DDDDD for basic headlight functions |
mglmx | 1:0ab26889af9b | 109 | unsigned int DCC_func_lighton = 0x90; //F0 turns on headlight function |
mglmx | 1:0ab26889af9b | 110 | unsigned int DCC_func_dimlight = 0x91; //F0 + F1 dims headlight |
mglmx | 1:0ab26889af9b | 111 | // |
mglmx | 1:0ab26889af9b | 112 | //Basic DCC Demo Commands |
mglmx | 1:0ab26889af9b | 113 | DCC_send_command(DCCaddress,DCC_func_lighton,200); // turn light on full |
mglmx | 1:0ab26889af9b | 114 | DCC_send_command(DCCaddress,DCC_func_dimlight,200); //dim light |
mglmx | 1:0ab26889af9b | 115 | DCC_send_command(DCCaddress,DCC_func_lighton,200); //light full again |
mglmx | 2:f580707c44fa | 116 | led2 = 1; |
mglmx | 1:0ab26889af9b | 117 | while(1) { |
mglmx | 4:50879dfb82d5 | 118 | |
mglmx | 4:50879dfb82d5 | 119 | |
mglmx | 4:50879dfb82d5 | 120 | |
mglmx | 4:50879dfb82d5 | 121 | if(d21 == 1 || d22 == 1 || d23 == 1){ |
mglmx | 4:50879dfb82d5 | 122 | lcd.cls(); |
mglmx | 4:50879dfb82d5 | 123 | lcd.printf("Choo Choo station"); |
mglmx | 4:50879dfb82d5 | 124 | DCC_send_command(DCCaddress,DCCinst_stop,400); // forward half speed train address 3 |
mglmx | 4:50879dfb82d5 | 125 | |
mglmx | 4:50879dfb82d5 | 126 | }else{ |
mglmx | 4:50879dfb82d5 | 127 | DCC_send_command(DCCaddress,DCCinst_forward,1); // forward half speed train address 3 |
mglmx | 4:50879dfb82d5 | 128 | } |
mglmx | 4:50879dfb82d5 | 129 | |
mglmx | 4:50879dfb82d5 | 130 | |
mglmx | 4:50879dfb82d5 | 131 | /* |
mglmx | 3:fe7010b693a0 | 132 | float f = pot.read(); |
mglmx | 3:fe7010b693a0 | 133 | float vin = f * 3.3; |
mglmx | 3:fe7010b693a0 | 134 | |
mglmx | 2:f580707c44fa | 135 | led3 = 1; |
mglmx | 3:fe7010b693a0 | 136 | if(switch1 == 1){ |
mglmx | 3:fe7010b693a0 | 137 | lcd.cls(); |
mglmx | 3:fe7010b693a0 | 138 | lcd.printf("Going forward"); |
mglmx | 3:fe7010b693a0 | 139 | greenled = 0; |
mglmx | 3:fe7010b693a0 | 140 | redled = 1; |
mglmx | 3:fe7010b693a0 | 141 | DCC_send_command(DCCaddress,DCCinst_forward,400); // forward half speed train address 3 |
mglmx | 3:fe7010b693a0 | 142 | lcd.cls(); |
mglmx | 3:fe7010b693a0 | 143 | |
mglmx | 3:fe7010b693a0 | 144 | lcd.printf("vin: %.4f",vin); |
mglmx | 3:fe7010b693a0 | 145 | wait(0.2); |
mglmx | 3:fe7010b693a0 | 146 | |
mglmx | 3:fe7010b693a0 | 147 | }else{ |
mglmx | 3:fe7010b693a0 | 148 | lcd.cls(); |
mglmx | 3:fe7010b693a0 | 149 | lcd.printf("Going backwards"); |
mglmx | 3:fe7010b693a0 | 150 | greenled = 1; |
mglmx | 3:fe7010b693a0 | 151 | redled = 0; |
mglmx | 3:fe7010b693a0 | 152 | DCC_send_command(DCCaddress,DCCinst_reverse,400); // reverse half speed train address 3 |
mglmx | 3:fe7010b693a0 | 153 | lcd.cls(); |
mglmx | 3:fe7010b693a0 | 154 | |
mglmx | 3:fe7010b693a0 | 155 | lcd.printf("vin: %.4f",vin); |
mglmx | 3:fe7010b693a0 | 156 | wait(0.2); |
mglmx | 3:fe7010b693a0 | 157 | |
mglmx | 3:fe7010b693a0 | 158 | } |
mglmx | 4:50879dfb82d5 | 159 | */ |
mglmx | 1:0ab26889af9b | 160 | } |
mglmx | 3:fe7010b693a0 | 161 | } |