Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/externals/clhep/include/CLHEP/Random/ranluxpp/ranlux_lcg.h

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /externals/clhep/include/CLHEP/Random/ranluxpp/ranlux_lcg.h (Version 11.3.0) and /externals/clhep/include/CLHEP/Random/ranluxpp/ranlux_lcg.h (Version 4.0)


  1 //                                                  1 
  2 // -*- C++ -*-                                    
  3 //                                                
  4 // -------------------------------------------    
  5 //                             HEP Random         
  6 //                       --- RanluxppEngine --    
  7 //                     helper implementation f    
  8 // -------------------------------------------    
  9                                                   
 10 #ifndef RANLUXPP_RANLUX_LCG_H                     
 11 #define RANLUXPP_RANLUX_LCG_H                     
 12                                                   
 13 #include "helpers.h"                              
 14                                                   
 15 #include <cstdint>                                
 16                                                   
 17 /// Convert RANLUX numbers to an LCG state        
 18 ///                                               
 19 /// \param[in] ranlux the RANLUX numbers as 57    
 20 /// \param[out] lcg the 576 bits of the LCG st    
 21 /// \param[in] c the carry bit of the RANLUX s    
 22 ///                                               
 23 /// \f$ m = 2^{576} - 2^{240} + 1 \f$             
 24 static void to_lcg(const uint64_t *ranlux, uns    
 25   unsigned carry = 0;                             
 26   // Subtract the final 240 bits.                 
 27   for (int i = 0; i < 9; i++) {                   
 28     uint64_t ranlux_i = ranlux[i];                
 29     uint64_t lcg_i = sub_overflow(ranlux_i, ca    
 30                                                   
 31     uint64_t bits = 0;                            
 32     if (i < 4) {                                  
 33       bits += ranlux[i + 5] >> 16;                
 34       if (i < 3) {                                
 35         bits += ranlux[i + 6] << 48;              
 36       }                                           
 37     }                                             
 38     lcg_i = sub_carry(lcg_i, bits, carry);        
 39     lcg[i] = lcg_i;                               
 40   }                                               
 41                                                   
 42   // Add and propagate the carry bit.             
 43   for (int i = 0; i < 9; i++) {                   
 44     lcg[i] = add_overflow(lcg[i], c, c);          
 45   }                                               
 46 }                                                 
 47                                                   
 48 /// Convert an LCG state to RANLUX numbers        
 49 ///                                               
 50 /// \param[in] lcg the 576 bits of the LCG sta    
 51 /// \param[out] ranlux the RANLUX numbers as 5    
 52 /// \param[out] c the carry bit of the RANLUX     
 53 ///                                               
 54 /// \f$ m = 2^{576} - 2^{240} + 1 \f$             
 55 static void to_ranlux(const uint64_t *lcg, uin    
 56   uint64_t r[9] = {0};                            
 57   int64_t c = compute_r(lcg, r);                  
 58                                                   
 59   // ranlux = t1 + t2 + c                         
 60   unsigned carry = 0;                             
 61   for (int i = 0; i < 9; i++) {                   
 62     uint64_t in_i = lcg[i];                       
 63     uint64_t tmp_i = add_overflow(in_i, carry,    
 64                                                   
 65     uint64_t bits = 0;                            
 66     if (i < 4) {                                  
 67       bits += lcg[i + 5] >> 16;                   
 68       if (i < 3) {                                
 69         bits += lcg[i + 6] << 48;                 
 70       }                                           
 71     }                                             
 72     tmp_i = add_carry(tmp_i, bits, carry);        
 73     ranlux[i] = tmp_i;                            
 74   }                                               
 75                                                   
 76   // If c = -1, we need to add it to all compo    
 77   int64_t c1 = c >> 1;                            
 78   ranlux[0] = add_overflow(ranlux[0], c, carry    
 79   for (int i = 1; i < 9; i++) {                   
 80     uint64_t ranlux_i = ranlux[i];                
 81     ranlux_i = add_overflow(ranlux_i, carry, c    
 82     ranlux_i = add_carry(ranlux_i, c1, carry);    
 83   }                                               
 84                                                   
 85   c_out = carry;                                  
 86 }                                                 
 87                                                   
 88 #endif                                            
 89