Contents
Fuel mix analysis demo creating contour plots
Uses a fixed electron temperature for all computations.
- to make the colormaps uniform: caxis([0.2 50]) - to lighten the colors: brighten(0.5)
Reference: Carpenter 1999, Figure 4
%-------------------------------------------------------------------------- % See also: PowerDHe3, Synchrotron %-------------------------------------------------------------------------- %-------------------------------------------------------------------------- % Copyright (c) 2018 Princeton Satellite Systems, Inc. All rights reserved. %-------------------------------------------------------------------------- ratios = logspace(-1.6,0.5); temps = linspace(40,140); d = PowerDHe3; ne = 4e20; zI = [1 2]; b = 5; d.tE = 30; % electron temp d.fD = 1; % as low as 0.25 d.fT = 1; pF = zeros(length(temps),length(ratios)); pN = []; pB = []; pS = [];
Model with equal temperatures, full T; electron temp is 0.9 Ti
d.fD = 1; % as low as 0.25 d.fT = 1; for k=1:length(ratios) % calculate ion densities from electron density assuming fuel ratio den = 1 + 2*ratios(k); density = 1/den*ne; d.nD = density; d.nHe3 = density*ratios(k); for j = 1:length(temps) d.tHe3 = temps(j); % potentially uo to 140 keV d.tD = temps(j); % potentially 70 keV d.tE = 0.9*temps(j); % these are powers in MW per cubic meter [pF(j,k), pN(j,k), pB(j,k), nNd, nNt] = PowerDHe3( d ); pS(j,k) = Synchrotron( [d.nD d.nHe3], zI, b, d.tE ); end end MakePlots( ratios, temps, pN, pB, pS, pF,... [2 3 4 5 6 7 8 9 10 20 30 40 50], 'D-D and D-T' ) drawnow;
data:image/s3,"s3://crabby-images/10ed5/10ed58901b938e0ba2dad08cee19012d356332ed" alt=""
data:image/s3,"s3://crabby-images/d4e2a/d4e2a5663ce4732aa211ab4ab8cf22a0bc331200" alt=""
data:image/s3,"s3://crabby-images/7e43f/7e43ffffc87cac466a59d3866abdc2f0bd6884b2" alt=""
data:image/s3,"s3://crabby-images/63ea0/63ea0a604eef3dd792bf31a7d41003ca25f15a70" alt=""
Model with equal temperatures, all T removed
d.fD = 1; % as low as 0.25 d.fT = 0; d.tE = 30; % electron temp pF = []; pN = []; pB = []; pS = []; for k=1:length(ratios) % calculate ion densities from electron density assuming fuel ratio den = 1 + 2*ratios(k); density = 1/den*ne; d.nD = density; d.nHe3 = density*ratios(k); for j = 1:length(temps) d.tHe3 = temps(j); % potentially uo to 140 keV d.tD = temps(j); % potentially 70 keV % these are powers in MW per cubic meter [pF(j,k), pN(j,k), pB(j,k), nNd, nNt] = PowerDHe3( d ); pS(j,k) = Synchrotron( [d.nD d.nHe3], zI, b, d.tE ); end end MakePlots( ratios, temps, pN, pB, pS, pF,... [0.3 0.5 1 2 3 4 5 6 7 8 9 10 20], 'zero D-T' ) drawnow
data:image/s3,"s3://crabby-images/b8619/b86191bd0ab5763caefc4f5a6c6b43f00b932d6d" alt=""
data:image/s3,"s3://crabby-images/af88e/af88e5a40402137d1a9d391c4eb32ca137467103" alt=""
data:image/s3,"s3://crabby-images/2cd7c/2cd7cd2f7f8f02d11ad949a433a867b2c7713f24" alt=""
data:image/s3,"s3://crabby-images/f48ab/f48ab42c584a54fe3236914a40d46fa55f1ce81f" alt=""
Model with different temperatures
temps2 = linspace(70,140); d.fD = 1; % as low as 0.25 d.fT = 0; d.tD = 70; % potentially 70 keV d.tE = 30; % electron temp pF = []; pN = []; pB = []; pS = []; for k=1:length(ratios) % calculate ion densities from electron density assuming fuel ratio den = 1 + 2*ratios(k); density = 1/den*ne; d.nD = density; d.nHe3 = density*ratios(k); for j = 1:length(temps2) d.tHe3 = temps2(j); % potentially uo to 140 keV % these are powers in MW per cubic meter [pF(j,k), pN(j,k), pB(j,k), nNd, nNt] = PowerDHe3( d ); pS(j,k) = Synchrotron( [d.nD d.nHe3], zI, b, d.tE ); end end MakePlots( ratios, temps2, pN, pB, pS, pF,... [0.1 0.2 0.3 0.5 1 2 3 4 5 6 7 8 9 10 20], '70 keV D, zero D-T' )
data:image/s3,"s3://crabby-images/b77c1/b77c1e60980de70052cacb6a81d4fd0dce23668a" alt=""
data:image/s3,"s3://crabby-images/ffb77/ffb770674ec1005ac24579b050ffa99a79de9233" alt=""
data:image/s3,"s3://crabby-images/a99c3/a99c3cae9e9bcba141ccaaaffae411abdbe11dff" alt=""
data:image/s3,"s3://crabby-images/654e4/654e4acd62bb905a1ffdddd38f6cb65dba6a634b" alt=""
Finished
Figui; function MakePlots( ratioPlot, tempPlot, pN, pB, pS, pF, N, str ) NewFig('Neutron Power') [c,h] = contourf(ratioPlot,tempPlot,pN./pF*100,N); clabel(c,h); set(gca,'xscale','log') grid on; title(['% Power in 3He-D Neutrons, ' str]) xlabel('Fuel Ratio (3He/D)') ylabel('Kinetic Temperature (keV)') set(gca,'xtick',[0.03 0.1 0.5 1 3]) set(gcf,'colormap',flipud(parula)) line([1 1],[100 140]) line([1 3],[100 100]) NewFig('Bremsstrahlung Power') [c,h] = contourf(ratioPlot,tempPlot,pB./pF*100); clabel(c,h); set(gca,'xscale','log') grid on; title(['% Power in Bremsstrahlung, ' str]) xlabel('Fuel Ratio (3He/D)') ylabel('Kinetic Temperature (keV)') set(gca,'xtick',[0.03 0.1 0.5 1 3]) set(gcf,'colormap',flipud(parula)) line([1 1],[100 140]) line([1 3],[100 100]) NewFig('% Power in Synchrotron (10% volume)') [c,h] = contourf(ratioPlot,tempPlot,0.1*pS./pF*100); clabel(c,h); set(gca,'xscale','log') set(gca,'xtick',[0.03 0.1 0.5 1 3]) grid on; xlabel('Fuel Ratio (3He/D)') title(['Synchrontron Power, ' str]) NewFig('Total Fusion Power') [c,h] = contourf(ratioPlot,tempPlot,pF); clabel(c,h); set(gca,'xscale','log') set(gca,'xtick',[0.03 0.1 0.5 1 3]) grid on; xlabel('Fuel Ratio (3He/D)') title(['Fusion Power, ' str]) caxis([0 16]) % Note: will change if tE, etc are changed!! cb = colorbar; cb.Title.String = 'MW/m3'; end %--------------------------------------
data:image/s3,"s3://crabby-images/9cc89/9cc8913815ac58e36712f682169887275e6cb6af" alt=""