File: genab.py

package info (click to toggle)
openmolcas 25.02-2
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 170,204 kB
  • sloc: f90: 498,088; fortran: 139,779; python: 13,587; ansic: 5,745; sh: 745; javascript: 660; pascal: 460; perl: 325; makefile: 17
file content (72 lines) | stat: -rwxr-xr-x 2,642 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#!/usr/bin/env python3
# -*- coding: utf-8 -*-

#***********************************************************************
# This file is part of OpenMolcas.                                     *
#                                                                      *
# OpenMolcas is free software; you can redistribute it and/or modify   *
# it under the terms of the GNU Lesser General Public License, v. 2.1. *
# OpenMolcas is distributed in the hope that it will be useful, but it *
# is provided "as is" and without any express or implied warranties.   *
# For more details see the full text of the license in the file        *
# LICENSE or in <http://www.gnu.org/licenses/>.                        *
#                                                                      *
# Copyright (C) 2017, Ignacio Fdez. Galván                             *
#***********************************************************************

# Generate alpha and beta recursion coefficients for the Rys polynomials
# Output compatible with the "abdata" file for Molcas

from mpmath import mp
from rys_aux import *

# Set floating point precision
# Single precision (32 bits): 24-bit significand, 6 decimal places
# Double precision (64 bits): 53-bit significand, 15 decimal places
# Quadruple precision (128 bits): 113-bit significand, 33 decimal places
mp.dps = 33

tabini = -2
tabend = 678
preci = mp.mpf('1e-20')
terms = 20

# Print header
print('''Data tables from genab.py
=========================

Each table gives the recursion parameters ALPHA(K), BETA(K) and the
zeroth order polynomial P0 needed to generate Rys polynomials up to
order MAXDEG for different values of the continuous parameter T.
NTAB1 and NTAB2 are the first and last table index. PRECIS is the
accuracy to which the values were computed. For each table with index
ITAB, the corresponding T value is:

  T = (sqrt(72900-(260-ITAB)*ITAB)+ITAB-270)/10

and the inverse formula for later interpolation:

  ITAB = 5*T+200*T/(14+T)

NTAB1, NTAB2, MAXDEG:
{0} {1} {2}
PRECIS
{3}'''.format(tabini, tabend, terms-1, preci))

# Compute and print alpha and beta values for different x values
for i in range(tabini, tabend+1):
  # Get the x value from the index
  x = mp.mpf(mp.sqrt(72900-(260-i)*i)+i-270)/10
  alpha, beta = rysab(terms, x, preci=preci)
  # Transform to the Molcas convention
  beta = [mp.sqrt(b) for b in beta]
  p0 = one/beta[0]
  beta[0] = zero

  # Print the results
  print('TAB POINT NR., T VALUE, P0 VALUE:')
  print('{0} {1} {2}'.format(i, figs(x), figs(p0)))
  print('ALPHA ARRAY:')
  printlist(alpha, 4, f=figs)
  print('BETA ARRAY:')
  printlist(beta, 4, f=figs)