-
Notifications
You must be signed in to change notification settings - Fork 848
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[WIP] Multizone adjoints for turbomachinery #2446
base: develop
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3413,8 +3413,17 @@ void CConfig::SetPostprocessing(SU2_COMPONENT val_software, unsigned short val_i | |
|
||
/*--- Using default frequency of 250 for all files when steady, and 1 for unsteady. ---*/ | ||
for (auto iVolumeFreq = 0; iVolumeFreq < nVolumeOutputFrequencies; iVolumeFreq++){ | ||
VolumeOutputFrequencies[iVolumeFreq] = Time_Domain ? 1 : 250; | ||
if (Multizone_Problem && DiscreteAdjoint) { | ||
VolumeOutputFrequencies[iVolumeFreq] = nOuterIter; | ||
} | ||
else { | ||
VolumeOutputFrequencies[iVolumeFreq] = Time_Domain ? 1 : 250; | ||
} | ||
} | ||
} else if (Multizone_Problem && DiscreteAdjoint) { | ||
SU2_MPI::Error(string("OUTPUT_WRT_FREQ cannot be specified for this solver " | ||
"(writing of restart and sensitivity files not possible for multizone discrete adjoint during runtime yet).\n" | ||
"Please remove this option from the config file, output files will be written when solver finalizes.\n"), CURRENT_FUNCTION); | ||
Comment on lines
+3425
to
+3426
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hmmm I'm pretty sure it is possible There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This is one for @oleburghardt |
||
} else if (nVolumeOutputFrequencies < nVolumeOutputFiles) { | ||
/*--- If there are fewer frequencies than files, repeat the last frequency. | ||
* This is useful to define 1 frequency for the restart file and 1 frequency for all the visualization files. ---*/ | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -672,11 +672,12 @@ void CFVMFlowSolverBase<V, R>::ComputeVorticityAndStrainMag(const CConfig& confi | |
StrainMag(iPoint) = sqrt(2.0*StrainMag(iPoint)); | ||
AD::SetPreaccOut(StrainMag(iPoint)); | ||
|
||
AD::EndPreacc(); | ||
|
||
/*--- Max is not differentiable, so we not register them for preacc. ---*/ | ||
Comment on lines
+675
to
677
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. What is the difference between ending the preaccumulation before or after? |
||
strainMax = max(strainMax, StrainMag(iPoint)); | ||
omegaMax = max(omegaMax, GeometryToolbox::Norm(3, Vorticity)); | ||
|
||
AD::EndPreacc(); | ||
} | ||
END_SU2_OMP_FOR | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -219,14 +219,14 @@ void CDiscAdjSolver::RegisterVariables(CGeometry *geometry, CConfig *config, boo | |
|
||
if ((config->GetKind_Regime() == ENUM_REGIME::COMPRESSIBLE) && (KindDirect_Solver == RUNTIME_FLOW_SYS) && config->GetBoolTurbomachinery()){ | ||
|
||
BPressure = config->GetPressureOut_BC(); | ||
Temperature = config->GetTotalTemperatureIn_BC(); | ||
|
||
if (!reset){ | ||
AD::RegisterInput(BPressure); | ||
AD::RegisterInput(Temperature); | ||
} | ||
|
||
BPressure = config->GetPressureOut_BC(); | ||
Temperature = config->GetTotalTemperatureIn_BC(); | ||
|
||
Comment on lines
-222
to
+229
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why are these wrong but not the others that follow the same pattern? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This threw a tagging error, and if I remember correctly it's because in the other sections the variables it accesses are directly used in the solver, whereas in the Giles implementation they are not, creating a mismatch in tags. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Can we fix it in a way that keeps a clear pattern for doing this type of thing? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I can give it a go |
||
config->SetPressureOut_BC(BPressure); | ||
config->SetTotalTemperatureIn_BC(Temperature); | ||
} | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.