10
0
mirror of https://github.com/QuantumPackage/qp2.git synced 2024-06-28 08:02:33 +02:00
QuantumPackage/src/bitmask
2021-12-17 18:15:47 +01:00
..
bitmask_cas_routines.irp.f
bitmasks_module.f90
bitmasks_routines.irp.f moved a subroutine from determinant to bitmask 2021-12-17 18:15:47 +01:00
bitmasks.ezfio_config
bitmasks.irp.f Fix bug with non-continuous active MOs and deleted 2021-06-01 11:33:39 +02:00
core_inact_act_virt.irp.f fixed a bug in two_rdm, added the possibility to Write/Read the all_states active 2 rdm 2020-04-02 14:22:01 +02:00
example.irp.f
EZFIO.cfg fixed a bug in two_rdm, added the possibility to Write/Read the all_states active 2 rdm 2020-04-02 14:22:01 +02:00
find_hole.irp.f
modify_bitmasks.irp.f added some stuffs for foboscf 2021-04-08 20:37:17 +02:00
mpi.irp.f
NEED
README.rst
track_orb.irp.f

==============
bitmask module
==============

The central part of this module is the :file:`bitmasks_module.f90` file. It contains
the constants that will be used to define on which kind of integer the bitmasks
will be defined.

In the program, to represent a determinant as a pair of bitstrings,
the determinant should be defined as

.. code-block:: fortran

  use bitmasks
  integer(bit_kind)  :: determinant(N_int,2)


:file:`bitmasks_routines.irp.f` contains helper routines to manipulate bitmask, like
transforming a bit string to a list of integers for example.


`bit_kind_shift`, `bit_kind_size` and `bit_kind` are supposed to be consistent::

   2**bit_kind_shift = bit_kind_size
   bit_kind = bit_kind_size / 8


For an example of how to use the bitmaks, see the file :file:`example.irp.f`.