|
|
DataMuseum.dkPresents historical artifacts from the history of: DKUUG/EUUG Conference tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about DKUUG/EUUG Conference tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - downloadIndex: T t
Length: 2503 (0x9c7)
Types: TextFile
Names: »tFix.cc«
└─⟦a05ed705a⟧ Bits:30007078 DKUUG GNU 2/12/89
└─⟦cc8755de2⟧ »./libg++-1.36.1.tar.Z«
└─⟦23757c458⟧
└─⟦this⟧ »libg++/tests/tFix.cc«
//
// testFix.cc : test Fix (variable length) classes
//
#include <Fix.h>
overload check;
overload checkb;
void check(const char* x, Fix y)
{
cout << x << " = " << (y) << "\n";
}
void check(const char* x, int y)
{
cout << x << " = " << (y) << "\n";
}
void check(const char* x, double y)
{
cout << x << " = " << (y) << "\n";
}
void checkb(const char* x, Fix y)
{
cout << x << " = " << (y) << " [" << length(y) << "]"<< "\n";
}
main() {
cout << "Fix: identities should be displayed\n"
<< "[X] displays the precision of a given value\n"
<< "[*] indicates that the full precision is not used for coding reasons\n";
Fix a; checkb("0 [16]",a);
Fix b = .5; checkb(".5 [16]",b);
Fix c(17,-.5); checkb("-.5 [17]",c);
Fix d(33,.1); checkb(".1 [33]",d);
Fix e = c; checkb("-.5 [17]",e);
checkb(".3 [16]",a = .3);
checkb(".5 [16]",a = b);
checkb(".1 [16]",a = d);
checkb(".1 [33*]",d = a);
checkb("-.2 [17]",c = -.2);
checkb("-.5 [17]",e);
check(".1 [16] == .1 [33*]",a == d);
d = .1;
check(".1 [16] == .1 [33]",a == d);
check(".1 [33] != .5 [16]",d != b);
check(".1 [33] > .5 [16]",d > b);
check(".1 [33] <= -.2 [17]",d <= c);
e = .5;
check("1073741824",mantissa(e));
check(".5",value(e));
checkb(".5 [17]",+e);
checkb("-.5 [17]",-e);
checkb(".1 [33] + .5 [16]",d+b);
checkb(".1 [33] - .5 [16]",d-b);
checkb(".1 [33] * .5 [16]",d*b);
checkb(".1 [33] * 3",d*3);
checkb(".1 [33] * -3",d*-3);
checkb("-.1 [33] * 3",(-d)*3);
checkb("-.1 [33] * -3",(-d)*-3);
checkb(".5 [17] * -2",e*-2);
checkb(".1 [33] % 25",d%25);
checkb(".1 [33] % -25",d%-25);
checkb(".1 [33] / .5 [16]",d/b);
checkb(".1 [33] << 1",d<<1);
checkb("-.1 [33] >> 2",(-d)>>2);
checkb("abs(-.2)",abs(c));
checkb("abs(.2)",abs(-c));
check("sgn(-.2)",sgn(c));
check("sgn(.2)",sgn(-c));
cout << "\nshow .1 [33]\n";
show(d);
Fix g = .95;
cout << "\nFix: range errors warned\n";
Fix f = 1.1; checkb("1.1 [16]",f);
checkb(".5 [16] / .1 [33]",b/d);
checkb(".5 [16] / 0. [16]",b/Fix(0.));
checkb(".5 [17] * 32768",e*32768);
cout << "\nFix: overflows saturated\n";
set_overflow_handler(Fix_overflow_saturate);
checkb(".95 [16] + .1 [33]",g+d);
checkb("-.1 [33] - .95 [16]",-d-g);
checkb(".5 [17] * 2",e*2);
cout << "\nFix: overflows generate warnings\n";
set_overflow_handler(Fix_overflow_warning);
checkb(".95 [16] + .1 [33]",g+d);
checkb("-.1 [33] - .95 [16]",-d-g);
checkb(".5 [17] * 2",e*2);
}