Barak Shoshany
Department of Physics, Brock University,
1812 Sir Isaac Brock Way, St. Catharines, Ontario, L2S 3A1, Canada
[email protected] | https://baraksh.com/
DOI: 10.21105/joss.03416
- New modules:
TCalcGeodesicWithTimeParameter[]
calculates the geodesic equations with respect to the time parameter (which is assumed to be the first coordinate) instead of an affine curve parameter.TCalcNormSquared[]
calculates the norm-squared of a tensor with respect to its metric, that is, the tensor contracted with itself in all indices. For example, for a vector vμ the norm-squared will be vμvμ and for a rank-2 tensor Tμν the result will be Tμν Tμν.TCite[]
displays information on how to cite this package in published research. Thank you for citing my work! :)
- Changes to existing modules:
TCalc*
modules no longer display a progress bar for the calculation. The progress bar wasn't too useful, since almost all tensor calculations are very fast even on an average laptop. Simplifications are the only operations which take any considerable amount of time, and thus progress bars are now displayed only for simplifications.TCovariantD
andTPartialD
:- If
TCovariantD
is used on a scalar, it is now replaced automatically withTPartialD
to improve performance, since the covariant derivative of a scalar is just a partial derivative anyway. - Fixed bug where acting on scalars incorrectly returned a list of lists instead of a vector.
- If
TGetComponents
now applies a function given in the last argument to the components, and then simplifies them (in parallel, if parallelization is enabled), before returning the components. Note thatTShow
andTList
have already had this option for some time, but nowTGetComponents
has it too.TLineElement
now simplifies the line element before returning it.TSimplify
now allows the user to simplify any expression, not just tensor objects.TSimplify[expression]
simplifiesexpression
based on the user-defined simplification assumptions set usingTSetAssumptions
. Ifexpression
is aList
, the components will be simplified in parallel. The user can thus make use of OGRe's optimized simplification process to simplify any Mathematica expression.
- Other changes:
- Fixed a bug where simplification assumptions were not applied correctly if parallelization was enabled.
- Added arXiv badge to
README.md
andCHANGELOG.md
. - Added a
CITATION.cff
file (in YAML format) to the GitHub repository. This should add an option to get a citation in different formats directly from GitHub repository by clicking on "cite this repository" on the sidebar to the right. - Added a
CITATION.bib
file (in BibTeX format) to the GitHub repository. You can use it to easily cite this package in your papers.
- This package is now published in the Journal of Open Source Software! I added links to the paper and updated the citation information. The old Zenodo citation should not be used anymore.
- If you use this package in published research, please cite the JOSS paper as detailed in the documentation. A BibTeX entry is also provided.
- The source code itself has not been changed.
- New modules:
TCalcGeodesicFromChristoffel
:- Creates a new rank-1 tensor object containing the geodesic equations obtained for each of the coordinates using the Christoffel symbols of the given metric: ẍσ + Γσμνẋμẋν = 0.
- The Christoffel symbols will be calculated automatically using
TCalcChristoffel
if they have not already been calculated.
TCalcGeodesicFromLagrangian
:- Creates a new rank-1 tensor object containing the geodesic equations obtained for each of the coordinates by applying the Euler-Lagrange equations to the curve Lagrangian.
- The Lagrangian will be calculated automatically using
TCalcLagrangian
(see below) if it has not already been calculated. - This module leaves the derivatives with respect to the curve parameter in the Euler-Lagrange equation unevaluated (using
Inactive
), which can sometimes help solve the geodesic equations by inspection. UseActivate
to evaluate the derivatives. (Recall thatTList
andTShow
can apply a function to the tensor's components before displaying them, so you can write e.g.TList["ID", Activate]
.) - Often the equations obtained in this way will be different from the ones obtained using
TCalcGeodesicFromChristoffel
, but they will always have the same solutions. Usually, one ofTCalcGeodesicFromChristoffel
orTCalcGeodesicFromLagrangian
will generate simpler equations for a given metric and/or coordinate system.
TCalcLagrangian
: Calculates the curve Lagrangian of a metric, defined as the norm-squared of the tangent to the curve: gμνẋμẋν. Taking the square root of (the absolute value of) the Lagrangian yields the integrand of the curve length functional. Varying the Lagrangian using the Euler-Lagrange equations yields the geodesic equations (seeTCalcGeodesicFromLagrangian
above).TMessage
:- Not really a module, just a placeholder symbol to which messages not associated with any specific OGRe module are attached.
- In particular, when a private module (called only internally within the package) invokes
Message
, the message will now be displayed asTMessage::<message_name>
instead of the awkwardOGRe`Private`<module_name>::<message_name>
. - Not all modules use
TMessage
yet; the transition will be performed gradually in the upcoming releases.
TSetAllowOverwrite
:- Allows or disallows overwriting tensors. The default value is
False
, which means you cannot create a new tensor with the same ID as an existing tensor. CallingTSetAllowOverwrite[True]
will allow overwriting tensors, which is more convenient, but can result in loss of data. - You will be warned whenever a tensor is being overwritten, but this warning can be turned off (like any other
Message
) usingOff[TMessage::WarningOverwrite]
. - This setting is persistent between sessions.
- Allows or disallows overwriting tensors. The default value is
TSetCurveParameter
:- Sets the curve parameter used by
TCalcGeodesicFromChristoffel
,TCalcGeodesicFromLagrangian
, andTCalcLagrangian
. These modules will produce results in terms of the coordinate symbols as functions of the curve parameter and their derivatives with respect to this parameter. The default value is λ. - If the Lagrangian or geodesic equation vector is displayed using
TList
orTShow
, the arguments of the coordinate functions are omitted (e.g. x instead of x[λ]) and derivatives with respect to the curve parameter are displayed in Newton (dot) notation (e.g. ẋ instead of x'[λ]) for improved readability. However, extracting the components usingTGetComponents
will produce the full expressions (e.g. to be used withDSolve
). - When the curve parameter is changed, the parameter of the coordinate functions in all of the tensors calculated so far will be changed accordingly.
- Sets the curve parameter used by
TSetReservedSymbols
:- Works similar to
TInitializeSymbols
, which has now been removed. However,TSetReservedSymbols
also saves the reserved symbols so they can be exported and then imported in a later session. - If the reserved symbol is a function of the coordinates,
TList
andTShow
will not show the arguments of the function when displaying the components of a tensor, for improved readability.
- Works similar to
TVolumeElementSquared
: Calculates the determinant of a given metric. The square root of the determinant (or its negative, for a pseudo-Riemannian metric) is the volume element.
- Changes to existing modules:
- All
TCalc*
modules now check if the metric exists first. TGetComponents
: This module now gets the components of the tensor in the default index configuration and/or coordinate system if either or both are not specified. However, if the default value is used, a message will let you know which representation the components are given in, to avoid confusion.TInitializeSymbols
has been removed and replaced withTSetReservedSymbols
(see above).TList
andTShow
:- Partial derivatives are now displayed in compact notation for improved readability.
TList
will no longer list the same element twice if it is non-zero but equal to minus itself (e.g.ComplexInfinity
).- See
TSetCurveParameter
andTSetReservedSymbols
above for other changes.
TNewMetric
: If the new metric overrides a previous metric with the same ID, all of the curvature tensors calculated from the metric being overwritten will be automatically deleted, for consistency.TSetParallelization
:- Now uses
$MaxLicenseSubprocesses
instead of the deprecated (as of Mathematica 12.3)$ConfiguredKernels
to determine how many kernels to launch when enabling parallelization. - Disabling parallelization now also closes the kernels.
- Tensor simplifications will no longer invoke parallelization if the tensor only has one component, to avoid unnecessary overhead.
- Now uses
- All
- Other changes:
- A button to open the GitHub repository directly in Visual Studio Code has been added to the badges in
README.md
.
- A button to open the GitHub repository directly in Visual Studio Code has been added to the badges in
- This release is dedicated to my grandfather Yona Shoshany, who taught me BASIC, my first programming language, in my early childhood. He passed away a day before this release was published.
- New modules:
TLineElement
: Displays the line element of a given metric in a coordinate system of your choice.TSetAutoUpdates
: Enables or disables automatic checks for updates at startup. Note that this setting is persistent between sessions.
- Changes to existing modules:
TInfo
:- Whenever this module prints out the name of a related tensor (e.g. the metric or the default coordinates), clicking on the tensor's name will execute
TInfo
for that tensor. - This module now provides clickable links for printing out the components of the tensor using
TList
orTShow
. - Calling
TInfo[]
with no parameters lists all the tensors created so far in this session: coordinate systems, metrics, and the tensors associated with each metric.
- Whenever this module prints out the name of a related tensor (e.g. the metric or the default coordinates), clicking on the tensor's name will execute
TSetParallelization
: CallingTSetParallelization[]
with no parameters now returns the current setting,True
orFalse
.
- Other changes:
- The startup message is now more compact. Instead of saying "To do X, type Y or click here", it now just says "To do X, type Y", where Y is a clickable link which executes the relevant command.
- The previous release of the package introduced an incompatibility with Mathematica 12.0 due to the use of the
Splice
function, which only works in v12.1 and later. This has now been fixed, and compatibility with v12.0 has been restored. Although I always develop the package using the latest version of Mathematica, I have now installed Mathematica 12.0 on my computer alongside the latest version, and will use it to ensure compatibility with v12.0 in all future releases of the package. - Dynamic content was removed from
OGRe_Documentation.nb
to prevent the message "This file contains potentially unsafe dynamic content" from appearing when opening it. - The version history has become too long to be included in
README.md
, so I moved it to a separate file,CHANGELOG.md
.
- Changes to existing modules:
TAddCoordTransformation
now has the clearer syntaxTAddCoordTransformation[sourceID -> targetID, rules]
. The old syntax (with,
instead of->
) can still be used.TChangeID
now has the clearer syntaxTChangeID[oldID -> newID]
. The old syntax (with,
instead of->
) can still be used.TChristoffel
,TEinsteinTensor
,TRicciScalar
,TRicciTensor
, andTRiemannTensor
have been renamed toTCalcChristoffel
,TCalcEinsteinTensor
,TCalcRicciScalar
,TCalcRicciTensor
, andTCalcRiemannTensor
respectively, to group them all together and clarify that they all calculate specific tensors usingTCalc
.TIndexLetters
,TParallelize
, andTSimplifyAssumptions
have been renamed toTSetIndexLetters
,TSetParallelization
, andTSetAssumptions
respectively, to group them all together and clarify that they all change various settings.TCalc
,TCalcChristoffel
,TCalcEinsteinTensor
,TCalcRicciScalar
,TCalcRicciTensor
,TCalcRiemannTensor
,TChangeID
,TImport
,TNewCoordinates
,TNewMetric
, andTNewTensor
no longer overwrite existing tensors, to prevent data loss. The user will be instructed to rename the existing tensor usingTChangeID
or delete it usingTDelete
first.
- Other changes:
- Usage messages:
- Many usage messages have been simplified, improved, or clarified.
- Fixed a bug where loading the package directly from GitHub led to usage messages not being displayed properly due to doubling of line breaks.
- The way that usage messages are defined internally has also been simplified.
- Automatic checks for update:
- The package now checks for new versions automatically at startup. No information (personal or otherwise) is sent or collected; the package simply checks the GitHub repository for updates. This check is done asynchronously, to prevent delaying the loading of the package.
- An upcoming release will introduce persistent storage of user settings, including a setting which will allow disabling the checks for update at startup. Until then, users interested in turning off these automatic checks can change the line
SessionSubmit[StartupCheckForUpdates[]];
inOGRe.m
toUpdateMessage = "Checking for updates is disabled.";
.
- Fixed several lines in the code where a semicolon was missing at the end of the line, causing the code to not run correctly since Mathematica interprets newlines as multiplication by default.
- This package now has a DOI for citation purposes. Information on how to cite it in publications has been added to the source code and to
README.md
. - Added GitHub badges to
README.md
.
- Usage messages:
- Changes to existing modules:
TExport
,TExportAll
,TImport
, andTImportAll
:- Added a clarification in the usage messages for
TExportAll
andTImportAll
that the directory where the file will be saved or read from can be changed usingSetDirectory
. - Importing tensors from a different OGRe version (whether older or newer) will now issue a warning that compatibility issues may occur.
Options
will now be populated correctly with the specific keys relevant to this version, even if you import from other versions which may use differentOptions
keys.
- Added a clarification in the usage messages for
- Other changes:
- The previous update of the package made use of the new Mathematica syntax for anonymous functions,
x |-> body
. However, since this is a new feature introduced in Mathematica 12.2, this accidentally made the package incompatible with earlier Mathematica versions. I changed it to the old syntaxFunction[x, body]
in order to maintain compatibility.
- The previous update of the package made use of the new Mathematica syntax for anonymous functions,
- New modules:
TDocs
: Opens the Mathematica notebookOGRe_Documentation.nb
directly from the GitHub repository. This allows users to instantly access the latest documentation from any Mathematica session, whether the package itself was loaded locally or from GitHub.TParallelize
:- Enables or disable the parallelization of tensor simplifications (see below). It is disabled by default.
- As a rule of thumb, if simplifications are taking less than a few seconds, then you should leave parallelization off, as it has a small overhead and may actually impede performance in that case. However, if simplifications are taking more than a few seconds, then it is highly recommended to enable parallelization for a significant performance boost.
- This setting will be exported when using
TExportAll
, so it will be imported automatically withTImportAll
in future sessions. - Aspects of the package other than simplification are not parallelized, since they are typically short calculations with few elements, and would not benefit from parallelization.
- Changes to existing modules:
TCalc
now displays a progress bar (see below).TCheckForUpdates
:- Fixed a bug where this module falsely reported that a new version is available.
- Fixed a bug where this module issued an error when giving the option to download
OGRe.m
to the current notebook directory if the notebook is an Untitled notebook, meaning it is not an actual file in the file system and thus does not have a notebook directory. - This module now gives the user the option to reload the new version directly from GitHub without saving it locally.
TList
andTShow
:- The output of these modules is now uneditable. I made this change after I noticed that some users were editing the output, thinking that they are editing the tensor itself. (An option to actually edit the elements of a tensor in
MatrixForm
may be added in a future version.) - These modules now take a fourth optional argument: a function to map to each of the tensor's elements before they are displayed. Typically this would be
ReplaceAll[rules]
to apply therules
to the elements, but any function can be used. Note that applyingReplaceAll
to the output ofTShow
orTList
directly won't work, since the output is formatted.
- The output of these modules is now uneditable. I made this change after I noticed that some users were editing the output, thinking that they are editing the tensor itself. (An option to actually edit the elements of a tensor in
TNewMetric
now verifies that the metric components are an invertible, symmetric, and square matrix.
- Other changes:
- The performance of simplifications has been improved considerably!
- Simplifications are now performed automatically less often, to prevent simplifying the same expression multiple times.
- In addition, simplifications can now be parallelized. This is enabled using the new module
TParallelize
(see above). The parallelization is implemented using a thread pool model (withParallelSubmit
andWaitAll
), which in my benchmarks was found to provide better performance than the simplerParallelize
orParallelMap
. - Parallelization can potentially provide a speedup proportional to the number of parallel kernels. Note that this number is determined by your Mathematica license, and it may be less than the number of cores in your CPU.
- Calculations with
TCalc
and simplifications now both display progress bars, so you can keep track of long calculations. This was a popular feature request, especially for simplifications, since they are usually the most time-consuming operations. - Improved the appearance of the welcome message.
- Messages from OGRe are now displayed with a special cell label.
- Information on how to load the package is now displayed in the
README.md
file.
- The performance of simplifications has been improved considerably!
- New modules:
TCheckForUpdates
: Automatically checks the GitHub repository for updates. If a new version of the package is available, the module will offer an option to download or install the new version and reload the package.TGetComponents
: Extracts the components of a tensor object in a specific representation as aList
.TInfo
: Displays information about a tensor object, and any other objects associated with it, in human-readable form.
- Changes to existing modules:
TAddCoordTransformation
now also calculates the Jacobian of the transformation when it is executed, and stores the result for future use within the tensor object of the source coordinates. This improves performance by using the pre-calculated Jacobian whenever a coordinate transformation is performed, instead of calculating it from scratch every time, as was the case in v1.0.TChristoffel
now explicitly marks the resulting tensor object as having special transformation properties. The Levi-Civita connection, whose components are the Christoffel symbols, does not transform like a tensor under a coordinate transformation, and OGRe now automatically knows to use the correct transformation rule. Please note that tensors created withTChristoffel
in v1.0 will not transform correctly, so they should be recalculated after updating.TExport
now adds a key named"OGReVersion"
which records the version of the package used to create the tensor being exported. This will be used in future versions to ensure backwards compatibility.TExportAll
now exports, in addition to all the tensors defined so far, a special key,Options
, containing information about the current session. Currently, this key stores the version of the package, the index letters to use, and the simplification assumptions set by the user. When importing the data in another session usingTImportAll
, the version number will be used to ensure backwards compatibility, and the other options will be used to restore any user-defined index letters and simplification assumptions made during the session.TNewTensor
now allows defining the components of the new tensor in any coordinate system. In v1.0, the components had to be defined in the default coordinate system of the associated metric. This is still the default behavior if a coordinate system is not specified, for compatibility with v1.0, but it is recommended to always specify the coordinate system explicitly, to avoid accidentally defining the tensor with the wrong components.TSimplifyAssumptions
now appends new simplification assumptions to the list of previously added assumptions, instead of replacing it. Also, OGRe now automatically assumes that all variables are real, which helps simplify certain expressions. If you are using more exotic variables, useTSimplifyAssumptions[!Reals]
to disable this assumption.
- Other changes:
- The
"Role"
key of each tensor object now indicates how that object was created. In v1.0, tensors created withTNewCoordinates
had the role"Coordinates"
and tensors created withTNewMetric
had the role"Metric"
, but all other tensors had the role"General"
. Now tensors will have the roles"Tensor"
,"Calculated"
,"Christoffel"
,"Riemann"
,"Ricci Tensor"
,"Ricci Scalar"
, or"Einstein"
if they were created usingTNewTensor
,TCalc
,TChristoffel
,TRiemannTensor
,TRicciTensor
,TRicciScalar
, orTEinstein
respectively. This is currently just for bookkeeping, but may have other uses in future versions. Note that tensors imported from v1.0 will still have the role"General"
. - Improved the formatting of the usage messages for all OGRe modules. They no longer break in the middle of words.
- Debug mode has been removed. If the package is loaded more than once in a single session, it will redefine all symbols but keep any previously defined tensors intact. This is useful both for debugging and for reloading the package after an update.
- The
- Bug fixes:
- Fixed a bug where the partial and covariant derivatives of a scalar were not calculated correctly.
- Initial release.