How to detect variable going below zero, without using PBPL ?


Closed Thread
Results 1 to 19 of 19
  1. #1
    Join Date
    Feb 2013
    Posts
    1,078

    Default How to detect variable going below zero, without using PBPL ?

    Hello again

    is there any way to avoid getting 65xxx numbers instead of negative numbers, when X-Y and Y is > X ?
    I know, that PBPL can do it, but I don't want to use 18 series.

    So maybe there is a way, instead of 0-65535, to have range of -32768 +32767 ?
    or any other trick, that if resulting variable is going below zero, it to become equal to zero?
    Last edited by CuriousOne; - 10th May 2022 at 11:02.

  2. #2
    Join Date
    May 2013
    Location
    australia
    Posts
    2,383


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    what have you tried ?
    in what way does it not provide a correct result?

    signed divides, multiplies and shifts need proper handling of the sign bit
    otherwise as long as the vars match in type signed integer math works as expected
    Warning I'm not a teacher

  3. #3
    Join Date
    Oct 2005
    Location
    Sweden
    Posts
    3,516


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    It depends on what you're doing with the number(s).
    If your displaying them using LCDOUT/SEROUT/HSEROUT/ARRAYWRITE you can use the SDEC modifier to display the value 65535 as -1.

    If you're doing further math with the numbers you need check the highest bit, if it's set the value is negative and you can use the ABS operator to retrieve the actual value, do whatever needs done (like a division) and then restore the sign.
    Code:
    X VAR WORD
    Sign VAR BIT
    
    X = -5000
    HSEROUT["Raw: ", DEC X, "    Signed: ", SDEC X, 13]
    
    Sign = X.15    ' Preserve sign
    X = ABS(X) / 5   ' Divide absolute value
    X.15 = Sign   ' Restore sign
    
    HSEROUT[SDEC X, 13]
    If all you want to do is cap the value at 0 then
    Code:
    IF X.15 THEN X = 0

  4. #4
    Join Date
    Feb 2013
    Posts
    1,078


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    I'm helping some fellow students to build an extinction meter.
    There's ADC reading, and based on liquid passed in the system, light transmission, compared to reference, might increase or decrease.
    So idea is, that they flow thru the "reference" liquid, ADC is read and that value is used as offset, which is deducted form further ADC readings, to get the info, what's going on.

  5. #5
    Join Date
    Apr 2014
    Location
    OK
    Posts
    557


    1 out of 1 members found this post helpful. Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    Code:
    ADCIN Baseline
    ADCIN Reference
    IF Reference < Baseline THEN
      'Sign = negative
      'Use subtraction in calculation
      'Denote a reduction
    ELSE
      'Sign = positive
      'Use addition in calculation
      'Denote an increase
    ENDIF
    Another possibility is use 128 = 0. If ADC Value < 128, treat as negative... I've created my own positive/negative methods that don't follow the standardized Signed Variable format. The math was easier my way for what I was doing. Just some thoughts that might spur ideas.

  6. #6
    Join Date
    Feb 2013
    Posts
    1,078


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    It's not ADC value reference that causes problems.
    Here's the explanation.

    Say ADC changes from 100 to 200 and "middle" point is being 150.
    So to have zero at my system variable output (which I later display both on screen and write to EEPROM), I'm deducting 150 from the input ADC value, to get zero. In case when ADC reading increases, than all is good, final variable value changes from 0 to 50, that's good. But if ADC value gets below 150, then things get bad.

  7. #7
    Join Date
    Apr 2014
    Location
    OK
    Posts
    557


    Did you find this post helpful? Yes | No

    Thumbs up Re: How to detect variable going below zero, without using PBPL ?

    Code:
    Zero VAR BYTE
    Variable VAR BYTE
    OtherVar VAR BYTE
    
    ADCIN, Zero
    ADCIN, Variable
    IF Variable < Zero THEN
      Zero = [some newly calculated value]
    ENDIF
    OtherVar = Variable - Zero
    Make up your own rules!

  8. #8
    Join Date
    May 2013
    Location
    australia
    Posts
    2,383


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    But if ADC value gets below 150, then things get bad.
    what does get bad mean ?

    show your code

  9. #9
    Join Date
    Feb 2013
    Posts
    1,078


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    Variable value should go to negative, but since we have no negative, it goes into 65xxx range

  10. #10
    Join Date
    May 2013
    Location
    australia
    Posts
    2,383


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    Variable value should go to negative, but since we have no negative, it goes into 65xxx range
    only if you interpret it incorrectly and ignore the sign bit



    show your code
    Warning I'm not a teacher

  11. #11
    Join Date
    Feb 2013
    Posts
    1,078


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    So by checking the last bit, I can know, whenever variable went into negative world, right?

  12. #12
    Join Date
    Nov 2003
    Location
    Greece
    Posts
    3,795


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    That is what post #3 says. Henrik explained it well.

    Ioannis

  13. #13
    Join Date
    Apr 2014
    Location
    OK
    Posts
    557


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    Whether signed or unsigned, 0 = 0.
    With an Unsigned BYTE (let's start simple), the range is 0 to 255. From 255, add 1 and you get 0 again, as the BYTE rolls over.
    With a Signed BYTE, the range is -128 to +127. Think in terms of binary: 127d = %0111 1111. Make sense so far?

    Working with a Signed BYTE, if you calculate: "0 - 1 =", you get %1111 1111 which equals -1.
    With an Unsigned BYTE, if you calculate: "0 - 1 =" you still get %1111 1111, but it equals 255.

    Think about this for Signed Variables:
    0d = %0000 0000
    1d = %0000 0001
    -1d = %1111 1111
    -2d = %1111 1110

    Sometimes just looking at the representations enables the light bulb to turn on.

    Now if we're working at the 16-bit WORD level:
    0d = %0000 0000 0000 0000
    1d = %0000 0000 0000 0001
    -1d = %1111 1111 1111 1111
    -2d = %1111 1111 1111 1110

    See the trend?? I hope this helps you figure some things out.

  14. #14
    Join Date
    May 2013
    Location
    australia
    Posts
    2,383


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    its called two's compliment , no magic involved

    https://en.wikipedia.org/wiki/Two%27s_complement
    Warning I'm not a teacher

  15. #15
    Join Date
    Feb 2013
    Posts
    1,078


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    I came into another issue.
    I have font array in EEPROM, and need to set offset for reading it. Depending on charset, this offset can be negative and positive.

    So I have to do it in a way like this:

    if langvar[x]=0 then
    Y=(topline[x])*8+OFS

    if langvar[x]=1 then
    Y=(topline[x])*8-OFS

    Can these two joined into single operation somehow?

  16. #16
    Join Date
    Nov 2003
    Location
    Greece
    Posts
    3,795


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    Code:
    if langvar[x]=0 then
        Y=(topline[x])*8+OFS
    else
        Y=(topline[x])*8-OFS
    endif
    Ioannis

  17. #17
    Join Date
    Feb 2013
    Posts
    1,078


    Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    No, I meant changing the value of OFS in the way, that addition will cause actual subtraction, due to overflow.

  18. #18
    Join Date
    Oct 2005
    Location
    Sweden
    Posts
    3,516


    1 out of 1 members found this post helpful. Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    As long as both variables are of the same size adding a two's compliment value to another is the same as subtracting the absolute value of one from the absolute value of the other.

    In these examples all variables are bytes.

    X = 0
    OFS = 1
    Y = X + OFS Y will have the value of 1.
    ***********************************************
    X = 0
    OFS = -1 OFS will have the value 255
    Y = X + OFS Y will contain the value 255 (which is -1)
    ***********************************************
    X = 10
    OFS = -5 OFS will have the value 251
    Y = X + OFS Y will have the value value 5
    ***********************************************
    X = -10 X will have the value 246
    OFS = - 15 OFS wil have the value 241
    Y = X + OFS Y will have the value 231 which is the same as -25
    ***********************************************

  19. #19
    Join Date
    May 2013
    Location
    australia
    Posts
    2,383


    1 out of 1 members found this post helpful. Did you find this post helpful? Yes | No

    Default Re: How to detect variable going below zero, without using PBPL ?

    in simple terms adding the two's compliment of a var to a number is equivalent to subtracting the var from a number
    providing they are all the same integer var type
    Warning I'm not a teacher

Similar Threads

  1. How to detect variable decrease moment?
    By CuriousOne in forum mel PIC BASIC Pro
    Replies: 5
    Last Post: - 4th February 2014, 23:02
  2. PBPL and TCP/IP
    By edtp in forum Ethernet
    Replies: 10
    Last Post: - 4th March 2011, 20:35
  3. Help, PBPL and DIV 32.
    By Rogerio in forum mel PIC BASIC Pro
    Replies: 7
    Last Post: - 16th March 2010, 11:37
  4. PBP and PBPL
    By keymuu in forum mel PIC BASIC Pro
    Replies: 45
    Last Post: - 30th January 2009, 18:58
  5. IF..AND/OR..THEN and PBPL
    By duncan303 in forum mel PIC BASIC Pro
    Replies: 5
    Last Post: - 25th January 2008, 17:45

Members who have read this thread : 2

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