0001 function undulator=atundulator(LUnd,nperiod,varargin)
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030 defaultAngPole=NaN;
0031 defaultB0andEnergy=[NaN NaN];
0032 defaultPoleGap=0;
0033
0034 expectedmagmodels={'multipoles','rectangularbend'};
0035
0036 p= inputParser;
0037 addRequired(p,'LUnd',@isnumeric);
0038 addRequired(p,'nperiod',@isnumeric);
0039 addParameter(p,'magnetmodel',expectedmagmodels{1},@(x)any(validatestring(x,expectedmagmodels)));
0040 addParameter(p,'BendAngle',defaultAngPole,@isnumeric);
0041 addParameter(p,'B0andEnergy',defaultB0andEnergy,@isnumeric);
0042 addParameter(p,'PoleGap',defaultPoleGap,@isnumeric);
0043
0044 parse(p,LUnd,nperiod,varargin{:});
0045 magnetmodel=p.Results.magnetmodel;
0046 BendAngle=p.Results.BendAngle;
0047 B0andEnergy=p.Results.B0andEnergy;
0048 PoleGap=p.Results.PoleGap;
0049
0050
0051 periodL=LUnd/nperiod;
0052
0053 DistPole=PoleGap;
0054 LPole=(periodL-2*DistPole)/4;
0055
0056 if ~isnan(B0andEnergy)
0057 B=B0andEnergy(1);
0058 Brho=B0andEnergy(2)/299792458;
0059 AngPole=(B*LPole)/Brho;
0060 elseif ~isnan(BendAngle)
0061 AngPole=BendAngle;
0062 else
0063 AngPole=0.0;
0064 end
0065
0066 switch magnetmodel
0067
0068 case 'multipoles'
0069
0070 undperiod=makeundperiod(...
0071 atmultipole('NegPole',LPole,0,-AngPole/LPole),...
0072 atmultipole('PosPole',LPole,0,AngPole/LPole),...
0073 atdrift('PoleGap',DistPole));
0074
0075 case 'rectangularbend'
0076
0077 undperiod=makeundperiod(...
0078 atrbend('NegPole',LPole,-AngPole,0,'BndMPoleSymplectic4Pass'),...
0079 atrbend('PosPole',LPole,AngPole,0,'BndMPoleSymplectic4Pass'),...
0080 atdrift('PoleGap',DistPole));
0081
0082 end
0083
0084 undulator=repmat(undperiod,nperiod,1);
0085
0086 end
0087
0088
0089 function undper=makeundperiod(halfnegpole,halfpospole,driftpole)
0090
0091 if driftpole.Length>0
0092 undper={...
0093 halfnegpole;...
0094 driftpole;...
0095 halfpospole;...
0096 halfpospole;...
0097 driftpole;...
0098 halfnegpole;...
0099 };
0100 elseif driftpole.Length==0
0101 undper={...
0102 halfnegpole;...
0103 halfpospole;...
0104 halfpospole;...
0105 halfnegpole;...
0106 };
0107 end
0108
0109 end
0110