Language Fundamentals/de
|  (→Arithmetic) |  (→Relational Operators) | ||
| Line 631: | Line 631: | ||
| = <span class="f_Header">Relational Operators</span> = | = <span class="f_Header">Relational Operators</span> = | ||
| − | + | Relationale Operatoren werden verwendet, um zwei Werte miteinander zu vergleichen. | |
| + | Die Operatoren sind in folgender Tabelle aufgelistet. | ||
| − | + | Das Ergebnis kann verwendet werden, um den Programmablauf zu steuern. | |
| <span style="font-family: Arial;"> </span> | <span style="font-family: Arial;"> </span> | ||
| Line 646: | Line 647: | ||
| | valign="top" width="100%" bgcolor="#ffffb2" style="width: 80px; background-color: rgb(255, 255, 178); border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" bgcolor="#ffffb2" style="width: 80px; background-color: rgb(255, 255, 178); border: 1px solid rgb(0, 0, 0);" |   | ||
| − | <span style="font-weight: bold;"> | + | <span style="font-weight: bold;">Ausdruck</span> | 
| |- style="vertical-align: top;" | |- style="vertical-align: top;" | ||
| Line 653: | Line 654: | ||
| | valign="top" width="100%" style="width: 65px; border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" style="width: 65px; border: 1px solid rgb(0, 0, 0);" |   | ||
| − | + | gleich | |
| | valign="top" width="100%" style="width: 80px; border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" style="width: 80px; border: 1px solid rgb(0, 0, 0);" |   | ||
| Line 663: | Line 664: | ||
| | valign="top" width="100%" style="width: 65px; border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" style="width: 65px; border: 1px solid rgb(0, 0, 0);" |   | ||
| − | + | unterschiedlich | |
| | valign="top" width="100%" style="width: 80px; border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" style="width: 80px; border: 1px solid rgb(0, 0, 0);" |   | ||
| Line 673: | Line 674: | ||
| | valign="top" width="100%" style="width: 65px; border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" style="width: 65px; border: 1px solid rgb(0, 0, 0);" |   | ||
| − | + | kleiner als | |
| | valign="top" width="100%" style="width: 80px; border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" style="width: 80px; border: 1px solid rgb(0, 0, 0);" |   | ||
| Line 683: | Line 684: | ||
| | valign="top" width="100%" style="width: 65px; border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" style="width: 65px; border: 1px solid rgb(0, 0, 0);" |   | ||
| − | + | größer als | |
| | valign="top" width="100%" style="width: 80px; border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" style="width: 80px; border: 1px solid rgb(0, 0, 0);" |   | ||
| Line 693: | Line 694: | ||
| | valign="top" width="100%" style="width: 65px; border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" style="width: 65px; border: 1px solid rgb(0, 0, 0);" |   | ||
| − | + | kleiner oder gleich | |
| | valign="top" width="100%" style="width: 80px; border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" style="width: 80px; border: 1px solid rgb(0, 0, 0);" |   | ||
| Line 703: | Line 704: | ||
| | valign="top" width="100%" style="width: 65px; border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" style="width: 65px; border: 1px solid rgb(0, 0, 0);" |   | ||
| − | + | größer oder gleich | |
| | valign="top" width="100%" style="width: 80px; border: 1px solid rgb(0, 0, 0);" |   | | valign="top" width="100%" style="width: 80px; border: 1px solid rgb(0, 0, 0);" |   | ||
Revision as of 21:08, 19 February 2013
Label, Schlüsselwörtern, Variablen und Operatoren bestehen aus Zeichen des BASCOM-Zeichensatzes.
Diese wiederum werden zusammengesetzt zu dem, was ein Programm ausmacht.
Dieses Kapitel beschreibt die Zeichen und das Format von BASCOM Programmzeilen.
Insbesondere beschreibt es:
| • | die spezielle Bedeutung von Zeichen des Zeichensatzes und besondere Bedeutung einiger Zeichen | 
| • | das Format einer BASCOM Programmzeile | 
| • | Zeilen LABELs | 
| • | Programm Zeilenlänge | 
Zeichensatz
The BASCOM BASIC character set consists of alphabetic characters, numeric characters, and special characters.
The alphabetic characters in BASCOM are the uppercase letters (A-Z) and lowercase letters (a-z) of the alphabet.
Der BASCOM BASIC Zeichensatz besteht alphabetischen Zeichen, numerischen Zeichen und Sonderzeichen. Die alphabetischen Zeichen sind die Zeichen A bis Z in Großschreibung und die Zeichen a bis z in Kleinschreibung.
Die BASCOM numerischen Zeichen sind die Zahlen von 0 bis 9. Die Zeichen A bis H können ebenfalls zur Darstellung hexadezimaler Zahlen verwendet werden. (A-F und &H zur Kennzeichnung einer hexadezimalen Zahl) .
Die folgenden Zeichen haben spezielle Bedeutungen in BASCOM Anweisungen und Ausdrücken:
| Character | Name | 
| ENTER | Abschluss einer Engabezeile | 
| 
 | Leerzeichen ( oder Space) | 
