1Vector(3)             User Contributed Perl Documentation            Vector(3)
2
3
4

NAME

6       Bit::Vector - Efficient bit vector, set of integers and "big int" math
7       library
8

SYNOPSIS

10   OVERLOADED OPERATORS
11       See Bit::Vector::Overload(3).
12
13   MORE STRING IMPORT/EXPORT
14       See Bit::Vector::String(3).
15
16   CLASS METHODS
17         Version
18             $version = Bit::Vector->Version();
19
20         Word_Bits
21             $bits = Bit::Vector->Word_Bits();  #  bits in a machine word
22
23         Long_Bits
24             $bits = Bit::Vector->Long_Bits();  #  bits in an unsigned long
25
26         new
27             $vector = Bit::Vector->new($bits);  #  bit vector constructor
28
29             @veclist = Bit::Vector->new($bits,$count);
30
31         new_Hex
32             $vector = Bit::Vector->new_Hex($bits,$string);
33
34         new_Bin
35             $vector = Bit::Vector->new_Bin($bits,$string);
36
37         new_Dec
38             $vector = Bit::Vector->new_Dec($bits,$string);
39
40         new_Enum
41             $vector = Bit::Vector->new_Enum($bits,$string);
42
43         Concat_List
44             $vector = Bit::Vector->Concat_List(@vectors);
45
46   OBJECT METHODS
47         new
48             $vec2 = $vec1->new($bits);  #  alternative call of constructor
49
50             @veclist = $vec->new($bits,$count);
51
52         Shadow
53             $vec2 = $vec1->Shadow();  #  new vector, same size but empty
54
55         Clone
56             $vec2 = $vec1->Clone();  #  new vector, exact duplicate
57
58         Concat
59             $vector = $vec1->Concat($vec2);
60
61         Concat_List
62             $vector = $vec1->Concat_List($vec2,$vec3,...);
63
64         Size
65             $bits = $vector->Size();
66
67         Resize
68             $vector->Resize($bits);
69             $vector->Resize($vector->Size()+5);
70             $vector->Resize($vector->Size()-5);
71
72         Copy
73             $vec2->Copy($vec1);
74
75         Empty
76             $vector->Empty();
77
78         Fill
79             $vector->Fill();
80
81         Flip
82             $vector->Flip();
83
84         Primes
85             $vector->Primes();  #  Sieve of Erathostenes
86
87         Reverse
88             $vec2->Reverse($vec1);
89
90         Interval_Empty
91             $vector->Interval_Empty($min,$max);
92
93         Interval_Fill
94             $vector->Interval_Fill($min,$max);
95
96         Interval_Flip
97             $vector->Interval_Flip($min,$max);
98
99         Interval_Reverse
100             $vector->Interval_Reverse($min,$max);
101
102         Interval_Scan_inc
103             if (($min,$max) = $vector->Interval_Scan_inc($start))
104
105         Interval_Scan_dec
106             if (($min,$max) = $vector->Interval_Scan_dec($start))
107
108         Interval_Copy
109             $vec2->Interval_Copy($vec1,$offset2,$offset1,$length);
110
111         Interval_Substitute
112             $vec2->Interval_Substitute($vec1,$off2,$len2,$off1,$len1);
113
114         is_empty
115             if ($vector->is_empty())
116
117         is_full
118             if ($vector->is_full())
119
120         equal
121             if ($vec1->equal($vec2))
122
123         Lexicompare (unsigned)
124             if ($vec1->Lexicompare($vec2) == 0)
125             if ($vec1->Lexicompare($vec2) != 0)
126             if ($vec1->Lexicompare($vec2) <  0)
127             if ($vec1->Lexicompare($vec2) <= 0)
128             if ($vec1->Lexicompare($vec2) >  0)
129             if ($vec1->Lexicompare($vec2) >= 0)
130
131         Compare (signed)
132             if ($vec1->Compare($vec2) == 0)
133             if ($vec1->Compare($vec2) != 0)
134             if ($vec1->Compare($vec2) <  0)
135             if ($vec1->Compare($vec2) <= 0)
136             if ($vec1->Compare($vec2) >  0)
137             if ($vec1->Compare($vec2) >= 0)
138
139         to_Hex
140             $string = $vector->to_Hex();
141
142         from_Hex
143             $vector->from_Hex($string);
144
145         to_Bin
146             $string = $vector->to_Bin();
147
148         from_Bin
149             $vector->from_Bin($string);
150
151         to_Dec
152             $string = $vector->to_Dec();
153
154         from_Dec
155             $vector->from_Dec($string);
156
157         to_Enum
158             $string = $vector->to_Enum();  #  e.g. "2,3,5-7,11,13-19"
159
160         from_Enum
161             $vector->from_Enum($string);
162
163         Bit_Off
164             $vector->Bit_Off($index);
165
166         Bit_On
167             $vector->Bit_On($index);
168
169         bit_flip
170             $bit = $vector->bit_flip($index);
171
172         bit_test
173         contains
174             $bit = $vector->bit_test($index);
175             $bit = $vector->contains($index);
176             if ($vector->bit_test($index))
177             if ($vector->contains($index))
178
179         Bit_Copy
180             $vector->Bit_Copy($index,$bit);
181
182         LSB (least significant bit)
183             $vector->LSB($bit);
184
185         MSB (most significant bit)
186             $vector->MSB($bit);
187
188         lsb (least significant bit)
189             $bit = $vector->lsb();
190
191         msb (most significant bit)
192             $bit = $vector->msb();
193
194         rotate_left
195             $carry = $vector->rotate_left();
196
197         rotate_right
198             $carry = $vector->rotate_right();
199
200         shift_left
201             $carry = $vector->shift_left($carry);
202
203         shift_right
204             $carry = $vector->shift_right($carry);
205
206         Move_Left
207             $vector->Move_Left($bits);  #  shift left "$bits" positions
208
209         Move_Right
210             $vector->Move_Right($bits);  #  shift right "$bits" positions
211
212         Insert
213             $vector->Insert($offset,$bits);
214
215         Delete
216             $vector->Delete($offset,$bits);
217
218         increment
219             $carry = $vector->increment();
220
221         decrement
222             $carry = $vector->decrement();
223
224         inc
225             $overflow = $vec2->inc($vec1);
226
227         dec
228             $overflow = $vec2->dec($vec1);
229
230         add
231             $carry = $vec3->add($vec1,$vec2,$carry);
232             ($carry,$overflow) = $vec3->add($vec1,$vec2,$carry);
233
234         subtract
235             $carry = $vec3->subtract($vec1,$vec2,$carry);
236             ($carry,$overflow) = $vec3->subtract($vec1,$vec2,$carry);
237
238         Neg
239         Negate
240             $vec2->Neg($vec1);
241             $vec2->Negate($vec1);
242
243         Abs
244         Absolute
245             $vec2->Abs($vec1);
246             $vec2->Absolute($vec1);
247
248         Sign
249             if ($vector->Sign() == 0)
250             if ($vector->Sign() != 0)
251             if ($vector->Sign() <  0)
252             if ($vector->Sign() <= 0)
253             if ($vector->Sign() >  0)
254             if ($vector->Sign() >= 0)
255
256         Multiply
257             $vec3->Multiply($vec1,$vec2);
258
259         Divide
260             $quot->Divide($vec1,$vec2,$rest);
261
262         GCD (Greatest Common Divisor)
263             $vecgcd->GCD($veca,$vecb);
264             $vecgcd->GCD($vecx,$vecy,$veca,$vecb);
265
266         Power
267             $vec3->Power($vec1,$vec2);
268
269         Block_Store
270             $vector->Block_Store($buffer);
271
272         Block_Read
273             $buffer = $vector->Block_Read();
274
275         Word_Size
276             $size = $vector->Word_Size();  #  number of words in "$vector"
277
278         Word_Store
279             $vector->Word_Store($offset,$word);
280
281         Word_Read
282             $word = $vector->Word_Read($offset);
283
284         Word_List_Store
285             $vector->Word_List_Store(@words);
286
287         Word_List_Read
288             @words = $vector->Word_List_Read();
289
290         Word_Insert
291             $vector->Word_Insert($offset,$count);
292
293         Word_Delete
294             $vector->Word_Delete($offset,$count);
295
296         Chunk_Store
297             $vector->Chunk_Store($chunksize,$offset,$chunk);
298
299         Chunk_Read
300             $chunk = $vector->Chunk_Read($chunksize,$offset);
301
302         Chunk_List_Store
303             $vector->Chunk_List_Store($chunksize,@chunks);
304
305         Chunk_List_Read
306             @chunks = $vector->Chunk_List_Read($chunksize);
307
308         Index_List_Remove
309             $vector->Index_List_Remove(@indices);
310
311         Index_List_Store
312             $vector->Index_List_Store(@indices);
313
314         Index_List_Read
315             @indices = $vector->Index_List_Read();
316
317         Or
318         Union
319             $vec3->Or($vec1,$vec2);
320             $set3->Union($set1,$set2);
321
322         And
323         Intersection
324             $vec3->And($vec1,$vec2);
325             $set3->Intersection($set1,$set2);
326
327         AndNot
328         Difference
329             $vec3->AndNot($vec1,$vec2);
330             $set3->Difference($set1,$set2);
331
332         Xor
333         ExclusiveOr
334             $vec3->Xor($vec1,$vec2);
335             $set3->ExclusiveOr($set1,$set2);
336
337         Not
338         Complement
339             $vec2->Not($vec1);
340             $set2->Complement($set1);
341
342         subset
343             if ($set1->subset($set2))  #  true if $set1 is subset of $set2
344
345         Norm
346             $norm = $set->Norm();
347             $norm = $set->Norm2();
348             $norm = $set->Norm3();
349
350         Min
351             $min = $set->Min();
352
353         Max
354             $max = $set->Max();
355
356         Multiplication
357             $matrix3->Multiplication($rows3,$cols3,
358                             $matrix1,$rows1,$cols1,
359                             $matrix2,$rows2,$cols2);
360
361         Product
362             $matrix3->Product($rows3,$cols3,
363                      $matrix1,$rows1,$cols1,
364                      $matrix2,$rows2,$cols2);
365
366         Closure
367             $matrix->Closure($rows,$cols);
368
369         Transpose
370             $matrix2->Transpose($rows2,$cols2,$matrix1,$rows1,$cols1);
371

IMPORTANT NOTES

373       • Method naming conventions
374
375         Method names completely in lower case indicate a boolean return
376         value.
377
378         (Except for the bit vector constructor method ""new()"", of course.)
379
380       • Boolean values
381
382         Boolean values in this module are always a numeric zero ("0") for
383         "false" and a numeric one ("1") for "true".
384
385       • Negative numbers
386
387         All numeric input parameters passed to any of the methods in this
388         module are regarded as being UNSIGNED (as opposed to the contents of
389         the bit vectors themselves, which are usually considered to be
390         SIGNED).
391
392         As a consequence, whenever you pass a negative number as an argument
393         to some method of this module, it will be treated as a (usually very
394         large) positive number due to its internal two's complement binary
395         representation, usually resulting in an "index out of range" error
396         message and program abortion.
397
398       • Bit order
399
400         Note that bit vectors are stored least order bit and least order word
401         first internally.
402
403         I.e., bit #0 of any given bit vector corresponds to bit #0 of word #0
404         in the array of machine words representing the bit vector.
405
406         (Where word #0 comes first in memory, i.e., it is stored at the least
407         memory address in the allocated block of memory holding the given bit
408         vector.)
409
410         Note however that machine words can be stored least order byte first
411         or last, depending on your system's implementation.
412
413         When you are exporting or importing a whole bit vector at once using
414         the methods ""Block_Read()"" and ""Block_Store()"" (the only time in
415         this module where this could make any difference), however, a
416         conversion to and from "least order byte first" order is
417         automatically supplied.
418
419         In other words, what ""Block_Read()"" provides and what
420         ""Block_Store()"" expects is always in "least order byte first"
421         order, regardless of the order in which words are stored internally
422         on your machine.
423
424         This is to make sure that what you export on one machine using
425         ""Block_Read()"" can always be read in correctly with
426         ""Block_Store()"" on a different machine.
427
428         Note further that whenever bit vectors are converted to and from
429         (binary or hexadecimal) strings, the RIGHTMOST bit is always the
430         LEAST SIGNIFICANT one, and the LEFTMOST bit is always the MOST
431         SIGNIFICANT bit.
432
433         This is because in our western culture, numbers are always
434         represented in this way (least significant to most significant digits
435         go from right to left).
436
437         Of course this requires an internal reversion of order, which the
438         corresponding conversion methods perform automatically (without any
439         additional overhead, it's just a matter of starting the internal loop
440         at the bottom or the top end).
441
442       • "Word" related methods
443
444         Note that all methods whose names begin with ""Word_"" are MACHINE-
445         DEPENDENT!
446
447         They depend on the size (number of bits) of an "unsigned int" (C
448         type) on your machine.
449
450         Therefore, you should only use these methods if you are ABSOLUTELY
451         CERTAIN that portability of your code is not an issue!
452
453         Note that you can use arbitrarily large chunks (i.e., fragments of
454         bit vectors) of up to 32 bits IN A PORTABLE WAY using the methods
455         whose names begin with ""Chunk_"".
456
457       • Chunk sizes
458
459         Note that legal chunk sizes for all methods whose names begin with
460         ""Chunk_"" range from "1" to ""Bit::Vector->Long_Bits();"" bits ("0"
461         is NOT allowed!).
462
463         In order to make your programs portable, however, you shouldn't use
464         chunk sizes larger than 32 bits, since this is the minimum size of an
465         "unsigned long" (C type) on all systems, as prescribed by ANSI C.
466
467       • Matching sizes
468
469         In general, for methods involving several bit vectors at the same
470         time, all bit vector arguments must have identical sizes (number of
471         bits), or a fatal "size mismatch" error will occur.
472
473         Exceptions from this rule are the methods ""Concat()"",
474         ""Concat_List()"", ""Copy()"", ""Interval_Copy()"" and
475         ""Interval_Substitute()"", where no conditions at all are imposed on
476         the size of their bit vector arguments.
477
478         In method ""Multiply()"", all three bit vector arguments must in
479         principle obey the rule of matching sizes, but the bit vector in
480         which the result of the multiplication is to be stored may be larger
481         than the two bit vector arguments containing the factors for the
482         multiplication.
483
484         In method ""Power()"", the bit vector for the result must be the same
485         size or greater than the base of the exponentiation term. The
486         exponent can be any size.
487
488       • Index ranges
489
490         All indices for any given bits must lie between "0" and
491         ""$vector->Size()-1"", or a fatal "index out of range" error will
492         occur.
493
494       • Object persistence
495
496         Since version 6.5, "Bit::Vector" objects can be serialized and de-
497         serialized automatically with "Storable", out-of-the-box, without
498         requiring any further user action for this to work.
499
500         This is also true for nested data structures (since version 6.8).
501
502         See the Storable(3) documentation for more details.
503

