View Full Version : Wired remote for Alpine
  
fratello
- 31st January 2012, 16:17
Hello ! 
Since I have good results with "wired remote for Pioneer HU" (see : http://www.picbasic.co.uk/forum/showthread.php?t=15229 ) one friend ask me to build something similar for his Alpine ...
I found a good topic here : http://www.mp3car.com/input-devices/131147-need-alpine-wired-remote-control-pinout.html , where it's described the "protocol". 
I intend to use the same hardware : PIC 16F628A and remote control stalk near the steering wheel, from Renault.
But...I need help to put in PBP this :
Vol Up    110101111101101110101011110110111101011011010101
Vol Dn    110101111101101110101011011011011111011011010101
Mute    110101111101101110101011101011011110111011010101
Pst up    110101111101101110101011101010111110111101010101
Pst dn    110101111101101110101011010101011111111101010101
Source    110101111101101110101011101101111101101101010101
Trk up    110101111101101110101011101110111101101011010101
Trk dn    110101111101101110101011010111011111101011010101
Power    110101111101101110101011011101111110101101010101
Ent/Play    110101111101101110101011010101111111110101010101
Band/prog    110101111101101110101011011010111111011101010101
Note that the same series of 1's and 0's is at the start and end of each command, so here are the unique parts of each:
(Start)    110101111101101110101011
Vol Up    11011011110101101
Vol Dn    01101101111101101
Mute    10101101111011101
Pst up    10101011111011110
Pst dn    01010101111111110
Source    10110111110110110
Trk up    10111011110110101
Trk dn    01011101111110101
Power    01110111111010110
Ent/Play    01010111111111010
Band/prog    01101011111101110
(End)    1010101
So if "0" is low for 1000 us, and "1" is high for 500 us AND low for 500 us, how can I write the code ?!
Something like this (pseudo-code):
;(Start)    110101111101101110101011
 ; Vol Up    11011011110101101
check: select case key  case 1     ; volume down 
portb.7 = high
pauseus 500
portb.7 = low
pauseus 500  ' this is first "1"
portb.7 = high
pauseus 500
port.7 = low
pauseus 500 ' this is second "1"
... so on, so on ?!?
I need "a clue" ! Thanks in advance !!!
HenrikOlsson
- 31st January 2012, 17:23
Hi,
Here's an idea:
'************************************************* ***************
'*  Name    : Fratello_Alpine.PBP                               *
'*  Author  : Henrik Olsson                                     *
'*  Notice  :                                                   *
'*          :                                                   *
'*  Date    : 2012-01-31                                        *
'*  Version : 1.0                                               *
'*  Notes   :                                                   *
'*          :                                                   *
'************************************************* ***************
' CONFIGs and hardware setup, ADCON, CMCON, TRIS whatever not shown here.
'------------------------------------------------------------------------
StartH CON %11010111        ' High 8 bits of start frame
StartM CON %11011011        ' Middle 8 nits of start frame
StartL CON %10101011        ' Low 8 bits of start frame
'------------------------------------------------------------------------
VolUpH CON %11011011        ' High 8 bits of command
VolUpM CON %11010110        ' Middle 8 nits of command
VolUpL CON %11010101        ' Low bit of command + 7bits END of frame
'------------------------------------------------------------------------
VolDnH CON %01101101        ' High 8 bits of command
VolDnM CON %11110110        ' Middle 8 nits of command
VolDnL CON %11010101        ' Low bit of command + 7bits END of frame 
'------------------------------------------------------------------------
ByteArray VAR BYTE[6]       ' 6 bytes = 48bits
BitCount  VAR BYTE          ' Index variable for above array
i         VAR BYTE          ' General purpose
'------------------------------------------------------------------------
' Initialise the first three bytes of the array, these are static.
ByteArray[0] = StartH 
ByteArray[1] = StartM
ByteArray[2] = StartL
    
Pause 1000
HSEROUT["Program start",13]
Main:
    For i = 0 to 20
        GOSUB VolumeUp
        Pause 300
    NEXT
    
    FOR i = 0 TO 20
        GOSUB VolumeDn
        Pause 300
    NEXT
    
    Goto Main
    
END
'------------------------------------------------------------------------
'------------------------------------------------------------------------
' Subroutines follows:
'------------------------------------------------------------------------    
VolumeUp:
    ' Set non static part of array to current command.
    ByteArray[3] = VolUpH
    ByteArray[4] = VolUpM
    ByteArray[5] = VolUpL
    GOSUB SendIt
RETURN
'------------------------------------------------------------------------
VolumeDn:
    ByteArray[3] = VolDnH
    ByteArray[4] = VolDnM
    ByteArray[5] = VolDnL
    GOSUB SendIt
RETURN
'------------------------------------------------------------------------   
SendIt:
    FOR BitCount = 0 to 47
        If ByteArray.0[BitCount] = 1 THEN
            GOSUB One
        ELSE
            GOSUB Zero
        ENDIF
    NEXT
RETURN
'------------------------------------------------------------------------
One:
    PORTB.7 = 1
    PAUSEUS 500
    PORTB.7 = 0
    PAUSEUS 500
RETURN
'------------------------------------------------------------------------
Zero:
    PortB.7 = 0
    PAUSEUS 1000
RETURN
/Henrik.
fratello
- 31st January 2012, 18:05
WOW !!! What fast and GREAT answer !!! :applause:
Thank YOU so much ! I will try this and post feed-back !
fratello
- 31st January 2012, 20:57
One little queries : In "SendIt:" which is the command to send (to portb.7) the data from ByteArray[n] (n=3;4;5) ? I miss something ? Thanks !
HenrikOlsson
- 31st January 2012, 21:35
Hi,
Not sure I understand what you mean....
Send it iterates thru the bytearray bit by bit. For each bit it GOSUBS either One or Zero based on if the bit is 1 or 0. It's in the routines One and Zero that the actual port is written.
With that said, the code is untested so I may have missed something.
fratello
- 1st February 2012, 08:39
I understand...Thanks !
Next step : need confirmation if works correct (just VolumeUp & VolumeDn at this moment) !
In attach : code and Proteus simulation.
fratello
- 1st February 2012, 14:32
Please, take a look at this two pictures ..."original" vs. testing ...
In "our" case, after commander begins ("an 8ms pulse at +5V and then 4.5ms at 0V"), we have 11101011110...instead 1101011111 ... :(
ScaleRobotics
- 1st February 2012, 15:17
It looks to me like the :
StartH CON %11010111        ' High 8 bits of start frame
is getting read out backwards, as it is incrementing from bit 0 to 47. I think you need to change some things so it gets read out forward.
HenrikOlsson
- 1st February 2012, 16:42
Yeah, didn't think that one thru all the way - apparently. But you're smart enought to move things around so the bits come in the right order.
fratello
- 1st February 2012, 17:04
I reverse ... something, and the results are Ok (in Proteus) ! Hope to testing soon if work ! Thank You all ! I will post the results !
;StartH CON %11010111        ' High 8 bits of start frame
StartH CON %11101011
StartM CON %11011011        ' Middle 8 nits of start frame
;StartL CON %10101011        ' Low 8 bits of start frame
StartL CON %11010101
'------------------------------------------------------------------------
VolUpH CON %11011011        ' High 8 bits of command
;VolUpM CON %11010110        ' Middle 8 nits of command
VolUpM CON %01101011
;VolUpL CON %11010101        ' Low bit of command + 7bits END of frame
VolUpL CON %10101011
fratello
- 9th February 2012, 19:46
Mr.Henrik Olsson : THANK YOU ! With some minors modification (reversing order ; changes in KeyPad2.pbp ; adding input/output timming), the code work PERFECT !!!
fratello
- 9th March 2012, 09:26
I have all information about code for JVC remote : http://www.avforums.com/forums/car-entertainment-ice-sat-nav/248455-jvc-stalk-adapter-diy-2.html#post16560076
The code is ... SO BIG :( ....
This is how commands look :
11111111000000000000000011111111
01110111011101110101010111<C>0111
11111111111111111111111111111111
01110111011101110101010111<C>0111
11111111111111111111111111111111
01110111011101110101010111<C>0111
11111111111111111111111111111111
where the <C>s should be replaced by:
0x04 Vol+                     01010111101010101
0x05 Vol-                     01111010111101010101       
0x08 Source                   01010101111010101 
0x0D Sound                    01111010111101111010101    
0x0E Mute                     01011110111101111010101     
0x12 Skip fwd or Right        01011110101011110101   
0x13 Skip back or left        01111011110101011110101 
0x14 Skip fwd hold or Up      01010111101011110101  
0x15 Skip back hold or down   01111010111101011110101
How #*&^%$#@"_)_ can write this in PBP ? I can figure out...Any help will be wellcome ! Thanks !
fratello
- 12th March 2012, 12:41
In front of each <Command> it's this : 00000000000000001111111101110111011101110101010111 <C>
How can be writting, more "elegant" this :
timp con 536
...
portb.x = 0
pauseus 8584 ; 16 x 536,5 us
portb.x = 0
pauseus 4292 ;   8 x 536,5 us
portb.x = 0
pauseus timp
portb.x = 0
pauseus 1610 ;   3 x 536,5 us
portb.x = 0
pauseus timp
portb.x = 0
pauseus 1610
portb.x = 0
pauseus timp
portb.x = 0
pauseus 1610
portb.x = 0
pauseus timp
portb.x = 0
pauseus 1610
portb.x = 0
pauseus timp
portb.x = 0
pauseus timp
portb.x = 0
pauseus timp
portb.x = 0
pauseus timp
portb.x = 0
pauseus timp
portb.x = 0
pauseus timp
portb.x = 0
pauseus timp
portb.x = 0
pauseus 1610
HenrikOlsson
- 12th March 2012, 16:54
Hi,
As last time this is completely untested. This builds and sends the command in steps which means that there will be some delay between the "preamble", "command" and "postamble". I don't know how tight the timing has to be so doing it this way may or may not work.
'************************************************* ***************
'*  Name    : Fratello_JVC.pbp                                  *
'*  Author  : Henrik Olsson                                     *
'*  Notice  :                                                   *
'*          :                                                   *
'*  Date    : 2012-03-12                                        *
'*  Version : 1.0                                               *
'*  Notes   :                                                   *
'*          :                                                   *
'************************************************* ***************
i VAR BYTE
j VAR BYTE
OutBuffer VAR BYTE[8]
BitsToSend VAR BYTE
Main:
    For j = 0 to 10
        GOSUB VolUp
        Pause 1000
    NEXT
    FOR j = 0 to 10
        GOSUB VolDn
        PAUSE 1000
    NEXT
GOTO Main
SendPreamble:
' 00000000  00000000  11111111  01110111 01110111 01010101  11
' Each individual byte reversed:
    OutBuffer[0] = %00000000
    OutBuffer[1] = %00000000
    OutBuffer[2] = %11111111
    OutBuffer[3] = %11101110
    OutBuffer[4] = %11101110
    OutBuffer[5] = %10101010
    OutBuffer[6] = %00000011
    BitsToSend = 50
    
    GOSUB SendBits
RETURN
'-----------------------------------------------------------------------
SendPostAmble:
' 01111111 11111111 11111111 11111111 11110111 01110111 01110101 010111
    OutBuffer[0] = %11111110
    OutBuffer[1] = %11111111
    OutBuffer[2] = %11111111
    OutBuffer[3] = %11111111
    OutBuffer[4] = %11101111
    OutBuffer[5] = %11101110
    OutBuffer[6] = %10101110
    OutBuffer[7] = %00111010
    
    BitsToSend = 54
    
    GOSUB SendBits
RETURN
'-----------------------------------------------------------------------
'-----------------------------------------------------------------------
VolUp:
    GOSUB SendPreAmble
    ' 01010111 10101010 1
    ' Each individual byte reversed
    OutBuffer[0] = %11101010
    OutBuffer[1] = %01010101
    OutBuffer[2] = %00000001
    
    BitsToSend = 17
    
    GOSUB SendBits
    GOSUB SendPostAmble
RETURN
'-----------------------------------------------------------------------
'-----------------------------------------------------------------------
VolDn:
    GOSUB SendPreAmble
    ' 01111010 11110101 0101
    ' Each individual byte reversed
    OutBuffer[0] = %01011110
    OutBuffer[1] = %10101111
    OutBuffer[2] = %00001010
    
    BitsToSend = 20
    GOSUB SendBits
    GOSUB SendPostAmble
RETURN
'-----------------------------------------------------------------------
'-----------------------------------------------------------------------
SendBits:
    BitsToSend = BitsToSend - 1
    For i = 0 to BitsToSend 
        PortB.0 = OutBuffer.0[i]
        PauseUs 536
    NEXT
RETURN
'-----------------------------------------------------------------------
Again, not tested so take it for what it is.
/Henrik.
fratello
- 12th March 2012, 16:59
WOW :._rolleyes: ! Amazing ! Thank YOU so much !!!
I discover, every time when someone, like YOU, post such a great example of code, how far I am from understanding this great art of programming !!!
I made the tests and post the results. Best regards !
fratello
- 12th March 2012, 18:18
I made some changes ....
VolUp:
    GOSUB SendPreAmble
    ' 01010111 10101010 1
    ' Each individual byte reversed
    OutBuffer[0] = %11101010
    OutBuffer[1] = %01010101  ; modified
    OutBuffer[2] = %00000001
    
    BitsToSend = 17
    
    GOSUB SendBits
    GOSUB SendPostAmble
    
    OutBuffer[0] = %11101010
    OutBuffer[1] = %01010101  ; modified
    OutBuffer[2] = %00000001
    
        BitsToSend = 17
    
    GOSUB SendBits
    GOSUB SendPostAmble
    
    OutBuffer[0] = %11101010
    OutBuffer[1] = %01010101  ; modified
    OutBuffer[2] = %00000001
    
        BitsToSend = 17
    
    GOSUB SendBits
    GOSUB SendFinalAmble    
RETURN
and added this :
SendFinalAmble:
' 01111111 11111111 11111111 11111111 11111111 11111111 11111111 111111
    OutBuffer[0] = %11111110
    OutBuffer[1] = %11111111
    OutBuffer[2] = %11111111
    OutBuffer[3] = %11111111
    OutBuffer[4] = %11111111
    OutBuffer[5] = %11111111
    OutBuffer[6] = %11111111
    OutBuffer[7] = %11111111
    
    BitsToSend = 54
    
    GOSUB SendBits
RETURN
...and in Proteus look fine !
HenrikOlsson
- 12th March 2012, 19:04
Are you sure you actually have to send the command three times? Personally I have NO knowlage about these things but I would've guessed (if this is captured from a remote for example) that it just kept repeating the command and postamble untill the button was released and then issued the 'FinalAmble'. So perhaps Preamble, Command, FinalAmble is all you actually need? Oh well, like I said, I have no idea really - just guessing, you'll figure it out.
/Henrik.
fratello
- 12th March 2012, 20:19
My informations are from one user of AVFORUMS.COM. 
"Every time you send the device and command codes, you should repeat the  device and command codes three times, but pause between them for about  20ms."  I think it's true...
fratello
- 13th March 2012, 16:04
Still beta-testing :) ...
I wonder...It's one way to obtain EXACTLY 536.5 us ?!?
HenrikOlsson
- 13th March 2012, 16:52
Depends.... What's you oscillator speed? At 20Mhz an instruction cycles is 200ns so, in theory, doing something like
PauseUs 536
@ NOP
@ NOP
should get you pretty close (536.4us). If the timing is that critical then it's probably not going to work the way I wrote it since there will be "gaps" between the preamble, command, postamble etc. You'd need to build the complete message in a larger array and then send it but that gets a bit complicated due to the variation in length of the commands (they won't line up at even byte boundries).
/Henrik.
fratello
- 13th March 2012, 17:44
Thank You for support !
The oscillator is 4 MHz...
HenrikOlsson
- 13th March 2012, 18:52
Hi,
Well, at 4Mhz each instruction cycle is 1us so the smallest time possible to resolve at that speed is just that - 1us. I don't think I can come up with any way to get higher resolution without increasing the oscillator speed.
/Henrik.
fratello
- 13th March 2012, 19:00
Understand... so, maybe, I need a 20 MHz oscillator speed. 
But first - hardware test ! Best regards !
fratello
- 23rd March 2012, 14:59
Mr.Henrik wrote the code...me just put together parts...
BUT : even if in Proteus the signal(s) appears to be OK, the HU-JVC don't react at all ! 
Maybe the "timming" need to be more accurate ?! At this point, I'm hopeless and stuck :( ... Any help will be appreciated !
Hex and dns attached...
;************************************************* **************************
;*
;*    Test variant, using 2N3904 on output - PORTC.0
;*
;************************************************* **************************
@ DEVICE PIC16F684, HS_OSC, WDT_OFF, PWRT_OFF, BOD_OFF, MCLR_OFF
DEFINE OSC 20
include "ALLDIGITAL.pbp"
TRISA= 000011                           
PORTA= 000011
PORTC= 000000
                
CMCON0 = 000111              ' Disable analog comparators.     
VRCON  = 000000               ' Disable Comparator Voltage Reference
ANSEL  = 000000               ' Set pin'S to digital
ADCON0 = 000000               ' Set up A/D converter - OFF 
Pause 1000
i VAR BYTE
j VAR BYTE
OutBuffer VAR BYTE[8]
BitsToSend VAR BYTE
Main:
if porta.0 = 0 then gosub VolUp        ' just for test
if porta.1 = 0 then gosub VolDn        ' just for test
Pause 100                 ' do it for 0.1 sec
Goto Main
'-----------------------------------------------------------------------
SendPreamble:        
; 01110111 01110111 01010101 11
    OutBuffer[0] = 010001 ; 101110 REVERSED BECAUSE OF USING TRANSISTOR AT OUTPUT !!!
    OutBuffer[1] = 010001 ; 101110
    OutBuffer[2] = 010101 ; 101010
    OutBuffer[3] = 111100 ; 000011
   
    BitsToSend = 26
    GOSUB SendBits
RETURN
'-----------------------------------------------------------------------
AGC:
TRISC.0 = 1 ; 0
PauseUs 8584
TRISC.0 = 0 ; 1
PauseUs 4292
RETURN
'-----------------------------------------------------------------------
SendPostAmble:
' 01111111 11111111 11111111 11111111 11110111 01110111 01110101 010111
    OutBuffer[0] = 000001 ; 111110
    OutBuffer[1] = 000000 ; 111111
    OutBuffer[2] = 000000 ; 111111
    OutBuffer[3] = 000000 ; 111111
    OutBuffer[4] = 110000 ; 001111
    
    BitsToSend = 36
    
    GOSUB SendBits
RETURN
'-----------------------------------------------------------------------
SendFinalAmble:
' 01111111 11111111 11111111 11111111 11111111 11111111 11111111 111111
    OutBuffer[0] = 000001 ; 111110
    OutBuffer[1] = 000000 ; 111111
    OutBuffer[2] = 000000 ; 111111
    OutBuffer[3] = 000000 ; 111111
    OutBuffer[4] = 000000 ; 111111
    OutBuffer[5] = 000000 ; 111111
    OutBuffer[6] = 000000 ; 111111
    OutBuffer[7] = 000000 ; 111111
    
    BitsToSend = 54
    
    GOSUB SendBits
RETURN
'-----------------------------------------------------------------------
VolUp:
    Gosub AGC
;==============================    
    GOSUB SendPreAmble    ; one
    ' Volume Up
    OutBuffer[0] = 010101 ; 101010
    OutBuffer[1] = 101010 ; 010101  
    OutBuffer[2] = 111110 ; 000001
    
    BitsToSend = 17
    GOSUB SendBits
    GOSUB SendPostAmble
;==============================    
    gosub SendPreamble    ; two
    ' Volume Up    
    OutBuffer[0] = 010101 ; 101010
    OutBuffer[1] = 101010 ; 010101  
    OutBuffer[2] = 111110 ; 000001
    
    BitsToSend = 17
    GOSUB SendBits   
    GOSUB SendPostAmble
;==============================    
    gosub sendPreamble    ; three
    ' Volume Up
    OutBuffer[0] = 010101 ; 101010
    OutBuffer[1] = 101010 ; 010101  
    OutBuffer[2] = 111110 ; 000001
    
    BitsToSend = 17
    GOSUB SendBits
    GOSUB SendFinalAmble    
RETURN            ; end command
'-----------------------------------------------------------------------
VolDn:
    Gosub AGC
;==============================    
    GOSUB SendPreAmble
    ' 01111010 11110101 0101
    ' Volume Down
    OutBuffer[0] = 100001 ; 011110
    OutBuffer[1] = 010000 ; 101111
    OutBuffer[2] = 110101 ; 001010
    
    BitsToSend = 20
    GOSUB SendBits
    GOSUB SendPostAmble
;==============================
    GOSUB SendPreAmble
    ' 01111010 11110101 0101
    ' Volume Down
    OutBuffer[0] = 100001 ; 011110
    OutBuffer[1] = 010000 ; 101111
    OutBuffer[2] = 110101 ; 001010
    
    BitsToSend = 20
    GOSUB SendBits
    GOSUB SendPostAmble
;==============================
    GOSUB SendPreAmble
    ' 01111010 11110101 0101
    ' Volume Down
    OutBuffer[0] = 100001 ; 011110
    OutBuffer[1] = 010000 ; 101111
    OutBuffer[2] = 110101 ; 001010
    
    BitsToSend = 20
    GOSUB SendBits
    GOSUB SendFinalAmble    
RETURN
'-----------------------------------------------------------------------
SendBits:
    BitsToSend = BitsToSend - 1
    For i = 0 to BitsToSend 
        TRISC.0 = OutBuffer.0[i]
        PauseUs 536
        @ nop
        @ nop  ; for 536.5 us
    NEXT
RETURN
'-----------------------------------------------------------------------
END
HenrikOlsson
- 23rd March 2012, 17:47
Hi,
Like I said earlier, with this aproach you're going to get variation in the bit to bit timing when going from preamble to data to postamble etc. You should be able to SEE this on the scope. Also verify that you actually GET 536.4us between bits (I think it'll be a bit more due to the FOR-NEXT loop) and adjust the delay to match exactly.
What I'd try, just to see IF timing is all there is to it is to stitch a complete packet together and send it in one go. Just extend the size of the array and load it up with bits, set BitsToSend accordingly and call SendBits.
/Henrik.
fratello
- 23rd March 2012, 19:30
You are such a fine gentleman !!! Thanks !
...so You say to put the entire command in "one place" ?
OutBuffer[0] = ....
to
OutBuffer[n] = ....
and
    BitsToSend = n x 8     GOSUB SendBits
?!
I have some doubt about how I understand this :
"You really shouldn't drive the output line at 5V or 3V or any other  voltage for a high output. If you want the output to be high, you do  that by turning off the PIC's output driver. This way it doesn't matter  what voltage the head unit uses, your hardware will always be  compatible. It'll work at 5V, 3.3V, or anything.
To do that, search the PIC manual for "Open-drain".
For the 16-bit PIC24F series, you configure the pins as open drain by  setting the bits in the ODCx register to '1's BEFORE you configure the  pin as an output by writing '0's to the TRISx register."
It's ok what I wrote in code, ie how I use  PortC and TrisC ?
HenrikOlsson
- 24th March 2012, 01:13
Exactly, take the complete bitstream and fill the array with that, make sure  you have the correct numbers of bits and then call SendBits. Because the actuall commads seem to be of different length the n*8 may not be true, make sure to count the actual number of bits in the packet.
Regarding the other comment....It totaly depends on the actual hardware you're using but since you indicate that you're using a transistor between the PIC and the actual unit I think you need to DRIVE that transistor base high AND low, not float it by setting TRIS - again, depends on how your hardware is done.
/Henrik.
fratello
- 31st March 2012, 13:14
Since I have no results with this code, I made this "PICKit2 IR capture tool" , from here : PIC Kit 2 IR capture tool « Spiralbrain's Blog (http://sunbizhosting.co.uk/%7Espiral/blog/?p=85)
The signals captured with this tool are totally different !!! I build even an IR widget for analyzing the IR signal...My conclusions :  my remote, JVC RM-RK252, send a different code than that presented till now in  this topic......I post the picture of all my captures, using AND an IR_Widget with IR_Scope (yes, I build this one too !)
So : this is how the volume_up signal is ! The red part (in pdf) it's the part common for all commands ; the black part is proper command.
Can I use Mr.Henrik examples for writting the new code ?!  I have some questions : 415, 560 and 1400 are values by itselfs ...How can I put them in code ? Using something like this : "Data 560, 1400 ( this in hex ?), 560,1400,560,415,560,415, so on, so on ...." ?
Thanks in advance for support and I apologize for my ignorance :( ...
fratello
- 31st March 2012, 17:51
Can be done in this way ???:
;
;          testing code for new JVC Remote
;                       march, 31
@ DEVICE PIC16F684, HS_OSC, WDT_OFF, PWRT_OFF, BOD_OFF, MCLR_OFF, PROTECT_ON
DEFINE OSC 20
include "ALLDIGITAL.pbp"
                          
PORTA= 000011
TRISA= 000011
PORTC= 000000
TRISC= 111110
                
CMCON0 = 000111              'Disable analog comparators.     
VRCON  = 000000               ' Disable Comparator Voltage Reference
ANSEL  = 000000               ' Set pin (AN2) to analog input, the rest to digital
ADCON0 = 000000               ' Set up A/D converter - Right Just., VDD REF., CH 3, ON
Pause 1000
i VAR BYTE
j VAR BYTE
pulse con 560
main:
if porta.0 = 0 then gosub VolUp
Pause 100 ' do it for 0.1 sec
goto main
VolUp :
TRISC.0 = 1
pauseus 4000
TRISC.0 = 0
pauseus 1900
TRISC.0 = 1
pauseus pulse
TRISC.0 = 0
pauseus 1400
TRISC.0 = 1
pauseus pulse
TRISC.0 = 0
pauseus 1400
TRISC.0 = 1
pauseus pulse
for i = 0 to 30
          Lookup i,[$BE,$8C,$8C,$2A,$2A,$2A,$2A,$2A,$2A,_
                    $8C,$2A,$2A,$2A,$2A,$2A,$2A,$2A,$2A,_
                    $8C,$2A,$2A,$2A,$8C,$2A,$2A,$2A,$2A,_
                    $2A,$2A,$8C,$8C] ,j 
TRISC.0 = 0 
PauseUs j*10
TRISC.0 = 1 
PauseUs pulse  
next i 
Return
In Proteus it's ok ; just the "preamble" part so far.
Any advice will be wellcome !
fratello
- 31st March 2012, 20:28
This code :
i VAR BYTE
j VAR BYTE
pulse con 560
main:
if porta.0 = 0 then  gosub volup
TRISC.0 = 1
goto main
VolUp :
Gosub Preamble
FOR I = 0 TO 17
            Lookup i,[$8C,$2A,$2A,$8C,$2A,$2A,$2A,$8C,$2A,$8C,_
                      $2A,$2A,$2A,$2A,$8C,$8C,$8C,$8C ] ,j
TRISC.0 = 0 
PauseUs j*10
TRISC.0 = 1 
PauseUs pulse  
next i
PauseUs 4500 
RETURN
Preamble :
TRISC.0 = 1
Pauseus 4000
for i = 0 to 30
          Lookup i,[$BE,$8C,$8C,$2A,$2A,$2A,$2A,$2A,$2A,_
                    $8C,$2A,$2A,$2A,$2A,$2A,$2A,$2A,$2A,_
                    $8C,$2A,$2A,$2A,$8C,$2A,$2A,$2A,$2A,$2A,$2A,_
                    $8C,$8C ] , j
TRISC.0 = 0 
PauseUs j*10
TRISC.0 = 1 
PauseUs pulse  
next i 
Return
give me, in Proteus (!), the code I need ...The next step it's hardware testing !
fratello
- 1st April 2012, 20:33
I put all the values into one command :
pulse con 567
MAIN :
if porta.0 = 0 then  
PORTC.0 = 0
pauseus 4032
for i = 0 to 48
lookup i,   [value, value, value, ....], j
PORTC.0 = 1 
PauseUs j
PORTC.0 = 0 
PauseUs pulse
next i
PORTC.0 = 0
PauseUs 4500
PORTC.0 = 1
ENDIF
PAUSE 25
goto main
...but testing hardware I have no results :( , despite the "full similarity" with code captured with IR_Scope !
Somebody has more experience with IR remote control ? It's the "lenght" of each pulse so critical ?
I don't understand what I do wrong ...
fratello
- 2nd April 2012, 19:08
Still no good news ... Cycle " for ...next"  generate a "big" delay ?
gadelhas
- 2nd April 2012, 19:49
Hi fratello;
 I dind't read the hole thread, but are you trying to reproduce a IV remote control??
 If so, i see on your last post that your reproducing the pulses, but you are not using modulation, and you must use modulation when using IV. Probably 36Khz, or 38Khz, or 40Khz.
HenrikOlsson
- 2nd April 2012, 19:50
Hi,
The actual FOR-NEXT construct will add some additional delay due to the fact that it is a jump isntruction and it has to make the comparison. Add to that the execution time of the LOOKUP instruction you're using. Why don't you just measure it and adjust the pulse constant so it matches the capture of the working remote?
/Henrik.
fratello
- 2nd April 2012, 21:07
Thanks !
@Gadelhas : I try to build a wired-remote, not IR remote ; I use IR remote just for reading codes, but I intend to use wired - steering wheel - remote.
@Henrik : Good ideea !!! I will try tomorrow to read MY signal ...by putting one LED to PIC output (?!)
fratello
- 3rd April 2012, 14:55
I make reverse-engineering ... I put one IR-LED on output (driving by transistor) to see how the code work !
And... surprise ! It's totally different by Proteus simulation and my whis !!!
Despite I try to "PauseUs 560" the Pauseus, measured in IR_Scope, it's 202 to 208 us !
I read this : "PAUSEUS assumes an oscillator frequency of 4MHz ;PAUSEUS 1000  ' Delay for 1 millisecond "
It's not applicable on my code ?! Why ? I use an 4 MHz crystal ,  I define "XT_OSC" ... I really don't understand :( ...
HenrikOlsson
- 3rd April 2012, 18:11
Hi,
Are you sure that it is a 4Mhz and not a 10Mhz crystal?
Do you have the correct capacitors inplace to load the crystal?
Try something like 
TRISC.0 = 0
Main:
  PortC.0 = 1
  Pauseus 1000
  PortC.0 = 0
  Pauseus 1000
Goto Main
What's the frequency of the output signal?
/Henrik.
fratello
- 3rd April 2012, 18:20
Unfortunately, I dont have an oscilloscope ...I use just software tools, which are not so accurate !
I capture the signal with OSCILLOSCOPE V1.40 and it's ok (measuring all pulses and pauses, dont know how accurate)...
 I am in big deadlock ! I don't know what else I can do.
kolega35
- 3rd February 2014, 12:26
Hi! I am from Turkey. Taken in the forum I read that you are running on the remote control for Alpine.What did you use microcontrollers.  I worked very hard, but did not succeed. Can you give pbp code for alpine? My adress is 
[email protected]    Thanks. 
Mr.Henrik Olsson : THANK YOU ! With some minors modification (reversing order ; changes in KeyPad2.pbp ; adding input/output timming), the code work PERFECT !!!
 
Powered by vBulletin® Version 4.1.7 Copyright © 2025 vBulletin Solutions, Inc. All rights reserved.