mirror of
https://develop.openfoam.com/Development/openfoam.git
synced 2025-11-28 03:28:01 +00:00
DimensionedScalarField, GeometricScalarField: Added more rigorous dimension-checking for 'pow' functions
This commit is contained in:
@ -106,6 +106,20 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
const DimensionedField<scalar, GeoMesh>& dsf2
|
const DimensionedField<scalar, GeoMesh>& dsf2
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
if (!dsf1.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Base field is not dimensionless: " << dsf1.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!dsf2.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent field is not dimensionless: " << dsf2.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<DimensionedField<scalar, GeoMesh>> tPow
|
tmp<DimensionedField<scalar, GeoMesh>> tPow
|
||||||
(
|
(
|
||||||
new DimensionedField<scalar, GeoMesh>
|
new DimensionedField<scalar, GeoMesh>
|
||||||
@ -117,11 +131,7 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
dsf1.db()
|
dsf1.db()
|
||||||
),
|
),
|
||||||
dsf1.mesh(),
|
dsf1.mesh(),
|
||||||
pow
|
dimless
|
||||||
(
|
|
||||||
dsf1.dimensions(),
|
|
||||||
dimensionedScalar("1", 1.0, dsf2.dimensions())
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -140,15 +150,25 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
{
|
{
|
||||||
const DimensionedField<scalar, GeoMesh>& dsf1 = tdsf1();
|
const DimensionedField<scalar, GeoMesh>& dsf1 = tdsf1();
|
||||||
|
|
||||||
|
if (!dsf1.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Base field is not dimensionless: " << dsf1.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!dsf2.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent field is not dimensionless: " << dsf2.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<DimensionedField<scalar, GeoMesh>> tPow = New
|
tmp<DimensionedField<scalar, GeoMesh>> tPow = New
|
||||||
(
|
(
|
||||||
tdsf1,
|
tdsf1,
|
||||||
"pow(" + dsf1.name() + ',' + dsf2.name() + ')',
|
"pow(" + dsf1.name() + ',' + dsf2.name() + ')',
|
||||||
pow
|
dimless
|
||||||
(
|
|
||||||
dsf1.dimensions(),
|
|
||||||
dimensionedScalar("1", 1.0, dsf2.dimensions())
|
|
||||||
)
|
|
||||||
);
|
);
|
||||||
|
|
||||||
pow(tPow.ref().field(), dsf1.field(), dsf2.field());
|
pow(tPow.ref().field(), dsf1.field(), dsf2.field());
|
||||||
@ -168,15 +188,25 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
{
|
{
|
||||||
const DimensionedField<scalar, GeoMesh>& dsf2 = tdsf2();
|
const DimensionedField<scalar, GeoMesh>& dsf2 = tdsf2();
|
||||||
|
|
||||||
|
if (!dsf1.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Base field is not dimensionless: " << dsf1.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!dsf2.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent field is not dimensionless: " << dsf2.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<DimensionedField<scalar, GeoMesh>> tPow = New
|
tmp<DimensionedField<scalar, GeoMesh>> tPow = New
|
||||||
(
|
(
|
||||||
tdsf2,
|
tdsf2,
|
||||||
"pow(" + dsf1.name() + ',' + dsf2.name() + ')',
|
"pow(" + dsf1.name() + ',' + dsf2.name() + ')',
|
||||||
pow
|
dimless
|
||||||
(
|
|
||||||
dsf1.dimensions(),
|
|
||||||
dimensionedScalar("1", 1.0, dsf2.dimensions())
|
|
||||||
)
|
|
||||||
);
|
);
|
||||||
|
|
||||||
pow(tPow.ref().field(), dsf1.field(), dsf2.field());
|
pow(tPow.ref().field(), dsf1.field(), dsf2.field());
|
||||||
@ -186,6 +216,7 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
return tPow;
|
return tPow;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
template<class GeoMesh>
|
template<class GeoMesh>
|
||||||
tmp<DimensionedField<scalar, GeoMesh>> pow
|
tmp<DimensionedField<scalar, GeoMesh>> pow
|
||||||
(
|
(
|
||||||
@ -196,6 +227,20 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
const DimensionedField<scalar, GeoMesh>& dsf1 = tdsf1();
|
const DimensionedField<scalar, GeoMesh>& dsf1 = tdsf1();
|
||||||
const DimensionedField<scalar, GeoMesh>& dsf2 = tdsf2();
|
const DimensionedField<scalar, GeoMesh>& dsf2 = tdsf2();
|
||||||
|
|
||||||
|
if (!dsf1.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Base field is not dimensionless: " << dsf1.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!dsf2.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent field is not dimensionless: " << dsf2.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<DimensionedField<scalar, GeoMesh>> tPow =
|
tmp<DimensionedField<scalar, GeoMesh>> tPow =
|
||||||
reuseTmpTmpDimensionedField<scalar, scalar, scalar, scalar, GeoMesh>::
|
reuseTmpTmpDimensionedField<scalar, scalar, scalar, scalar, GeoMesh>::
|
||||||
New
|
New
|
||||||
@ -203,11 +248,7 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
tdsf1,
|
tdsf1,
|
||||||
tdsf2,
|
tdsf2,
|
||||||
"pow(" + dsf1.name() + ',' + dsf2.name() + ')',
|
"pow(" + dsf1.name() + ',' + dsf2.name() + ')',
|
||||||
pow
|
dimless
|
||||||
(
|
|
||||||
dsf1.dimensions(),
|
|
||||||
dimensionedScalar("1", 1.0, dsf2.dimensions())
|
|
||||||
)
|
|
||||||
);
|
);
|
||||||
|
|
||||||
pow(tPow.ref().field(), dsf1.field(), dsf2.field());
|
pow(tPow.ref().field(), dsf1.field(), dsf2.field());
|
||||||
@ -226,6 +267,13 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
const dimensionedScalar& ds
|
const dimensionedScalar& ds
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
if (!ds.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent is not dimensionless: " << ds.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<DimensionedField<scalar, GeoMesh>> tPow
|
tmp<DimensionedField<scalar, GeoMesh>> tPow
|
||||||
(
|
(
|
||||||
new DimensionedField<scalar, GeoMesh>
|
new DimensionedField<scalar, GeoMesh>
|
||||||
@ -246,6 +294,7 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
return tPow;
|
return tPow;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
template<class GeoMesh>
|
template<class GeoMesh>
|
||||||
tmp<DimensionedField<scalar, GeoMesh>> pow
|
tmp<DimensionedField<scalar, GeoMesh>> pow
|
||||||
(
|
(
|
||||||
@ -253,6 +302,13 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
const dimensionedScalar& ds
|
const dimensionedScalar& ds
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
if (!ds.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent is not dimensionless: " << ds.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
const DimensionedField<scalar, GeoMesh>& dsf = tdsf();
|
const DimensionedField<scalar, GeoMesh>& dsf = tdsf();
|
||||||
|
|
||||||
tmp<DimensionedField<scalar, GeoMesh>> tPow = New
|
tmp<DimensionedField<scalar, GeoMesh>> tPow = New
|
||||||
@ -269,6 +325,7 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
return tPow;
|
return tPow;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
template<class GeoMesh>
|
template<class GeoMesh>
|
||||||
tmp<DimensionedField<scalar, GeoMesh>> pow
|
tmp<DimensionedField<scalar, GeoMesh>> pow
|
||||||
(
|
(
|
||||||
@ -279,6 +336,7 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
return pow(dsf, dimensionedScalar(s));
|
return pow(dsf, dimensionedScalar(s));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
template<class GeoMesh>
|
template<class GeoMesh>
|
||||||
tmp<DimensionedField<scalar, GeoMesh>> pow
|
tmp<DimensionedField<scalar, GeoMesh>> pow
|
||||||
(
|
(
|
||||||
@ -297,6 +355,20 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
const DimensionedField<scalar, GeoMesh>& dsf
|
const DimensionedField<scalar, GeoMesh>& dsf
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
if (!ds.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Base scalar is not dimensionless: " << ds.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!dsf.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent field is not dimensionless: " << dsf.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<DimensionedField<scalar, GeoMesh>> tPow
|
tmp<DimensionedField<scalar, GeoMesh>> tPow
|
||||||
(
|
(
|
||||||
new DimensionedField<scalar, GeoMesh>
|
new DimensionedField<scalar, GeoMesh>
|
||||||
@ -308,7 +380,7 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
dsf.db()
|
dsf.db()
|
||||||
),
|
),
|
||||||
dsf.mesh(),
|
dsf.mesh(),
|
||||||
pow(ds, dsf.dimensions())
|
dimless
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -327,11 +399,25 @@ tmp<DimensionedField<scalar, GeoMesh>> pow
|
|||||||
{
|
{
|
||||||
const DimensionedField<scalar, GeoMesh>& dsf = tdsf();
|
const DimensionedField<scalar, GeoMesh>& dsf = tdsf();
|
||||||
|
|
||||||
|
if (!ds.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Base scalar is not dimensionless: " << ds.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!dsf.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent field is not dimensionless: " << dsf.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<DimensionedField<scalar, GeoMesh>> tPow = New
|
tmp<DimensionedField<scalar, GeoMesh>> tPow = New
|
||||||
(
|
(
|
||||||
tdsf,
|
tdsf,
|
||||||
"pow(" + ds.name() + ',' + dsf.name() + ')',
|
"pow(" + ds.name() + ',' + dsf.name() + ')',
|
||||||
pow(ds, dsf.dimensions())
|
dimless
|
||||||
);
|
);
|
||||||
|
|
||||||
pow(tPow.ref().field(), ds.value(), dsf.field());
|
pow(tPow.ref().field(), ds.value(), dsf.field());
|
||||||
|
|||||||
@ -138,6 +138,20 @@ tmp<GeometricField<scalar, PatchField, GeoMesh>> pow
|
|||||||
const GeometricField<scalar, PatchField, GeoMesh>& gsf2
|
const GeometricField<scalar, PatchField, GeoMesh>& gsf2
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
if (!gsf1.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Base field is not dimensionless: " << gsf1.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!gsf2.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent field is not dimensionless: " << gsf2.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
||||||
(
|
(
|
||||||
new GeometricField<scalar, PatchField, GeoMesh>
|
new GeometricField<scalar, PatchField, GeoMesh>
|
||||||
@ -151,11 +165,7 @@ tmp<GeometricField<scalar, PatchField, GeoMesh>> pow
|
|||||||
IOobject::NO_WRITE
|
IOobject::NO_WRITE
|
||||||
),
|
),
|
||||||
gsf1.mesh(),
|
gsf1.mesh(),
|
||||||
pow
|
dimless
|
||||||
(
|
|
||||||
gsf1.dimensions(),
|
|
||||||
dimensionedScalar("1", gsf2.dimensions(), 1.0)
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -174,17 +184,27 @@ tmp<GeometricField<scalar, PatchField, GeoMesh>> pow
|
|||||||
{
|
{
|
||||||
const GeometricField<scalar, PatchField, GeoMesh>& gsf1 = tgsf1();
|
const GeometricField<scalar, PatchField, GeoMesh>& gsf1 = tgsf1();
|
||||||
|
|
||||||
|
if (!gsf1.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Base field is not dimensionless: " << gsf1.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!gsf2.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent field is not dimensionless: " << gsf2.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
||||||
(
|
(
|
||||||
New
|
New
|
||||||
(
|
(
|
||||||
tgsf1,
|
tgsf1,
|
||||||
"pow(" + gsf1.name() + ',' + gsf2.name() + ')',
|
"pow(" + gsf1.name() + ',' + gsf2.name() + ')',
|
||||||
pow
|
dimless
|
||||||
(
|
|
||||||
gsf1.dimensions(),
|
|
||||||
dimensionedScalar("1", gsf2.dimensions(), 1.0)
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -205,17 +225,27 @@ tmp<GeometricField<scalar, PatchField, GeoMesh>> pow
|
|||||||
{
|
{
|
||||||
const GeometricField<scalar, PatchField, GeoMesh>& gsf2 = tgsf2();
|
const GeometricField<scalar, PatchField, GeoMesh>& gsf2 = tgsf2();
|
||||||
|
|
||||||
|
if (!gsf1.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Base field is not dimensionless: " << gsf1.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!gsf2.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent field is not dimensionless: " << gsf2.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
||||||
(
|
(
|
||||||
New
|
New
|
||||||
(
|
(
|
||||||
tgsf2,
|
tgsf2,
|
||||||
"pow(" + gsf1.name() + ',' + gsf2.name() + ')',
|
"pow(" + gsf1.name() + ',' + gsf2.name() + ')',
|
||||||
pow
|
dimless
|
||||||
(
|
|
||||||
gsf1.dimensions(),
|
|
||||||
dimensionedScalar("1", gsf2.dimensions(), 1.0)
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -236,6 +266,20 @@ tmp<GeometricField<scalar, PatchField, GeoMesh>> pow
|
|||||||
const GeometricField<scalar, PatchField, GeoMesh>& gsf1 = tgsf1();
|
const GeometricField<scalar, PatchField, GeoMesh>& gsf1 = tgsf1();
|
||||||
const GeometricField<scalar, PatchField, GeoMesh>& gsf2 = tgsf2();
|
const GeometricField<scalar, PatchField, GeoMesh>& gsf2 = tgsf2();
|
||||||
|
|
||||||
|
if (!gsf1.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Base field is not dimensionless: " << gsf1.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!gsf2.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent field is not dimensionless: " << gsf2.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
||||||
(
|
(
|
||||||
reuseTmpTmpGeometricField
|
reuseTmpTmpGeometricField
|
||||||
@ -244,11 +288,7 @@ tmp<GeometricField<scalar, PatchField, GeoMesh>> pow
|
|||||||
tgsf1,
|
tgsf1,
|
||||||
tgsf2,
|
tgsf2,
|
||||||
"pow(" + gsf1.name() + ',' + gsf2.name() + ')',
|
"pow(" + gsf1.name() + ',' + gsf2.name() + ')',
|
||||||
pow
|
dimless
|
||||||
(
|
|
||||||
gsf1.dimensions(),
|
|
||||||
dimensionedScalar("1", gsf2.dimensions(), 1.0)
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -281,6 +321,13 @@ tmp<GeometricField<scalar, PatchField, GeoMesh>> pow
|
|||||||
const dimensionedScalar& ds
|
const dimensionedScalar& ds
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
if (!ds.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent is not dimensionless: " << ds.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
||||||
(
|
(
|
||||||
new GeometricField<scalar, PatchField, GeoMesh>
|
new GeometricField<scalar, PatchField, GeoMesh>
|
||||||
@ -310,6 +357,13 @@ tmp<GeometricField<scalar, PatchField, GeoMesh>> pow
|
|||||||
const dimensionedScalar& ds
|
const dimensionedScalar& ds
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
if (!ds.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent is not dimensionless: " << ds.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
const GeometricField<scalar, PatchField, GeoMesh>& gsf = tgsf();
|
const GeometricField<scalar, PatchField, GeoMesh>& gsf = tgsf();
|
||||||
|
|
||||||
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
||||||
@ -370,6 +424,20 @@ tmp<GeometricField<scalar, PatchField, GeoMesh>> pow
|
|||||||
const GeometricField<scalar, PatchField, GeoMesh>& gsf
|
const GeometricField<scalar, PatchField, GeoMesh>& gsf
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
if (!ds.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Base scalar is not dimensionless: " << ds.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!gsf.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent field is not dimensionless: " << gsf.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
||||||
(
|
(
|
||||||
new GeometricField<scalar, PatchField, GeoMesh>
|
new GeometricField<scalar, PatchField, GeoMesh>
|
||||||
@ -383,7 +451,7 @@ tmp<GeometricField<scalar, PatchField, GeoMesh>> pow
|
|||||||
IOobject::NO_WRITE
|
IOobject::NO_WRITE
|
||||||
),
|
),
|
||||||
gsf.mesh(),
|
gsf.mesh(),
|
||||||
pow(ds, gsf.dimensions())
|
dimless
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -402,13 +470,27 @@ tmp<GeometricField<scalar, PatchField, GeoMesh>> pow
|
|||||||
{
|
{
|
||||||
const GeometricField<scalar, PatchField, GeoMesh>& gsf = tgsf();
|
const GeometricField<scalar, PatchField, GeoMesh>& gsf = tgsf();
|
||||||
|
|
||||||
|
if (!ds.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Base scalar is not dimensionless: " << ds.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!gsf.dimensions().dimensionless())
|
||||||
|
{
|
||||||
|
FatalErrorInFunction
|
||||||
|
<< "Exponent field is not dimensionless: " << gsf.dimensions()
|
||||||
|
<< exit(FatalError);
|
||||||
|
}
|
||||||
|
|
||||||
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
tmp<GeometricField<scalar, PatchField, GeoMesh>> tPow
|
||||||
(
|
(
|
||||||
New
|
New
|
||||||
(
|
(
|
||||||
tgsf,
|
tgsf,
|
||||||
"pow(" + ds.name() + ',' + gsf.name() + ')',
|
"pow(" + ds.name() + ',' + gsf.name() + ')',
|
||||||
pow(ds, gsf.dimensions())
|
dimless
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user