Skip to content
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 discrete adjoints for turbomachinery #2317

Open
wants to merge 34 commits into
base: develop
Choose a base branch
from

Conversation

oleburghardt
Copy link
Contributor

@oleburghardt oleburghardt commented Jul 2, 2024

Proposed Changes

This is, for now, a brief note on @joshkellyjak 's and my WIP on a discrete adjoint functionality for multizone (multi-stage, multi-row) turbomachinery cases. We intend to realize everything through the native multizone discrete adjoint solver, though some turbo-specific problems need to be resolved.

This will, probably, involve further additions/corrections/cleanups around the mixing plane interface so that it is recorded properly. The current recording seems to still be not fully correct.

Related Work

None, so far.


su2double gammaIn_BC = 0;
if (nDim == 3){
gammaIn_BC = FlowDir[2]; //atan(FlowDir[2]/FlowDir[0]);

Check notice

Code scanning / CodeQL

Commented-out code Note

This comment appears to contain commented-out code.
@oleburghardt
Copy link
Contributor Author

oleburghardt commented Aug 14, 2024

@joshkellyjak @pcarruscag Should I make some first commits for a "tag type / debug" recording to this branch? (This problem is the main motivation but technically it's quite unrelated.)

We need it here, but it might be better to merge it from a dedicated branch.

…l write restart files during runtime (there is a bug, potentially when clearing the tape).
@joshkellyjak
Copy link
Contributor

@joshkellyjak @pcarruscag Should I make some first commits for a "tag type / debug" recording to this branch? (This problem is the main motivation but technically it's quite unrelated.)

We need it here, but it might be better to merge it from a dedicated branch.

Personally I would like this to selfishly enhance my understanding, but I don't think it should be merged when we complete the PR. Could be useful documentation for the website.

@oleburghardt
Copy link
Contributor Author

Personally I would like this to selfishly enhance my understanding, but I don't think it should be merged when we complete the PR. Could be useful documentation for the website.

Well I think the functionality should be merged at some point. It might become too much for this PR(?). Let me just go ahead and create a dedicated branch for the tag tape. We could just use that branch as a helper then and prepare it for develop after this one is merged.

@pcarruscag
Copy link
Member

Ah now I got the comment. I would keep adding the debug tape separate from fixing the turbo issues

Common/src/CConfig.cpp Fixed Show fixed Hide fixed
Common/src/CConfig.cpp Fixed Show fixed Hide fixed
Common/src/CConfig.cpp Fixed Show fixed Hide fixed
@joshkellyjak
Copy link
Contributor

Reverting an accidental merge

Comment on lines 6515 to 6698

visc_numerics->SetSecondary(S_domain, S_boundary);

/*--- Turbulent kinetic energy ---*/

if (config->GetKind_Turb_Model() == TURB_MODEL::SST)
visc_numerics->SetTurbKineticEnergy(solver_container[TURB_SOL]->GetNodes()->GetSolution(iPoint,0),
solver_container[TURB_SOL]->GetNodes()->GetSolution(iPoint,0));

/*--- Compute and update residual ---*/

auto residual = visc_numerics->ComputeResidual(config);
LinSysRes.SubtractBlock(iPoint, residual);

/*--- Jacobian contribution for implicit integration ---*/

if (implicit)
if (config->GetKind_TimeIntScheme() == EULER_IMPLICIT)
Jacobian.SubtractBlock2Diag(iPoint, residual.jacobian_i);

}
/*--- Store number of Newton iterations at BC ---*/
if(config->GetKind_FluidModel() == DATADRIVEN_FLUID)
nodes->SetNewtonSolverIterations(iPoint, GetFluidModel()->GetnIter_Newton());

}
END_SU2_OMP_FOR
}

/*--- Free locally allocated memory ---*/
delete [] Normal;

delete [] Velocity_b;
delete [] Velocity_i;

delete [] S_boundary;
delete [] delta_c;
delete [] deltaprim;
delete [] cj;
for (iVar = 0; iVar < nVar; iVar++)
for (unsigned short iVar = 0; iVar < nVar; iVar++)
{
delete [] R_Matrix[iVar];
}
for (iVar = 0; iVar < nVar-1; iVar++)
for (unsigned short iVar = 0; iVar < nVar-1; iVar++)
{
delete [] R_c_inv[iVar];
delete [] R_c[iVar];
}
delete [] R_Matrix;
delete [] R_c;
delete [] R_c_inv;
delete [] R;
delete [] c_avg;
delete [] dcjs;

delete [] AverageTurboMach;
delete [] UnitNormal;
delete [] turboNormal;
delete [] turboVelocity;
}

void CEulerSolver::BC_Giles_Total_Inlet( CNumerics *conv_numerics, CConfig *config, unsigned short val_marker,
su2double *&c_avg, su2double *&R, su2double **&R_c_inv, su2double **&R_c, unsigned short iSpan, unsigned short SpanwisePosition) {

/*--- Calculates boundry condition for quasi-3D and 1D total boundary conditions ---*/

/*--- Retrieve the specified boundary conditions. ---*/
auto const Marker_Tag = config->GetMarker_All_TagBound(val_marker);
auto P_Total = config->GetGiles_Var1(Marker_Tag);
auto T_Total = config->GetGiles_Var2(Marker_Tag);
auto const FlowDir = config->GetGiles_FlowDir(Marker_Tag);
auto const alphaIn_BC = atan(FlowDir[1]/FlowDir[0]);

su2double gammaIn_BC = 0;
if (nDim == 3){
gammaIn_BC = FlowDir[2]; //atan(FlowDir[2]/FlowDir[0]);
}

/*--- Non-dim. the inputs---*/
P_Total /= config->GetPressure_Ref();
T_Total /= config->GetTemperature_Ref();

/* --- Computes the total state --- */
GetFluidModel()->SetTDState_PT(P_Total, T_Total);
auto const Enthalpy_BC = GetFluidModel()->GetStaticEnergy()+ GetFluidModel()->GetPressure()/GetFluidModel()->GetDensity();
auto const Entropy_BC = GetFluidModel()->GetEntropy();

/* --- Computes the inverse matrix R_c --- */
conv_numerics->ComputeResJacobianGiles(GetFluidModel(), AveragePressure[val_marker][iSpan], AverageDensity[val_marker][iSpan],
AverageTurboVelocity[val_marker][iSpan], alphaIn_BC, gammaIn_BC, R_c, R_c_inv);

GetFluidModel()->SetTDState_Prho(AveragePressure[val_marker][SpanwisePosition], AverageDensity[val_marker][SpanwisePosition]);
auto AverageEnthalpy = GetFluidModel()->GetStaticEnergy() + AveragePressure[val_marker][SpanwisePosition]/AverageDensity[val_marker][SpanwisePosition];
auto AverageEntropy = GetFluidModel()->GetEntropy();


su2double avgVel2 = 0.0;
for (unsigned short iDim = 0; iDim < nDim; iDim++) avgVel2 += AverageVelocity[val_marker][iSpan][iDim]*AverageVelocity[val_marker][iSpan][iDim];

Check notice

Code scanning / CodeQL

Long switch case Note

Switch has at least one case that is too long:
MIXING_IN_1D (89 lines)
.
Switch has at least one case that is too long:
MASS_FLOW_OUTLET (83 lines)
.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants