Coordinate system issues: cylindricalCS / fixedProfileFvPatchField
- cyclindricalCS cannot be run-time selected: missing TypeName and addToRunTimeSelectionTable.
- hard to specify
coordinateSystem
{
coordinateRotation
{
type axesRotation;
e3 (1 0 0);
e1 (0 1 0);
}
type cylindricalCS;
origin (0 0 0.01);
}
With this in place we could re-write various boundary conditions to use cylindrical coordinates. E.g. fixedProfileFvPatchField
.
Remark: cylindrical coordinateRotation currently stores transformation tensors. This should be stored outside.
No child items are currently assigned. Use child items to break down this issue into smaller parts.
Link issues together to show that they're related. Learn more.
Activity
- Author Maintainer
Or have Function2, Function3 and directly obtain a value from a (set of) 2D/3D coordinate(s).
This could ultimately replace e.g. timeVaryingMappedFixedValue.
- Mattijs Janssens changed the description
changed the description
- Mattijs Janssens changed title from fixedProfileFvPatchField is 1D in cartesion coords only. Why not e.g. axisymmetric to Coordinate system issues: cylindricalCS / fixedProfileFvPatchField
changed title from fixedProfileFvPatchField is 1D in cartesion coords only. Why not e.g. axisymmetric to Coordinate system issues: cylindricalCS / fixedProfileFvPatchField
- Mattijs Janssens changed the description
changed the description
- Mattijs Janssens added bug label
added bug label
- Author Maintainer
coordinate system cannot be re-read. It requires keyword coordinateRotation which does not get written. Writing gets done with:
os.writeKeyword("coordinateSystem"); coordSys_->writeDict(os, true);
- type gets written as coordinateSystem instead of cylindrical
- there is no coordinateRotation section
Edited by Mattijs Janssens - Author Maintainer
coordinateSystem::New(const dictionary&)
doesn't use the run-time selection system so is only good for constructing a coordinateRotation. - Maintainer
While fixing #884 (closed), I started taking a more general re-visit of coordinate systems. I have a local branch with various bits of refactoring that will cleanup a fair amount of other junk.
I also noticed the output you mention (which really does look quite dubious), but held off making any radical changes at all for 1806.
I believe that the
coordinateSystem::New(const dictionary&)
is a holdover from when the globally referenced coordinate systems got put in and we changed to the two-parameter form. At some point, these were also supposed to work with havingtype
being optional and defaulting to the equivalent ofcartesian
. - Author Maintainer
More: coordinateSystem has non-virtual clone(), writeDict(). clone() uses default copy constructor so does not copy coordinateRotation (since autoPtr steals it). Hence cannot be used in e.g. bc in decomposePar.
- Maintainer
This is one of the issues that I detected with autoPtr. This is the main reason std::auto_ptr was deprecated and replaced with std::unique_ptr that only allows a move construct and move assignment.
If we undefine these
// Transitional features/misfeatures: #define Foam_autoPtr_copyConstruct #define Foam_autoPtr_copyAssign #define Foam_autoPtr_castOperator
we'd see that things like coordinateSystem etc have default copy constructors, which implicitly call the autoPtr copy (and steal) constructor.
IMO stealing should be disallowed, but this means that all classes that currently have an autoPtr as a member will to explicitly define a copy constructor.
Edited by Mark OLESEN - Mark OLESEN mentioned in commit 8a9db156
mentioned in commit 8a9db156
- Mark OLESEN mentioned in commit f34edc62
mentioned in commit f34edc62
- Mark OLESEN mentioned in commit 1a7cc714
mentioned in commit 1a7cc714
- Mark OLESEN mentioned in commit 3c3cf51f
mentioned in commit 3c3cf51f
- Maintainer
Conclusions from discussion yesterday with @Mattijs about !211 (merged)
- The split of coordinate system into the origin (coordinateSystem) and orientation (coordinateRotation) isn't really need. We only need a runtime means of specifying the orientation. So move the rotation matrix to be a direct part of coordinateSystem and its associated transformations.
- Position-dependent transformations (eg, a vector at some location in a cylindrical coordinate system) belong in the corresponding coordinate system (eg, cylindricalCS).
Discussion today with @andy.
- OK with the above points, but for things like rotorDiskSource that are called often, should provide a caching mechanism for the position-dependent rotation tensors. The caching may need to be realized via some fancy sub-class instance or equivalent with a capture of a given pointField reference.
The current coordinateRotation has both
R()
andRtr()
, but we can eliminate one of these by simply using the opposite tensor-vector, vector-tensor inner product instead.
Edited by Mark OLESEN - Author Maintainer
caching mechanism: can we see if it goes without. For most cylindrical transformations we don't need a tensor but can just use a crossproduct instead.
- Mark OLESEN mentioned in commit 301ffe43
mentioned in commit 301ffe43
- Mark OLESEN mentioned in commit 0d3bcd1b
mentioned in commit 0d3bcd1b
- Mark OLESEN mentioned in commit e338c11a
mentioned in commit e338c11a
- Mark OLESEN mentioned in commit 53637669
mentioned in commit 53637669
- Mark OLESEN mentioned in commit 331e53b5
mentioned in commit 331e53b5
- Mark OLESEN mentioned in commit a4362605
mentioned in commit a4362605
- Mark OLESEN mentioned in commit 00a509ea
mentioned in commit 00a509ea
- Mark OLESEN mentioned in commit a947ee23
mentioned in commit a947ee23
- Mark OLESEN mentioned in commit fb13c6af
mentioned in commit fb13c6af
- Mark OLESEN mentioned in commit 065a2089
mentioned in commit 065a2089
- Mark OLESEN mentioned in commit 0d792cd5
mentioned in commit 0d792cd5
- Mark OLESEN mentioned in commit c75d5118
mentioned in commit c75d5118
- Mark OLESEN mentioned in commit e2182625
mentioned in commit e2182625
- Mattijs Janssens mentioned in commit 07e29aef
mentioned in commit 07e29aef
- Mark OLESEN mentioned in commit 4b338a33
mentioned in commit 4b338a33
- Mark OLESEN mentioned in commit b608f90e
mentioned in commit b608f90e
- Mark OLESEN mentioned in commit cbf94175
mentioned in commit cbf94175
- Mark OLESEN mentioned in commit e9acb89a
mentioned in commit e9acb89a