10
0
mirror of https://github.com/LCPQ/quantum_package synced 2025-01-10 13:08:23 +01:00
This repository is version 1 of QP. This version is not supported any more. Version 2 is available here : https://github.com/QuantumPackage/qp2
Go to file
Anthony Scemama 9bcef539d2 Merge pull request #113 from scemama/master
Mysterious OpenMP bug
2015-11-13 17:44:46 +01:00
bin Improved setup scripts to auto-install curl and m4 2014-10-23 22:40:21 +02:00
config no more connected_to_ref in mrcc_dress + cleaning 2015-10-29 11:40:11 +01:00
data installation zlib OK 2015-06-08 20:46:36 +02:00
doc Spelling 2015-06-16 14:35:16 +02:00
install Debuging travis 2015-07-16 10:49:25 +02:00
lib Add Downloads and lib 2015-06-08 15:02:08 +02:00
ocaml Merge branch 'master' of https://github.com/LCPQ/quantum_package into LCPQ-master 2015-11-07 01:38:20 +01:00
plugins Corrected Hartree-Fock MOs when not converged 2015-11-13 10:51:03 +01:00
scripts Removed git --local in is_master_repository.py 2015-11-13 09:36:04 +01:00
src Davidson optimization 2015-11-13 17:36:29 +01:00
testing_no_regression Fix ei_handler ocaml_global 2015-06-19 10:32:19 +02:00
.gitattributes Added gitattributes 2015-04-02 12:30:34 +02:00
.gitignore filter_connected_davidson sans proxy 2015-10-22 11:24:04 +02:00
.travis.yml connected_to_ref 2015-10-25 21:23:12 +01:00
configure Add g++ dependency for Ninja in configure 2015-10-30 13:54:58 +01:00
LICENSE Initial commit 2014-04-01 02:24:45 -07:00
README.md Fix typo 2015-10-05 14:27:18 +02:00

Quantum package

Build Status

Gitter

Set of quantum chemistry programs and libraries. (under GNU GENERAL PUBLIC LICENSE v2)

For more information, you can visit the wiki of the project, or bellow for the installation instruction.

Installation

Requirements

  • Fortran compiler (ifort and gfortran are tested)
  • Python >= 2.6
  • GNU make
  • Bash

Standard installation

1) Configure

$ ./configure <config_file> (--production | --development)

For example you can type ./configure config/gfortran.cfg --production

This command have to purpose :

  • Download and install all the requirements. Installing OCaml and the Core library may take some time (up to 20min on an old machine).
  • And create the file which contains all the tree dependencies for the binaries.
    Its not a Makefile, but a Ninja file (so dont type make is hopeless, type ninja instead)

####Compilation Flags (<config_file>)

<config_file> is the path to the file who contain all the flags useful for the compilation: like the optimization flags, the Lapack libary, etc. We have two default configure file in $QP_ROOT/config : ifort.cfg and gfortran.cfg. You can edit these files to modify the compiling options.

What utilization of the code will you do?

  • If you only want the binaries (for production workflow) use the flag --production in when calling this script. Its quicker
  • Else if you are a developer and you want to be able to compile specific modules use: --development. It will create for you the build.ninja in each module

2) Set environment variable

source quantum_package.rc

This file contains all the environment variables needed by the quantum package both to compile and run. This should also be done before running calculations.

Optional) Add some new module

  Usage: qp_install_module.py list (--installed|--avalaible-local|--avalaible-remote)
   qp_install_module.py install <name>...
   qp_install_module.py create -n <name> [<children_module>...]
   qp_install_module.py download -n <name> [<path_folder>...]

For exemple you can type : qp_install_module.py install Full_CI

3) Compiling the fortran

ninja 

Just type ninja if you are in $QP_ROOT (or ninja -f $QP_ROOT/build.ninja elsewhere). The compilation will take approximately 3 min.

If you have set the --developement flag in a specific module you can go in the corresponding module directory and run ninja to build only this module. You can type ninja all in a module for compiling all the submodule

4) Compiling the OCaml

cd ocaml ; make ; cd -

5) Testing if all is ok

cd testing_no_regression ; ./unit_test.py

Installing behind a firewall !

  1. Download tsocks:

    wget http://sourceforge.net/projects/tsocks/files/latest/download mv download tsocks.tar.gz

  2. Tranfer tsocks.tar.gz on the remote host

  3. Configure tsocks with the proper directory for the tsocks.conf file:

    tar -zxvf tsocks.tar.gz cd tsocks-* ./configure with-conf=${PWD}/tsocks.conf

  4. Create the tsocks.conf file with the following content:

    server = 127.0.0.1 server_port = 10000

  5. Create the tsocks library:

    make

  6. Add the libtsocks.so to the LD_PRELOAD environment variable:

    export LD_PRELOAD=“${PWD}/libtsocks.so.1.8”

  7. Create a custom curl command to set the tsocks option: open a file named curl, which is accessible from your PATH environment variable before the real curl command, and fill this file with:

    #!/bin/bash /usr/bin/curl socks5 127.0.0.1:10000 $@

  8. Start a tsocks ssh tunnel:

    ssh -fN -D 10000 user@external-server.com

Note on EZFIO.cfg

##Format specification :

Required:
    [<provider_name>]   The name of the provider in irp.f90 and in the EZFIO lib
    doc:<str>           The plain text documentation
    type:<str>          A Fancy_type supported by the ocaml.
                            type `ei_handler.py get_supported_type` for a list
    interface:<str>     The interface is list of string sepeared by ","  who can containt :
                          - ezfio (if you only whant the ezfiolib)
                          - provider (if you want the provider)
                          - ocaml (if you want the ocaml gestion)
Optional:
    default: <str>      The default value needed,
                            if 'ocaml' is in interface list.
                           ! No list is allowed for now !
    size: <str>         The size information.
                            (by default is one)
                            Example : 1, =sum(ao_num); (ao_num,3)
                            ATTENTION : The module and the value are separed by a "." not a "_".
                            For exemple (determinants.n_det)
    ezfio_name: <str>   The name for the EZFIO lib
                             (by default is <provider_name>)
    ezfio_dir: <str>    Will be the folder of EZFIO.
                              (by default is <module_lower>)

##Example of EZFIO.cfg:

[thresh_SCF]
doc: Threshold on the convergence of the Hartree Fock energy
type: Threshold
default: 1.e-10
interface: provider,ezfio,ocaml
size: 1

[energy]
type: Strictly_negative_float
doc: Calculated HF energy
interface: ezfio

#FAQ

Error: ezfio_* is already defined.

Why ?

You have two or more ezfio configuration file for the same variable. Check in $QP_ROOT/install/config/

Fix

- rm $QP_ROOT/install/EZFIO/config/*
- ninja