source: ThirdParty/mpqc_open/src/lib/chemistry/cca/ccaiter.h@ 482400e

Action_Thermostats Add_AtomRandomPerturbation Add_RotateAroundBondAction Add_SelectAtomByNameAction Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_StructOpt_integration_tests Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.6.0 Candidate_v1.6.1 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_ChronosMutex Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion GeometryObjects Gui_displays_atomic_force_velocity IndependentFragmentGrids_IntegrationTest JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks RotateToPrincipalAxisSystem_UndoRedo StoppableMakroAction Subpackage_levmar Subpackage_vmg ThirdParty_MPQC_rebuilt_buildsystem TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps Ubuntu_1604_changes stable
Last change on this file since 482400e was 860145, checked in by Frederik Heber <heber@…>, 8 years ago

Merge commit '0b990dfaa8c6007a996d030163a25f7f5fc8a7e7' as 'ThirdParty/mpqc_open'

  • Property mode set to 100644
File size: 576 bytes
Line 
1#ifdef __GNUG__
2#pragma interface
3#endif
4
5#ifndef _ccaiter_h
6#define _ccaiter_h
7
8#include <chemistry/qc/basis/cartiter.h>
9
10namespace MPQC {
11
12class CartesianIterCCA : public sc::CartesianIter {
13 int *avec, *bvec, *cvec;
14 public:
15 CartesianIterCCA(int l) : CartesianIter(l) {}
16 void start() {
17 bfn_=b_=c_=0;
18 a_=l_;
19 }
20 void next() {
21 if (c_ < l_ - a_) {
22 b_--;
23 c_++;
24 }
25 else {
26 a_--;
27 c_ = 0;
28 b_ = l_ - a_;
29 }
30 bfn_++;
31 }
32 operator int() {
33 return (a_ >= 0);
34 }
35};
36
37}
38
39#endif
Note: See TracBrowser for help on using the repository browser.