Move seperate bytes into a word


Closed Thread
Results 1 to 19 of 19

Hybrid View

  1. #1
    Join Date
    Sep 2004
    Location
    montreal, canada
    Posts
    6,898


    Did you find this post helpful? Yes | No

    Default

    this one
    Code:
    Z VAR WORD
    A VAR Z.LOWBYTE
    B VAR BYTE
    C VAR Z.HIGHBYTE
    D VAR BYTE
    
    '
    '    Some other code where you set A, B, C & D BYTE variables
    '
    
    Z.HIGHBYTE = Z.HIGHBYTE | (D<<4)
    Z.LOWBYTE = Z.LOWBYTE | (B<<4)
    ought to be the the less memory hungry.

    while changing the last two line by
    Code:
    Z = Z | (B<<4) | (D<<12)
    should use more code space.

    In the above A & C are Aliases, so shouldn't need any extra RAM.

    this
    Code:
    z=a+b<<4+c<<8+d<<12
    ought to use load of RAM and time to execute... BUT this said, I'm rusty and my memory/capacity fade since few months...
    Last edited by mister_e; - 11th November 2008 at 22:37.
    Steve

    It's not a bug, it's a random feature.
    There's no problem, only learning opportunities.

  2. #2
    Join Date
    Jul 2003
    Location
    Colorado Springs
    Posts
    4,959


    Did you find this post helpful? Yes | No

    Default

    Here's one that won't get used.
    But since the questions of how big and how fast came up, you won't find anything smaller or faster. (unless Bruce shows up)
    Code:
    GroupVars  VAR BYTE[6]
      A    VAR GroupVars(0)
      B    VAR GroupVars(1)
      C    VAR GroupVars(2)
      D    VAR GroupVars(3)
      ZW   VAR WORD EXT : @ZW = _GroupVars + 4
    
    ASM
        CHK?RP _GroupVars
        swapf  _D, W     ; swap nibbles in D
        iorwf  _C, W     ; or with C
        movwf  ZW + 1    ; move to Highbyte of word
        swapf  _B, W     ; swap nibbles in B
        iorwf  _A, W     ; or with A
        movwf  ZW        ; move to LowByte of word
    ENDASM
    DT

  3. #3
    Join Date
    Sep 2004
    Location
    montreal, canada
    Posts
    6,898


    Did you find this post helpful? Yes | No

    Default

    yeah, no complaint at all, ASM route is easy & fast, but the only minor problem it use a bit more of RAM?

    Who cares anyway
    Last edited by mister_e; - 12th November 2008 at 00:55.
    Steve

    It's not a bug, it's a random feature.
    There's no problem, only learning opportunities.

  4. #4
    Join Date
    Jul 2003
    Location
    Colorado Springs
    Posts
    4,959


    Did you find this post helpful? Yes | No

    Default

    Technically, it uses less RAM.

    A statement like z=a+b<<4+c<<8+d<<12

    Will create 3 T variables to hold the intermediate results.
    Each T var is a Word (Long for PBPL), so it uses at least 6 more bytes of RAM.
    Of course, if the program already had T vars from other statements, it won't make any difference.

    For Flash, it uses 6-8 words depending on variable locations.
    z=a+b<<4+c<<8+d<<12, uses ~60 depending on library routines already used.

    And Time wise, it takes about 6-8 uS @ 4Mhz
    z=a+b<<4+c<<8+d<<12, uses several hundred.
    <br>
    DT

  5. #5
    Join Date
    Nov 2003
    Location
    Greece
    Posts
    4,175


    Did you find this post helpful? Yes | No

    Default

    OK, that was not fair Darrel!

    Cannot beat ASM code of course.

    If I wanted to do that way, how can one find what this CHK?RP does? Where does this come from? I suppose there is no RTFM on this. Maybe digging deep inside PBP's librarys?

    Ioannis

  6. #6
    Join Date
    Jul 2003
    Posts
    2,405


    Did you find this post helpful? Yes | No

    Default 4 bytes RAM, 4 instructions to convert

    OK - here's a little smaller verion...;o}
    Code:
    Z VAR WORD BANK0 ; use BANKA for 18F part
    A VAR Z.LowByte
    B VAR BYTE BANK0
    C VAR Z.HighByte
    D VAR BYTE BANK0
    
    A=%00000001
    B=%00000010
    C=%00000011
    D=%00000100
    
    ASM
        CHK?RP _Z
        swapf  _B, W     ; swap nibbles in B, result in W
        iorwf  _A, F     ; or with A, result in A (low byte is done)
        swapf  _D, W     ; swap nibbles in D, result in W
        iorwf  _C, F     ; or with C, result in C (HighByte is done)
    ENDASM
    Z = %0100 0011 0010 0001
    Last edited by Bruce; - 12th November 2008 at 09:29. Reason: Force vars into same bank
    Regards,

    -Bruce
    tech at rentron.com
    http://www.rentron.com

  7. #7
    Join Date
    Nov 2005
    Location
    Bombay, India
    Posts
    974


    Did you find this post helpful? Yes | No

    Default

    Wow! What compact and fast code! Both Bruce and DT must have been coding in Assembler for ages to have such skill I might have coded it like Steve(mister_e) here and just got the job done. But, I guess, this is how compiler writers optimize their code generation capabilities. I would like to hazard a thought that this kind of optimisations would help PBP generate tighter code.

Similar Threads

  1. Bits, Bytes Words and Arrays
    By Melanie in forum FAQ - Frequently Asked Questions
    Replies: 24
    Last Post: - 14th June 2016, 07:55
  2. Read/Write Problem
    By Tobias in forum mel PIC BASIC Pro
    Replies: 1
    Last Post: - 10th February 2010, 01:51
  3. Minimizing code space
    By Tobias in forum mel PIC BASIC Pro
    Replies: 2
    Last Post: - 30th May 2009, 07:25
  4. DS2760 Thermocouple Kit from Parallax in PicBasicPro
    By seanharmon in forum mel PIC BASIC Pro
    Replies: 3
    Last Post: - 8th July 2008, 23:19
  5. calculation problem
    By nicolelawsc in forum mel PIC BASIC Pro
    Replies: 2
    Last Post: - 31st March 2006, 15:23

Members who have read this thread : 0

You do not have permission to view the list of names.

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts