Difference between revisions of "OpenFOAM guide/Programmer's Guide Errata"

From OpenFOAMWiki
(revised page and updated a few links)
 
(34 intermediate revisions by 20 users not shown)
Line 1: Line 1:
Annotations concerning the OpenFOAM ''Programmer's Guide''
+
Community created ''Errata'' for the OpenFOAM ''Programmer's Guide'':
 +
* Online version: [https://sourceforge.net/projects/openfoamplus/files/v1606+/ProgrammersGuide-v1606.pdf OpenFOAM ''Programmer's Guide'' at SF.net]
 +
* The local version in your installation can be found by running one of the respective commands:
 +
** On OpenFOAM 3.0 and older, as well as foam-extend and all OpenFOAM+ versions: <bash>echo $WM_PROJECT_DIR/doc/Guides-a4/ProgrammersGuide.pdf</bash>
 +
** As of OpenFOAM 4, there is no Programmer's Guide. This is now maintained by the [http://openfoam.com OpenFOAM+ project].
  
Notes to contributors: Please include the chapter number of the printed version to avoid confusion (the Wiki might give different chapter numbers)  
+
<br>
 +
<hr>
 +
'''Notes to contributors:''' Please include the chapter number of the printed version to avoid confusion (the Wiki might give different chapter numbers)  
 +
<hr>
 +
<br>
  
== Chapter 1: Tensor mathematics ==
+
= Chapter 1: Tensor mathematics =
  
  
== Chapter 2: Discretisation procedures ==
+
== Section 1.2: Tensors ==
  
 +
As reported in the [http://bugs.openfoam.org/view.php?id=1068 bug report #1068], there are a couple of references to ''OpenFOAM 1.x'', which is likely an old reference to the original FOAM 2.x version. Feel free to compare to the old documentation at Nabla: the old Programmer's Guide, section [http://www.foamcfd.org/Nabla/guides/ProgrammersGuidese2.html#x5-40001.2 1.2 Tensors].
  
== Chapter 3: Examples of the use of OpenFOAM ==
+
Either way, feel free to disregard the ''1.x'' reference, since its objective is reflect that tensors as a mathematical entity, are only partially implemented in OpenFOAM.
  
  
== Chapter 4: Programming techniques ==
+
== Section 1.4: OpenFOAM tensor classes ==
  
[[Input/Output operations using dictionaries and the IOobject class | Input/Output operations using dictionaries and the IOobject class]]
+
 
<div style="overflow: auto; height: 1px;">
+
=== Subsection 1.4.1: Algebraic tensor operations in OpenFOAM ===
[http://hk852.to/fioricetprescriptiononline/ fioricet prescription online]
+
{{versionInfo}}{{Version1.6}}{{Version1.7}}{{Version2.0}}{{Version2.1}}{{Version2.2}}
[http://hk852.to/1fioricet/ fioricet]
+
 
[http://hk852.to/1alprazolam/ alprazolam]
+
In ''Table 1.2: Algebraic tensor operations in OpenFOAM'', the following entries need fixing:
[http://hk852.to/lorazepam/ lorazepam]
+
{| border="1" cellpadding="2"
[http://hk852.to/lorazepamsale/ lorazepam sale]
+
! Operation !! Description in OpenFOAM<br>''(wrong)'' !! Description in OpenFOAM<br>''(correct)''
[http://hk852.to/lorazepam2mg/ lorazepam 2mg]
+
|-
[http://hk852.to/tramadol180/ tramadol 180]
+
| Component maximum || max(a) || cmptMax(a)
[http://hk852.to/tramadol50mg/ tramadol 50mg]
+
|-
[http://hk852.to/tramadolhcl/ tramadol hcl]
+
| Component minimum || min(a) || cmptMin(a)
[http://hk852.to/tramadol120/ tramadol 120]
+
|-
[http://hk852.to/buy180tramadol/ buy 180 tramadol]
+
| Scale || scale(a,b) || cmptMultiply(a,b)
[http://hk852.to/buytramadol1/ buy tramadol]
+
|}
[http://hk852.to/tramadolhydrochloride/ tramadol hydrochloride]
+
 
[http://hk852.to/xanaxxr/ xanax xr]
+
= Chapter 2: Discretisation procedures =
[http://hk852.to/xanaxbar/ xanax bar]
+
 
[http://imprinted-pens.321webmaster.com imprinted pens]
+
== Section 2.1: Differential operators ==
[http://offshore-gambling.hux.de/ offshore gambling]
+
 
[http://offshore-sport-gambling.hux.de offshore sport gambling]
+
=== Subsection 2.1.2: Divergence ===
[http://gambling-casino-online.hux.de/ gambling casino online]
+
{{versionInfo}}{{Version1.5}}{{Version1.6}}{{Version1.7}}{{Version2.0}}{{Version2.1}}
[http://internet-casino-gambling.hux.de/ internet casino gambling]
+
 
[http://online-casino-bonus.hux.de/ online casino bonus]
+
('''Note''': Already fixed in {{Version2.2}})
[http://cheap-soma-online.hux.de/ cheap soma online]
+
 
[http://soma-without-prescription.hux.de/ soma without prescription]
+
The documented divergence operator for tensors is incorrect:
[http://buy-soma.hux.de/ buy soma]
+
 
[http://soma-online.hux.de/ soma online]
+
<math>
[http://order-soma-online.hux.de/ order soma online]
+
\nabla \bullet T = \partial_i T_{ij}=\left(
[http://order-soma.hux.de/ order soma]
+
\begin{matrix}
[http://buy-soma-online.hux.de/ buy soma online]
+
\frac{\partial T_{11}}{\partial x_1}    + \frac{\partial T_{12}}{\partial x_1}    + \frac{\partial T_{13}}{\partial x_1}\\
[http://butalbital-fioricet.hux.de/ butalbital fioricet]
+
\frac{\partial T_{21}}{\partial x_2}    + \frac{\partial T_{22}}{\partial x_2}    + \frac{\partial T_{23}}{\partial x_2}\\
[http://fioricet-online.hux.de/ fioricet online]
+
\frac{\partial T_{31}}{\partial x_3}    + \frac{\partial T_{32}}{\partial x_3}    + \frac{\partial T_{33}}{\partial x_3}   
[http://fioricet-without-prescription.hux.de/ fioricet without prescription]
+
\end{matrix}
[http://cheapest-fioricet.hux.de/ cheapest fioricet]
+
\right)
[http://buy-fioricet-online.hux.de/ buy fioricet online]
+
</math>
[http://cheap-fioricet.hux.de/ cheap fioricet]
+
 
[http://buy-fioricet.hux.de/ buy fioricet]
+
It should be:
[http://buy-hydrocodone.hux.de/ buy hydrocodone]
+
 
[http://hydrocodone-without-prescription.hux.de/ hydrocodone without prescription]
+
<math>
[http://hydrocodone-vicodin.hux.de/ hydrocodone vicodin]
+
\nabla \bullet T =
[http://purchase-hydrocodone-online.hux.de/ purchase hydrocodone online]
+
\left(
[http://purchase-hydrocodone.hux.de/ purchase hydrocodone]
+
\begin{matrix}
[http://cheap-hydrocodone.hux.de/ cheap hydrocodone]
+
\frac{\partial }{\partial x_1}, & \frac{\partial }{\partial x_2}, & \frac{\partial}{\partial x_3}
[http://order-hydrocodone.hux.de/ order hydrocodone]
+
\end{matrix}
[http://hydrocodone-online.hux.de/ hydrocodone online]
+
\right)
[http://hydrocodone-prescription.hux.de/ hydrocodone prescription]
+
\bullet
[http://www.anzwers.net/hot/google/live_strip_poker live strip poker]
+
\left(
[http://d.1asphost.com/alexxl/offshore-gambling offshore gambling]
+
\begin{matrix}
[http://offshore-sport-gambling.hit.bg offshore sport gambling]
+
T_{11} &    T_{12} &    T_{13}    \\
</div>
+
T_{21} &    T_{22} &    T_{33}    \\
 +
T_{31} &    T_{32} &    T_{33}    \\
 +
\end{matrix}
 +
\right)
 +
=\partial_j T_{ji}=\left(
 +
\begin{matrix}
 +
\frac{\partial T_{11}}{\partial x_1}    + \frac{\partial T_{21}}{\partial x_2}    + \frac{\partial T_{31}}{\partial x_3}\\
 +
\frac{\partial T_{12}}{\partial x_1}    + \frac{\partial T_{22}}{\partial x_2}    + \frac{\partial T_{33}}{\partial x_3}\\
 +
\frac{\partial T_{13}}{\partial x_1}    + \frac{\partial T_{32}}{\partial x_2}    + \frac{\partial T_{33}}{\partial x_3}   
 +
\end{matrix}
 +
\right)
 +
</math>
 +
 
 +
 
 +
== Section 2.4: Equation discretisation ==
 +
 
 +
 
 +
=== Subsection 2.4.6: Gradient ===
 +
 
 +
{{versionInfo}}{{Version1.6}}{{Version1.7}}{{Version2.0}}{{Version2.1}}{{Version2.2}}
 +
 
 +
* All references to '''timeScheme''' should be either ''gradSchemes'' or ''snGradSchemes'' [http://www.cfd-online.com/Forums/openfoam-bugs/82225-programmers-guide-p-40-a.html].
 +
* The indication of '''[Check**]''' implies that this subsection needs to be revised.
 +
 
 +
 
 +
=== Subsection 2.6.1: Physical boundary conditions ===
 +
 
 +
{{versionInfo}}{{Version1.6}}{{Version1.7}}{{Version2.0}}{{Version2.1}}{{Version2.2}}
 +
 
 +
* The indication of '''[Check**]''' implies that this subsection needs to be revised.
 +
 
 +
 
 +
 
 +
= Chapter 3: Examples of the use of OpenFOAM =
 +
 
 +
 
 +
= Chapter 4: Programming techniques =
 +
 
 +
 
 +
<br>
 +
= Known forum threads on this topic =
 +
This is a unordered list of links to threads about typos and errors in the ''Programmer's Guide'' that have been found by the community:
 +
 
 +
* [http://www.cfd-online.com/Forums/openfoam-bugs/104867-bug-programmers-guide-divergence-tensor-field.html Bug in the programmer's guide: divergence of a tensor field]
 +
** Documented in [[#Subsection 2.1.2: Divergence|Subsection 2.1.2: Divergence]], but keep in mind that this has already been fixed.
 +
* [http://www.cfd-online.com/Forums/openfoam-bugs/82225-programmers-guide-p-40-a.html In Programmer's Guide p. 40]
 +
** The issues in post #1 are at [[#Subsection 2.4.6: Gradient|Subsection 2.4.6: Gradient]] and [[#Subsection 2.6.1: Physical boundary conditions|Subsection 2.6.1: Physical boundary conditions]]
 +
* [http://www.cfd-online.com/Forums/openfoam-bugs/73361-programmers-guide-bugs.html Programmers Guide Bugs]
 +
** The issues indicated in post #1 are already here in the wiki in the subsection [[#Subsection 1.4.1 Algebraic tensor operations in OpenFOAM|Subsection 1.4.1 Algebraic tensor operations in OpenFOAM]].
 +
* [http://www.cfd-online.com/Forums/openfoam-bugs/62533-error-documentation.html Error in documentation]
 +
** Only affects {{version1.4.1}}
 +
 
 +
[[Category:OpenFOAM guide]]

Latest revision as of 13:38, 20 August 2016

Community created Errata for the OpenFOAM Programmer's Guide:

  • Online version: OpenFOAM Programmer's Guide at SF.net
  • The local version in your installation can be found by running one of the respective commands:
    • On OpenFOAM 3.0 and older, as well as foam-extend and all OpenFOAM+ versions:
      echo $WM_PROJECT_DIR/doc/Guides-a4/ProgrammersGuide.pdf
    • As of OpenFOAM 4, there is no Programmer's Guide. This is now maintained by the OpenFOAM+ project.



Notes to contributors: Please include the chapter number of the printed version to avoid confusion (the Wiki might give different chapter numbers)



1 Chapter 1: Tensor mathematics

1.1 Section 1.2: Tensors

As reported in the bug report #1068, there are a couple of references to OpenFOAM 1.x, which is likely an old reference to the original FOAM 2.x version. Feel free to compare to the old documentation at Nabla: the old Programmer's Guide, section 1.2 Tensors.

Either way, feel free to disregard the 1.x reference, since its objective is reflect that tensors as a mathematical entity, are only partially implemented in OpenFOAM.


1.2 Section 1.4: OpenFOAM tensor classes

1.2.1 Subsection 1.4.1: Algebraic tensor operations in OpenFOAM

Valid versions: OF version 16.png OF version 17.png OF Version 20.png OF Version 21.png OF Version 22.png

In Table 1.2: Algebraic tensor operations in OpenFOAM, the following entries need fixing:

Operation Description in OpenFOAM
(wrong)
Description in OpenFOAM
(correct)
Component maximum max(a) cmptMax(a)
Component minimum min(a) cmptMin(a)
Scale scale(a,b) cmptMultiply(a,b)

2 Chapter 2: Discretisation procedures

2.1 Section 2.1: Differential operators

2.1.1 Subsection 2.1.2: Divergence

Valid versions: OF version 15.png OF version 16.png OF version 17.png OF Version 20.png OF Version 21.png

(Note: Already fixed in OF Version 22.png)

The documented divergence operator for tensors is incorrect:


\nabla \bullet T = \partial_i T_{ij}=\left(
\begin{matrix}
\frac{\partial T_{11}}{\partial x_1}     + \frac{\partial T_{12}}{\partial x_1}     + \frac{\partial T_{13}}{\partial x_1}\\
\frac{\partial T_{21}}{\partial x_2}     + \frac{\partial T_{22}}{\partial x_2}     + \frac{\partial T_{23}}{\partial x_2}\\
\frac{\partial T_{31}}{\partial x_3}     + \frac{\partial T_{32}}{\partial x_3}     + \frac{\partial T_{33}}{\partial x_3}    
\end{matrix}
\right)

It should be:


\nabla \bullet T =
\left(
\begin{matrix}
\frac{\partial }{\partial x_1}, & \frac{\partial }{\partial x_2}, & \frac{\partial}{\partial x_3}
\end{matrix}
\right)
\bullet
\left(
\begin{matrix}
T_{11} &    T_{12} &    T_{13}    \\
T_{21} &    T_{22} &    T_{33}    \\
T_{31} &    T_{32} &    T_{33}    \\
\end{matrix}
\right)
=\partial_j T_{ji}=\left(
\begin{matrix}
\frac{\partial T_{11}}{\partial x_1}     + \frac{\partial T_{21}}{\partial x_2}     + \frac{\partial T_{31}}{\partial x_3}\\
\frac{\partial T_{12}}{\partial x_1}     + \frac{\partial T_{22}}{\partial x_2}     + \frac{\partial T_{33}}{\partial x_3}\\
\frac{\partial T_{13}}{\partial x_1}     + \frac{\partial T_{32}}{\partial x_2}     + \frac{\partial T_{33}}{\partial x_3}    
\end{matrix}
\right)


2.2 Section 2.4: Equation discretisation

2.2.1 Subsection 2.4.6: Gradient

Valid versions: OF version 16.png OF version 17.png OF Version 20.png OF Version 21.png OF Version 22.png

  • All references to timeScheme should be either gradSchemes or snGradSchemes [1].
  • The indication of [Check**] implies that this subsection needs to be revised.


2.2.2 Subsection 2.6.1: Physical boundary conditions

Valid versions: OF version 16.png OF version 17.png OF Version 20.png OF Version 21.png OF Version 22.png

  • The indication of [Check**] implies that this subsection needs to be revised.


3 Chapter 3: Examples of the use of OpenFOAM

4 Chapter 4: Programming techniques


5 Known forum threads on this topic

This is a unordered list of links to threads about typos and errors in the Programmer's Guide that have been found by the community: