Geant4粒子源创建——各种形状的粒子源

// 圆形

void B1PrimaryGeneratorAction::GeneratePrimaries(G4Event* anEvent)
{
  G4double envSizeXY = 0.01 *mm;
  G4double envSizeZ = 0.01 *mm;


  G4double r = (5.0 * G4UniformRand()) *cm;

// 设置一个0~5cm之间的半径
  G4double theta = 2.0 * M_PI * G4UniformRand();

// 设置0~2*pi的极角

  G4double x0 = (r * cos(theta)) *cm;
  G4double y0 = (r * sin(theta)) *cm;

// 用三角函数来设置x0和y0,要用<math.h>头文件
  G4double z0 = -10.0 *cm;

  fParticleGun->SetParticlePosition(G4ThreeVector(x0, y0, z0));

  fParticleGun->GeneratePrimaryVertex(anEvent);
}

// 线形

void B1PrimaryGeneratorAction::GeneratePrimaries(G4Event* anEvent)
{
  G4double envSizeX = 0.01 *mm;
  G4double envSizeY = 0.01 *mm;
  G4double envSizeZ = 0.01 *mm;

  G4double x0 = 5 * G4UniformRand() *cm;

 // 从-5cm到+5cm的10cm线源
  G4double y0 = 0. *cm;
  G4double z0 = -10.0 *cm;

  fParticleGun->SetParticlePosition(G4ThreeVector(x0, y0, z0));

  fParticleGun->GeneratePrimaryVertex(anEvent);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值