![Campbell CR850 Скачать руководство пользователя страница 143](http://html1.mh-extra.com/html/campbell/cr850/cr850_operators-manual_3829356143.webp)
Section 7. Installation
143
7.7.3.9.1 Floating-Point Arithmetic
Variables and calculations are performed internally in single precision IEEE four-
byte floating point with some operations calculated in double precision.
Note
Single-precision float has 24 bits of mantissa. Double precision has a 32-bit
extension of the mantissa, resulting in 56 bits of precision. Instructions that use
double precision are
AddPrecise()
,
Average()
,
AvgRun()
,
AvgSpa()
,
CovSpa()
,
MovePrecise()
,
RMSSpa()
,
StdDev()
,
StdDevSpa()
, and
Totalize()
.
Floating-point arithmetic is common in many electronic, computational systems,
but it has pitfalls high-level programmers should be aware of. Several sources
discuss floating-point arithmetic thoroughly. One readily available source is the
topic
Floating Point
at www.wikipedia.org. In summary, CR800 programmers
should consider at least the following:
•
Floating-point numbers do not perfectly mimic real numbers.
•
Floating-point arithmetic does not perfectly mimic true arithmetic.
•
Avoid use of equality in conditional statements. Use >= and <= instead. For
example, use
If X >= Y then do
rather than
If X = Y then do
.
•
When programming extended-cyclical summation of non-integers, use the
AddPrecise()
instruction. Otherwise, as the size of the sum increases,
fractional addends will have an ever decreasing effect on the magnitude of
the sum, because normal floating-point numbers are limited to about 7 digits
of resolution.
7.7.3.9.2 Mathematical Operations
Mathematical operations are written out much as they are algebraically. For
example, to convert Celsius temperature to Fahrenheit, the syntax is:
TempF = TempC * 1.8 + 32
Read More!
To save code space while filling an array or partial array with the
same value, see CRBasic example
Use of Move() to Conserve Code Space
(p. 151).
CRBasic example
Use of Variable Arrays to Conserve Code Space
(p. 151)
shows
example code to convert twenty temperatures in a variable array from °C to °F.
7.7.3.9.3 Expressions with Numeric Data Types
FLOAT
s,
LONG
s and
Boolean
s are cross-converted to other data types, such as
FP2
, by using "=".
Boolean from FLOAT or LONG
When a
FLOAT
or
LONG
is converted to a
Boolean
as shown in CRBasic
example
Conversion of FLOAT / LONG to Boolean
(p. 144), zero becomes false
(
0
) and non-zero becomes true (
-1
).
Содержание CR850
Страница 2: ......
Страница 4: ......
Страница 6: ......
Страница 26: ...Table of Contents 26...
Страница 30: ...Section 2 Cautionary Statements 30...
Страница 32: ...Section 3 Initial Inspection 32...
Страница 35: ...Section 4 Quickstart Tutorial 35 Figure 2 Wiring panel...
Страница 55: ...Section 4 Quickstart Tutorial 55 Figure 24 PC200W View data utility...
Страница 78: ...Section 5 System Overview 78...
Страница 80: ...Section 6 CR800 Specifications 80...
Страница 95: ...Section 7 Installation 95 Figure 35 DevConfig OS download window Figure 36 Dialog box confirming OS download...
Страница 104: ...Section 7 Installation 104 Figure 43 Include File settings via DevConfig Figure 44 Include File settings via PakBusGraph...
Страница 267: ...Section 7 Installation 267 Figure 84 Running average signal attenuation...
Страница 268: ...Section 7 Installation 268...
Страница 384: ...Section 8 Operation 384 Figure 113 Using the keyboard display...
Страница 385: ...Section 8 Operation 385 8 8 1 Data Display Figure 114 Displaying data with the keyboard display...
Страница 387: ...Section 8 Operation 387 Figure 116 Real time custom...
Страница 388: ...Section 8 Operation 388 8 8 1 3 Final Storage Tables Figure 117 Final storage tables...
Страница 389: ...Section 8 Operation 389 8 8 2 Run Stop Program Figure 118 Run Stop Program...
Страница 390: ...Section 8 Operation 390 8 8 3 File Display Figure 119 File display...
Страница 396: ...Section 8 Operation 396...
Страница 402: ...Section 9 Maintenance 402...
Страница 450: ...Section 11 Glossary 450...
Страница 504: ...Appendix A CRBasic Programming Instructions 504...
Страница 526: ...Appendix B Status Table and Settings 526...
Страница 530: ...Appendix C Serial Port Pinouts 530...
Страница 536: ...Appendix E FP2 Data Format 536...
Страница 550: ...Appendix F Other Campbell Scientific Products 550...
Страница 564: ...Index 564 WriteIO 464 Writing Program 108 X XML 448 XOR 473 Y Y intercept 141 142 Z Zero 155 166 Zero Basis 151...
Страница 565: ......