| ' | einfaches Anführungszeichen (Apostroph) | 
| * | Stern (Multiplikation Symbol) | 
| + | Plus Zeichen | 
| , | Komma | 
| - | Minus Zeichen | 
| . | Punkt (Dezimalpunkt) | 
| / | Schrägstrich (Slash) (Division Symbol) wird wie \ behandelt | 
| : | Doppelpunkt | 
| " | doppelte Anführungszeichen | 
| ; | Semikolon | 
| < | kleiner als | 
| = | Gleichheitszeichen (Zuweisungssymbol or relationaler Operator) | 
| > | größer als | 
| \ | Schrägstrich rückwärts (Backslash) (Division Symbol) | 
| ^ | Exponent | 
Die BASCOM Programmzeile
BASCOM Programmzeilen haben folgende Syntax:
[[Line-identifier]] [[Statement]] [[:Statement]] ... [[Comment]]
Sprungmarken (Label)
BASCOM unterstützt alphanumerische Sprungmarken (Label).
Ein Label besteht aus 1 bis 32 Buchstaben oder Zahlen. Sie beginnen mit einem Buchstaben und enden mit einem Doppelpunkt.
BASCOM Schlüsselwörter sind nicht erlaubt. (z.B. print:)
Beispiele zu gültigen Label:
Alpha:
ScreenSUB:
Test3A:
Groß- Kleinschreibung wird nicht unterschieden. Folgende Beispiele zeigen unterschiedliche Schreibweisen, stehen aber für ein und dasselbe Label.
alpha:
Alpha:
ALPHA:
Label können an einer beliebigen Stelle in einer Zeile beginnen, so lange sich links vom Label lediglich Leerzeichen befinden.
Leerzeichen innerhalb des Label Namen und zwischen Label Name und dem abschließenden Doppelpunkt sind nicht erlaubt.
In einer Zeile darf sich nur ein Label befinden. In einer Zeile mit einem Label darf sich nur dieses Label befinden, also keine weiteren Anweisungen oder Instruktionen oder Ausdrücke. Ein Label ist der einzige Ausdruck in einer Zeile. (z.B. NICHT Label: print hier muss die Print Anweisung in der folgenden Zeile stehen)
BASCOM Anweisungen (Befehle)
Eine BASCOM Anweisung ist entweder "ausführbar" oder "nicht ausführbar".
Eine ausführbare Anweisung (Befehl) führt Schritte in der Programmlogik aus. Ein Beispiel eines ausführbare Befehl ist "Print". Hier wird der Befehl zur Ausgabe von Daten gegeben.
Nicht ausführbare Anweisungen dienen z.B. der Speicherzuweisung, Deklaration oder Definition des Types von Variablen.
Im folgenden Beispiele für "nicht ausführbare Anweisungen"
| • | REM (Startet eine Kommentierung) | 
| • | DIM (legt den Typ einer Variablen fest) | 
Eine Kommentierung (Comment) ist eine "nicht ausführbare Anweisung" und dient dazu Schritte im Programm zu beschreiben oder verdeutlichen. Verwenden sie gerade zu Beginn viele Kommentierungen, damit sie sich selbst den Sinn und Zweck von Befehlszeilen verdeutlichen.
Eine Kommentierung wird eingeleitet mit dem Befehl (REM) oder einem einfachen Anführungszeichen ('). Solch eine Kommentierung hat lediglich in der betreffenden Zeile Gültigkeit. (siehe auch Blockkommentierung)
Die folgenden Zeilen bewirken das gleiche:
PRINT " Quantity remaining" : REM Print report label.
PRINT " Quantity remaining" ' Print report label.
Es können mehrere BASCOM Befehle in einer Zeile stehen, diese müssen aber mit einem Doppelpunkt von einander getrennt sein, wie nachfolgendes Beispiel zeigt.
FOR I = 1 TO 5 : PRINT " Gday, mate." : NEXT I
BASCOM Zeilenlänge
Wenn sie den BASCOM eigenen Editor benutzen, ist die Länge einer Zeile nicht beschränkt. Zur besseren Übersicht wird aber dazu geraten, die Zeile auf 80 Zeichen zu beschränken.
Datentypen
Jede BASCOM Variable ist einem Datentyp zugeordnet. Hiervon hängt ab, was in einer Variablen gespeichert werden kann. Der nächste Abschnitt beschreibt die elementaren Datentypen.
Elementare Datentypen
| • | Bit (1/8 Byte). Ein BIT kann nur genau eine Informationseinheit speichern. Dies ist entweder eine 0 oder eine 1. Eine Gruppe von 8 Bit nennt man 1 BYTE. | 
| • | Byte (1 Byte). Bytes werden als "unsigned" (vorzeichenlos) 8-Bit Werte gespeichert. Ein Byte kann eine natürliche Zahl im Bereich von 0 bis 255 darstellen. (nicht negative ganze Zahl) | 
| • | Integer (zwei Byte). Integer wird als "signed" (vorzeichenbehaftet) 16-Bit binäre Zahl gespeichert. Der darstellbare Zahlenraum liegt hierbei von -32.768 bis +32.767 | 
| • | Word (zwei Byte). WORD wird als "unsigned" (vorzeichenlos) 16-Bit Werte gespeichert. Ein Word kann eine natürliche Zahl im Bereich von 0 bis 65535 darstellen. | 
| • | Dword (vier Byte). DWORD wird als "unsigned" (vorzeichenlos) 32-Bit Werte gespeichert. Ein DWord kann eine natürliche Zahl im Bereich von 0 bis 4294967295 darstellen. | 
| • | Long (vier Byte). Integer wird als "signed" (vorzeichenbehaftet) 32-Bit binäre Zahl gespeichert. Der darstellbare Zahlenraum liegt hierbei von -2147483648 bis 2147483647. | 
| • | Single (vier Byte). Singles wird als "signed" (vorzeichenbehaftet) 32-Bit binäre Zahl gespeichert. Der darstellbare Zahlenraum liegt hierbei von 1.5 x 10^–45 bis 3.4 x 10^38 | 
| • | Double (acht Byte). Double wird als "signed" (vorzeichenbehaftet) 64-Bit binäre Zahl gespeichert.Der darstellbare Zahlenraum liegt hierbei von 5.0 x 10^–324 bis 1.7 x 10^308 | 
| • | String (bis zu 254 Byte). String (Zeichenkette) wird als Folge von Bytes gespeichert mit abschließenden Byte mit Wert 0. Ein String mit einer Länge von 10 Zeichen belegt 11 Byte Speicher. | 
Variablen können intern (Standard), extern oder im EEPROM gespeichert werden.
Variablen
Eine Variable ist ein Name, welcher auf ein Objekt in einem Speicherbereich zeigt
Einer numerischen Variable kann, ihrer Definition entsprechend, nur eine Zahl zugewiesen werden.
Im Folgenden ein paar Beispiele von Variablen Zuweisungen:
| • | Einen konstanten Wert zuweisen: | 
A = 5
C = 1.1
| • | Den Wert einer anderen Variable einer Variable zuweisen: | 
abc = def
k = g
| • | Den Wert durch die Kombination von anderen Variablen, Konstanten und Operatoren erhalten: Temp = a + 5 | 
Temp = C + 5
| • | Den Wert durch Aufruf einer Funktion erhalten: | 
Temp = Asc(S)
Variablen Namen
Ein BASCOM Variablen Name kann bis zu 32 Zeichen lang sein.
Der Name darf Buchstaben und Zahlen enthalten.
Das erste Zeichen des Namen muss ein Buchstabe sein
Ein Variablenname darf kein reserviertes Wort sein, aber kann es beinhalten.
Die Anweisung im folgenden Beispiel ist nicht erlaubt, da AND ein reserviertes Wort ist:
AND = 8
Die Anweisung im folgenden Beispiel ist gültig:
ToAND = 8
Reservierte Wörter umfassen alle BASCOM Befehle, Ausdrücke, Funktion, interne Register und Operatoren.
(siehe BASCOM Reservierte Wörter, für eine Liste mit allen reservierten Wörtern).
Hexadezimal Zahlen werden mit &H angegeben. Binäre Zahlen werden mit &B angegeben.
a = &HA , a = &B1010 and a = 10 weist der Variablen das Gleiche zu.
Vor der Benutzung einer Variable, muss diese dem Compiler durch eine DIM Anweisung bekannt gemacht werden.
Dim b1 As Bit, I as Integer, k as Byte , s As String * 10
Bei dem Variablentyp STRING muss zusätzlich die Länge des String angegeben werden
Ebenfalls möglich: DEFINT, DEFBIT, DEFBYTE ,DEFWORD ,DEFLNG or DEFSNG.
Beispiel: DEFINT c teilt dem Compiler mit, dass alle undefinierten Variablen welche mit dem Zeichen "c" anfangen, vom Typ INTEGER sind.
Ausdrücke und Operatoren
Dieses Kapitel beschreibt, wie man Ausdrücke und Operatoren in BASCOM anwendet.
Bei jeder Berechnung werden Ausdrücke und Operatoren verwendet.
Dieses Kapitel beschreibt, wie Ausdrücke gebildet werden und schließt mit der Beschreibung der Art von Operatoren:
| • | Arithmetische Operatoren, werden für Berechnungen verwendet. | 
| • | Verhältnis (Relational) Operatoren, Vergleich von numerischen oder auch String Variablen. | 
| • | Logische Operatoren, Testen von Bedingungen oder Veränderung von Bits. | 
| • | Funktions Operatoren, zur Ergänzung der einfachen Operatoren. | 
Expressions and Operators
Ein Ausdruck kann eine numerische Konstante, eine Variable oder ein einzelner Wert durch die Kombination von Konstanten, Variablen und andere Ausdrücken mit Operatoren sein.
Operatoren führen mathematischen oder logischen Operationen an Werten durch.
Die von BASCOM zur Verfügung stehenden Operatoren sind in vier Gruppen einzuordnen:
1. Arithmetisch
2. Verhältnis (Relational)
3. Logisch
4. Funktionen
Arithmetic
Arithmetische Operatoren sind +, - , * , \, / und ^.
| • | Integer | 
Integer Division wird durch den Schrägstrich rückwärts (\)(Backslash) dargestellt.
Beispiel: Z = X \ Y
| • | Modulo Arithmetik | 
Modulo Arithmetik wird mit MOD durchgeführt.
Eine Modulo Arithmetik ergibt den Teilungsrest einer ganzzahligen Division.
Beispiel: X = 10 \ 4 : remainder = 10 MOD 4
| • | Overflow und "Division by zero" (Überlauf und Teilung durch 0) | 
"Division by zero" oder Teilung durch 0, erzeugt einen Fehler.
Hierbei findet keine Fehlerausgabe statt, sie müssen selbst dafür Sorge tragen, dass dies nicht eintreten kann.
Relational Operators
Relationale Operatoren werden verwendet, um zwei Werte miteinander zu vergleichen. Die Operatoren sind in folgender Tabelle aufgelistet.
Das Ergebnis kann verwendet werden, um den Programmablauf zu steuern.
| Operator | Relation Tested | Ausdruck | 
| = | gleich | X = Y | 
| <> | unterschiedlich | X <> Y | 
| < | kleiner als | X < Y | 
| > | größer als | X > Y | 
| <= | kleiner oder gleich | X <= Y | 
| >= | größer oder gleich | X >= Y | 
Logical Operators
Logical operators perform tests on relations, bit manipulations, or Boolean operators.
There four operators in BASCOM are :
| Operator | Meaning | 
| NOT | Logical complement | 
| AND | Conjunction | 
| OR | Disjunction | 
| XOR | Exclusive or | 
It is possible to use logical operators to test bytes for a particular bit pattern.
For example the AND operator can be used to mask all but one of the bits of a status byte, while OR can be used to merge two bytes to create a particular binary value.
Example
A = 63 And 19
PRINT A
A = 10 Or 9
PRINT A
Output
19
11
Floating point SINGLE (4 BYTE)(ASM code used is supplied by Jack Tidwell)
Single numbers conforming to the IEEE binary floating point standard.
An eight bit exponent and 24 bit mantissa are supported.
Using four bytes the format is shown below:
31 30________23 22______________________________0
s exponent mantissa
The exponent is biased by 128. Above 128 are positive exponents and below are negative. The sign bit is 0 for positive numbers and 1 for negative. The mantissa is stored in hidden bit normalized format so that 24 bits of precision can be obtained.
All mathematical operations are supported by the single.
You can also convert a single to an integer or word or vise versa:
Dim I as Integer, S as Single
S = 100.1 'assign the single
I = S 'will convert the single to an integer
Here is a fragment from the Microsoft knowledge base about FP:
Floating-point mathematics is a complex topic that confuses many programmers. The tutorial below should help you recognize programming situations where floating-point errors are likely to occur and how to avoid them. It should also allow you to recognize cases that are caused by inherent floating-point math limitations as opposed to actual compiler bugs.
Decimal and Binary Number Systems
Normally, we count things in base 10. The base is completely arbitrary. The only reason that people have traditionally used base 10 is that they have 10 fingers, which have made handy counting tools.
The number 532.25 in decimal (base 10) means the following:
(5 * 10^2) + (3 * 10^1) + (2 * 10^0) + (2 * 10^-1) + (5 * 10^-2)
500 + 30 + 2 + 2/10 + 5/100
_________
= 532.25
In the binary number system (base 2), each column represents a power of 2 instead of 10. For example, the number 101.01 means the following:
(1 * 2^2) + (0 * 2^1) + (1 * 2^0) + (0 * 2^-1) + (1 * 2^-2)
4 + 0 + 1 + 0 + 1/4
_________
= 5.25 Decimal
How Integers Are Represented in PCs
Because there is no fractional part to an integer, its machine representation is much simpler than it is for floating-point values. Normal integers on personal computers (PCs) are 2 bytes (16 bits) long with the most significant bit indicating the sign. Long integers are 4 bytes long.
Positive values are straightforward binary numbers. For example:
1 Decimal = 1 Binary
2 Decimal = 10 Binary
22 Decimal = 10110 Binary, etc.
However, negative integers are represented using the two's complement scheme. To get the two's complement representation for a negative number, take the binary representation for the number's absolute value and then flip all the bits and add 1. For example:
4 Decimal = 0000 0000 0000 0100
1111 1111 1111 1011 Flip the Bits
-4 = 1111 1111 1111 1100 Add 1
Note that adding any combination of two's complement numbers together
using ordinary binary arithmetic produces the correct result.
Floating-Point Complications
Every decimal integer can be exactly represented by a binary integer; however, this is not true for fractional numbers. In fact, every number that is irrational in base 10 will also be irrational in any system with a base smaller than 10.
For binary, in particular, only fractional numbers that can be represented in the form p/q, where q is an integer power of 2, can be expressed exactly, with a finite number of bits.
Even common decimal fractions, such as decimal 0.0001, cannot be represented exactly in binary. (0.0001 is a repeating binary fraction with a period of 104 bits!)
This explains why a simple example, such as the following
SUM = 0
FOR I% = 1 TO 10000
 SUM = SUM + 0.0001
NEXT I%
PRINT SUM ' Theoretically = 1.0.
will PRINT 1.000054 as output. The small error in representing 0.0001
in binary propagates to the sum.
For the same reason, you should always be very cautious when making comparisons on real numbers. The following example illustrates a common programming error:
item1# = 69.82#
item2# = 69.20# + 0.62#
IF item1# = item2# then print "Equality!"
This will NOT PRINT "Equality!" because 69.82 cannot be represented exactly in binary, which causes the value that results from the assignment to be SLIGHTLY different (in binary) than the value that is generated from the expression. In practice, you should always code such comparisons in such a way as to allow for some tolerance.
General Floating-Point Concepts
It is very important to realize that any binary floating-point system can represent only a finite number of floating-point values in exact form. All other values must be approximated by the closest represent able value. The IEEE standard specifies the method for rounding values to the "closest" represent able value. BASCOM supports the standard and rounds according to the IEEE rules.
Also, keep in mind that the numbers that can be represented in IEEE are spread out over a very wide range. You can imagine them on a number line. There is a high density of represent able numbers near 1.0 and -1.0 but fewer and fewer as you go towards 0 or infinity.
The goal of the IEEE standard, which is designed for engineering calculations, is to maximize accuracy (to get as close as possible to the actual number). Precision refers to the number of digits that you can represent. The IEEE standard attempts to balance the number of bits dedicated to the exponent with the number of bits used for the fractional part of the number, to keep both accuracy and precision within acceptable limits.
IEEE Details
Floating-point numbers are represented in the following form, where
[exponent] is the binary exponent:
X = Fraction * 2^(exponent - bias)
[Fraction] is the normalized fractional part of the number, normalized because the exponent is adjusted so that the leading bit is always a 1. This way, it does not have to be stored, and you get one more bit of precision. This is why there is an implied bit. You can think of this like scientific notation, where you manipulate the exponent to have one digit to the left of the decimal point, except in binary, you can always manipulate the exponent so that the first bit is a 1, since there are only 1s and 0s.
[bias] is the bias value used to avoid having to store negative exponents.
The bias for single-precision numbers is 127 and 1023 (decimal) for double-precision numbers.
The values equal to all 0's and all 1's (binary) are reserved for representing special cases. There are other special cases as well, that indicate various error conditions.
Single-Precision Examples
2 = 1 * 2^1 = 0100 0000 0000 0000 ... 0000 0000 = 4000 0000 hex
Note the sign bit is zero, and the stored exponent is 128, or
100 0000 0 in binary, which is 127 plus 1. The stored mantissa is (1.)
000 0000 ... 0000 0000, which has an implied leading 1 and binary point, so the actual mantissa is 1.
-2 = -1 * 2^1 = 1100 0000 0000 0000 ... 0000 0000 = C000 0000 hex
Same as +2 except that the sign bit is set. This is true for all IEEE format floating-point numbers.
4 = 1 * 2^2 = 0100 0000 1000 0000 ... 0000 0000 = 4080 0000 hex
Same mantissa, exponent increases by one (biased value is 129, or 100 0000 1 in binary.
6 = 1.5 * 2^2 = 0100 0000 1100 0000 ... 0000 0000 = 40C0 0000 hex
Same exponent, mantissa is larger by half -- it's
(1.) 100 0000 ... 0000 0000, which, since this is a binary fraction, is 1-1/2 (the values of the fractional digits are 1/2, 1/4, 1/8, etc.).
1 = 1 * 2^0 = 0011 1111 1000 0000 ... 0000 0000 = 3F80 0000 hex
Same exponent as other powers of 2, mantissa is one less than 2 at 127, or 011 1111 1 in binary.
.75 = 1.5 * 2^-1 = 0011 1111 0100 0000 ... 0000 0000 = 3F40 0000 hex
The biased exponent is 126, 011 1111 0 in binary, and the mantissa is (1.) 100 0000 ... 0000 0000, which is 1-1/2.
2.5 = 1.25 * 2^1 = 0100 0000 0010 0000 ... 0000 0000 = 4020 0000 hex
Exactly the same as 2 except that the bit which represents 1/4 is set in the mantissa.
0.1 = 1.6 * 2^-4 = 0011 1101 1100 1100 ... 1100 1101 = 3DCC CCCD hex
1/10 is a repeating fraction in binary. The mantissa is just shy of 1.6, and the biased exponent says that 1.6 is to be divided by 16 (it is 011 1101 1 in binary, which is 123 n decimal). The true exponent is 123 - 127 = -4, which means that the factor by which to multiply is 2**-4 = 1/16. Note that the stored mantissa is rounded up in the last bit. This is an attempt to represent the un-representable number as accurately as possible. (The reason that 1/10 and 1/100 are not exactly representable in binary is similar to the way that 1/3 is not exactly representable in decimal.)
0 = 1.0 * 2^-128 = all zeros -- a special case.
Other Common Floating-Point Errors
The following are common floating-point errors:
1. Round-off error
This error results when all of the bits in a binary number cannot be used in a calculation.
Example: Adding 0.0001 to 0.9900 (Single Precision)
Decimal 0.0001 will be represented as:
(1.)10100011011011100010111 * 2^(-14+Bias) (13 Leading 0s in Binary!)
0.9900 will be represented as:
(1.)11111010111000010100011 * 2^(-1+Bias)
Now to actually add these numbers, the decimal (binary) points must be aligned. For this they must be Unnormalized. Here is the resulting addition:
.000000000000011010001101 * 2^0 <- Only 11 of 23 Bits retained
+.111111010111000010100011 * 2^0
________________________________
.111111010111011100110000 * 2^0
This is called a round-off error because some computers round when shifting for addition. Others simply truncate. Round-off errors are important to consider whenever you are adding or multiplying two very different values.
2. Subtracting two almost equal values
.1235
-.1234
_____
.0001
This will be normalized. Note that although the original numbers each had four significant digits, the result has only one significant digit.
3. Overflow and underflow
This occurs when the result is too large or too small to be represented by the data type.
4. Quantizing error
This occurs with those numbers that cannot be represented in exact form by the floating-point standard.
Rounding
When a Long is assigned to a single, the number is rounded according to the rules of the IEEE committee.
For explanation: 1.500000 is exact the middle between 1.00000 and 2.000000. If x.500000 is always rounded up, than there is trend for higher values than the average of all numbers. So their rule says, half time to round up and half time to round down, if value behind LSB is exact ..500000000.
The rule is, round this .500000000000 to next even number, that means if LSB is 1 (half time) to round up, so the LSB is going to 0 (=even), if LSB is 0 (other half time) to round down, that means no rounding.
This rounding method is best since the absolute error is 0.
You can override the default IEEE rounding method by specifying the $LIB LONG2FLOAT.LBX library which rounds up to the next number. This is the method used up to 1.11.7.4 of the compiler.
Double
The double is essential the same as a single. Except the double consist of 8 bytes instead of 4. The exponent is 11 bits leaving 52 bits for the mantissa.
Arrays
An array is a set of sequentially indexed elements having the same type. Each element of an array has a unique index number that identifies it. Changes made to an element of an array do not affect the other elements.
The index must be a numeric constant, a byte, an integer, word or long.
The maximum number of elements is 65535. For Xmega with huge memory it is 8MB!
The first element of an array is always one by default. This means that elements are 1-based.
You can change this with CONFIG BASE=0. In this case, the first element will be element 0.
Arrays can be used on each place where a 'normal' variable is expected.
You can add an offset to the index too. This could be used to emulate a 2 dimensional array.
row_index = row : shift row_index, left,4
value = parameter_array(column+row_index)
Example
'create an array named a, with 10 elements (1 to 10)
Dim A(10) As Byte
'create an integer
Dim C As Integer
'now fill the array
For C = 1 To 10
'assign array element
A(c)= C
' print it
Print A(c)
Next
'you can add an offset to the index too
C = 0
A(c + 1)= 100
Print A(c + 1)
End
Strings
A string is used to store text. A string must be dimensioned with the length specified.
DIM S as STRING * 5
Will create a string that can store a text with a maximum length of 5 bytes.
The space used is 6 bytes because a string is terminated with a null byte.
To assign the string:
Ds = "abcd"
To insert special characters into the string :
s= "AB{027}cd"
The {ascii} will insert the ASCII value into the string.
The number of digits must be 3.
s = "{27}" will assign "{27}" to the string instead of escape character 27!
Because the null byte (ASCII 0) is used to terminate a string, you can not embed a null byte into a string.
Casting
In BASCOM-AVR when you perform operations on variables they all must be of the same data type.
long = long1 * long2 ' for example
The assigned variables data type determines what kind of math is performed.
For example when you assign a long, long math will be used.
If you try to store the result of a LONG into a byte, only the LSB of the LONG will be stored into the BYTE.
Byte = LONG
When LONG = 256 , it will not fit into a BYTE. The result will be 256 AND 255 = 0.
Of course you are free to use different data types. The correct result is only guaranteed when you are using data types of the same kind or that result always can fit into the target data type.
When you use strings, the same rules apply. But there is one exception:
Dim b as Byte
 
b = 123 ' ok this is normal
 
b = "A" ' b = 65
When the target is a byte and the source variable is a string constant denoted by "", the ASCII value will be stored in the byte. This works also for tests :
IF b = "A" then ' when b = 65
 
END IF
This is different compared to QB/VB where you can not assign a string to a byte variable.
SINGLE CONVERSION
When you want to convert a SINGLE into a byte, word, integer or long the compiler will automatic convert the values when the source string is of the SINGLE data type.
integer = single
You can also convert a byte, word, integer or long into a SINGLE by assigning this variable to a SINGLE.
single = long
| Languages | English • Deutsch | 
|---|