source: trunk/source/geometry/magneticfield/test/OtherFields/src/G4HarmonicPolMagField.cc @ 1202

Last change on this file since 1202 was 1199, checked in by garnier, 15 years ago

nvx fichiers dans CVS

File size: 4.1 KB
Line 
1//
2// ********************************************************************
3// * License and Disclaimer                                           *
4// *                                                                  *
5// * The  Geant4 software  is  copyright of the Copyright Holders  of *
6// * the Geant4 Collaboration.  It is provided  under  the terms  and *
7// * conditions of the Geant4 Software License,  included in the file *
8// * LICENSE and available at  http://cern.ch/geant4/license .  These *
9// * include a list of copyright holders.                             *
10// *                                                                  *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work  make  any representation or  warranty, express or implied, *
14// * regarding  this  software system or assume any liability for its *
15// * use.  Please see the license in the file  LICENSE  and URL above *
16// * for the full disclaimer and the limitation of liability.         *
17// *                                                                  *
18// * This  code  implementation is the result of  the  scientific and *
19// * technical work of the GEANT4 collaboration.                      *
20// * By using,  copying,  modifying or  distributing the software (or *
21// * any work based  on the software)  you  agree  to acknowledge its *
22// * use  in  resulting  scientific  publications,  and indicate your *
23// * acceptance of all terms of the Geant4 Software license.          *
24// ********************************************************************
25//
26//
27// $Id: G4HarmonicPolMagField.cc,v 1.3 2006/06/29 18:26:56 gunter Exp $
28// GEANT4 tag $Name: HEAD $
29//
30
31#include "G4HarmonicPolMagField.hh"
32#include "globals.hh"
33#include "geomdefs.hh"
34
35G4HarmonicPolMagField::G4HarmonicPolMagField()
36{
37    ;
38}
39
40// ................ 
41
42G4HarmonicPolMagField::~G4HarmonicPolMagField()
43{
44   ;
45}
46
47// ------------------------------------------------------------------------
48
49
50void
51   G4HarmonicPolMagField::GetFieldValue (const G4double yTrack[3],
52                                               G4double *B         )  const
53{
54   G4int i ;
55   G4double a = 1.00 ;   // mm -> m
56   G4double a2 = a*a, a3 = a2*a, a4 = a2*a2, a5 = a3*a2 ;
57   G4double x = a*yTrack[0], y = a*yTrack[1], z = a*yTrack[2] ;
58   G4double x2 = x*x, y2 = y*y, z2 = z*z ;
59   G4double x3 = x2*x, y3 = y2*y, z3 = z2*z ;
60   G4double xy = x*y, xz = x*z, yz = y*z, xyz = x*y*z ;
61   static G4double
62   c[24] = {
63             0.010, 0.010, 0.010,                            // 3(0)
64             0.0001, 0.0001, 0.0001, 0.0001, 0.0001,                  // 5(1)
65             0.00001, 0.00001, 0.00001, 0.00001, 0.00001, 0.00001, 0.00001, // 7(2)
66             0.000001, 0.000001, 0.000001, 0.000001, 0.000001, 0.000001,
67             0.0000001, 0.0000001, 0.0000001                       // 9(3)
68            } ;                               // total :   24
69   
70   //   for(i=0;i<24;i++)
71   //   {
72   //      c[i] = 1.0*c[i] ;
73   //   }
74   B[0] =  c[1]
75          -2*c[3]*x + c[4]*z +c[6]*y -2*c[7]*x
76          -6*c[8]*xz + c[9]*(z2-x2) -2*c[10]*xy + c[11]*yz - 2*c[12]*xz
77          +c[13]*(y2-x2) - 6*c[14]*xy
78          -4*c[15]*(3*x*z2-x3) +c[16]*(z3-3*x2*z) - 6*c[17]*xyz +c[18]*y*(z2-x2)
79          -2*c[19]*(x*z2+x*y2-2*x3/3) + c[20]*z*(y2-x2) - 6*c[21]*xyz
80          +c[22]*(y3-3*x2*y) - 4*c[23]*(3*x*y2-x3) ;
81   
82   B[1] =  c[2]
83          +c[5]*z + c[6]*x + 2*c[7]*y
84          +c[10]*(z2-x2) + c[11]*xz +2*c[12]*yz +2*c[13]*xy + 3*c[14]*(y2-x2)
85          +c[17]*(z3-3*x2*z) + c[18]*(x*z2-x3/3) +2*c[19]*y*(z2-x2)
86          +2*c[20]*xyz
87          +3*c[21]*z*(y2-x2) + c[22]*(3*x*y2-x3) + 4*c[23]*(y3-3*x2*y) ;
88   
89   B[2] =  c[0]
90          +c[3]*z + c[4]*x + c[5]*y
91          +3*c[8]*(z2-x2) + 2*c[9]*xz + 2*c[10]*yz + c[11]*xy + c[12]*(y2-x2)
92          +4*c[15]*(z3-3*x2*z) + c[16]*(3*x*z2-x3) + 3*c[17]*(y*z2-x2*y)
93          +2*c[18]*xyz
94          +2*c[19]*z*(y2-x2) + c[20]*(x*y2-x3/3) + c[21]*(y3-3*x2*y) ;
95   for(i=0;i<3;i++)
96   {
97      B[i] = 0.1*B[i] ;
98   }
99   
100   return ;
101}
102
103// -----------------------------------------------------------------
104
Note: See TracBrowser for help on using the repository browser.