~ubuntu-branches/ubuntu/karmic/psicode/karmic

« back to all changes in this revision

Viewing changes to src/bin/cints/Default_Deriv1/enuc_deriv1.c

  • Committer: Bazaar Package Importer
  • Author(s): Michael Banck, Michael Banck, Daniel Leidert
  • Date: 2009-02-23 00:12:02 UTC
  • mfrom: (1.1.2 upstream)
  • Revision ID: james.westby@ubuntu.com-20090223001202-rutldoy3dimfpesc
Tags: 3.4.0-1
* New upstream release.

[ Michael Banck ]
* debian/patches/01_DESTDIR.dpatch: Refreshed.
* debian/patches/02_FHS.dpatch: Removed, applied upstream.
* debian/patches/03_debian_docdir: Likewise.
* debian/patches/04_man.dpatch: Likewise.
* debian/patches/06_466828_fix_gcc_43_ftbfs.dpatch: Likewise.
* debian/patches/07_464867_move_executables: Fixed and refreshed.
* debian/patches/00list: Adjusted.
* debian/control: Improved description.
* debian/patches-held: Removed.
* debian/rules (install/psi3): Do not ship the ruby bindings for now.

[ Daniel Leidert ]
* debian/rules: Fix txtdir via DEB_MAKE_INSTALL_TARGET.
* debian/patches/01_DESTDIR.dpatch: Refreshed.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
#include<stdio.h>
2
 
#include<libipv1/ip_lib.h>
3
 
#include<math.h>
4
 
#include<libciomr/libciomr.h>
5
 
#include<libint/libint.h>
6
 
 
7
 
#include"defines.h"
8
 
#define EXTERN
9
 
#include"global.h"
10
 
 
11
 
 
12
 
void enuc_deriv1()
13
 
{
14
 
  int i, j;
15
 
  double rij2, tmp;
16
 
  double **grad_enuc;
17
 
 
18
 
  if (Molecule.num_atoms == 0)
19
 
    return;
20
 
 
21
 
  grad_enuc = block_matrix(Molecule.num_atoms,3);
22
 
  for(i=0; i<Molecule.num_atoms; i++)
23
 
    for(j=0; j<Molecule.num_atoms; j++)
24
 
      if (j != i) {
25
 
        rij2 =  (Molecule.centers[i].x-Molecule.centers[j].x)*(Molecule.centers[i].x-Molecule.centers[j].x);
26
 
        rij2 += (Molecule.centers[i].y-Molecule.centers[j].y)*(Molecule.centers[i].y-Molecule.centers[j].y);
27
 
        rij2 += (Molecule.centers[i].z-Molecule.centers[j].z)*(Molecule.centers[i].z-Molecule.centers[j].z);
28
 
        tmp = Molecule.centers[i].Z_nuc*Molecule.centers[j].Z_nuc/(rij2*sqrt(rij2));
29
 
        grad_enuc[i][0] -= (Molecule.centers[i].x-Molecule.centers[j].x)*tmp;
30
 
        grad_enuc[i][1] -= (Molecule.centers[i].y-Molecule.centers[j].y)*tmp;
31
 
        grad_enuc[i][2] -= (Molecule.centers[i].z-Molecule.centers[j].z)*tmp;
32
 
      }
33
 
 
34
 
  if (UserOptions.print_lvl >= PRINT_OEDERIV)
35
 
    print_atomvec("Nuclear repulsion component of the forces (a.u.)",grad_enuc);
36
 
 
37
 
  add_mat(Grad,grad_enuc,Grad,Molecule.num_atoms,3);
38
 
  free_block(grad_enuc);
39
 
  
40
 
  return;
41
 
}
42