]> www.ginac.de Git - cln.git/blob - src/integer/bitwise/cl_I_byte.h
370db1062629a556535dce700bf1d5bcc36b8641
[cln.git] / src / integer / bitwise / cl_I_byte.h
1 // cl_I internals for BYTE operations
2
3 #ifndef _CL_I_BYTE_H
4 #define _CL_I_BYTE_H
5
6 #include "cl_number.h"
7 #include "cl_integer_class.h"
8
9 // cl_fullbyte(p,q) liefert zu p,q die Zahl 2^q-2^p als Integer,
10 // wobei p und q uintL sind. Bei p<=q ist das Ergebnis also
11 // ein Integer >=0, bei dem genau die Bits p,...,q-1 gesetzt sind.
12 extern const cl_I cl_fullbyte (uintL p, uintL q);
13
14 // Extrahiere die Bits p,...,q-1 der Zahl x,
15 // wobei 0 <= p <= q <= l = (integer-length x).
16 // Ergebnis (wie bei LDB) ein Integer >=0.
17 extern const cl_I ldb_extract (const cl_I& x, uintL p, uintL q);
18
19 // Teste, ob eines der Bits p,...,q-1 der Zahl x /=0 ist,
20 // wobei 0 <= p <= q <= l = (integer-length x).
21 // Ergebnis (wie bei LDB-TEST) cl_false wenn nein, cl_true wenn ja.
22 extern cl_boolean ldb_extract_test (const cl_I& x, uintL p, uintL q);
23
24 // Extrahiere die Bits p,...,q-1 der Zahl x,
25 // wobei 0 <= p <= q <= l = (integer-length x).
26 // Ergebnis (wie bei MASK-FIELD) ein Integer >=0.
27 extern const cl_I mkf_extract (const cl_I& x, uintL p, uintL q);
28
29 #endif /* _CL_I_BYTE_H */