DESCRIPTION

505   OVERLOADED OPERATORS
506       See Bit::Vector::Overload(3).
507
508   MORE STRING IMPORT/EXPORT
509       See Bit::Vector::String(3).
510
511   CLASS METHODS
512       • "$version = Bit::Vector->Version();"
513
514         Returns the current version number of this module.
515
516       • "$bits = Bit::Vector->Word_Bits();"
517
518         Returns the number of bits of an "unsigned int" (C type) on your
519         machine.
520
521         (An "unsigned int" is also called a "machine word", hence the name of
522         this method.)
523
524       • "$bits = Bit::Vector->Long_Bits();"
525
526         Returns the number of bits of an "unsigned long" (C type) on your
527         machine.
528
529       • "$vector = Bit::Vector->new($bits);"
530
531         This is the bit vector constructor method.
532
533         Call this method to create a new bit vector containing "$bits" bits
534         (with indices ranging from "0" to ""$bits-1"").
535
536         Note that - in contrast to previous versions - bit vectors of length
537         zero (i.e., with "$bits = 0") are permitted now.
538
539         The method returns a reference to the newly created bit vector.
540
541         A new bit vector is always initialized so that all bits are cleared
542         (turned off).
543
544         An exception will be raised if the method is unable to allocate the
545         necessary memory.
546
547         Note that if you specify a negative number for "$bits" it will be
548         interpreted as a large positive number due to its internal two's
549         complement binary representation.
550
551         In such a case, the bit vector constructor method will obediently
552         attempt to create a bit vector of that size, probably resulting in an
553         exception, as explained above.
554
555       • "@veclist = Bit::Vector->new($bits,$count);"
556
557         You can also create more than one bit vector at a time if you specify
558         the optional second parameter "$count".
559
560         The method returns a list of "$count" bit vectors which all have the
561         same number of bits "$bits" (and which are all initialized, i.e., all
562         bits are cleared).
563
564         If "$count" is zero, an empty list is returned.
565
566         If "$bits" is zero, a list of null-sized bit vectors is returned.
567
568         Note again that if you specify a negative number for "$count" it will
569         be interpreted as a large positive number due to its internal two's
570         complement binary representation.
571
572         In such a case, the bit vector constructor method will obediently
573         attempt to create that many bit vectors, probably resulting in an
574         exception ("out of memory").
575
576       • "$vector = Bit::Vector->new_Hex($bits,$string);"
577
578         This method is an alternative constructor which allows you to create
579         a new bit vector object (with "$bits" bits) and to initialize it all
580         in one go.
581
582         The method internally first calls the bit vector constructor method
583         ""new()"" and then passes the given string to the method
584         ""from_Hex()"".
585
586         However, this method is more efficient than performing these two
587         steps separately: First because in this method, the memory area
588         occupied by the new bit vector is not initialized to zeros (which is
589         pointless in this case), and second because it saves you from the
590         associated overhead of one additional method invocation.
591
592         An exception will be raised if the necessary memory cannot be
593         allocated (see the description of the method ""new()"" immediately
594         above for possible causes) or if the given string cannot be converted
595         successfully (see the description of the method ""from_Hex()""
596         further below for details).
597
598         In the latter case, the memory occupied by the new bit vector is
599         released first (i.e., "free"d) before the exception is actually
600         raised.
601
602       • "$vector = Bit::Vector->new_Bin($bits,$string);"
603
604         This method is an alternative constructor which allows you to create
605         a new bit vector object (with "$bits" bits) and to initialize it all
606         in one go.
607
608         The method internally first calls the bit vector constructor method
609         ""new()"" and then passes the given string to the method
610         ""from_Bin()"".
611
612         However, this method is more efficient than performing these two
613         steps separately: First because in this method, the memory area
614         occupied by the new bit vector is not initialized to zeros (which is
615         pointless in this case), and second because it saves you from the
616         associated overhead of one additional method invocation.
617
618         An exception will be raised if the necessary memory cannot be
619         allocated (see the description of the method ""new()"" above for
620         possible causes) or if the given string cannot be converted
621         successfully (see the description of the method ""from_Bin()""
622         further below for details).
623
624         In the latter case, the memory occupied by the new bit vector is
625         released first (i.e., "free"d) before the exception is actually
626         raised.
627
628       • "$vector = Bit::Vector->new_Dec($bits,$string);"
629
630         This method is an alternative constructor which allows you to create
631         a new bit vector object (with "$bits" bits) and to initialize it all
632         in one go.
633
634         The method internally first calls the bit vector constructor method
635         ""new()"" and then passes the given string to the method
636         ""from_Dec()"".
637
638         However, this method is more efficient than performing these two
639         steps separately: First because in this method, ""new()"" does not
640         initialize the memory area occupied by the new bit vector with zeros
641         (which is pointless in this case, because ""from_Dec()"" will do it
642         anyway), and second because it saves you from the associated overhead
643         of one additional method invocation.
644
645         An exception will be raised if the necessary memory cannot be
646         allocated (see the description of the method ""new()"" above for
647         possible causes) or if the given string cannot be converted
648         successfully (see the description of the method ""from_Dec()""
649         further below for details).
650
651         In the latter case, the memory occupied by the new bit vector is
652         released first (i.e., "free"d) before the exception is actually
653         raised.
654
655       • "$vector = Bit::Vector->new_Enum($bits,$string);"
656
657         This method is an alternative constructor which allows you to create
658         a new bit vector object (with "$bits" bits) and to initialize it all
659         in one go.
660
661         The method internally first calls the bit vector constructor method
662         ""new()"" and then passes the given string to the method
663         ""from_Enum()"".
664
665         However, this method is more efficient than performing these two
666         steps separately: First because in this method, ""new()"" does not
667         initialize the memory area occupied by the new bit vector with zeros
668         (which is pointless in this case, because ""from_Enum()"" will do it
669         anyway), and second because it saves you from the associated overhead
670         of one additional method invocation.
671
672         An exception will be raised if the necessary memory cannot be
673         allocated (see the description of the method ""new()"" above for
674         possible causes) or if the given string cannot be converted
675         successfully (see the description of the method ""from_Enum()""
676         further below for details).
677
678         In the latter case, the memory occupied by the new bit vector is
679         released first (i.e., "free"d) before the exception is actually
680         raised.
681
682       • "$vector = Bit::Vector->Concat_List(@vectors);"
683
684         This method creates a new vector containing all bit vectors from the
685         argument list in concatenated form.
686
687         The argument list may contain any number of arguments (including
688         zero); the only condition is that all arguments must be bit vectors.
689
690         There is no condition concerning the length (in number of bits) of
691         these arguments.
692
693         The vectors from the argument list are not changed in any way.
694
695         If the argument list is empty or if all arguments have length zero,
696         the resulting bit vector will also have length zero.
697
698         Note that the RIGHTMOST bit vector from the argument list will become
699         the LEAST significant part of the resulting bit vector, and the
700         LEFTMOST bit vector from the argument list will become the MOST
701         significant part of the resulting bit vector.
702
703   OBJECT METHODS
704       • "$vec2 = $vec1->new($bits);"
705
706         "@veclist = $vec->new($bits);"
707
708         This is an alternative way of calling the bit vector constructor
709         method.
710
711         Vector "$vec1" (or "$vec") is not affected by this, it just serves as
712         an anchor for the method invocation mechanism.
713
714         In fact ALL class methods in this module can be called this way, even
715         though this is probably considered to be "politically incorrect" by
716         OO ("object-orientation") aficionados. ;-)
717
718         So even if you are too lazy to type ""Bit::Vector->"" instead of
719         ""$vec1->"" (and even though laziness is - allegedly - a programmer's
720         virtue ":-)"), maybe it is better not to use this feature if you
721         don't want to get booed at. ;-)
722
723       • "$vec2 = $vec1->Shadow();"
724
725         Creates a NEW bit vector "$vec2" of the SAME SIZE as "$vec1" but
726         which is EMPTY.
727
728         Just like a shadow that has the same shape as the object it
729         originates from, but is flat and has no volume, i.e., contains
730         nothing.
731
732       • "$vec2 = $vec1->Clone();"
733
734         Creates a NEW bit vector "$vec2" of the SAME SIZE as "$vec1" which is
735         an EXACT COPY of "$vec1".
736
737       • "$vector = $vec1->Concat($vec2);"
738
739         This method returns a new bit vector object which is the result of
740         the concatenation of the contents of "$vec1" and "$vec2".
741
742         Note that the contents of "$vec1" become the MOST significant part of
743         the resulting bit vector, and "$vec2" the LEAST significant part.
744
745         If both bit vector arguments have length zero, the resulting bit
746         vector will also have length zero.
747
748       • "$vector = $vec1->Concat_List($vec2,$vec3,...);"
749
750         This is an alternative way of calling this (class) method as an
751         object method.
752
753         The method returns a new bit vector object which is the result of the
754         concatenation of the contents of "$vec1 . $vec2 . $vec3 . ..."
755
756         See the section "class methods" above for a detailed description of
757         this method.
758
759         Note that the argument list may be empty and that all arguments must
760         be bit vectors if it isn't.
761
762       • "$bits = $vector->Size();"
763
764         Returns the size (number of bits) the given vector was created with
765         (or ""Resize()""d to).
766
767       • "$vector->Resize($bits);"
768
769         Changes the size of the given vector to the specified number of bits.
770
771         This method allows you to change the size of an existing bit vector,
772         preserving as many bits from the old vector as will fit into the new
773         one (i.e., all bits with indices smaller than the minimum of the
774         sizes of both vectors, old and new).
775
776         If the number of machine words needed to store the new vector is
777         smaller than or equal to the number of words needed to store the old
778         vector, the memory allocated for the old vector is reused for the new
779         one, and only the relevant book-keeping information is adjusted
780         accordingly.
781
782         This means that even if the number of bits increases, new memory is
783         not necessarily being allocated (i.e., if the old and the new number
784         of bits fit into the same number of machine words).
785
786         If the number of machine words needed to store the new vector is
787         greater than the number of words needed to store the old vector, new
788         memory is allocated for the new vector, the old vector is copied to
789         the new one, the remaining bits in the new vector are cleared (turned
790         off) and the old vector is deleted, i.e., the memory that was
791         allocated for it is released.
792
793         (An exception will be raised if the method is unable to allocate the
794         necessary memory for the new vector.)
795
796         As a consequence, if you decrease the size of a given vector so that
797         it will use fewer machine words, and increase it again later so that
798         it will use more words than immediately before but still less than
799         the original vector, new memory will be allocated anyway because the
800         information about the size of the original vector is lost whenever
801         you resize it.
802
803         Note also that if you specify a negative number for "$bits" it will
804         be interpreted as a large positive number due to its internal two's
805         complement binary representation.
806
807         In such a case, "Resize()" will obediently attempt to create a bit
808         vector of that size, probably resulting in an exception, as explained
809         above.
810
811         Finally, note that - in contrast to previous versions - resizing a
812         bit vector to a size of zero bits (length zero) is now permitted.
813
814       • "$vec2->Copy($vec1);"
815
816         Copies the contents of bit vector "$vec1" to bit vector "$vec2".
817
818         The previous contents of bit vector "$vec2" get overwritten, i.e.,
819         are lost.
820
821         Both vectors must exist beforehand, i.e., this method does not CREATE
822         any new bit vector object.
823
824         The two vectors may be of any size.
825
826         If the source bit vector is larger than the target, this method will
827         copy as much of the least significant bits of the source vector as
828         will fit into the target vector, thereby discarding any extraneous
829         most significant bits.
830
831         BEWARE that this causes a brutal cutoff in the middle of your data,
832         and it will also leave you with an almost unpredictable sign if
833         subsequently the number in the target vector is going to be
834         interpreted as a number! (You have been warned!)
835
836         If the target bit vector is larger than the source, this method fills
837         up the remaining most significant bits in the target bit vector with
838         either 0's or 1's, depending on the sign (= the most significant bit)
839         of the source bit vector. This is also known as "sign extension".
840
841         This makes it possible to copy numbers from a smaller bit vector into
842         a larger one while preserving the number's absolute value as well as
843         its sign (due to the two's complement binary representation of
844         numbers).
845
846       • "$vector->Empty();"
847
848         Clears all bits in the given vector.
849
850       • "$vector->Fill();"
851
852         Sets all bits in the given vector.
853
854       • "$vector->Flip();"
855
856         Flips (i.e., complements) all bits in the given vector.
857
858       • "$vector->Primes();"
859
860         Clears the given bit vector and sets all bits whose indices are prime
861         numbers.
862
863         This method uses the algorithm known as the "Sieve of Erathostenes"
864         internally.
865
866       • "$vec2->Reverse($vec1);"
867
868         This method copies the given vector "$vec1" to the vector "$vec2",
869         thereby reversing the order of all bits.
870
871         I.e., the least significant bit of "$vec1" becomes the most
872         significant bit of "$vec2", whereas the most significant bit of
873         "$vec1" becomes the least significant bit of "$vec2", and so forth
874         for all bits in between.
875
876         Note that in-place processing is also possible, i.e., "$vec1" and
877         "$vec2" may be identical.
878
879         (Internally, this is the same as
880         "$vec1->Interval_Reverse(0,$vec1->Size()-1);".)
881
882       • "$vector->Interval_Empty($min,$max);"
883
884         Clears all bits in the interval "[$min..$max]" (including both
885         limits) in the given vector.
886
887         "$min" and "$max" may have the same value; this is the same as
888         clearing a single bit with ""Bit_Off()"" (but less efficient).
889
890         Note that "$vector->Interval_Empty(0,$vector->Size()-1);" is the same
891         as "$vector->Empty();" (but less efficient).
892
893       • "$vector->Interval_Fill($min,$max);"
894
895         Sets all bits in the interval "[$min..$max]" (including both limits)
896         in the given vector.
897
898         "$min" and "$max" may have the same value; this is the same as
899         setting a single bit with ""Bit_On()"" (but less efficient).
900
901         Note that "$vector->Interval_Fill(0,$vector->Size()-1);" is the same
902         as "$vector->Fill();" (but less efficient).
903
904       • "$vector->Interval_Flip($min,$max);"
905
906         Flips (i.e., complements) all bits in the interval "[$min..$max]"
907         (including both limits) in the given vector.
908
909         "$min" and "$max" may have the same value; this is the same as
910         flipping a single bit with ""bit_flip()"" (but less efficient).
911
912         Note that "$vector->Interval_Flip(0,$vector->Size()-1);" is the same
913         as "$vector->Flip();" and "$vector->Complement($vector);" (but less
914         efficient).
915
916       • "$vector->Interval_Reverse($min,$max);"
917
918         Reverses the order of all bits in the interval "[$min..$max]"
919         (including both limits) in the given vector.
920
921         I.e., bits "$min" and "$max" swap places, and so forth for all bits
922         in between.
923
924         "$min" and "$max" may have the same value; this has no effect
925         whatsoever, though.
926
927       • "if (($min,$max) = $vector->Interval_Scan_inc($start))"
928
929         Returns the minimum and maximum indices of the next contiguous block
930         of set bits (i.e., bits in the "on" state).
931
932         The search starts at index "$start" (i.e., "$min" >= "$start") and
933         proceeds upwards (i.e., "$max" >= "$min"), thus repeatedly increments
934         the search pointer "$start" (internally).
935
936         Note though that the contents of the variable (or scalar literal
937         value) "$start" is NOT altered. I.e., you have to set it to the
938         desired value yourself prior to each call to ""Interval_Scan_inc()""
939         (see also the example given below).
940
941         Actually, the bit vector is not searched bit by bit, but one machine
942         word at a time, in order to speed up execution (which means that this
943         method is quite efficient).
944
945         An empty list is returned if no such block can be found.
946
947         Note that a single set bit (surrounded by cleared bits) is a valid
948         block by this definition. In that case the return values for "$min"
949         and "$max" are the same.
950
951         Typical use:
952
953             $start = 0;
954             while (($start < $vector->Size()) &&
955                 (($min,$max) = $vector->Interval_Scan_inc($start)))
956             {
957                 $start = $max + 2;
958
959                 # do something with $min and $max
960             }
961
962       • "if (($min,$max) = $vector->Interval_Scan_dec($start))"
963
964         Returns the minimum and maximum indices of the next contiguous block
965         of set bits (i.e., bits in the "on" state).
966
967         The search starts at index "$start" (i.e., "$max" <= "$start") and
968         proceeds downwards (i.e., "$min" <= "$max"), thus repeatedly
969         decrements the search pointer "$start" (internally).
970
971         Note though that the contents of the variable (or scalar literal
972         value) "$start" is NOT altered. I.e., you have to set it to the
973         desired value yourself prior to each call to ""Interval_Scan_dec()""
974         (see also the example given below).
975
976         Actually, the bit vector is not searched bit by bit, but one machine
977         word at a time, in order to speed up execution (which means that this
978         method is quite efficient).
979
980         An empty list is returned if no such block can be found.
981
982         Note that a single set bit (surrounded by cleared bits) is a valid
983         block by this definition. In that case the return values for "$min"
984         and "$max" are the same.
985
986         Typical use:
987
988             $start = $vector->Size() - 1;
989             while (($start >= 0) &&
990                 (($min,$max) = $vector->Interval_Scan_dec($start)))
991             {
992                 $start = $min - 2;
993
994                 # do something with $min and $max
995             }
996
997       • "$vec2->Interval_Copy($vec1,$offset2,$offset1,$length);"
998
999         This method allows you to copy a stretch of contiguous bits (starting
1000         at any position "$offset1" you choose, with a length of "$length"
1001         bits) from a given "source" bit vector "$vec1" to another position
1002         "$offset2" in a "target" bit vector "$vec2".
1003
1004         Note that the two bit vectors "$vec1" and "$vec2" do NOT need to have
1005         the same (matching) size!
1006
1007         Consequently, any of the two terms ""$offset1 + $length"" and
1008         ""$offset2 + $length"" (or both) may exceed the actual length of its
1009         corresponding bit vector (""$vec1->Size()"" and ""$vec2->Size()"",
1010         respectively).
1011
1012         In such a case, the "$length" parameter is automatically reduced
1013         internally so that both terms above are bounded by the number of bits
1014         of their corresponding bit vector.
1015
1016         This may even result in a length of zero, in which case nothing is
1017         copied at all.
1018
1019         (Of course the value of the "$length" parameter, supplied by you in
1020         the initial method call, may also be zero right from the start!)
1021
1022         Note also that "$offset1" and "$offset2" must lie within the range
1023         "0" and, respectively, ""$vec1->Size()-1"" or ""$vec2->Size()-1"", or
1024         a fatal "offset out of range" error will occur.
1025
1026         Note further that "$vec1" and "$vec2" may be identical, i.e., you may
1027         copy a stretch of contiguous bits from one part of a given bit vector
1028         to another part.
1029
1030         The source and the target interval may even overlap, in which case
1031         the copying is automatically performed in ascending or descending
1032         order (depending on the direction of the copy - downwards or upwards
1033         in the bit vector, respectively) to handle this situation correctly,
1034         i.e., so that no bits are being overwritten before they have been
1035         copied themselves.
1036
1037       • "$vec2->Interval_Substitute($vec1,$off2,$len2,$off1,$len1);"
1038
1039         This method is (roughly) the same for bit vectors (i.e., arrays of
1040         booleans) as what the "splice" function in Perl is for lists (i.e.,
1041         arrays of scalars).
1042
1043         (See "splice" in perlfunc for more details about this function.)
1044
1045         The method allows you to substitute a stretch of contiguous bits
1046         (defined by a position (offset) "$off1" and a length of "$len1" bits)
1047         from a given "source" bit vector "$vec1" for a different stretch of
1048         contiguous bits (defined by a position (offset) "$off2" and a length
1049         of "$len2" bits) in another, "target" bit vector "$vec2".
1050
1051         Note that the two bit vectors "$vec1" and "$vec2" do NOT need to have
1052         the same (matching) size!
1053
1054         Note further that "$off1" and "$off2" must lie within the range "0"
1055         and, respectively, ""$vec1->Size()"" or ""$vec2->Size()"", or a fatal
1056         "offset out of range" error will occur.
1057
1058         Alert readers will have noticed that these upper limits are NOT
1059         ""$vec1->Size()-1"" and ""$vec2->Size()-1"", as they would be for any
1060         other method in this module, but that these offsets may actually
1061         point to one position PAST THE END of the corresponding bit vector.
1062
1063         This is necessary in order to make it possible to APPEND a given
1064         stretch of bits to the target bit vector instead of REPLACING
1065         something in it.
1066
1067         For reasons of symmetry and generality, the same applies to the
1068         offset in the source bit vector, even though such an offset (one
1069         position past the end of the bit vector) does not serve any practical
1070         purpose there (but does not cause any harm either).
1071
1072         (Actually this saves you from the need of testing for this special
1073         case, in certain circumstances.)
1074
1075         Note that whenever the term ""$off1 + $len1"" exceeds the size
1076         ""$vec1->Size()"" of bit vector "$vec1" (or if ""$off2 + $len2""
1077         exceeds ""$vec2->Size()""), the corresponding length ("$len1" or
1078         "$len2", respectively) is automatically reduced internally so that
1079         ""$off1 + $len1 <= $vec1->Size()"" (and ""$off2 + $len2 <=
1080         $vec2->Size()"") holds.
1081
1082         (Note that this does NOT alter the intended result, even though this
1083         may seem counter-intuitive at first!)
1084
1085         This may even result in a length ("$len1" or "$len2") of zero.
1086
1087         A length of zero for the interval in the SOURCE bit vector (""$len1
1088         == 0"") means that the indicated stretch of bits in the target bit
1089         vector (starting at position "$off2") is to be replaced by NOTHING,
1090         i.e., is to be DELETED.
1091
1092         A length of zero for the interval in the TARGET bit vector ("$len2 ==
1093         0") means that NOTHING is replaced, and that the stretch of bits from
1094         the source bit vector is simply INSERTED into the target bit vector
1095         at the indicated position ("$off2").
1096
1097         If both length parameters are zero, nothing is done at all.
1098
1099         Note that in contrast to any other method in this module (especially
1100         ""Interval_Copy()"", ""Insert()"" and ""Delete()""), this method
1101         IMPLICITLY and AUTOMATICALLY adapts the length of the resulting bit
1102         vector as needed, as given by
1103
1104                 $size = $vec2->Size();   #  before
1105                 $size += $len1 - $len2;  #  after
1106
1107         (The only other method in this module that changes the size of a bit
1108         vector is the method ""Resize()"".)
1109
1110         In other words, replacing a given interval of bits in the target bit
1111         vector with a longer or shorter stretch of bits from the source bit
1112         vector, or simply inserting (""$len2 == 0"") a stretch of bits into
1113         or deleting (""$len1 == 0"") an interval of bits from the target bit
1114         vector will automatically increase or decrease, respectively, the
1115         size of the target bit vector accordingly.
1116
1117         For the sake of generality, this may even result in a bit vector with
1118         a size of zero (containing no bits at all).
1119
1120         This is also the reason why bit vectors of length zero are permitted
1121         in this module in the first place, starting with version 5.0.
1122
1123         Finally, note that "$vec1" and "$vec2" may be identical, i.e., in-
1124         place processing is possible.
1125
1126         (If you think about that for a while or if you look at the code, you
1127         will see that this is far from trivial!)
1128
1129       • "if ($vector->is_empty())"
1130
1131         Tests whether the given bit vector is empty, i.e., whether ALL of its
1132         bits are cleared (in the "off" state).
1133
1134         In "big integer" arithmetic, this is equivalent to testing whether
1135         the number stored in the bit vector is zero ("0").
1136
1137         Returns "true" ("1") if the bit vector is empty and "false" ("0")
1138         otherwise.
1139
1140         Note that this method also returns "true" ("1") if the given bit
1141         vector has a length of zero, i.e., if it contains no bits at all.
1142
1143       • "if ($vector->is_full())"
1144
1145         Tests whether the given bit vector is full, i.e., whether ALL of its
1146         bits are set (in the "on" state).
1147
1148         In "big integer" arithmetic, this is equivalent to testing whether
1149         the number stored in the bit vector is minus one ("-1").
1150
1151         Returns "true" ("1") if the bit vector is full and "false" ("0")
1152         otherwise.
1153
1154         If the given bit vector has a length of zero (i.e., if it contains no
1155         bits at all), this method returns "false" ("0").
1156
1157       • "if ($vec1->equal($vec2))"
1158
1159         Tests the two given bit vectors for equality.
1160
1161         Returns "true" ("1") if the two bit vectors are exact copies of one
1162         another and "false" ("0") otherwise.
1163
1164       • "$cmp = $vec1->Lexicompare($vec2);"
1165
1166         Compares the two given bit vectors, which are regarded as UNSIGNED
1167         numbers in binary representation.
1168
1169         The method returns ""-1"" if the first bit vector is smaller than the
1170         second bit vector, "0" if the two bit vectors are exact copies of one
1171         another and "1" if the first bit vector is greater than the second
1172         bit vector.
1173
1174       • "$cmp = $vec1->Compare($vec2);"
1175
1176         Compares the two given bit vectors, which are regarded as SIGNED
1177         numbers in binary representation.
1178
1179         The method returns ""-1"" if the first bit vector is smaller than the
1180         second bit vector, "0" if the two bit vectors are exact copies of one
1181         another and "1" if the first bit vector is greater than the second
1182         bit vector.
1183
1184       • "$string = $vector->to_Hex();"
1185
1186         Returns a hexadecimal string representing the given bit vector.
1187
1188         Note that this representation is quite compact, in that it only needs
1189         at most twice the number of bytes needed to store the bit vector
1190         itself, internally.
1191
1192         Note also that since a hexadecimal digit is always worth four bits,
1193         the length of the resulting string is always a multiple of four bits,
1194         regardless of the true length (in bits) of the given bit vector.
1195
1196         Finally, note that the LEAST significant hexadecimal digit is located
1197         at the RIGHT end of the resulting string, and the MOST significant
1198         digit at the LEFT end.
1199
1200       • "$vector->from_Hex($string);"
1201
1202         Allows to read in the contents of a bit vector from a hexadecimal
1203         string, such as returned by the method ""to_Hex()"" (see above).
1204
1205         Remember that the least significant bits are always to the right of a
1206         hexadecimal string, and the most significant bits to the left.
1207         Therefore, the string is actually read in from right to left while
1208         the bit vector is filled accordingly, 4 bits at a time, starting with
1209         the least significant bits and going upward to the most significant
1210         bits.
1211
1212         If the given string contains less hexadecimal digits than are needed
1213         to completely fill the given bit vector, the remaining (most
1214         significant) bits are all cleared.
1215
1216         This also means that, even if the given string does not contain
1217         enough digits to completely fill the given bit vector, the previous
1218         contents of the bit vector are erased completely.
1219
1220         If the given string is longer than it needs to fill the given bit
1221         vector, the superfluous characters are simply ignored.
1222
1223         (In fact they are ignored completely - they are not even checked for
1224         proper syntax. See also below for more about that.)
1225
1226         This behaviour is intentional so that you may read in the string
1227         representing one bit vector into another bit vector of different
1228         size, i.e., as much of it as will fit.
1229
1230         If during the process of reading the given string any character is
1231         encountered which is not a hexadecimal digit, a fatal syntax error
1232         ensues ("input string syntax error").
1233
1234       • "$string = $vector->to_Bin();"
1235
1236         Returns a binary string representing the given bit vector.
1237
1238         Example:
1239
1240           $vector = Bit::Vector->new(8);
1241           $vector->Primes();
1242           $string = $vector->to_Bin();
1243           print "'$string'\n";
1244
1245         This prints:
1246
1247           '10101100'
1248
1249         (Bits #7, #5, #3 and #2 are set.)
1250
1251         Note that the LEAST significant bit is located at the RIGHT end of
1252         the resulting string, and the MOST significant bit at the LEFT end.
1253
1254       • "$vector->from_Bin($string);"
1255
1256         This method allows you to read in the contents of a bit vector from a
1257         binary string, such as returned by the method ""to_Bin()"" (see
1258         above).
1259
1260         Note that this method assumes that the LEAST significant bit is
1261         located at the RIGHT end of the binary string, and the MOST
1262         significant bit at the LEFT end. Therefore, the string is actually
1263         read in from right to left while the bit vector is filled
1264         accordingly, one bit at a time, starting with the least significant
1265         bit and going upward to the most significant bit.
1266
1267         If the given string contains less binary digits ("0" and "1") than
1268         are needed to completely fill the given bit vector, the remaining
1269         (most significant) bits are all cleared.
1270
1271         This also means that, even if the given string does not contain
1272         enough digits to completely fill the given bit vector, the previous
1273         contents of the bit vector are erased completely.
1274
1275         If the given string is longer than it needs to fill the given bit
1276         vector, the superfluous characters are simply ignored.
1277
1278         (In fact they are ignored completely - they are not even checked for
1279         proper syntax. See also below for more about that.)
1280
1281         This behaviour is intentional so that you may read in the string
1282         representing one bit vector into another bit vector of different
1283         size, i.e., as much of it as will fit.
1284
1285         If during the process of reading the given string any character is
1286         encountered which is not either "0" or "1", a fatal syntax error
1287         ensues ("input string syntax error").
1288
1289       • "$string = $vector->to_Dec();"
1290
1291         This method returns a string representing the contents of the given
1292         bit vector converted to decimal (base 10).
1293
1294         Note that this method assumes the given bit vector to be SIGNED (and
1295         to contain a number in two's complement binary representation).
1296
1297         Consequently, whenever the most significant bit of the given bit
1298         vector is set, the number stored in it is regarded as being NEGATIVE.
1299
1300         The resulting string can be fed into ""from_Dec()"" (see below) in
1301         order to copy the contents of this bit vector to another one (or to
1302         restore the contents of this one). This is not advisable, though,
1303         since this would be very inefficient (there are much more efficient
1304         methods for storing and copying bit vectors in this module).
1305
1306         Note that such conversion from binary to decimal is inherently slow
1307         since the bit vector has to be repeatedly divided by 10 with
1308         remainder until the quotient becomes 0 (each remainder in turn
1309         represents a single decimal digit of the resulting string).
1310
1311         This is also true for the implementation of this method in this
1312         module, even though a considerable effort has been made to speed it
1313         up: instead of repeatedly dividing by 10, the bit vector is
1314         repeatedly divided by the largest power of 10 that will fit into a
1315         machine word. The remainder is then repeatedly divided by 10 using
1316         only machine word arithmetics, which is much faster than dividing the
1317         whole bit vector ("divide and rule" principle).
1318
1319         According to my own measurements, this resulted in an 8-fold speed
1320         increase over the straightforward approach.
1321
1322         Still, conversion to decimal should be used only where absolutely
1323         necessary.
1324
1325         Keep the resulting string stored in some variable if you need it
1326         again, instead of converting the bit vector all over again.
1327
1328         Beware that if you set the configuration for overloaded operators to
1329         "output=decimal", this method will be called for every bit vector
1330         enclosed in double quotes!
1331
1332       • "$vector->from_Dec($string);"
1333
1334         This method allows you to convert a given decimal number, which may
1335         be positive or negative, into two's complement binary representation,
1336         which is then stored in the given bit vector.
1337
1338         The decimal number should always be provided as a string, to avoid
1339         possible truncation (due to the limited precision of integers in
1340         Perl) or formatting (due to Perl's use of scientific notation for
1341         large numbers), which would lead to errors.
1342
1343         If the binary representation of the given decimal number is too big
1344         to fit into the given bit vector (if the given bit vector does not
1345         contain enough bits to hold it), a fatal "numeric overflow error"
1346         occurs.
1347
1348         If the input string contains other characters than decimal digits
1349         ("0-9") and an optional leading sign (""+"" or ""-""), a fatal "input
1350         string syntax error" occurs.
1351
1352         Beware that large positive numbers which cause the most significant
1353         bit to be set (e.g. "255" in a bit vector with 8 bits) will be
1354         printed as negative numbers when converted back to decimal using the
1355         method "to_Dec()" (e.g.  "-1", in our example), because numbers with
1356         the most significant bit set are considered to be negative in two's
1357         complement binary representation.
1358
1359         Note also that while it is possible to thusly enter negative numbers
1360         as large positive numbers (e.g. "255" for "-1" in a bit vector with 8
1361         bits), the contrary isn't, i.e., you cannot enter "-255" for "+1", in
1362         our example.  A fatal "numeric overflow error" will occur if you try
1363         to do so.
1364
1365         If possible program abortion is unwanted or intolerable, use
1366         ""eval"", like this:
1367
1368           eval { $vector->from_Dec("1152921504606846976"); };
1369           if ($@)
1370           {
1371               # an error occurred
1372           }
1373
1374         There are four possible error messages:
1375
1376           if ($@ =~ /item is not a string/)
1377
1378           if ($@ =~ /input string syntax error/)
1379
1380           if ($@ =~ /numeric overflow error/)
1381
1382           if ($@ =~ /unable to allocate memory/)
1383
1384         Note that the conversion from decimal to binary is costly in terms of
1385         processing time, since a lot of multiplications have to be carried
1386         out (in principle, each decimal digit must be multiplied with the
1387         binary representation of the power of 10 corresponding to its
1388         position in the decimal number, i.e., 1, 10, 100, 1000, 10000 and so
1389         on).
1390
1391         This is not as time consuming as the opposite conversion, from binary
1392         to decimal (where successive divisions have to be carried out, which
1393         are even more expensive than multiplications), but still noticeable.
1394
1395         Again (as in the case of ""to_Dec()""), the implementation of this
1396         method in this module uses the principle of "divide and rule" in
1397         order to speed up the conversion, i.e., as many decimal digits as
1398         possible are first accumulated (converted) in a machine word and only
1399         then stored in the given bit vector.
1400
1401         Even so, use this method only where absolutely necessary if speed is
1402         an important consideration in your application.
1403
1404         Beware that if you set the configuration for overloaded operators to
1405         "input=decimal", this method will be called for every scalar operand
1406         you use!
1407
1408       • "$string = $vector->to_Enum();"
1409
1410         Converts the given bit vector or set into an enumeration of single
1411         indices and ranges of indices (".newsrc" style), representing the
1412         bits that are set ("1") in the bit vector.
1413
1414         Example:
1415
1416           $vector = Bit::Vector->new(20);
1417           $vector->Bit_On(2);
1418           $vector->Bit_On(3);
1419           $vector->Bit_On(11);
1420           $vector->Interval_Fill(5,7);
1421           $vector->Interval_Fill(13,19);
1422           print "'", $vector->to_Enum(), "'\n";
1423
1424         which prints
1425
1426           '2,3,5-7,11,13-19'
1427
1428         If the given bit vector is empty, the resulting string will also be
1429         empty.
1430
1431         Note, by the way, that the above example can also be written a little
1432         handier, perhaps, as follows:
1433
1434           Bit::Vector->Configuration("out=enum");
1435           $vector = Bit::Vector->new(20);
1436           $vector->Index_List_Store(2,3,5,6,7,11,13,14,15,16,17,18,19);
1437           print "'$vector'\n";
1438
1439       • "$vector->from_Enum($string);"
1440
1441         This method first empties the given bit vector and then tries to set
1442         the bits and ranges of bits specified in the given string.
1443
1444         The string "$string" must only contain unsigned integers or ranges of
1445         integers (two unsigned integers separated by a dash "-"), separated
1446         by commas (",").
1447
1448         All other characters are disallowed (including white space!)  and
1449         will lead to a fatal "input string syntax error".
1450
1451         In each range, the first integer (the lower limit of the range) must
1452         always be less than or equal to the second integer (the upper limit),
1453         or a fatal "minimum > maximum index" error occurs.
1454
1455         All integers must lie in the permitted range for the given bit
1456         vector, i.e., they must lie between "0" and ""$vector->Size()-1"".
1457
1458         If this condition is not met, a fatal "index out of range" error
1459         occurs.
1460
1461         If possible program abortion is unwanted or intolerable, use
1462         ""eval"", like this:
1463
1464           eval { $vector->from_Enum("2,3,5-7,11,13-19"); };
1465           if ($@)
1466           {
1467               # an error occurred
1468           }
1469
1470         There are four possible error messages:
1471
1472           if ($@ =~ /item is not a string/)
1473
1474           if ($@ =~ /input string syntax error/)
1475
1476           if ($@ =~ /index out of range/)
1477
1478           if ($@ =~ /minimum > maximum index/)
1479
1480         Note that the order of the indices and ranges is irrelevant, i.e.,
1481
1482           eval { $vector->from_Enum("11,5-7,3,13-19,2"); };
1483
1484         results in the same vector as in the example above.
1485
1486         Ranges and indices may also overlap.
1487
1488         This is because each (single) index in the string is passed to the
1489         method ""Bit_On()"", internally, and each range to the method
1490         ""Interval_Fill()"".
1491
1492         This means that the resulting bit vector is just the union of all the
1493         indices and ranges specified in the given string.
1494
1495       • "$vector->Bit_Off($index);"
1496
1497         Clears the bit with index "$index" in the given vector.
1498
1499       • "$vector->Bit_On($index);"
1500
1501         Sets the bit with index "$index" in the given vector.
1502
1503       • "$vector->bit_flip($index)"
1504
1505         Flips (i.e., complements) the bit with index "$index" in the given
1506         vector.
1507
1508         Moreover, this method returns the NEW state of the bit in question,
1509         i.e., it returns "0" if the bit is cleared or "1" if the bit is set
1510         (AFTER flipping it).
1511
1512       • "if ($vector->bit_test($index))"
1513
1514         "if ($vector->contains($index))"
1515
1516         Returns the current state of the bit with index "$index" in the given
1517         vector, i.e., returns "0" if it is cleared (in the "off" state) or
1518         "1" if it is set (in the "on" state).
1519
1520       • "$vector->Bit_Copy($index,$bit);"
1521
1522         Sets the bit with index "$index" in the given vector either to "0" or
1523         "1" depending on the boolean value "$bit".
1524
1525       • "$vector->LSB($bit);"
1526
1527         Allows you to set the least significant bit in the given bit vector
1528         to the value given by the boolean parameter "$bit".
1529
1530         This is a (faster) shortcut for ""$vector->Bit_Copy(0,$bit);"".
1531
1532       • "$vector->MSB($bit);"
1533
1534         Allows you to set the most significant bit in the given bit vector to
1535         the value given by the boolean parameter "$bit".
1536
1537         This is a (faster) shortcut for
1538         ""$vector->Bit_Copy($vector->Size()-1,$bit);"".
1539
1540       • "$bit = $vector->lsb();"
1541
1542         Returns the least significant bit of the given bit vector.
1543
1544         This is a (faster) shortcut for ""$bit = $vector->bit_test(0);"".
1545
1546       • "$bit = $vector->msb();"
1547
1548         Returns the most significant bit of the given bit vector.
1549
1550         This is a (faster) shortcut for ""$bit =
1551         $vector->bit_test($vector->Size()-1);"".
1552
1553       • "$carry_out = $vector->rotate_left();"
1554
1555           carry             MSB           vector:           LSB
1556            out:
1557           +---+            +---+---+---+---     ---+---+---+---+
1558           |   |  <---+---  |   |   |   |    ...    |   |   |   |  <---+
1559           +---+      |     +---+---+---+---     ---+---+---+---+      |
1560                      |                                                |
1561                      +------------------------------------------------+
1562
1563         The least significant bit (LSB) is the bit with index "0", the most
1564         significant bit (MSB) is the bit with index ""$vector->Size()-1"".
1565
1566       • "$carry_out = $vector->rotate_right();"
1567
1568                   MSB           vector:           LSB            carry
1569                                                                   out:
1570                  +---+---+---+---     ---+---+---+---+           +---+
1571           +--->  |   |   |   |    ...    |   |   |   |  ---+---> |   |
1572           |      +---+---+---+---     ---+---+---+---+     |     +---+
1573           |                                                |
1574           +------------------------------------------------+
1575
1576         The least significant bit (LSB) is the bit with index "0", the most
1577         significant bit (MSB) is the bit with index ""$vector->Size()-1"".
1578
1579       • "$carry_out = $vector->shift_left($carry_in);"
1580
1581           carry         MSB           vector:           LSB         carry
1582            out:                                                      in:
1583           +---+        +---+---+---+---     ---+---+---+---+        +---+
1584           |   |  <---  |   |   |   |    ...    |   |   |   |  <---  |   |
1585           +---+        +---+---+---+---     ---+---+---+---+        +---+
1586
1587         The least significant bit (LSB) is the bit with index "0", the most
1588         significant bit (MSB) is the bit with index ""$vector->Size()-1"".
1589
1590       • "$carry_out = $vector->shift_right($carry_in);"
1591
1592           carry         MSB           vector:           LSB         carry
1593            in:                                                       out:
1594           +---+        +---+---+---+---     ---+---+---+---+        +---+
1595           |   |  --->  |   |   |   |    ...    |   |   |   |  --->  |   |
1596           +---+        +---+---+---+---     ---+---+---+---+        +---+
1597
1598         The least significant bit (LSB) is the bit with index "0", the most
1599         significant bit (MSB) is the bit with index ""$vector->Size()-1"".
1600
1601       • "$vector->Move_Left($bits);"
1602
1603         Shifts the given bit vector left by "$bits" bits, i.e., inserts
1604         "$bits" new bits at the lower end (least significant bit) of the bit
1605         vector, moving all other bits up by "$bits" places, thereby losing
1606         the "$bits" most significant bits.
1607
1608         The inserted new bits are all cleared (set to the "off" state).
1609
1610         This method does nothing if "$bits" is equal to zero.
1611
1612         Beware that the whole bit vector is cleared WITHOUT WARNING if
1613         "$bits" is greater than or equal to the size of the given bit vector!
1614
1615         In fact this method is equivalent to
1616
1617           for ( $i = 0; $i < $bits; $i++ ) { $vector->shift_left(0); }
1618
1619         except that it is much more efficient (for "$bits" greater than or
1620         equal to the number of bits in a machine word on your system) than
1621         this straightforward approach.
1622
1623       • "$vector->Move_Right($bits);"
1624
1625         Shifts the given bit vector right by "$bits" bits, i.e., deletes the
1626         "$bits" least significant bits of the bit vector, moving all other
1627         bits down by "$bits" places, thereby creating "$bits" new bits at the
1628         upper end (most significant bit) of the bit vector.
1629
1630         These new bits are all cleared (set to the "off" state).
1631
1632         This method does nothing if "$bits" is equal to zero.
1633
1634         Beware that the whole bit vector is cleared WITHOUT WARNING if
1635         "$bits" is greater than or equal to the size of the given bit vector!
1636
1637         In fact this method is equivalent to
1638
1639           for ( $i = 0; $i < $bits; $i++ ) { $vector->shift_right(0); }
1640
1641         except that it is much more efficient (for "$bits" greater than or
1642         equal to the number of bits in a machine word on your system) than
1643         this straightforward approach.
1644
1645       • "$vector->Insert($offset,$bits);"
1646
1647         This method inserts "$bits" fresh new bits at position "$offset" in
1648         the given bit vector.
1649
1650         The "$bits" most significant bits are lost, and all bits starting
1651         with bit number "$offset" up to and including bit number
1652         ""$vector->Size()-$bits-1"" are moved up by "$bits" places.
1653
1654         The now vacant "$bits" bits starting at bit number "$offset" (up to
1655         and including bit number ""$offset+$bits-1"") are then set to zero
1656         (cleared).
1657
1658         Note that this method does NOT increase the size of the given bit
1659         vector, i.e., the bit vector is NOT extended at its upper end to
1660         "rescue" the "$bits" uppermost (most significant) bits - instead,
1661         these bits are lost forever.
1662
1663         If you don't want this to happen, you have to increase the size of
1664         the given bit vector EXPLICITLY and BEFORE you perform the "Insert"
1665         operation, with a statement such as the following:
1666
1667           $vector->Resize($vector->Size() + $bits);
1668
1669         Or use the method ""Interval_Substitute()"" instead of ""Insert()"",
1670         which performs automatic growing and shrinking of its target bit
1671         vector.
1672
1673         Note also that "$offset" must lie in the permitted range between "0"
1674         and ""$vector->Size()-1"", or a fatal "offset out of range" error
1675         will occur.
1676
1677         If the term ""$offset + $bits"" exceeds ""$vector->Size()-1"", all
1678         the bits starting with bit number "$offset" up to bit number
1679         ""$vector->Size()-1"" are simply cleared.
1680
1681       • "$vector->Delete($offset,$bits);"
1682
1683         This method deletes, i.e., removes the bits starting at position
1684         "$offset" up to and including bit number ""$offset+$bits-1"" from the
1685         given bit vector.
1686
1687         The remaining uppermost bits (starting at position ""$offset+$bits""
1688         up to and including bit number ""$vector->Size()-1"") are moved down
1689         by "$bits" places.
1690
1691         The now vacant uppermost (most significant) "$bits" bits are then set
1692         to zero (cleared).
1693
1694         Note that this method does NOT decrease the size of the given bit
1695         vector, i.e., the bit vector is NOT clipped at its upper end to "get
1696         rid of" the vacant "$bits" uppermost bits.
1697
1698         If you don't want this, i.e., if you want the bit vector to shrink
1699         accordingly, you have to do so EXPLICITLY and AFTER the "Delete"
1700         operation, with a couple of statements such as these:
1701
1702           $size = $vector->Size();
1703           if ($bits > $size) { $bits = $size; }
1704           $vector->Resize($size - $bits);
1705
1706         Or use the method ""Interval_Substitute()"" instead of ""Delete()"",
1707         which performs automatic growing and shrinking of its target bit
1708         vector.
1709
1710         Note also that "$offset" must lie in the permitted range between "0"
1711         and ""$vector->Size()-1"", or a fatal "offset out of range" error
1712         will occur.
1713
1714         If the term ""$offset + $bits"" exceeds ""$vector->Size()-1"", all
1715         the bits starting with bit number "$offset" up to bit number
1716         ""$vector->Size()-1"" are simply cleared.
1717
1718       • "$carry = $vector->increment();"
1719
1720         This method increments the given bit vector.
1721
1722         Note that this method regards bit vectors as being unsigned, i.e.,
1723         the largest possible positive number is directly followed by the
1724         smallest possible (or greatest possible, speaking in absolute terms)
1725         negative number:
1726
1727           before:  2 ^ (b-1) - 1    (= "0111...1111")
1728           after:   2 ^ (b-1)        (= "1000...0000")
1729
1730         where ""b"" is the number of bits of the given bit vector.
1731
1732         The method returns "false" ("0") in all cases except when a carry
1733         over occurs (in which case it returns "true", i.e., "1"), which
1734         happens when the number "1111...1111" is incremented, which gives
1735         "0000...0000" plus a carry over to the next higher (binary) digit.
1736
1737         This can be used for the terminating condition of a "while" loop, for
1738         instance, in order to cycle through all possible values the bit
1739         vector can assume.
1740
1741       • "$carry = $vector->decrement();"
1742
1743         This method decrements the given bit vector.
1744
1745         Note that this method regards bit vectors as being unsigned, i.e.,
1746         the smallest possible (or greatest possible, speaking in absolute
1747         terms) negative number is directly followed by the largest possible
1748         positive number:
1749
1750           before:  2 ^ (b-1)        (= "1000...0000")
1751           after:   2 ^ (b-1) - 1    (= "0111...1111")
1752
1753         where ""b"" is the number of bits of the given bit vector.
1754
1755         The method returns "false" ("0") in all cases except when a carry
1756         over occurs (in which case it returns "true", i.e., "1"), which
1757         happens when the number "0000...0000" is decremented, which gives
1758         "1111...1111" minus a carry over to the next higher (binary) digit.
1759
1760         This can be used for the terminating condition of a "while" loop, for
1761         instance, in order to cycle through all possible values the bit
1762         vector can assume.
1763
1764       • "$overflow = $vec2->inc($vec1);"
1765
1766         This method copies the contents of bit vector "$vec1" to bit vector
1767         "$vec2" and increments the copy (not the original).
1768
1769         If by incrementing the number its sign becomes invalid, the return
1770         value ("overflow" flag) will be true ("1"), or false ("0") if not.
1771         (See the description of the method "add()" below for a more in-depth
1772         explanation of what "overflow" means).
1773
1774         Note that in-place operation is also possible, i.e., "$vec1" and
1775         "$vec2" may be identical.
1776
1777       • "$overflow = $vec2->dec($vec1);"
1778
1779         This method copies the contents of bit vector "$vec1" to bit vector
1780         "$vec2" and decrements the copy (not the original).
1781
1782         If by decrementing the number its sign becomes invalid, the return
1783         value ("overflow" flag) will be true ("1"), or false ("0") if not.
1784         (See the description of the method "subtract()" below for a more in-
1785         depth explanation of what "overflow" means).
1786
1787         Note that in-place operation is also possible, i.e., "$vec1" and
1788         "$vec2" may be identical.
1789
1790       • "$carry = $vec3->add($vec1,$vec2,$carry);"
1791
1792         "($carry,$overflow) = $vec3->add($vec1,$vec2,$carry);"
1793
1794         This method adds the two numbers contained in bit vector "$vec1" and
1795         "$vec2" with carry "$carry" and stores the result in bit vector
1796         "$vec3".
1797
1798         I.e.,
1799                     $vec3 = $vec1 + $vec2 + $carry
1800
1801         Note that the "$carry" parameter is a boolean value, i.e., only its
1802         least significant bit is taken into account. (Think of it as though
1803         ""$carry &= 1;"" was always executed internally.)
1804
1805         In scalar context, the method returns a boolean value which indicates
1806         if a carry over (to the next higher bit position) has occured. In
1807         list context, the method returns the carry and the overflow flag (in
1808         this order).
1809
1810         The overflow flag is true ("1") if the sign (i.e., the most
1811         significant bit) of the result is wrong. This can happen when adding
1812         two very large positive numbers or when adding two (by their absolute
1813         value) very large negative numbers. See also further below.
1814
1815         The carry in- and output is needed mainly for cascading, i.e., to add
1816         numbers that are fragmented into several pieces.
1817
1818         Example:
1819
1820           # initialize
1821
1822           for ( $i = 0; $i < $n; $i++ )
1823           {
1824               $a[$i] = Bit::Vector->new($bits);
1825               $b[$i] = Bit::Vector->new($bits);
1826               $c[$i] = Bit::Vector->new($bits);
1827           }
1828
1829           # fill @a and @b
1830
1831           # $a[  0 ] is low order part,
1832           # $a[$n-1] is high order part,
1833           # and same for @b
1834
1835           # add
1836
1837           $carry = 0;
1838           for ( $i = 0; $i < $n; $i++ )
1839           {
1840               $carry = $c[$i]->add($a[$i],$b[$i],$carry);
1841           }
1842
1843         Note that it makes no difference to this method whether the numbers
1844         in "$vec1" and "$vec2" are unsigned or signed (i.e., in two's
1845         complement binary representation).
1846
1847         Note however that the return value (carry flag) is not meaningful
1848         when the numbers are SIGNED.
1849
1850         Moreover, when the numbers are signed, a special type of error can
1851         occur which is commonly called an "overflow error".
1852
1853         An overflow error occurs when the sign of the result (its most
1854         significant bit) is flipped (i.e., falsified) by a carry over from
1855         the next-lower bit position ("MSB-1").
1856
1857         In fact matters are a bit more complicated than that: the overflow
1858         flag is set to "true" whenever there is a carry over from bit
1859         position MSB-1 to the most significant bit (MSB) but no carry over
1860         from the MSB to the output carry flag, or vice-versa, i.e., when
1861         there is no carry over from bit position MSB-1 to the most
1862         significant bit (MSB) but a carry over to the output carry flag.
1863
1864         Thus the overflow flag is the result of an exclusive-or operation
1865         between incoming and outgoing carry over at the most significant bit
1866         position.
1867
1868       • "$carry = $vec3->subtract($vec1,$vec2,$carry);"
1869
1870         "($carry,$overflow) = $vec3->subtract($vec1,$vec2,$carry);"
1871
1872         This method subtracts the two numbers contained in bit vector "$vec1"
1873         and "$vec2" with carry "$carry" and stores the result in bit vector
1874         "$vec3".
1875
1876         I.e.,
1877                     $vec3 = $vec1 - $vec2 - $carry
1878
1879         Note that the "$carry" parameter is a boolean value, i.e., only its
1880         least significant bit is taken into account. (Think of it as though
1881         ""$carry &= 1;"" was always executed internally.)
1882
1883         In scalar context, the method returns a boolean value which indicates
1884         if a carry over (to the next higher bit position) has occured. In
1885         list context, the method returns the carry and the overflow flag (in
1886         this order).
1887
1888         The overflow flag is true ("1") if the sign (i.e., the most
1889         significant bit) of the result is wrong. This can happen when
1890         subtracting a very large negative number from a very large positive
1891         number or vice-versa. See also further below.
1892
1893         The carry in- and output is needed mainly for cascading, i.e., to
1894         subtract numbers that are fragmented into several pieces.
1895
1896         Example:
1897
1898           # initialize
1899
1900           for ( $i = 0; $i < $n; $i++ )
1901           {
1902               $a[$i] = Bit::Vector->new($bits);
1903               $b[$i] = Bit::Vector->new($bits);
1904               $c[$i] = Bit::Vector->new($bits);
1905           }
1906
1907           # fill @a and @b
1908
1909           # $a[  0 ] is low order part,
1910           # $a[$n-1] is high order part,
1911           # and same for @b
1912
1913           # subtract
1914
1915           $carry = 0;
1916           for ( $i = 0; $i < $n; $i++ )
1917           {
1918               $carry = $c[$i]->subtract($a[$i],$b[$i],$carry);
1919           }
1920
1921         Note that it makes no difference to this method whether the numbers
1922         in "$vec1" and "$vec2" are unsigned or signed (i.e., in two's
1923         complement binary representation).
1924
1925         Note however that the return value (carry flag) is not meaningful
1926         when the numbers are SIGNED.
1927
1928         Moreover, when the numbers are signed, a special type of error can
1929         occur which is commonly called an "overflow error".
1930
1931         An overflow error occurs when the sign of the result (its most
1932         significant bit) is flipped (i.e., falsified) by a carry over from
1933         the next-lower bit position ("MSB-1").
1934
1935         In fact matters are a bit more complicated than that: the overflow
1936         flag is set to "true" whenever there is a carry over from bit
1937         position MSB-1 to the most significant bit (MSB) but no carry over
1938         from the MSB to the output carry flag, or vice-versa, i.e., when
1939         there is no carry over from bit position MSB-1 to the most
1940         significant bit (MSB) but a carry over to the output carry flag.
1941
1942         Thus the overflow flag is the result of an exclusive-or operation
1943         between incoming and outgoing carry over at the most significant bit
1944         position.
1945
1946       • "$vec2->Neg($vec1);"
1947
1948         "$vec2->Negate($vec1);"
1949
1950         This method calculates the two's complement of the number in bit
1951         vector "$vec1" and stores the result in bit vector "$vec2".
1952
1953         Calculating the two's complement of a given number in binary
1954         representation consists of inverting all bits and incrementing the
1955         result by one.
1956
1957         This is the same as changing the sign of the given number from ""+""
1958         to ""-"" or vice-versa. In other words, applying this method twice on
1959         a given number yields the original number again.
1960
1961         Note that in-place processing is also possible, i.e., "$vec1" and
1962         "$vec2" may be identical.
1963
1964         Most importantly, beware that this method produces a counter-
1965         intuitive result if the number contained in bit vector "$vec1" is "2
1966         ^ (n-1)" (i.e., "1000...0000"), where ""n"" is the number of bits the
1967         given bit vector contains: The negated value of this number is the
1968         number itself!
1969
1970       • "$vec2->Abs($vec1);"
1971
1972         "$vec2->Absolute($vec1);"
1973
1974         Depending on the sign (i.e., the most significant bit) of the number
1975         in bit vector "$vec1", the contents of bit vector "$vec1" are copied
1976         to bit vector "$vec2" either with the method ""Copy()"" (if the
1977         number in bit vector "$vec1" is positive), or with ""Negate()"" (if
1978         the number in bit vector "$vec1" is negative).
1979
1980         In other words, this method calculates the absolute value of the
1981         number in bit vector "$vec1" and stores the result in bit vector
1982         "$vec2".
1983
1984         Note that in-place processing is also possible, i.e., "$vec1" and
1985         "$vec2" may be identical.
1986
1987         Most importantly, beware that this method produces a counter-
1988         intuitive result if the number contained in bit vector "$vec1" is "2
1989         ^ (n-1)" (i.e., "1000...0000"), where ""n"" is the number of bits the
1990         given bit vector contains: The absolute value of this number is the
1991         number itself, even though this number is still negative by
1992         definition (the most significant bit is still set)!
1993
1994       • "$sign = $vector->Sign();"
1995
1996         This method returns "0" if all bits in the given bit vector are
1997         cleared, i.e., if the given bit vector contains the number "0", or if
1998         the given bit vector has a length of zero (contains no bits at all).
1999
2000         If not all bits are cleared, this method returns ""-1"" if the most
2001         significant bit is set (i.e., if the bit vector contains a negative
2002         number), or "1" otherwise (i.e., if the bit vector contains a
2003         positive number).
2004
2005       • "$vec3->Multiply($vec1,$vec2);"
2006
2007         This method multiplies the two numbers contained in bit vector
2008         "$vec1" and "$vec2" and stores the result in bit vector "$vec3".
2009
2010         Note that this method regards its arguments as SIGNED.
2011
2012         If you want to make sure that a large number can never be treated as
2013         being negative by mistake, make your bit vectors at least one bit
2014         longer than the largest number you wish to represent, right from the
2015         start, or proceed as follows:
2016
2017             $msb1 = $vec1->msb();
2018             $msb2 = $vec2->msb();
2019             $vec1->Resize($vec1->Size()+1);
2020             $vec2->Resize($vec2->Size()+1);
2021             $vec3->Resize($vec3->Size()+1);
2022             $vec1->MSB($msb1);
2023             $vec2->MSB($msb2);
2024             $vec3->Multiply($vec1,$vec2);
2025
2026         Note also that all three bit vector arguments must in principle obey
2027         the rule of matching sizes, but that the bit vector "$vec3" may be
2028         larger than the two factors "$vec1" and "$vec2".
2029
2030         In fact multiplying two binary numbers with ""n"" bits may yield a
2031         result which is at most ""2n"" bits long.
2032
2033         Therefore, it is usually a good idea to let bit vector "$vec3" have
2034         twice the size of bit vector "$vec1" and "$vec2", unless you are
2035         absolutely sure that the result will fit into a bit vector of the
2036         same size as the two factors.
2037
2038         If you are wrong, a fatal "numeric overflow error" will occur.
2039
2040         Finally, note that in-place processing is possible, i.e., "$vec3" may
2041         be identical with "$vec1" or "$vec2", or both.
2042
2043       • "$quot->Divide($vec1,$vec2,$rest);"
2044
2045         This method divides the two numbers contained in bit vector "$vec1"
2046         and "$vec2" and stores the quotient in bit vector "$quot" and the
2047         remainder in bit vector "$rest".
2048
2049         I.e.,
2050                     $quot = $vec1 / $vec2;  #  div
2051                     $rest = $vec1 % $vec2;  #  mod
2052
2053         Therefore, "$quot" and "$rest" must be two DISTINCT bit vectors, or a
2054         fatal "result vector(s) must be distinct" error will occur.
2055
2056         Note also that a fatal "division by zero error" will occur if "$vec2"
2057         is equal to zero.
2058
2059         Note further that this method regards its arguments as SIGNED.
2060
2061         If you want to make sure that a large number can never be treated as
2062         being negative by mistake, make your bit vectors at least one bit
2063         longer than the largest number you wish to represent, right from the
2064         start, or proceed as follows:
2065
2066             $msb1 = $vec1->msb();
2067             $msb2 = $vec2->msb();
2068             $vec1->Resize($vec1->Size()+1);
2069             $vec2->Resize($vec2->Size()+1);
2070             $quot->Resize($quot->Size()+1);
2071             $rest->Resize($rest->Size()+1);
2072             $vec1->MSB($msb1);
2073             $vec2->MSB($msb2);
2074             $quot->Divide($vec1,$vec2,$rest);
2075
2076         Finally, note that in-place processing is possible, i.e., "$quot" may
2077         be identical with "$vec1" or "$vec2" or both, and "$rest" may also be
2078         identical with "$vec1" or "$vec2" or both, as long as "$quot" and
2079         "$rest" are distinct. (!)
2080
2081       • "$vecgcd->GCD($veca,$vecb);"
2082
2083         This method calculates the "Greatest Common Divisor" of the two
2084         numbers contained in bit vector "$veca" and "$vecb" and stores the
2085         result in bit vector "$vecgcd".
2086
2087         The method uses Euklid's algorithm internally:
2088
2089             int GCD(int a, int b)
2090             {
2091                 int t;
2092
2093                 while (b != 0)
2094                 {
2095                     t = a % b; /* = remainder of (a div b) */
2096                     a = b;
2097                     b = t;
2098                 }
2099                 return(a);
2100             }
2101
2102         Note that "GCD(z,0) == GCD(0,z) == z".
2103
2104       • "$vecgcd->GCD($vecx,$vecy,$veca,$vecb);"
2105
2106         This variant of the "GCD" method calculates the "Greatest Common
2107         Divisor" of the two numbers contained in bit vector "$veca" and
2108         "$vecb" and stores the result in bit vector "$vecgcd".
2109
2110         Moreover, it determines the two factors which are necessary in order
2111         to represent the greatest common divisor as a linear combination of
2112         its two arguments, i.e., the two factors "x" and "y" so that
2113         "GCD(a,b) == x * a + y * b", and stores them in bit vector "$vecx"
2114         and "$vecy", respectively.
2115
2116         For example:
2117
2118           a = 2322
2119           b =  654
2120
2121           GCD( 2322, 654 ) == 6
2122
2123           x =  20
2124           y = -71
2125
2126           20 * 2322 - 71 * 654 == 6
2127
2128         Please see http://www.cut-the-knot.org/blue/extension.shtml for an
2129         explanation of how this extension of Euklid's algorithm works.
2130
2131       • "$vec3->Power($vec1,$vec2);"
2132
2133         This method calculates the exponentiation of base "$vec1" elevated to
2134         the "$vec2" power, i.e., ""$vec1 ** $vec2"", and stores the result in
2135         bit vector "$vec3".
2136
2137         The method uses an efficient divide-and-conquer algorithm:
2138
2139         Suppose the exponent is (decimal) 13, for example. The binary
2140         representation of this exponent is "1101".
2141
2142         This means we want to calculate
2143
2144           $vec1 * $vec1 * $vec1 * $vec1 * $vec1 * $vec1 * $vec1 * $vec1 *
2145           $vec1 * $vec1 * $vec1 * $vec1 *
2146           $vec1
2147
2148         That is, "$vec1" multiplied with itself 13 times. The grouping into
2149         lines above is no coincidence. The first line comprises 8 factors,
2150         the second contains 4, and the last line just one. This just happens
2151         to be the binary representation of 13. ";-)"
2152
2153         We then calculate a series of squares (of squares of squares...) of
2154         the base, i.e.,
2155
2156           $power[0] = $vec1;
2157           $power[1] = $vec1 * $vec1;
2158           $power[2] = $power[1] * $power[1];
2159           $power[3] = $power[2] * $power[2];
2160           etc.
2161
2162         To calculate the power of our example, we simply initialize our
2163         result with 1 and consecutively multiply it with the items of the
2164         series of powers we just calculated, if the corresponding bit of the
2165         binary representation of the exponent is set:
2166
2167           $result = 1;
2168           $result *= $power[0] if ($vec2 & 1);
2169           $result *= $power[1] if ($vec2 & 2);
2170           $result *= $power[2] if ($vec2 & 4);
2171           $result *= $power[3] if ($vec2 & 8);
2172           etc.
2173
2174         The bit vector "$vec3" must be of the same size as the base "$vec1"
2175         or greater. "$vec3" and "$vec1" may be the same vector (i.e., in-
2176         place calculation as in ""$vec1 **= $vec2;"" is possible), but
2177         "$vec3" and "$vec2" must be distinct. Finally, the exponent "$vec2"
2178         must be positive. A fatal error occurs if any of these conditions is
2179         not met.
2180
2181       • "$vector->Block_Store($buffer);"
2182
2183         This method allows you to load the contents of a given bit vector in
2184         one go.
2185
2186         This is useful when you store the contents of a bit vector in a file,
2187         for instance (using method ""Block_Read()""), and when you want to
2188         restore the previously saved bit vector.
2189
2190         For this, "$buffer" MUST be a string (NO automatic conversion from
2191         numeric to string is provided here as would normally in Perl!)
2192         containing the bit vector in "low order byte first" order.
2193
2194         If the given string is shorter than what is needed to completely fill
2195         the given bit vector, the remaining (most significant) bytes of the
2196         bit vector are filled with zeros, i.e., the previous contents of the
2197         bit vector are always erased completely.
2198
2199         If the given string is longer than what is needed to completely fill
2200         the given bit vector, the superfluous bytes are simply ignored.
2201
2202         See "sysread" in perlfunc for how to read in the contents of
2203         "$buffer" from a file prior to passing it to this method.
2204
2205       • "$buffer = $vector->Block_Read();"
2206
2207         This method allows you to export the contents of a given bit vector
2208         in one block.
2209
2210         This is useful when you want to save the contents of a bit vector for
2211         later, for instance in a file.
2212
2213         The advantage of this method is that it allows you to do so in the
2214         compactest possible format, in binary.
2215
2216         The method returns a Perl string which contains an exact copy of the
2217         contents of the given bit vector in "low order byte first" order.
2218
2219         See "syswrite" in perlfunc for how to write the data from this string
2220         to a file.
2221
2222       • "$size = $vector->Word_Size();"
2223
2224         Each bit vector is internally organized as an array of machine words.
2225
2226         The methods whose names begin with "Word_" allow you to access this
2227         internal array of machine words.
2228
2229         Note that because the size of a machine word may vary from system to
2230         system, these methods are inherently MACHINE-DEPENDENT!
2231
2232         Therefore, DO NOT USE these methods unless you are absolutely certain
2233         that portability of your code is not an issue!
2234
2235         You have been warned!
2236
2237         To be machine-independent, use the methods whose names begin with
2238         ""Chunk_"" instead, with chunk sizes no greater than 32 bits.
2239
2240         The method ""Word_Size()"" returns the number of machine words that
2241         the internal array of words of the given bit vector contains.
2242
2243         This is similar in function to the term ""scalar(@array)"" for a Perl
2244         array.
2245
2246       • "$vector->Word_Store($offset,$word);"
2247
2248         This method allows you to store a given value "$word" at a given
2249         position "$offset" in the internal array of words of the given bit
2250         vector.
2251
2252         Note that "$offset" must lie in the permitted range between "0" and
2253         ""$vector->Word_Size()-1"", or a fatal "offset out of range" error
2254         will occur.
2255
2256         This method is similar in function to the expression
2257         ""$array[$offset] = $word;"" for a Perl array.
2258
2259       • "$word = $vector->Word_Read($offset);"
2260
2261         This method allows you to access the value of a given machine word at
2262         position "$offset" in the internal array of words of the given bit
2263         vector.
2264
2265         Note that "$offset" must lie in the permitted range between "0" and
2266         ""$vector->Word_Size()-1"", or a fatal "offset out of range" error
2267         will occur.
2268
2269         This method is similar in function to the expression ""$word =
2270         $array[$offset];"" for a Perl array.
2271
2272       • "$vector->Word_List_Store(@words);"
2273
2274         This method allows you to store a list of values "@words" in the
2275         internal array of machine words of the given bit vector.
2276
2277         Thereby the LEFTMOST value in the list ("$words[0]") is stored in the
2278         LEAST significant word of the internal array of words (the one with
2279         offset "0"), the next value from the list ("$words[1]") is stored in
2280         the word with offset "1", and so on, as intuitively expected.
2281
2282         If the list "@words" contains fewer elements than the internal array
2283         of words of the given bit vector contains machine words, the
2284         remaining (most significant) words are filled with zeros.
2285
2286         If the list "@words" contains more elements than the internal array
2287         of words of the given bit vector contains machine words, the
2288         superfluous values are simply ignored.
2289
2290         This method is comparable in function to the expression ""@array =
2291         @words;"" for a Perl array.
2292
2293       • "@words = $vector->Word_List_Read();"
2294
2295         This method allows you to retrieve the internal array of machine
2296         words of the given bit vector all at once.
2297
2298         Thereby the LEFTMOST value in the returned list ("$words[0]") is the
2299         LEAST significant word from the given bit vector, and the RIGHTMOST
2300         value in the returned list ("$words[$#words]") is the MOST
2301         significant word of the given bit vector.
2302
2303         This method is similar in function to the expression ""@words =
2304         @array;"" for a Perl array.
2305
2306       • "$vector->Word_Insert($offset,$count);"
2307
2308         This method inserts "$count" empty new machine words at position
2309         "$offset" in the internal array of words of the given bit vector.
2310
2311         The "$count" most significant words are lost, and all words starting
2312         with word number "$offset" up to and including word number
2313         ""$vector->Word_Size()-$count-1"" are moved up by "$count" places.
2314
2315         The now vacant "$count" words starting at word number "$offset" (up
2316         to and including word number ""$offset+$count-1"") are then set to
2317         zero (cleared).
2318
2319         Note that this method does NOT increase the size of the given bit
2320         vector, i.e., the bit vector is NOT extended at its upper end to
2321         "rescue" the "$count" uppermost (most significant) words - instead,
2322         these words are lost forever.
2323
2324         If you don't want this to happen, you have to increase the size of
2325         the given bit vector EXPLICITLY and BEFORE you perform the "Insert"
2326         operation, with a statement such as the following:
2327
2328           $vector->Resize($vector->Size() + $count * Bit::Vector->Word_Bits());
2329
2330         Note also that "$offset" must lie in the permitted range between "0"
2331         and ""$vector->Word_Size()-1"", or a fatal "offset out of range"
2332         error will occur.
2333
2334         If the term ""$offset + $count"" exceeds ""$vector->Word_Size()-1"",
2335         all the words starting with word number "$offset" up to word number
2336         ""$vector->Word_Size()-1"" are simply cleared.
2337
2338       • "$vector->Word_Delete($offset,$count);"
2339
2340         This method deletes, i.e., removes the words starting at position
2341         "$offset" up to and including word number ""$offset+$count-1"" from
2342         the internal array of machine words of the given bit vector.
2343
2344         The remaining uppermost words (starting at position
2345         ""$offset+$count"" up to and including word number
2346         ""$vector->Word_Size()-1"") are moved down by "$count" places.
2347
2348         The now vacant uppermost (most significant) "$count" words are then
2349         set to zero (cleared).
2350
2351         Note that this method does NOT decrease the size of the given bit
2352         vector, i.e., the bit vector is NOT clipped at its upper end to "get
2353         rid of" the vacant "$count" uppermost words.
2354
2355         If you don't want this, i.e., if you want the bit vector to shrink
2356         accordingly, you have to do so EXPLICITLY and AFTER the "Delete"
2357         operation, with a couple of statements such as these:
2358
2359           $bits = $vector->Size();
2360           $count *= Bit::Vector->Word_Bits();
2361           if ($count > $bits) { $count = $bits; }
2362           $vector->Resize($bits - $count);
2363
2364         Note also that "$offset" must lie in the permitted range between "0"
2365         and ""$vector->Word_Size()-1"", or a fatal "offset out of range"
2366         error will occur.
2367
2368         If the term ""$offset + $count"" exceeds ""$vector->Word_Size()-1"",
2369         all the words starting with word number "$offset" up to word number
2370         ""$vector->Word_Size()-1"" are simply cleared.
2371
2372       • "$vector->Chunk_Store($chunksize,$offset,$chunk);"
2373
2374         This method allows you to set more than one bit at a time with
2375         different values.
2376
2377         You can access chunks (i.e., ranges of contiguous bits) between one
2378         and at most ""Bit::Vector->Long_Bits()"" bits wide.
2379
2380         In order to be portable, though, you should never use chunk sizes
2381         larger than 32 bits.
2382
2383         If the given "$chunksize" does not lie between "1" and
2384         ""Bit::Vector->Long_Bits()"", a fatal "chunk size out of range" error
2385         will occur.
2386
2387         The method copies the "$chunksize" least significant bits from the
2388         value "$chunk" to the given bit vector, starting at bit position
2389         "$offset" and proceeding upwards until bit number
2390         ""$offset+$chunksize-1"".
2391
2392         (I.e., bit number "0" of "$chunk" becomes bit number "$offset" in the
2393         given bit vector, and bit number ""$chunksize-1"" becomes bit number
2394         ""$offset+$chunksize-1"".)
2395
2396         If the term ""$offset+$chunksize-1"" exceeds ""$vector->Size()-1"",
2397         the corresponding superfluous (most significant) bits from "$chunk"
2398         are simply ignored.
2399
2400         Note that "$offset" itself must lie in the permitted range between
2401         "0" and ""$vector->Size()-1"", or a fatal "offset out of range" error
2402         will occur.
2403
2404         This method (as well as the other ""Chunk_"" methods) is useful, for
2405         example, when you are reading in data in chunks of, say, 8 bits,
2406         which you need to access later, say, using 16 bits at a time (like
2407         audio CD wave files, for instance).
2408
2409       • "$chunk = $vector->Chunk_Read($chunksize,$offset);"
2410
2411         This method allows you to read the values of more than one bit at a
2412         time.
2413
2414         You can read chunks (i.e., ranges of contiguous bits) between one and
2415         at most ""Bit::Vector->Long_Bits()"" bits wide.
2416
2417         In order to be portable, though, you should never use chunk sizes
2418         larger than 32 bits.
2419
2420         If the given "$chunksize" does not lie between "1" and
2421         ""Bit::Vector->Long_Bits()"", a fatal "chunk size out of range" error
2422         will occur.
2423
2424         The method returns the "$chunksize" bits from the given bit vector
2425         starting at bit position "$offset" and proceeding upwards until bit
2426         number ""$offset+$chunksize-1"".
2427
2428         (I.e., bit number "$offset" of the given bit vector becomes bit
2429         number "0" of the returned value, and bit number
2430         ""$offset+$chunksize-1"" becomes bit number ""$chunksize-1"".)
2431
2432         If the term ""$offset+$chunksize-1"" exceeds ""$vector->Size()-1"",
2433         the non-existent bits are simply not returned.
2434
2435         Note that "$offset" itself must lie in the permitted range between
2436         "0" and ""$vector->Size()-1"", or a fatal "offset out of range" error
2437         will occur.
2438
2439       • "$vector->Chunk_List_Store($chunksize,@chunks);"
2440
2441         This method allows you to fill the given bit vector with a list of
2442         data packets ("chunks") of any size ("$chunksize") you like (within
2443         certain limits).
2444
2445         In fact the given "$chunksize" must lie in the range between "1" and
2446         ""Bit::Vector->Long_Bits()"", or a fatal "chunk size out of range"
2447         error will occur.
2448
2449         In order to be portable, though, you should never use chunk sizes
2450         larger than 32 bits.
2451
2452         The given bit vector is thereby filled in ascending order: The first
2453         chunk from the list (i.e., "$chunks[0]") fills the "$chunksize" least
2454         significant bits, the next chunk from the list ("$chunks[1]") fills
2455         the bits number "$chunksize" to number ""2*$chunksize-1"", the third
2456         chunk ("$chunks[2]") fills the bits number ""2*$chunksize"", to
2457         number ""3*$chunksize-1"", and so on.
2458
2459         If there a less chunks in the list than are needed to fill the entire
2460         bit vector, the remaining (most significant) bits are cleared, i.e.,
2461         the previous contents of the given bit vector are always erased
2462         completely.
2463
2464         If there are more chunks in the list than are needed to fill the
2465         entire bit vector, and/or if a chunk extends beyond
2466         ""$vector->Size()-1"" (which happens whenever ""$vector->Size()"" is
2467         not a multiple of "$chunksize"), the superfluous chunks and/or bits
2468         are simply ignored.
2469
2470         The method is useful, for example (and among many other
2471         applications), for the conversion of packet sizes in a data stream.
2472
2473         This method can also be used to store an octal string in a given bit
2474         vector:
2475
2476           $vector->Chunk_List_Store(3, split(//, reverse $string));
2477
2478         Note however that unlike the conversion methods ""from_Hex()"",
2479         ""from_Bin()"", ""from_Dec()"" and ""from_Enum()"", this statement
2480         does not include any syntax checking, i.e., it may fail silently,
2481         without warning.
2482
2483         To perform syntax checking, add the following statements:
2484
2485           if ($string =~ /^[0-7]+$/)
2486           {
2487               # okay, go ahead with conversion as shown above
2488           }
2489           else
2490           {
2491               # error, string contains other than octal characters
2492           }
2493
2494         Another application is to store a repetitive pattern in a given bit
2495         vector:
2496
2497           $pattern = 0xDEADBEEF;
2498           $length = 32;            # = length of $pattern in bits
2499           $size = $vector->Size();
2500           $factor = int($size / $length);
2501           if ($size % $length) { $factor++; }
2502           $vector->Chunk_List_Store($length, ($pattern) x $factor);
2503
2504       • "@chunks = $vector->Chunk_List_Read($chunksize);"
2505
2506         This method allows you to access the contents of the given bit vector
2507         in form of a list of data packets ("chunks") of a size ("$chunksize")
2508         of your choosing (within certain limits).
2509
2510         In fact the given "$chunksize" must lie in the range between "1" and
2511         ""Bit::Vector->Long_Bits()"", or a fatal "chunk size out of range"
2512         error will occur.
2513
2514         In order to be portable, though, you should never use chunk sizes
2515         larger than 32 bits.
2516
2517         The given bit vector is thereby read in ascending order: The
2518         "$chunksize" least significant bits (bits number "0" to
2519         ""$chunksize-1"") become the first chunk in the returned list (i.e.,
2520         "$chunks[0]"). The bits number "$chunksize" to ""2*$chunksize-1""
2521         become the next chunk in the list ("$chunks[1]"), and so on.
2522
2523         If ""$vector->Size()"" is not a multiple of "$chunksize", the last
2524         chunk in the list will contain fewer bits than "$chunksize".
2525
2526         BEWARE that for large bit vectors and/or small values of
2527         "$chunksize", the number of returned list elements can be extremely
2528         large! BE CAREFUL!
2529
2530         You could blow up your application with lack of memory (each list
2531         element is a full-grown Perl scalar, internally, with an associated
2532         memory overhead for its administration!) or at least cause a
2533         noticeable, more or less long-lasting "freeze" of your application!
2534
2535         Possible applications:
2536
2537         The method is especially useful in the conversion of packet sizes in
2538         a data stream.
2539
2540         This method can also be used to convert a given bit vector to a
2541         string of octal numbers:
2542
2543           $string = reverse join('', $vector->Chunk_List_Read(3));
2544
2545       • "$vector->Index_List_Remove(@indices);"
2546
2547         This method allows you to specify a list of indices of bits which
2548         should be turned off in the given bit vector.
2549
2550         In fact this method is a shortcut for
2551
2552             foreach $index (@indices)
2553             {
2554                 $vector->Bit_Off($index);
2555             }
2556
2557         In contrast to all other import methods in this module, this method
2558         does NOT clear the given bit vector before processing its list of
2559         arguments.
2560
2561         Instead, this method allows you to accumulate the results of various
2562         consecutive calls.
2563
2564         (The same holds for the method ""Index_List_Store()"". As a
2565         consequence, you can "wipe out" what you did using the method
2566         ""Index_List_Remove()"" by passing the identical argument list to the
2567         method ""Index_List_Store()"".)
2568
2569       • "$vector->Index_List_Store(@indices);"
2570
2571         This method allows you to specify a list of indices of bits which
2572         should be turned on in the given bit vector.
2573
2574         In fact this method is a shortcut for
2575
2576             foreach $index (@indices)
2577             {
2578                 $vector->Bit_On($index);
2579             }
2580
2581         In contrast to all other import methods in this module, this method
2582         does NOT clear the given bit vector before processing its list of
2583         arguments.
2584
2585         Instead, this method allows you to accumulate the results of various
2586         consecutive calls.
2587
2588         (The same holds for the method ""Index_List_Remove()"". As a
2589         consequence, you can "wipe out" what you did using the method
2590         ""Index_List_Store()"" by passing the identical argument list to the
2591         method ""Index_List_Remove()"".)
2592
2593       • "@indices = $vector->Index_List_Read();"
2594
2595         This method returns a list of Perl scalars.
2596
2597         The list contains one scalar for each set bit in the given bit
2598         vector.
2599
2600         BEWARE that for large bit vectors, this can result in a literally
2601         overwhelming number of list elements! BE CAREFUL! You could run out
2602         of memory or slow down your application considerably!
2603
2604         Each scalar contains the number of the index corresponding to the bit
2605         in question.
2606
2607         These indices are always returned in ascending order.
2608
2609         If the given bit vector is empty (contains only cleared bits) or if
2610         it has a length of zero (if it contains no bits at all), the method
2611         returns an empty list.
2612
2613         This method can be useful, for instance, to obtain a list of prime
2614         numbers:
2615
2616             $limit = 1000; # or whatever
2617             $vector = Bit::Vector->new($limit+1);
2618             $vector->Primes();
2619             @primes = $vector->Index_List_Read();
2620
2621       • "$vec3->Or($vec1,$vec2);"
2622
2623         "$set3->Union($set1,$set2);"
2624
2625         This method calculates the union of "$set1" and "$set2" and stores
2626         the result in "$set3".
2627
2628         This is usually written as ""$set3 = $set1 u $set2"" in set theory
2629         (where "u" is the "cup" operator).
2630
2631         (On systems where the "cup" character is unavailable this operator is
2632         often denoted by a plus sign "+".)
2633
2634         In-place calculation is also possible, i.e., "$set3" may be identical
2635         with "$set1" or "$set2" or both.
2636
2637       • "$vec3->And($vec1,$vec2);"
2638
2639         "$set3->Intersection($set1,$set2);"
2640
2641         This method calculates the intersection of "$set1" and "$set2" and
2642         stores the result in "$set3".
2643
2644         This is usually written as ""$set3 = $set1 n $set2"" in set theory
2645         (where "n" is the "cap" operator).
2646
2647         (On systems where the "cap" character is unavailable this operator is
2648         often denoted by an asterisk "*".)
2649
2650         In-place calculation is also possible, i.e., "$set3" may be identical
2651         with "$set1" or "$set2" or both.
2652
2653       • "$vec3->AndNot($vec1,$vec2);"
2654
2655         "$set3->Difference($set1,$set2);"
2656
2657         This method calculates the difference of "$set1" less "$set2" and
2658         stores the result in "$set3".
2659
2660         This is usually written as ""$set3 = $set1 \ $set2"" in set theory
2661         (where "\" is the "less" operator).
2662
2663         In-place calculation is also possible, i.e., "$set3" may be identical
2664         with "$set1" or "$set2" or both.
2665
2666       • "$vec3->Xor($vec1,$vec2);"
2667
2668         "$set3->ExclusiveOr($set1,$set2);"
2669
2670         This method calculates the symmetric difference of "$set1" and
2671         "$set2" and stores the result in "$set3".
2672
2673         This can be written as ""$set3 = ($set1 u $set2) \ ($set1 n $set2)""
2674         in set theory (the union of the two sets less their intersection).
2675
2676         When sets are implemented as bit vectors then the above formula is
2677         equivalent to the exclusive-or between corresponding bits of the two
2678         bit vectors (hence the name of this method).
2679
2680         Note that this method is also much more efficient than evaluating the
2681         above formula explicitly since it uses a built-in machine language
2682         instruction internally.
2683
2684         In-place calculation is also possible, i.e., "$set3" may be identical
2685         with "$set1" or "$set2" or both.
2686
2687       • "$vec2->Not($vec1);"
2688
2689         "$set2->Complement($set1);"
2690
2691         This method calculates the complement of "$set1" and stores the
2692         result in "$set2".
2693
2694         In "big integer" arithmetic, this is equivalent to calculating the
2695         one's complement of the number stored in the bit vector "$set1" in
2696         binary representation.
2697
2698         In-place calculation is also possible, i.e., "$set2" may be identical
2699         with "$set1".
2700
2701       • "if ($set1->subset($set2))"
2702
2703         Returns "true" ("1") if "$set1" is a subset of "$set2" (i.e.,
2704         completely contained in "$set2") and "false" ("0") otherwise.
2705
2706         This means that any bit which is set ("1") in "$set1" must also be
2707         set in "$set2", but "$set2" may contain set bits which are not set in
2708         "$set1", in order for the condition of subset relationship to be true
2709         between these two sets.
2710
2711         Note that by definition, if two sets are identical, they are also
2712         subsets (and also supersets) of each other.
2713
2714       • "$norm = $set->Norm();"
2715
2716         Returns the norm (number of bits which are set) of the given vector.
2717
2718         This is equivalent to the number of elements contained in the given
2719         set.
2720
2721         Uses a byte lookup table for calculating the number of set bits per
2722         byte, and thus needs a time for evaluation (and a number of loops)
2723         linearly proportional to the length of the given bit vector (in
2724         bytes).
2725
2726         This should be the fastest algorithm on average.
2727
2728       • "$norm = $set->Norm2();"
2729
2730         Returns the norm (number of bits which are set) of the given vector.
2731
2732         This is equivalent to the number of elements contained in the given
2733         set.
2734
2735         This does the same as the method ""Norm()"" above, only with a
2736         different algorithm:
2737
2738         This method counts the number of set and cleared bits at the same
2739         time and will stop when either of them has been exhausted, thus
2740         needing at most half as many loops per machine word as the total
2741         number of bits in a machine word - in fact it will need a number of
2742         loops equal to the minimum of the number of set bits and the number
2743         of cleared bits.
2744
2745         This might be a faster algorithm than of the method ""Norm()"" above
2746         on some systems, depending on the system's architecture and the
2747         compiler and optimisation used, for bit vectors with sparse set bits
2748         and for bit vectors with sparse cleared bits (i.e., predominantly set
2749         bits).
2750
2751       • "$norm = $set->Norm3();"
2752
2753         Returns the norm (number of bits which are set) of the given vector.
2754
2755         This is equivalent to the number of elements contained in the given
2756         set.
2757
2758         This does the same as the two methods ""Norm()"" and ""Norm2()""
2759         above, however with a different algorithm.
2760
2761         In fact this is the implementation of the method ""Norm()"" used in
2762         previous versions of this module.
2763
2764         The method needs a number of loops per machine word equal to the
2765         number of set bits in that machine word.
2766
2767         Only for bit vectors with sparse set bits will this method be fast;
2768         it will depend on a system's architecture and compiler whether the
2769         method will be faster than any of the two methods above in such
2770         cases.
2771
2772         On average however, this is probably the slowest method of the three.
2773
2774       • "$min = $set->Min();"
2775
2776         Returns the minimum of the given set, i.e., the minimum of all
2777         indices of all set bits in the given bit vector "$set".
2778
2779         If the set is empty (no set bits), plus infinity (represented by the
2780         constant "MAX_LONG" on your system) is returned.
2781
2782         (This constant is usually 2 ^ (n-1) - 1, where ""n"" is the number of
2783         bits of an unsigned long on your machine.)
2784
2785       • "$max = $set->Max();"
2786
2787         Returns the maximum of the given set, i.e., the maximum of all
2788         indices of all set bits in the given bit vector "$set".
2789
2790         If the set is empty (no set bits), minus infinity (represented by the
2791         constant "MIN_LONG" on your system) is returned.
2792
2793         (This constant is usually -(2 ^ (n-1) - 1) or -(2 ^ (n-1)), where
2794         ""n"" is the number of bits of an unsigned long on your machine.)
2795
2796       • "$m3->Multiplication($r3,$c3,$m1,$r1,$c1,$m2,$r2,$c2);"
2797
2798         This method multiplies two boolean matrices (stored as bit vectors)
2799         "$m1" and "$m2" and stores the result in matrix "$m3".
2800
2801         The method uses the binary "xor" operation (""^"") as the boolean
2802         addition operator (""+"").
2803
2804         An exception is raised if the product of the number of rows and
2805         columns of any of the three matrices differs from the actual size of
2806         their underlying bit vector.
2807
2808         An exception is also raised if the numbers of rows and columns of the
2809         three matrices do not harmonize in the required manner:
2810
2811           rows3 == rows1
2812           cols3 == cols2
2813           cols1 == rows2
2814
2815         This method is used by the module "Math::MatrixBool".
2816
2817         See Math::MatrixBool(3) for details.
2818
2819       • "$m3->Product($r3,$c3,$m1,$r1,$c1,$m2,$r2,$c2);"
2820
2821         This method multiplies two boolean matrices (stored as bit vectors)
2822         "$m1" and "$m2" and stores the result in matrix "$m3".
2823
2824         This special method uses the binary "or" operation (""|"") as the
2825         boolean addition operator (""+"").
2826
2827         An exception is raised if the product of the number of rows and
2828         columns of any of the three matrices differs from the actual size of
2829         their underlying bit vector.
2830
2831         An exception is also raised if the numbers of rows and columns of the
2832         three matrices do not harmonize in the required manner:
2833
2834           rows3 == rows1
2835           cols3 == cols2
2836           cols1 == rows2
2837
2838         This method is used by the module "Math::MatrixBool".
2839
2840         See Math::MatrixBool(3) for details.
2841
2842       • "$matrix->Closure($rows,$cols);"
2843
2844         This method calculates the reflexive transitive closure of the given
2845         boolean matrix (stored as a bit vector) using Kleene's algoritm.
2846
2847         (See Math::Kleene(3) for a brief introduction into the theory behind
2848         Kleene's algorithm.)
2849
2850         The reflexive transitive closure answers the question whether a path
2851         exists between any two vertices of a graph whose edges are given as a
2852         matrix:
2853
2854         If a (directed) edge exists going from vertex "i" to vertex "j", then
2855         the element in the matrix with coordinates (i,j) is set to "1"
2856         (otherwise it remains set to "0").
2857
2858         If the edges are undirected, the resulting matrix is symmetric, i.e.,
2859         elements (i,j) and (j,i) always contain the same value.
2860
2861         The matrix representing the edges of the graph only answers the
2862         question whether an EDGE exists between any two vertices of the graph
2863         or not, whereas the reflexive transitive closure answers the question
2864         whether a PATH (a series of adjacent edges) exists between any two
2865         vertices of the graph!
2866
2867         Note that the contents of the given matrix are modified by this
2868         method, so make a copy of the initial matrix in time if you are going
2869         to need it again later.
2870
2871         An exception is raised if the given matrix is not quadratic, i.e., if
2872         the number of rows and columns of the given matrix is not identical.
2873
2874         An exception is also raised if the product of the number of rows and
2875         columns of the given matrix differs from the actual size of its
2876         underlying bit vector.
2877
2878         This method is used by the module "Math::MatrixBool".
2879
2880         See Math::MatrixBool(3) for details.
2881
2882       • "$matrix2->Transpose($rows2,$cols2,$matrix1,$rows1,$cols1);"
2883
2884         This method calculates the transpose of a boolean matrix "$matrix1"
2885         (stored as a bit vector) and stores the result in matrix "$matrix2".
2886
2887         The transpose of a boolean matrix, representing the edges of a graph,
2888         can be used for finding the strongly connected components of that
2889         graph.
2890
2891         An exception is raised if the product of the number of rows and
2892         columns of any of the two matrices differs from the actual size of
2893         its underlying bit vector.
2894
2895         An exception is also raised if the following conditions are not met:
2896
2897           rows2 == cols1
2898           cols2 == rows1
2899
2900         Note that in-place processing ("$matrix1" and "$matrix2" are
2901         identical) is only possible if the matrix is quadratic. Otherwise, a
2902         fatal "matrix is not quadratic" error will occur.
2903
2904         This method is used by the module "Math::MatrixBool".
2905
2906         See Math::MatrixBool(3) for details.
2907

SEE ALSO

2909       Bit::Vector::Overload(3), Bit::Vector::String(3), Storable(3).
2910
2911       Set::IntRange(3), Math::MatrixBool(3), Math::MatrixReal(3),
2912       DFA::Kleene(3), Math::Kleene(3), Graph::Kruskal(3).
2913

VERSION

2915       This man page documents "Bit::Vector" version 7.4.
2916

AUTHOR

2918         Steffen Beyer
2919         mailto:STBEY@cpan.org
2920         http://www.engelschall.com/u/sb/download/
2921
2923       Copyright (c) 1995 - 2013 by Steffen Beyer. All rights reserved.
2924

LICENSE

2926       This package is free software; you can redistribute it and/or modify it
2927       under the same terms as Perl itself, i.e., under the terms of the
2928       "Artistic License" or the "GNU General Public License".
2929
2930       The C library at the core of this Perl module can additionally be
2931       redistributed and/or modified under the terms of the "GNU Library
2932       General Public License".
2933
2934       Please refer to the files "Artistic.txt", "GNU_GPL.txt" and
2935       "GNU_LGPL.txt" in this distribution for details!
2936

DISCLAIMER

2938       This package is distributed in the hope that it will be useful, but
2939       WITHOUT ANY WARRANTY; without even the implied warranty of
2940       MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
2941
2942       See the "GNU General Public License" for more details.
2943
2944
2945
2946perl v5.36.0                      2022-07-22                         Vector(3)
Impressum