Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
Gyacomo
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package Registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Antoine Cyril David Hoffmann
Gyacomo
Commits
4136d4f5
Commit
4136d4f5
authored
4 years ago
by
Antoine Cyril David Hoffmann
Browse files
Options
Downloads
Patches
Plain Diff
debug linear 1D run
parent
bdb19df4
No related branches found
No related tags found
No related merge requests found
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
wk/linear_study.m
+25
-33
25 additions, 33 deletions
wk/linear_study.m
wk/setup.m
+4
-4
4 additions, 4 deletions
wk/setup.m
with
29 additions
and
37 deletions
wk/linear_study.m
+
25
−
33
View file @
4136d4f5
...
@@ -5,28 +5,25 @@ default_plots_options
...
@@ -5,28 +5,25 @@ default_plots_options
%% Set Up parameters
%% Set Up parameters
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% PHYSICAL PARAMETERS
%% PHYSICAL PARAMETERS
NU
=
1e
0
;
% Collision frequency
NU
=
1e
-1
;
% Collision frequency
TAU
=
1.0
;
% e/i temperature ratio
TAU
=
1.0
;
% e/i temperature ratio
ETAB
=
0.
5
;
ETAB
=
0.
66
;
ETAN
=
1.0
;
% Density gradient
ETAN
=
1.0
;
% Density gradient
ETAT
=
0.0
;
% Temperature gradient
ETAT
=
0.0
;
% Temperature gradient
MU
=
0
e-
4
;
% Hyper diffusivity coefficient
MU
=
1
e-
3
;
% Hyper diffusivity coefficient
LAMBDAD
=
0.0
;
LAMBDAD
=
0.0
;
NOISE0
=
1.0e-5
;
NOISE0
=
1.0e-5
;
%% GRID PARAMETERS
%% GRID PARAMETERS
N
=
5
0
;
% Frequency gridpoints (Nkr = N/2)
N
=
10
0
;
% Frequency gridpoints (Nkr = N/2)
L
=
100
;
% Size of the squared frequency domain
L
=
100
;
% Size of the squared frequency domain
PMAXE
=
12
;
JMAXE
=
6
;
PMAXI
=
12
;
JMAXI
=
6
;
KREQ0
=
1
;
% put kr = 0
KREQ0
=
1
;
% put kr = 0
%% TIME PARAMETERS
%% TIME PARAMETERS
TMAX
=
3
00
;
% Maximal time unit
TMAX
=
1
00
;
% Maximal time unit
DT
=
1e-
3
;
% Time step
DT
=
1e-
2
;
% Time step
SPS0D
=
0.5
;
% Sampling per time unit for 2D arrays
SPS0D
=
0.5
;
% Sampling per time unit for 2D arrays
SPS2D
=
1
;
% Sampling per time unit for 2D arrays
SPS2D
=
1
;
% Sampling per time unit for 2D arrays
SPS5D
=
0.1
;
% Sampling per time unit for 5D arrays
SPS5D
=
0.1
;
% Sampling per time unit for 5D arrays
SPSCP
=
0
;
% Sampling per time unit for checkpoints
RESTART
=
0
;
% To restart from last checkpoint
RESTART
=
0
;
% To restart from last checkpoint
JOB2LOAD
=
00
;
JOB2LOAD
=
00
;
%% OPTIONS
%% OPTIONS
...
@@ -44,34 +41,29 @@ KPAR = 0.0; % Parellel wave vector component
...
@@ -44,34 +41,29 @@ KPAR = 0.0; % Parellel wave vector component
%% PARAMETER SCANS
%% PARAMETER SCANS
if
1
if
1
%% Parameter scan over PJ
%% Parameter scan over PJ
NU
=
1e-2
;
% Collision frequency
PA
=
[
2
,
6
,
8
,
12
];
ETAB
=
0.5
;
JA
=
[
1
,
3
,
4
,
6
];
ETAN
=
1.0
;
% PA = [2];
TMAX
=
400
;
% JA = [1];
PA
=
[
2
,
8
,
12
,
20
,
40
];
JA
=
[
1
,
4
,
6
,
10
,
20
];
% PA = [40];
% JA = [20];
Nparam
=
numel
(
PA
);
Nparam
=
numel
(
PA
);
param_name
=
'PJ'
;
CO
=
-
2
;
% Collision operator (0 : L.Bernstein, -1 : Full Coulomb, -2 : Dougherty)
DT
=
5e-3
;
% Time step
gamma_Ni
=
zeros
(
Nparam
,
N
);
gamma_Ni
=
zeros
(
Nparam
,
N
/
2
+
1
);
Ni00_ST
=
zeros
(
Nparam
,
N
,
TMAX
);
Ni00_ST
=
zeros
(
Nparam
,
N
/
2
+
1
,
TMAX
);
for
i
=
1
:
Nparam
for
i
=
1
:
Nparam
% Change scan parameter
% Change scan parameter
PMAXE
=
PA
(
i
);
PMAXI
=
PA
(
i
);
PMAXE
=
PA
(
i
);
PMAXI
=
PA
(
i
);
JMAXE
=
JA
(
i
);
JMAXI
=
JA
(
i
);
JMAXE
=
JA
(
i
);
JMAXI
=
JA
(
i
);
setup
setup
% Run linear simulation
% Run linear simulation
system
(
'./../bin/helaz'
);
system
(
...
[
'cd ../results/'
,
SIMID
,
'/'
,
PARAMS
,
'/; mpirun -np 8 ./../../../bin/helaz; cd ../../../wk'
]
...
)
% Load and process results
% Load and process results
load_results
load_results
tend
=
Ts2D
(
end
);
tstart
=
0.4
*
tend
;
tend
=
Ts2D
(
end
);
tstart
=
0.4
*
tend
;
for
ik
z
=
1
:
N
for
ik
r
=
1
:
N
/
2
+
1
gamma_Ni
(
i
,
ik
z
)
=
LinearFit_s
(
Ts2D
,
squeeze
(
abs
(
Ni00
(
1
,
ikz
,:))),
tstart
,
tend
);
gamma_Ni
(
i
,
ik
r
)
=
LinearFit_s
(
Ts2D
,
squeeze
(
abs
(
Ni00
(
ikr
,
1
,:))),
tstart
,
tend
);
Ni00_ST
(
i
,
ik
z
,
1
:
numel
(
Ts2D
))
=
squeeze
((
Ni00
(
1
,
ikz
,:)));
Ni00_ST
(
i
,
ik
r
,
1
:
numel
(
Ts2D
))
=
squeeze
((
Ni00
(
ikr
,
1
,:)));
end
end
gamma_Ni
(
i
,:)
=
real
(
gamma_Ni
(
i
,:)
.*
(
gamma_Ni
(
i
,:)
>=
0.0
));
gamma_Ni
(
i
,:)
=
real
(
gamma_Ni
(
i
,:)
.*
(
gamma_Ni
(
i
,:)
>=
0.0
));
% Clean output
% Clean output
...
@@ -96,9 +88,9 @@ if 0
...
@@ -96,9 +88,9 @@ if 0
fig
=
figure
;
FIGNAME
=
'space_time_Ni00'
;
fig
=
figure
;
FIGNAME
=
'space_time_Ni00'
;
i
=
3
;
i
=
3
;
plt
=
@
(
x
)
squeeze
((
abs
(
x
)));
plt
=
@
(
x
)
squeeze
((
abs
(
x
)));
for
ik
z
=
1
:
4
:
numel
(
k
z
)/
2
+
1
for
ik
r
=
1
:
4
:
numel
(
k
r
)/
2
+
1
NAME
=
[
'$k_z='
,
num2str
(
k
z
(
ik
z
)),
'$'
];
NAME
=
[
'$k_z='
,
num2str
(
k
r
(
ik
r
)),
'$'
];
semilogy
(
1
:
TMAX
,
plt
(
Ni00_ST
(
i
,
ik
z
,
1
:
TMAX
)),
'DisplayName'
,
NAME
);
hold
on
;
semilogy
(
1
:
TMAX
,
plt
(
Ni00_ST
(
i
,
ik
r
,
1
:
TMAX
)),
'DisplayName'
,
NAME
);
hold
on
;
end
end
grid
on
;
xlabel
(
'$t c_s/\rho_s$'
);
ylabel
(
'$|Ni^{00}|$'
);
grid
on
;
xlabel
(
'$t c_s/\rho_s$'
);
ylabel
(
'$|Ni^{00}|$'
);
title
([
'$\eta_B='
,
num2str
(
ETAB
),
'$; $P,J='
,
num2str
(
PA
(
i
)),
','
,
num2str
(
JA
(
i
)),
'$, $\nu='
,
num2str
(
NU
),
'$'
])
title
([
'$\eta_B='
,
num2str
(
ETAB
),
'$; $P,J='
,
num2str
(
PA
(
i
)),
','
,
num2str
(
JA
(
i
)),
'$, $\nu='
,
num2str
(
NU
),
'$'
])
...
@@ -109,17 +101,17 @@ end
...
@@ -109,17 +101,17 @@ end
if
1
if
1
%% Plot
%% Plot
fig
=
figure
;
FIGNAME
=
'linear_study'
;
fig
=
figure
;
FIGNAME
=
'linear_study'
;
plt
=
@
(
x
)
circshift
(
x
,
N
/
2
-
1
)
;
plt
=
@
(
x
)
x
;
for
i
=
1
:
Nparam
for
i
=
1
:
Nparam
clr
=
line_colors
(
mod
(
i
-
1
,
numel
(
line_colors
(:,
1
)))
+
1
,:);
clr
=
line_colors
(
mod
(
i
-
1
,
numel
(
line_colors
(:,
1
)))
+
1
,:);
linestyle
=
line_styles
(
floor
((
i
-
1
)/
numel
(
line_colors
(:,
1
)))
+
1
);
linestyle
=
line_styles
(
floor
((
i
-
1
)/
numel
(
line_colors
(:,
1
)))
+
1
);
plot
(
plt
(
k
z
),
plt
(
gamma_Ni
(
i
,:)),
...
plot
(
plt
(
k
r
),
plt
(
gamma_Ni
(
i
,:)),
...
'Color'
,
clr
,
...
'Color'
,
clr
,
...
'LineStyle'
,
linestyle
{
1
},
...
'LineStyle'
,
linestyle
{
1
},
...
'DisplayName'
,[
'$P=$'
,
num2str
(
PA
(
i
)),
', $J=$'
,
num2str
(
JA
(
i
))]);
'DisplayName'
,[
'$P=$'
,
num2str
(
PA
(
i
)),
', $J=$'
,
num2str
(
JA
(
i
))]);
hold
on
;
hold
on
;
end
end
grid
on
;
xlabel
(
'$k_z$'
);
ylabel
(
'$\gamma(N_i^{00})$'
);
xlim
([
0.0
,
max
(
k
z
)]);
grid
on
;
xlabel
(
'$k_z$'
);
ylabel
(
'$\gamma(N_i^{00})$'
);
xlim
([
0.0
,
max
(
k
r
)]);
title
([
'$\eta_B='
,
num2str
(
ETAB
),
'$, $\nu='
,
num2str
(
NU
),
'$'
])
title
([
'$\eta_B='
,
num2str
(
ETAB
),
'$, $\nu='
,
num2str
(
NU
),
'$'
])
legend
(
'show'
)
legend
(
'show'
)
saveas
(
fig
,[
SIMDIR
,
'gamma_Ni_vs_'
,
param_name
,
'_'
,
PARAMS
,
'.fig'
]);
saveas
(
fig
,[
SIMDIR
,
'gamma_Ni_vs_'
,
param_name
,
'_'
,
PARAMS
,
'.fig'
]);
...
...
This diff is collapsed.
Click to expand it.
wk/setup.m
+
4
−
4
View file @
4136d4f5
...
@@ -5,10 +5,10 @@ GRID.pmaxe = PMAXE; % Electron Hermite moments
...
@@ -5,10 +5,10 @@ GRID.pmaxe = PMAXE; % Electron Hermite moments
GRID
.
jmaxe
=
JMAXE
;
% Electron Laguerre moments
GRID
.
jmaxe
=
JMAXE
;
% Electron Laguerre moments
GRID
.
pmaxi
=
PMAXI
;
% Ion Hermite moments
GRID
.
pmaxi
=
PMAXI
;
% Ion Hermite moments
GRID
.
jmaxi
=
JMAXI
;
% Ion Laguerre moments
GRID
.
jmaxi
=
JMAXI
;
% Ion Laguerre moments
GRID
.
Nr
=
N
*
(
1
-
KREQ0
)
+
KREQ0
;
% r grid resolution
GRID
.
Nr
=
N
;
% r grid resolution
GRID
.
Lr
=
L
*
(
1
-
KREQ0
)
;
% r length
GRID
.
Lr
=
L
;
% r length
GRID
.
Nz
=
N
;
% z ''
GRID
.
Nz
=
N
*
(
1
-
KREQ0
)
+
KREQ0
;
% z ''
GRID
.
Lz
=
L
;
% z ''
GRID
.
Lz
=
L
*
(
1
-
KREQ0
)
;
% z ''
GRID
.
kpar
=
KPAR
;
GRID
.
kpar
=
KPAR
;
% Model parameters
% Model parameters
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment