xAct`Spinors`

This is the doc file SpinorsDoc.nb of version 0.9.2 of Spinors`. Last update on 9 September 2009.

Authors

© 2006-2009, under the GNU General Public License (GPL)
     Alfonso García-Parrado Gómez-Lobo
    Centro de Matematica
    Universidade do Minho, Portugal
    algar@mai.liu.se
     and
     José M. Martín-García
    Institut d'Astrophysique de Paris & Laboratoire Univers et Théories, CNRS, France
    garcia@iap.fr
    http://metric.iem.csic.es/Martin-Garcia/

Intro

Spinors` is the xAct` package for computations with spinors in four dimensional Lorentzian manifolds. The conventions adopted in the standard formulae of the spinor calculus are those of Penrose & Rindler, Spinors and Space-Time, Cambridge University Press (Vols. 1, 2). We assume that the user is already familiar with spinor calculus and therefore we will not explain the terminology or symbols related to this subject unless necessary to clarify the workings of the package.

Load the package

This loads the package from the default directory, for example $Home/.Mathematica/Applications/xAct/ for a single-user installation under Linux.  

In[1]:=

"SpinorsDoc_1.gif"

Out[1]=

"SpinorsDoc_2.gif"

In[2]:=

<<xAct`Spinors`

"SpinorsDoc_3.gif"

"SpinorsDoc_4.gif"

"SpinorsDoc_5.gif"

"SpinorsDoc_6.gif"

"SpinorsDoc_7.gif"

"SpinorsDoc_8.gif"

"SpinorsDoc_9.gif"

"SpinorsDoc_10.gif"

"SpinorsDoc_11.gif"

"SpinorsDoc_12.gif"

"SpinorsDoc_13.gif"

"SpinorsDoc_14.gif"

"SpinorsDoc_15.gif"

"SpinorsDoc_16.gif"

Comparing, we see that all packages take about 50 Mb  in Mathematica 7.0:

In[3]:=

"SpinorsDoc_17.gif"

Out[3]=

"SpinorsDoc_18.gif"

In[4]:=

"SpinorsDoc_19.gif"

Out[4]=

"SpinorsDoc_20.gif"

There are several contexts: xAct`Spinors`, xAct`xTensor`, xAct`xPerm` and xAct`xCore` contain the respective reserved words. System` contains Mathematica's reserved words.  The current context Global` will contain your definitions and right now is empty.

In[5]:=

"SpinorsDoc_21.gif"

Out[5]=

"SpinorsDoc_22.gif"

In[6]:=

"SpinorsDoc_23.gif"

Out[6]=

"SpinorsDoc_24.gif"

In[7]:=

"SpinorsDoc_25.gif"

"SpinorsDoc_26.gif"

1. Example session

Spinors are elements of a complex vector bundle (spin bundle) whose base space is a four dimensional Lorentzian manifold (spacetime). Therefore we need to define first a four dimensional differentiable manifold and a Lorentzian metric, which will be kept fixed in all this notebook. See xTensor` doc file for details about how to carry this out. Note also that all the tools and notation developed in xAct` to work with generic complex vector bundles apply in the particular case of a spin bundle, so the user will be assumed familiar with them. We refer again to the  xTensor` doc file for detailed documentation about this point.

Definition of a four dimensional  manifold M4:

In[8]:=

"SpinorsDoc_27.gif"

"SpinorsDoc_28.gif"

"SpinorsDoc_29.gif"

Definition of a Lorentzian metric on the manifold:

In[9]:=

"SpinorsDoc_30.gif"

"SpinorsDoc_31.gif"

"SpinorsDoc_32.gif"

"SpinorsDoc_33.gif"

"SpinorsDoc_34.gif"

"SpinorsDoc_35.gif"

"SpinorsDoc_36.gif"

"SpinorsDoc_37.gif"

"SpinorsDoc_38.gif"

"SpinorsDoc_39.gif"

"SpinorsDoc_40.gif"

"SpinorsDoc_41.gif"

"SpinorsDoc_42.gif"

"SpinorsDoc_43.gif"

"SpinorsDoc_44.gif"

"SpinorsDoc_45.gif"

"SpinorsDoc_46.gif"

"SpinorsDoc_47.gif"

"SpinorsDoc_48.gif"

"SpinorsDoc_49.gif"

"SpinorsDoc_50.gif"

The command DefSpinStructure defines a complex spin bundle named Spin comprising the spin metric ε[-A,-B], the soldering form σ[a,-A,-A†]and the extension of the Levi-Civita covariant derivative CD to the unique covariant derivative CDe which is compatible with the soldering form and the spin metric (spin covariant derivative).  The option SpinorPrefix is used to introduce a tag which will be prepended automatically to  any spinor related to a spacetime tensor.

In[10]:=

"SpinorsDoc_51.gif"

"SpinorsDoc_52.gif"

"SpinorsDoc_53.gif"

"SpinorsDoc_54.gif"

"SpinorsDoc_55.gif"

"SpinorsDoc_56.gif"

"SpinorsDoc_57.gif"

"SpinorsDoc_58.gif"

"SpinorsDoc_59.gif"

"SpinorsDoc_60.gif"

"SpinorsDoc_61.gif"

"SpinorsDoc_62.gif"

"SpinorsDoc_63.gif"

"SpinorsDoc_64.gif"

"SpinorsDoc_65.gif"

"SpinorsDoc_66.gif"

"SpinorsDoc_67.gif"

"SpinorsDoc_68.gif"

"SpinorsDoc_69.gif"

"SpinorsDoc_70.gif"

"SpinorsDoc_71.gif"

"SpinorsDoc_72.gif"

"SpinorsDoc_73.gif"

"SpinorsDoc_74.gif"

"SpinorsDoc_75.gif"

"SpinorsDoc_76.gif"

"SpinorsDoc_77.gif"

"SpinorsDoc_78.gif"

"SpinorsDoc_79.gif"

"SpinorsDoc_80.gif"

"SpinorsDoc_81.gif"

"SpinorsDoc_82.gif"

"SpinorsDoc_83.gif"

"SpinorsDoc_84.gif"

"SpinorsDoc_85.gif"

"SpinorsDoc_86.gif"

"SpinorsDoc_87.gif"

When a spin structure is defined, several new objects are defined automatically. These are the spinor equivalents of the Riemann, the Ricci, the traceless Ricci and the Weyl tensors. Note the character σ prepended to each head in the output . This is the default output form of the tag mentioned above. This output form can be changed with the option SpinorMark in the command DefSpinStructure.

In[11]:=

"SpinorsDoc_88.gif"

Out[11]=

"SpinorsDoc_89.gif"

The curvature spinors are also automatically defined.

In[12]:=

"SpinorsDoc_90.gif"

Out[12]=

"SpinorsDoc_91.gif"

Each of the above spinors can be decomposed into irreducible parts by means of the command Decomposition.  Let us see some examples.  

In[13]:=

"SpinorsDoc_92.gif"

Out[13]=

"SpinorsDoc_93.gif"

The decomposition of the spinor equivalent of the Ricci tensor is

In[14]:=

"SpinorsDoc_94.gif"

Out[14]=

"SpinorsDoc_95.gif"

The decomposition of the spinor equivalent of the Weyl tensor is

In[15]:=

"SpinorsDoc_96.gif"

Out[15]=

"SpinorsDoc_97.gif"

The inner curvature of the spin bundle can be also decomposed according to standard rules .

In[16]:=

"SpinorsDoc_98.gif"

Out[16]=

"SpinorsDoc_99.gif"

In[17]:=

"SpinorsDoc_100.gif"

Out[17]=

"SpinorsDoc_101.gif"

In[18]:=

"SpinorsDoc_102.gif"

Out[18]=

"SpinorsDoc_103.gif"

In[19]:=

"SpinorsDoc_104.gif"

Out[19]=

"SpinorsDoc_105.gif"

Spinors` is able to work with the 2-index derivatives used in spinor calculus.

In[20]:=

"SpinorsDoc_106.gif"

Out[20]=

"SpinorsDoc_107.gif"

As is well-known this is nothing but a shorthand for

In[21]:=

"SpinorsDoc_108.gif"

Out[21]=

"SpinorsDoc_109.gif"

We can also transform one-index covariant derivatives back into their two index form by means of the soldering form.

In[22]:=

"SpinorsDoc_110.gif"

Out[22]=

"SpinorsDoc_111.gif"

In[23]:=

"SpinorsDoc_112.gif"

Out[23]=

"SpinorsDoc_113.gif"

In[24]:=

"SpinorsDoc_114.gif"

Out[24]=

"SpinorsDoc_115.gif"

Spinors are defined using the command DefSpinor, which is nothing but a renaming of standard xAct` command DefTensor (by default the option Dagger->Complex is assumed).

In[25]:=

"SpinorsDoc_116.gif"

"SpinorsDoc_117.gif"

"SpinorsDoc_118.gif"

In this case the spinor just defined can be related to a tensor in the spacetime tangent bundle.  This vector is given by

In[26]:=

"SpinorsDoc_119.gif"

Out[26]=

"SpinorsDoc_120.gif"

The soldering form can be absorbed into the spinor κ. In this case a new tensor is automatically defined.

In[27]:=

"SpinorsDoc_121.gif"

"SpinorsDoc_122.gif"

"SpinorsDoc_123.gif"

"SpinorsDoc_124.gif"

Out[27]=

"SpinorsDoc_125.gif"

The original spinor may be also recovered from "SpinorsDoc_126.gif".

In[28]:=

"SpinorsDoc_127.gif"

Out[28]=

"SpinorsDoc_128.gif"

In[29]:=

"SpinorsDoc_129.gif"

Out[29]=

"SpinorsDoc_130.gif"

An interesting feature is the possibility of working with Hermitian spinors. These are defined by supplying the option Dagger->Hermitian to DefSpinor.

In[30]:=

"SpinorsDoc_131.gif"

"SpinorsDoc_132.gif"

"SpinorsDoc_133.gif"

We check that the new spinor μ is hermitian.

In[31]:=

"SpinorsDoc_134.gif"

Out[31]=

"SpinorsDoc_135.gif"

Any Hermitian spinor has a tensor counterpart which is real. We compute the tensor counterpart of μ and check that the result is a real rank-2 spacetime tensor.

In[32]:=

"SpinorsDoc_136.gif"

"SpinorsDoc_137.gif"

"SpinorsDoc_138.gif"

Out[32]=

"SpinorsDoc_139.gif"

In[33]:=

"SpinorsDoc_140.gif"

Out[33]=

"SpinorsDoc_141.gif"

The xAct` command ContractMetric is aware of the standard index raising and lowering conventions for the spinor indices and therefore it can act on spinor expressions without further options. We present some examples:

In[34]:=

"SpinorsDoc_142.gif"

"SpinorsDoc_143.gif"

"SpinorsDoc_144.gif"

We consider the following list of quantities.

In[35]:=

"SpinorsDoc_145.gif"

Out[35]=

"SpinorsDoc_146.gif"

In[36]:=

"SpinorsDoc_147.gif"

Out[36]=

"SpinorsDoc_148.gif"

The same goes for the remaining xAct` commands. For example ToCanonical takes into account the "see-saw" rule when canonicalising spinor expressions and adds the suitable signs.  Also it works with any kind of spinor expression without any further option. To see this let us canonicalise the following list of spinor expressions.

In[37]:=

"SpinorsDoc_149.gif"

Out[37]=

"SpinorsDoc_150.gif"

In[38]:=

"SpinorsDoc_151.gif"

Out[38]=

"SpinorsDoc_152.gif"

A spin structure can be undefined and all its dependent symbols are thus removed from the session. To accomplish this we remove first all the visitors of the soldering form σ:

In[39]:=

"SpinorsDoc_153.gif"

"SpinorsDoc_154.gif"

"SpinorsDoc_155.gif"

"SpinorsDoc_156.gif"

"SpinorsDoc_157.gif"

"SpinorsDoc_158.gif"

"SpinorsDoc_159.gif"

"SpinorsDoc_160.gif"

"SpinorsDoc_161.gif"

"SpinorsDoc_162.gif"

"SpinorsDoc_163.gif"

"SpinorsDoc_164.gif"

"SpinorsDoc_165.gif"

"SpinorsDoc_166.gif"

"SpinorsDoc_167.gif"

"SpinorsDoc_168.gif"

"SpinorsDoc_169.gif"

"SpinorsDoc_170.gif"

and all the objects defined on the Spin vbundle :

In[40]:=

"SpinorsDoc_171.gif"

Out[40]=

"SpinorsDoc_172.gif"

In[41]:=

"SpinorsDoc_173.gif"

"SpinorsDoc_174.gif"

"SpinorsDoc_175.gif"

"SpinorsDoc_176.gif"

"SpinorsDoc_177.gif"

"SpinorsDoc_178.gif"

"SpinorsDoc_179.gif"

Finally the spin structure and all its dependent objects are removed.

In[42]:=

"SpinorsDoc_180.gif"

"SpinorsDoc_181.gif"

"SpinorsDoc_182.gif"

"SpinorsDoc_183.gif"

"SpinorsDoc_184.gif"

"SpinorsDoc_185.gif"

"SpinorsDoc_186.gif"

"SpinorsDoc_187.gif"

"SpinorsDoc_188.gif"

"SpinorsDoc_189.gif"

"SpinorsDoc_190.gif"

"SpinorsDoc_191.gif"

"SpinorsDoc_192.gif"

"SpinorsDoc_193.gif"

"SpinorsDoc_194.gif"

"SpinorsDoc_195.gif"

"SpinorsDoc_196.gif"

"SpinorsDoc_197.gif"

"SpinorsDoc_198.gif"

"SpinorsDoc_199.gif"

"SpinorsDoc_200.gif"

Now, we are only left with spacetime quantities.

In[43]:=

"SpinorsDoc_201.gif"

Out[43]=

"SpinorsDoc_202.gif"

2. Definition of a spin structure

In our present context we need the following ingredients to introduce a spin structure on a Lorentzian manifold: a 2-dimensional complex vector bundle (the spin bundle), the antisymmetric spin metric and the soldering form. This last quantity is a mixed object having indices in the spin bundle and the tangent bundle and serves to relate space-time quantities to spinor quantities and back (see e. g. appendix A of A. Ashtekar Lectures on non-perturbative canonical gravity World Scientific, Singapore, 1991). The explicit components of the soldering form in a basis are known as the Infeld-Van der Waerden symbols. It can be shown that there exists a unique covariant derivative (spin covariant derivative) which is compatible with both the spin metric and the soldering form. The restriction of the spin covariant derivative to tensors defined on the tangent bundle coincides with the Levi-Civita covariant derivative.

It is possible to introduce a spin structure both in a spacetime with or without torsion. We separate those two cases:

2.1. Spin structures on spacetimes without torsion

To define a spin structure we need first a four dimensional Lorentzian manifold

In[44]:=

"SpinorsDoc_203.gif"

Out[44]=

"SpinorsDoc_204.gif"

DefSpinStructure                        Define a spin structure on a four dimensional Lorentzian manifold.
UndefSpinStructure                   Undefine a spin structure.  
$SolderingForms
                           List of soldering forms (a.k.a. spin structures).

We define a spin structure comprising the complex vector bundle Spin whose abstract indices are {A, B, C, D, F, H, L, P, Q}. We need to supply as arguments the name of the metric tensor of the background Lorentzian manifold g[-a,-b], the name of the antisymmetric spin metric ε[-A,-B], the name of the soldering form σ[a,-A,-A†] and the name of the spin covariant derivative CDe[-a].The option SpinorPrefix is used to introduce a tag which will be  prepended automatically to  any spinor related to a spacetime tensor and the option SpinorMark introduces a formatting of the tag SP different to the default one. The long output of DefSpinStructure can be suppressed  by adding the option Info->False which deactivates the information of the definition commands .

In[45]:=

"SpinorsDoc_205.gif"

"SpinorsDoc_206.gif"

"SpinorsDoc_207.gif"

We choose a formatting for the "primed" spinor indices according to the standard conventions used in the literature.

In[46]:=

"SpinorsDoc_208.gif"

By convention we choose the  symbol σ as the representative of all the elements which comprise the spin structure. Hence it will sometimes be referred to as "the spin structure". In particular this means that it is the host of the spinor counterparts of the metric tensor, the volume element and all the curvature spinors associated to the covariant derivative CDe .

In[47]:=

"SpinorsDoc_209.gif"

Out[47]=

"SpinorsDoc_210.gif"

The set of soldering forms is kept in the global variable $SolderingForms.

In[48]:=

"SpinorsDoc_211.gif"

Out[48]=

"SpinorsDoc_212.gif"

All the essential algebraic properties of the soldering form are included as automatic rules. Example:

In[49]:=

"SpinorsDoc_213.gif"

Out[49]=

"SpinorsDoc_214.gif"

It is possible to define a second spin structure on the manifold M4.

In[50]:=

"SpinorsDoc_215.gif"

In[51]:=

"SpinorsDoc_216.gif"

Out[51]=

"SpinorsDoc_217.gif"

If we have more than one spin structure in the session then we need to specify which one are we working with in some of the Spinors` commands. Otherwise it is automatically assumed that we work with the default spin structure which is the first element of the list $SolderingForms.Examples:

In[52]:=

"SpinorsDoc_218.gif"

Out[52]=

"SpinorsDoc_219.gif"

In[53]:=

"SpinorsDoc_220.gif"

Out[53]=

"SpinorsDoc_221.gif"

In[54]:=

"SpinorsDoc_222.gif"

Out[54]=

"SpinorsDoc_223.gif"

In[55]:=

"SpinorsDoc_224.gif"

Out[55]=

"SpinorsDoc_225.gif"

In[56]:=

"SpinorsDoc_226.gif"

Out[56]=

"SpinorsDoc_227.gif"

In[57]:=

"SpinorsDoc_228.gif"

Out[57]=

"SpinorsDoc_229.gif"

In[58]:=

"SpinorsDoc_230.gif"

Out[58]=

"SpinorsDoc_231.gif"

We remove the spin structure σ2. As usual, we start with the visitors of σ2 and then we proceed to erase the spin structure itself.

In[59]:=

"SpinorsDoc_232.gif"

"SpinorsDoc_233.gif"

"SpinorsDoc_234.gif"

"SpinorsDoc_235.gif"

"SpinorsDoc_236.gif"

"SpinorsDoc_237.gif"

"SpinorsDoc_238.gif"

"SpinorsDoc_239.gif"

"SpinorsDoc_240.gif"

"SpinorsDoc_241.gif"

"SpinorsDoc_242.gif"

"SpinorsDoc_243.gif"

"SpinorsDoc_244.gif"

"SpinorsDoc_245.gif"

"SpinorsDoc_246.gif"

In[60]:=

"SpinorsDoc_247.gif"

"SpinorsDoc_248.gif"

"SpinorsDoc_249.gif"

"SpinorsDoc_250.gif"

"SpinorsDoc_251.gif"

"SpinorsDoc_252.gif"

"SpinorsDoc_253.gif"

"SpinorsDoc_254.gif"

"SpinorsDoc_255.gif"

"SpinorsDoc_256.gif"

"SpinorsDoc_257.gif"

"SpinorsDoc_258.gif"

"SpinorsDoc_259.gif"

"SpinorsDoc_260.gif"

"SpinorsDoc_261.gif"

"SpinorsDoc_262.gif"

"SpinorsDoc_263.gif"

"SpinorsDoc_264.gif"

"SpinorsDoc_265.gif"

"SpinorsDoc_266.gif"

"SpinorsDoc_267.gif"

2.2. Spin structures on spacetimes with torsion

It is possible to define a spin structure on a spacetime in which the connection compatible with the metric tensor is assumed to have torsion. In this section we illustrate this.

We need to define a new 4-dimensional manifold and a new metric. Note the non-standard symmetry properties of the curvature tensors:

In[61]:=

"SpinorsDoc_268.gif"

"SpinorsDoc_269.gif"

"SpinorsDoc_270.gif"

In[62]:=

"SpinorsDoc_271.gif"

"SpinorsDoc_272.gif"

"SpinorsDoc_273.gif"

"SpinorsDoc_274.gif"

"SpinorsDoc_275.gif"

"SpinorsDoc_276.gif"

"SpinorsDoc_277.gif"

"SpinorsDoc_278.gif"

"SpinorsDoc_279.gif"

"SpinorsDoc_280.gif"

"SpinorsDoc_281.gif"

"SpinorsDoc_282.gif"

"SpinorsDoc_283.gif"

"SpinorsDoc_284.gif"

"SpinorsDoc_285.gif"

"SpinorsDoc_286.gif"

"SpinorsDoc_287.gif"

"SpinorsDoc_288.gif"

"SpinorsDoc_289.gif"

"SpinorsDoc_290.gif"

"SpinorsDoc_291.gif"

Definition of the spin structure

In[63]:=

"SpinorsDoc_292.gif"

"SpinorsDoc_293.gif"

"SpinorsDoc_294.gif"

"SpinorsDoc_295.gif"

"SpinorsDoc_296.gif"

"SpinorsDoc_297.gif"

"SpinorsDoc_298.gif"

"SpinorsDoc_299.gif"

"SpinorsDoc_300.gif"

"SpinorsDoc_301.gif"

"SpinorsDoc_302.gif"

"SpinorsDoc_303.gif"

"SpinorsDoc_304.gif"

"SpinorsDoc_305.gif"

"SpinorsDoc_306.gif"

"SpinorsDoc_307.gif"

"SpinorsDoc_308.gif"

"SpinorsDoc_309.gif"

"SpinorsDoc_310.gif"

"SpinorsDoc_311.gif"

"SpinorsDoc_312.gif"

"SpinorsDoc_313.gif"

"SpinorsDoc_314.gif"

"SpinorsDoc_315.gif"

"SpinorsDoc_316.gif"

"SpinorsDoc_317.gif"

"SpinorsDoc_318.gif"

"SpinorsDoc_319.gif"

"SpinorsDoc_320.gif"

"SpinorsDoc_321.gif"

"SpinorsDoc_322.gif"

"SpinorsDoc_323.gif"

This is the torsion tensor.

In[64]:=

"SpinorsDoc_324.gif"

Out[64]=

"SpinorsDoc_325.gif"

We compute next the spinor equivalent of the torsion.

In[65]:=

"SpinorsDoc_326.gif"

Out[65]=

"SpinorsDoc_327.gif"

In[66]:=

"SpinorsDoc_328.gif"

Out[66]=

"SpinorsDoc_329.gif"

This can be decomposed as follows.

In[67]:=

"SpinorsDoc_330.gif"

Out[67]=

"SpinorsDoc_331.gif"

In[68]:=

"SpinorsDoc_332.gif"

Out[68]=

"SpinorsDoc_333.gif"

The spinor "SpinorsDoc_334.gif" is called the "torsion spinor" of the covariant derivative. It is symmetric in the last pair of indices.

In[69]:=

"SpinorsDoc_335.gif"

Out[69]=

"SpinorsDoc_336.gif"

That spinor appears in all standard expressions involving the torsion. Let us see an example:

In[70]:=

"SpinorsDoc_337.gif"

"SpinorsDoc_338.gif"

"SpinorsDoc_339.gif"

This is the spinor form of the Ricci identity associated to the covariant derivative cde. As is well known this spinor form contains the "box operator" whose expansion contains explicitly the torsion spinor.

In[71]:=

"SpinorsDoc_340.gif"

Out[71]=

"SpinorsDoc_341.gif"

In[72]:=

"SpinorsDoc_342.gif"

Out[72]=

"SpinorsDoc_343.gif"

We remove all the symbols used in this subsection.

In[73]:=

"SpinorsDoc_344.gif"

"SpinorsDoc_345.gif"

"SpinorsDoc_346.gif"

"SpinorsDoc_347.gif"

"SpinorsDoc_348.gif"

"SpinorsDoc_349.gif"

"SpinorsDoc_350.gif"

"SpinorsDoc_351.gif"

"SpinorsDoc_352.gif"

"SpinorsDoc_353.gif"

"SpinorsDoc_354.gif"

"SpinorsDoc_355.gif"

"SpinorsDoc_356.gif"

In[74]:=

"SpinorsDoc_357.gif"

"SpinorsDoc_358.gif"

"SpinorsDoc_359.gif"

In[75]:=

"SpinorsDoc_360.gif"

"SpinorsDoc_361.gif"

"SpinorsDoc_362.gif"

"SpinorsDoc_363.gif"

"SpinorsDoc_364.gif"

"SpinorsDoc_365.gif"

"SpinorsDoc_366.gif"

"SpinorsDoc_367.gif"

"SpinorsDoc_368.gif"

"SpinorsDoc_369.gif"

"SpinorsDoc_370.gif"

"SpinorsDoc_371.gif"

"SpinorsDoc_372.gif"

"SpinorsDoc_373.gif"

"SpinorsDoc_374.gif"

"SpinorsDoc_375.gif"

"SpinorsDoc_376.gif"

"SpinorsDoc_377.gif"

"SpinorsDoc_378.gif"

"SpinorsDoc_379.gif"

In[76]:=

"SpinorsDoc_380.gif"

"SpinorsDoc_381.gif"

"SpinorsDoc_382.gif"

"SpinorsDoc_383.gif"

"SpinorsDoc_384.gif"

"SpinorsDoc_385.gif"

"SpinorsDoc_386.gif"

"SpinorsDoc_387.gif"

"SpinorsDoc_388.gif"

"SpinorsDoc_389.gif"

"SpinorsDoc_390.gif"

"SpinorsDoc_391.gif"

"SpinorsDoc_392.gif"

"SpinorsDoc_393.gif"

"SpinorsDoc_394.gif"

"SpinorsDoc_395.gif"

In[77]:=

"SpinorsDoc_396.gif"

"SpinorsDoc_397.gif"

"SpinorsDoc_398.gif"

In[78]:=

"SpinorsDoc_399.gif"

Out[78]=

"SpinorsDoc_400.gif"

3. Transformation between spinor and tensor expressions

Being able to transform spinor expressions into tensor ones and back is an important issue. Sometimes this is a trivial task but there are cases in which more efforts are required.  Spinors` has a complete suite of commands which enable us to handle any case as we show below.

3.1. Insertion and removal of soldering forms in an expression

When transforming a spinor expression into a tensor one (or vice-versa) we may need to insert or eliminate a number of soldering forms.  Spinors`  provides commands to perform this task in an efficient fashion.

PutSolderingForm         Contraction of spinor/tensor indices with a suitable number of soldering forms
ContractSolderingForm    Transformation of contracted products of soldering forms into tensor/spinor expressions
SeparateSolderingForm    Extraction of spinor/tensor indices by means of soldering forms

Simple application: we start with the Riemann tensor and finish with its spinor counterpart

In[79]:=

"SpinorsDoc_401.gif"

Out[79]=

"SpinorsDoc_402.gif"

In[80]:=

"SpinorsDoc_403.gif"

Out[80]=

"SpinorsDoc_404.gif"

In[81]:=

"SpinorsDoc_405.gif"

Out[81]=

"SpinorsDoc_406.gif"

We can now follow previous procedure backwards and end up in the spacetime Riemann tensor.

In[82]:=

"SpinorsDoc_407.gif"

Out[82]=

"SpinorsDoc_408.gif"

In[83]:=

"SpinorsDoc_409.gif"

Out[83]=

"SpinorsDoc_410.gif"

Sometimes intermediate objects need to be created  in a computation like the one just shown. This is done by the system in an automatic way.

In[84]:=

"SpinorsDoc_411.gif"

"SpinorsDoc_412.gif"

In[85]:=

"SpinorsDoc_413.gif"

Out[85]=

"SpinorsDoc_414.gif"

Here, the contraction of the soldering forms results in the spinor counterpart of the tensor M[-a, -b]. The former has not been defined previously and thus the system must introduce this new object (a message informing about this is issued). The definition of spinor counterparts of tensor objects can be performed by the user independently (see next section).

In[86]:=

"SpinorsDoc_415.gif"

"SpinorsDoc_416.gif"

"SpinorsDoc_417.gif"

"SpinorsDoc_418.gif"

Out[86]=

"SpinorsDoc_419.gif"

The separation of the soldering form gets us back to the original tensor "SpinorsDoc_420.gif".

In[87]:=

"SpinorsDoc_421.gif"

Out[87]=

"SpinorsDoc_422.gif"

In[88]:=

"SpinorsDoc_423.gif"

Out[88]=

"SpinorsDoc_424.gif"

The spinors SP—M and SP—M† are visitors of M. Therefore if we wish to remove M, we need to remove first its visitors.

In[89]:=

"SpinorsDoc_425.gif"

"SpinorsDoc_426.gif"

"SpinorsDoc_427.gif"

In[90]:=

"SpinorsDoc_428.gif"

"SpinorsDoc_429.gif"

There are cases in which we need to tell explicitly how the indices of the soldering forms should be contracted when they act on an expression.  This is achieved by means of extra options in the commands just ilustrated.

Consider an expression containing spacetime and spinor indices.

In[91]:=

"SpinorsDoc_430.gif"

Out[91]=

"SpinorsDoc_431.gif"

By default SeparateSolderingForm will extract soldering forms from all the tensor indices and all the complex conjugated pairs of spinor indices.

In[92]:=

"SpinorsDoc_432.gif"

Out[92]=

"SpinorsDoc_433.gif"

We may control with extra options the vector bundles whose indices will be pulled out by SeparateSolderingForm.

In[93]:=

"SpinorsDoc_434.gif"

Out[93]=

"SpinorsDoc_435.gif"

In[94]:=

"SpinorsDoc_436.gif"

Out[94]=

"SpinorsDoc_437.gif"

A similar index-selection is also available for PutSolderingForm.

In[95]:=

"SpinorsDoc_438.gif"

Out[95]=

"SpinorsDoc_439.gif"

In[96]:=

"SpinorsDoc_440.gif"

Out[96]=

"SpinorsDoc_441.gif"

The following expression is the spinor form of a tensor (Bel-Robinson tensor). If we wish to use PutSolderingForm to find its tensor equivalent we need to pass an argument stating how the spinor indices are grouped into tensor ones as there is not a unique way of doing it.  This is achieved by means of the head  Pair which represents conjugated pairs of spinor indices.

In[97]:=

"SpinorsDoc_442.gif"

Out[97]=

"SpinorsDoc_443.gif"

In[98]:=

"SpinorsDoc_444.gif"

Out[98]=

"SpinorsDoc_445.gif"

3.2. Relations between spinors and tensors

There are spinors which can be put into relation with tensors and tensors which can be put into relation with spinors. In both cases the relation is carried out by means of the soldering form. Whenever one of these relations apply, Spinors` enables the user to define the spinor (resp. tensor) counterpart of a tensor (resp. spinor).   

DefSpinorOfTensor          Defines the spinor counterpart of a tensor (when applicable)
DefTensorOfSpinor          Defines the tensor counterpart of a spinor (when applicable)

Let us define a spinor.

In[99]:=

"SpinorsDoc_446.gif"

"SpinorsDoc_447.gif"

"SpinorsDoc_448.gif"

This spinor has a tensor counterpart. To introduce it into the session we use the command DefTensorOfSpinor in the following way:

In[100]:=

"SpinorsDoc_449.gif"

"SpinorsDoc_450.gif"

"SpinorsDoc_451.gif"

The output form of the tensor is actually constructed from that of the spinor:

In[101]:=

"SpinorsDoc_452.gif"

Out[101]=

"SpinorsDoc_453.gif"

The symbol KT represents the tensor counterpart of the spinor κ.This must be a symbol which does not correspond to any object defined previously in the session.  From this point on, the system stores  KT as the tensor counterpart of κ. Any of the commands which relate spinors to tensors are now aware of this binding between κ and KT.Let us see some examples:

In[102]:=

"SpinorsDoc_454.gif"

Out[102]=

"SpinorsDoc_455.gif"

We start from the spinor "SpinorsDoc_456.gif" transform it into a tensor and then back to the same spinor all by using PutSolderingForm/ContractSolderingForm.

In[103]:=

"SpinorsDoc_457.gif"

Out[103]=

"SpinorsDoc_458.gif"

In[104]:=

"SpinorsDoc_459.gif"

Out[104]=

"SpinorsDoc_460.gif"

In[105]:=

"SpinorsDoc_461.gif"

Out[105]=

"SpinorsDoc_462.gif"

In[106]:=

"SpinorsDoc_463.gif"

Out[106]=

"SpinorsDoc_464.gif"

In[107]:=

"SpinorsDoc_465.gif"

Out[107]=

"SpinorsDoc_466.gif"

Similarly we can introduce the spinor counterpart of any tensor already defined in the sesssion. For example:

In[108]:=

"SpinorsDoc_467.gif"

"SpinorsDoc_468.gif"

"SpinorsDoc_469.gif"

In[109]:=

"SpinorsDoc_470.gif"

"SpinorsDoc_471.gif"

"SpinorsDoc_472.gif"

As above the symbol ST should not correspond to any of the symbols defined previously in the session. Note carefully the index arrangement in the spinor  ST. This is fixed by convention and cannot be altered by the user. We will come back to this important point below.  For now we present some manipulation examples.

In[110]:=

"SpinorsDoc_473.gif"

Out[110]=

"SpinorsDoc_474.gif"

In[111]:=

"SpinorsDoc_475.gif"

Out[111]=

"SpinorsDoc_476.gif"

In[112]:=

"SpinorsDoc_477.gif"

Out[112]=

"SpinorsDoc_478.gif"

In[113]:=

"SpinorsDoc_479.gif"

Out[113]=

"SpinorsDoc_480.gif"

In[114]:=

"SpinorsDoc_481.gif"

Out[114]=

"SpinorsDoc_482.gif"

In[115]:=

"SpinorsDoc_483.gif"

Out[115]=

"SpinorsDoc_484.gif"

The above examples can be generalized to tensors and spinors with a higher number of indices with the following provision: in the commands DefSpinorOfTensor and DefTensorOfSpinor spinor indices must be always arranged according to the pattern index-Dagger[index]. Otherwise an error message is thrown.

In[116]:=

"SpinorsDoc_485.gif"

"SpinorsDoc_486.gif"

In[117]:=

"SpinorsDoc_487.gif"

"SpinorsDoc_488.gif"

"SpinorsDoc_489.gif"

In[118]:=

"SpinorsDoc_490.gif"

"SpinorsDoc_491.gif"

We undefine the objects used in this subsection. Note that whenever we wish to undefine a spinor (tensor) quantity with a tensor (spinor) counterpart we must erase first the latter, which is a visitor of the former.

In[119]:=

"SpinorsDoc_492.gif"

"SpinorsDoc_493.gif"

"SpinorsDoc_494.gif"

In[120]:=

"SpinorsDoc_495.gif"

"SpinorsDoc_496.gif"

"SpinorsDoc_497.gif"

In[121]:=

"SpinorsDoc_498.gif"

"SpinorsDoc_499.gif"

"SpinorsDoc_500.gif"

In[122]:=

"SpinorsDoc_501.gif"

"SpinorsDoc_502.gif"

"SpinorsDoc_503.gif"

In[123]:=

"SpinorsDoc_504.gif"

"SpinorsDoc_505.gif"

"SpinorsDoc_506.gif"

3.3. Products of soldering forms

Contracted products of soldering forms appear in a natural way when transforming spinor expressions into tensor ones and back. Therefore it is important to be able to work with such products. In this subsection we show how Spinors` deals with such quantities.

The simplest case is the product of 2 soldering forms which gives rise to an auxiliary quantity which is needed when going from spinor expressions to tensor expressions.

In[124]:=

"SpinorsDoc_507.gif"

Out[124]=

"SpinorsDoc_508.gif"

The algebraic properties of  "SpinorsDoc_509.gif" are stored as automatic rules.

In[125]:=

"SpinorsDoc_510.gif"

Out[125]=

"SpinorsDoc_511.gif"

In[126]:=

"SpinorsDoc_512.gif"

Global`Sigmaσ

Dagger[Sigmaσ]^:=Sigmaσ†
DependenciesOfTensor[Sigmaσ]^:={M4}
HostsOf[Sigmaσ]^:={M4,TangentM4}
Info[Sigmaσ]^:=False
MasterOf[Sigmaσ]^:=σ
PrintAs[Sigmaσ]^:=Σσ
ServantsOf[Sigmaσ]^:={Sigmaσ†}
SlotsOfTensor[Sigmaσ]^:={TangentM4,TangentM4,-Spin,-Spin}
SymmetryGroupOfTensor[Sigmaσ]^:=StrongGenSet[{1},GenSet[-Cycles[{1,2},{3,4}]]]
TensorID[Sigmaσ]^:={}
xTensorQ[Sigmaσ]^:=True
"SpinorsDoc_513.gif"
"SpinorsDoc_514.gif"
"SpinorsDoc_515.gif"
"SpinorsDoc_516.gif"
"SpinorsDoc_517.gif"
"SpinorsDoc_518.gif"
"SpinorsDoc_519.gif"
"SpinorsDoc_520.gif"
"SpinorsDoc_521.gif"
"SpinorsDoc_522.gif"

One of the previous properties is that the "square" of "SpinorsDoc_523.gif" gives rise to the "tetra-metric".  The latter is a four rank spacetime tensor which is defined in eq. (3.4.57) of vol. 1 of Penrose & Rindler (note that they use the name U for it).

In[127]:=

"SpinorsDoc_524.gif"

Out[127]//InputForm=

-Tetrag[-d, -b, -a, -c]

This is the explicit definition of the tetra-metric (note that there is a sign difference between formula (3.4.57) of  Vol. 1of Penrose & Rindler and our formula).

In[128]:=

"SpinorsDoc_525.gif"

Out[128]=

"SpinorsDoc_526.gif"

As we can see the tetra-metric only depends on spacetime quantities. Therefore the tetra-metric is always automatically defined whenever a Lorentzian four dimensional metric is introduced regardless to whether a spin structure has been defined. Also automatic rules implementing the algebraic properties of the tetra-metric are stored.

In[129]:=

"SpinorsDoc_527.gif"

Global`Tetrag

Dagger[Tetrag]^=Tetrag†
DependenciesOfTensor[Tetrag]^={M4}
HostsOf[Tetrag]^={M4,TangentM4}
Info[Tetrag]^={tensor,}
MasterOf[Tetrag]^=g
PrintAs[Tetrag]^=Gg
ServantsOf[Tetrag]^={Tetrag†}
SlotsOfTensor[Tetrag]^={-TangentM4,-TangentM4,-TangentM4,-TangentM4}
SymmetryGroupOfTensor[Tetrag]^=StrongGenSet[{1},GenSet[Cycles[{1,2},{3,4}],Cycles[{1,3},{2,4}]]]
TensorID[Tetrag]^={}
xTensorQ[Tetrag]^=True

A typical problem is the computation of a product of soldering forms with no free spinor indices. These always give rise to contracted products of tetra metrics. Let us see some examples.

In[130]:=

"SpinorsDoc_528.gif"

Out[130]=

"SpinorsDoc_529.gif"

In[131]:=

"SpinorsDoc_530.gif"

Out[131]=

"SpinorsDoc_531.gif"

In[132]:=

"SpinorsDoc_532.gif"

Out[132]=

"SpinorsDoc_533.gif"

In[133]:=

"SpinorsDoc_534.gif"

Out[133]=

"SpinorsDoc_535.gif"

Expressions of the sort just found are frequent in computations involving the transformation of spinor expressions into tensor ones. Let us see an example

Transformation of the Weyl tensor into its spinor counterpart

In[134]:=

"SpinorsDoc_536.gif"

Out[134]=

"SpinorsDoc_537.gif"

In[135]:=

"SpinorsDoc_538.gif"

Out[135]=

"SpinorsDoc_539.gif"

In[136]:=

"SpinorsDoc_540.gif"

Out[136]=

"SpinorsDoc_541.gif"

This spinor expression can be transformed back into the Weyl tensor

In[137]:=

"SpinorsDoc_542.gif"

Out[137]=

"SpinorsDoc_543.gif"

We use this expression to write the Weyl spinor "SpinorsDoc_544.gif" in terms of the Weyl tensor "SpinorsDoc_545.gif".

In[138]:=

"SpinorsDoc_546.gif"

Out[138]=

"SpinorsDoc_547.gif"

In[139]:=

"SpinorsDoc_548.gif"

Out[139]=

"SpinorsDoc_549.gif"

In[140]:=

"SpinorsDoc_550.gif"

Out[140]=

"SpinorsDoc_551.gif"

In[141]:=

"SpinorsDoc_552.gif"

Out[141]=

"SpinorsDoc_553.gif"

Now we can use previous rule to find the tensor expression of any invariant written in terms of the Weyl spinor. For example consider

In[142]:=

"SpinorsDoc_554.gif"

Out[142]=

"SpinorsDoc_555.gif"

A direct use of ContractSolderingForm would contract the soldering forms with the Weyl tensor, yielding an undesired result:

In[143]:=

"SpinorsDoc_556.gif"

Out[143]=

"SpinorsDoc_557.gif"

Instead we specify contraction of the indices on the soldering form which are dummies, generating a product of "tetra-metrics".

In[144]:=

"SpinorsDoc_558.gif"

Out[144]=

"SpinorsDoc_559.gif"

In[145]:=

"SpinorsDoc_560.gif"

Out[145]=

"SpinorsDoc_561.gif"

Finally we expand the tetra-metrics into ordinary metrics and volume elements. The simplification of the resulting expression provides the final answer.

In[146]:=

"SpinorsDoc_562.gif"

Out[146]=

"SpinorsDoc_563.gif"

In[147]:=

"SpinorsDoc_564.gif"

Out[147]=

"SpinorsDoc_565.gif"

Clean up :

In[148]:=

"SpinorsDoc_566.gif"

4. Decomposition of a spinor into irreducible parts

A classical result of the spinor algebra is the posibility of decomposing any spinor into a sum which consists of a totally symmetric spinor of the same rank as the given spinor plus other terms which are outer products of the antisymmetric metric with totally symmetric spinors of lower rank (see proposition 3.3.54 of Penrose & Rindler vol. I for full details). In Spinors` there is an automated procedure to find such a decomposition as we explain below.

IrreducibleDecomposition                      Finds the decomposition of any spinor into irreducible parts

We show how IrreducibleDecomposition works by means of some simple examples. Let us start by defining a spinor

In[149]:=

"SpinorsDoc_567.gif"

"SpinorsDoc_568.gif"

"SpinorsDoc_569.gif"

The decomposition of the spinor just introduced into irreducible parts is given by

In[150]:=

"SpinorsDoc_570.gif"

"SpinorsDoc_571.gif"

"SpinorsDoc_572.gif"

Out[150]=

"SpinorsDoc_573.gif"

The command IrreducibleDecomposition defines first the totally symmetric spinors intervening in the decomposition (irreducible spinors). The actual decomposition is found in a second step and displayed in the output. In order to represent the irreducible spinors, we introduce an indexed quantity with a variable number of slots (see the documentation of the package xTensor` for further details about this). Note the labels on each of the totally symmetric spinors: these are label indices which are used to distinguish each of the irreducible spinors. The pairs of numbers which appear inside the list indicate which slots of the tensor being decomposed have been picked to "pull out" factors of the antisymmetric metric.    

This is the list of all the irreducible spinors resulting from the decomposition of Kh[-A, -B, -C, -D].

In[151]:=

"SpinorsDoc_574.gif"

Out[151]=

"SpinorsDoc_575.gif"

The symbol TF (trace free) is prepended to the symbol Kh.  All the quantities of the previous list which are not scalars are totally symmetric.

In[152]:=

"SpinorsDoc_576.gif"

Out[152]=

"SpinorsDoc_577.gif"

The irreducible spinors are servants of the spinor they decompose. Therefore they are removed if the latter is erased.

In[153]:=

"SpinorsDoc_578.gif"

"SpinorsDoc_579.gif"

"SpinorsDoc_580.gif"

"SpinorsDoc_581.gif"

"SpinorsDoc_582.gif"

Example of the decomposition of a mixed spinor.

In[154]:=

"SpinorsDoc_583.gif"

"SpinorsDoc_584.gif"

"SpinorsDoc_585.gif"

Out[154]=

"SpinorsDoc_586.gif"

5. Spin-compatible covariant derivatives

Spinors`  includes the concept of spin-compatible covariant derivative. A covariant derivative is spin-compatible if it yields zero when acting upon a soldering form. The spin covariant derivative which extends the Levi-Civita covariant derivative is an example of it.  

DefSpinCovD               Defines a  spin-compatible covariant derivative
UndefSpinCovD             Undefines  a spin-compatible covariant derivative

We define a covariant derivative which is spin-compatible with the soldering form σ. Note that the syntax of DefSpinCovD is similar to the xAct` command DefCovD used to define covariant derivatives.  We use non-standard symbols to denote the derivative:

In[155]:=

"SpinorsDoc_587.gif"

"SpinorsDoc_588.gif"

"SpinorsDoc_589.gif"

"SpinorsDoc_590.gif"

"SpinorsDoc_591.gif"

"SpinorsDoc_592.gif"

"SpinorsDoc_593.gif"

"SpinorsDoc_594.gif"

"SpinorsDoc_595.gif"

"SpinorsDoc_596.gif"

"SpinorsDoc_597.gif"

"SpinorsDoc_598.gif"

"SpinorsDoc_599.gif"

"SpinorsDoc_600.gif"

"SpinorsDoc_601.gif"

"SpinorsDoc_602.gif"

"SpinorsDoc_603.gif"

"SpinorsDoc_604.gif"

"SpinorsDoc_605.gif"

"SpinorsDoc_606.gif"

"SpinorsDoc_607.gif"

"SpinorsDoc_608.gif"

"SpinorsDoc_609.gif"

"SpinorsDoc_610.gif"

"SpinorsDoc_611.gif"

Several new objects are defined along with the covariant derivative. These are the same which are introduced by DefCovD plus the spinor equivalents of all the curvature quantities. By definition the compatibility of the covariant derivative nb with the spin structure associated to σ means that

In[156]:=

"SpinorsDoc_612.gif"

Out[156]=

"SpinorsDoc_613.gif"

Rules to decompose the curvature spinors into irreducible parts are also available. For example, let us compute the full decomposition of the spinor counterpart of the Riemann tensor of the covariant derivative nb in irreducible parts.

In[157]:=

"SpinorsDoc_614.gif"

Out[157]=

"SpinorsDoc_615.gif"

In[158]:=

"SpinorsDoc_616.gif"

Out[158]=

"SpinorsDoc_617.gif"

In[159]:=

"SpinorsDoc_618.gif"

Out[159]=

"SpinorsDoc_619.gif"

In[160]:=

"SpinorsDoc_620.gif"

Out[160]=

"SpinorsDoc_621.gif"

In[161]:=

"SpinorsDoc_622.gif"

Out[161]=

"SpinorsDoc_623.gif"

Note that the curvature spinors associated to a generic spin-compatible covariant derivative do not have the same symmetries as those of the spin covariant derivative.

In[162]:=

"SpinorsDoc_624.gif"

Out[162]=

"SpinorsDoc_625.gif"

There are also decomposition rules for the torsion spinor.

In[163]:=

"SpinorsDoc_626.gif"

Out[163]=

"SpinorsDoc_627.gif"

In[164]:=

"SpinorsDoc_628.gif"

Out[164]=

"SpinorsDoc_629.gif"

In[165]:=

"SpinorsDoc_630.gif"

Out[165]=

"SpinorsDoc_631.gif"

In[166]:=

"SpinorsDoc_632.gif"

Out[166]=

"SpinorsDoc_633.gif"

The covariant derivative nb can be manipulated in 2-index or in single index notation.

In[167]:=

"SpinorsDoc_634.gif"

Out[167]=

"SpinorsDoc_635.gif"

In[168]:=

"SpinorsDoc_636.gif"

Out[168]=

"SpinorsDoc_637.gif"

In[169]:=

"SpinorsDoc_638.gif"

Out[169]=

"SpinorsDoc_639.gif"

In postfix notation :

In[170]:=

"SpinorsDoc_640.gif"

In[171]:=

"SpinorsDoc_641.gif"

Out[171]=

"SpinorsDoc_642.gif"

In[172]:=

"SpinorsDoc_643.gif"

The spinor expression of the Ricci identities of any spin-compatible covariant derivative is neatly rendered in terms of the box operator. This is a linear differential operator and Spinors`  is able to work with it. The box operator is represented by the head BoxCovDname where the symbol CovDname represents the spin-compatible covariant derivative.

Action of the box  operator on a spinor and some simple manipulations involving it.

In[173]:=

"SpinorsDoc_644.gif"

"SpinorsDoc_645.gif"

"SpinorsDoc_646.gif"

In[174]:=

"SpinorsDoc_647.gif"

Out[174]=

"SpinorsDoc_648.gif"

In[175]:=

"SpinorsDoc_649.gif"

Out[175]=

"SpinorsDoc_650.gif"

In[176]:=

"SpinorsDoc_651.gif"

Out[176]=

"SpinorsDoc_652.gif"

In[177]:=

"SpinorsDoc_653.gif"

Out[177]=

"SpinorsDoc_654.gif"

The box operator can be expanded into spin covariant derivatives or into curvature spinors plus the torsion, according to known formulae (see eqs. (4.9.8)-(4.9.17) of Penrose & Rindler Vol. 2). Spinors has built-in rules to perform these expansions.

BoxToCovD                     Expand the box operator into covariant derivatives
BoxToCurvature                Expand the box operator into curvature spinors

Examples of the expansion of the Box operator.

In[178]:=

"SpinorsDoc_655.gif"

Out[178]=

"SpinorsDoc_656.gif"

In[179]:=

"SpinorsDoc_657.gif"

Out[179]=

"SpinorsDoc_658.gif"

In[180]:=

"SpinorsDoc_659.gif"

Out[180]=

"SpinorsDoc_660.gif"

Similar computations for the box operator arising from the covariant derivative nb. Note the presence of an extra term due to the fact that the covariant derivative nb has torsion.

In[181]:=

"SpinorsDoc_661.gif"

Out[181]=

"SpinorsDoc_662.gif"

In[182]:=

"SpinorsDoc_663.gif"

Out[182]=

"SpinorsDoc_664.gif"

In[183]:=

"SpinorsDoc_665.gif"

Out[183]=

"SpinorsDoc_666.gif"

Other computations involving the box operator.

In[184]:=

"SpinorsDoc_667.gif"

Out[184]=

"SpinorsDoc_668.gif"

In[185]:=

"SpinorsDoc_669.gif"

Out[185]=

"SpinorsDoc_670.gif"

In[186]:=

"SpinorsDoc_671.gif"

Out[186]=

"SpinorsDoc_672.gif"

In[187]:=

"SpinorsDoc_673.gif"

Out[187]=

"SpinorsDoc_674.gif"

In[188]:=

"SpinorsDoc_675.gif"

Out[188]=

"SpinorsDoc_676.gif"

In[189]:=

"SpinorsDoc_677.gif"

Out[189]=

"SpinorsDoc_678.gif"

We no longer need the spin-compatible covariant derivative nb :

In[190]:=

"SpinorsDoc_679.gif"

"SpinorsDoc_680.gif"

"SpinorsDoc_681.gif"

"SpinorsDoc_682.gif"

"SpinorsDoc_683.gif"

"SpinorsDoc_684.gif"

"SpinorsDoc_685.gif"

"SpinorsDoc_686.gif"

"SpinorsDoc_687.gif"

"SpinorsDoc_688.gif"

"SpinorsDoc_689.gif"

"SpinorsDoc_690.gif"

"SpinorsDoc_691.gif"

"SpinorsDoc_692.gif"

"SpinorsDoc_693.gif"

"SpinorsDoc_694.gif"

"SpinorsDoc_695.gif"

"SpinorsDoc_696.gif"

"SpinorsDoc_697.gif"

"SpinorsDoc_698.gif"

"SpinorsDoc_699.gif"

"SpinorsDoc_700.gif"

"SpinorsDoc_701.gif"

"SpinorsDoc_702.gif"

6. Example: Killing spinors

Let us introduce a symmetric valence-2 spinor:

In[191]:=

"SpinorsDoc_703.gif"

"SpinorsDoc_704.gif"

"SpinorsDoc_705.gif"

We will say that the spinor "SpinorsDoc_706.gif"  is a Killing spinor if the following differential condition is fulfilled.

In[192]:=

"SpinorsDoc_707.gif"

Out[192]=

"SpinorsDoc_708.gif"

In[193]:=

"SpinorsDoc_709.gif"

Killing spinors have a number of applications. For example whenever a Killing spinor exists then automatically one can construct a conformal Killing-Yano tensor and a conformal Killing spinor in the spacetime which in turn lead to the existence of integration constants for the geodesic equations. These results were presented by M. Walker and R. Penrose in "On Quadratic First Integrals of the Geodesic Equations in {2,2} Spacetimes" Comm. Math. Phys. 18 265-274 (1970) and we will re-derive them with the aid of Spinors`.

6.2. Existence of a Killing spinor

The existence of a Killing spinor imposes restrictions on the Weyl spinor. To find them, we start by taking the derivative of the Killing spinor condition.

In[194]:=

"SpinorsDoc_710.gif"

Out[194]=

"SpinorsDoc_711.gif"

We decompose each term of this sum into irreducible parts by making use of the "box operator".

In[195]:=

"SpinorsDoc_712.gif"

Out[195]=

"SpinorsDoc_713.gif"

The action of the box operator is computed next.

In[196]:=

"SpinorsDoc_714.gif"

Out[196]=

"SpinorsDoc_715.gif"

We decompose the curvature spinor into irreducible parts.

In[197]:=

"SpinorsDoc_716.gif"

Out[197]=

"SpinorsDoc_717.gif"

In[198]:=

"SpinorsDoc_718.gif"

Out[198]=

"SpinorsDoc_719.gif"

We are only interested in the symmetric part of this expression.

In[199]:=

"SpinorsDoc_720.gif"

In[200]:=

"SpinorsDoc_721.gif"

Out[200]=

"SpinorsDoc_722.gif"

We will refer to this condition as the Killing spinor integrability condition.

In[201]:=

"SpinorsDoc_723.gif"

This algebraic condition implies that the algebraic type of the Weyl spinor can be only D or N.

6.3. Conformal Killing-Yano tensors

We are going to find the tensor representation of the Killing spinor condition. To that end we define an antisymmetric tensor and its spinor counterpart.

In[202]:=

"SpinorsDoc_724.gif"

"SpinorsDoc_725.gif"

In[203]:=

"SpinorsDoc_726.gif"

"SpinorsDoc_727.gif"

"SpinorsDoc_728.gif"

The spinor "SpinorsDoc_729.gif" is defined by the condition:

In[204]:=

"SpinorsDoc_730.gif"

Out[204]=

"SpinorsDoc_731.gif"

This entails:

In[205]:=

"SpinorsDoc_732.gif"

Out[205]=

"SpinorsDoc_733.gif"

In[206]:=

"SpinorsDoc_734.gif"

Out[206]=

"SpinorsDoc_735.gif"

In[207]:=

"SpinorsDoc_736.gif"

Out[207]=

"SpinorsDoc_737.gif"

In[208]:=

"SpinorsDoc_738.gif"

Out[208]=

"SpinorsDoc_739.gif"

In[209]:=

"SpinorsDoc_740.gif"

We need to compute the complex conjugate of this rule

In[210]:=

"SpinorsDoc_741.gif"

Out[210]=

"SpinorsDoc_742.gif"

In[211]:=

"SpinorsDoc_743.gif"

Out[211]=

"SpinorsDoc_744.gif"

In[212]:=

"SpinorsDoc_745.gif"

We can now proceed to the computation of the spinor form of the Killing spinor condition. First of all, we need to have as many primed indices as unprimed ones and we achieve this by multiplying by "SpinorsDoc_746.gif" on both sides of the Killing spinor condition.

In[213]:=

"SpinorsDoc_747.gif"

Out[213]=

"SpinorsDoc_748.gif"

This can be now transformed into a tensor expression.

In[214]:=

"SpinorsDoc_749.gif"

Out[214]=

"SpinorsDoc_750.gif"

In[215]:=

"SpinorsDoc_751.gif"

Out[215]=

"SpinorsDoc_752.gif"

We replace "SpinorsDoc_753.gif"  by the expression in terms of "SpinorsDoc_754.gif" found above.

In[216]:=

"SpinorsDoc_755.gif"

Out[216]=

"SpinorsDoc_756.gif"

We get rid of spinor indices in the covariant derivatives.

In[217]:=

"SpinorsDoc_757.gif"

Out[217]=

"SpinorsDoc_758.gif"

Finally, we replace the product of soldering form by products of "tetra-metrics". This eliminates all the spinor indices.

In[218]:=

"SpinorsDoc_759.gif"

Out[218]=

"SpinorsDoc_760.gif"

All the quantities appearing in previous expression are tensorial, so we may replace the spin covariant derivative by the Levi-Civita covariant derivative.

In[219]:=

"SpinorsDoc_761.gif"

Out[219]=

"SpinorsDoc_762.gif"

In[220]:=

"SpinorsDoc_763.gif"

Out[220]=

"SpinorsDoc_764.gif"

In[221]:=

"SpinorsDoc_765.gif"

Out[221]=

"SpinorsDoc_766.gif"

In[222]:=

"SpinorsDoc_767.gif"

Out[222]=

"SpinorsDoc_768.gif"

In[223]:=

"SpinorsDoc_769.gif"

Out[223]=

"SpinorsDoc_770.gif"

We split this expression into real and imaginary parts.

In[224]:=

"SpinorsDoc_771.gif"

Out[224]=

"SpinorsDoc_772.gif"

In[225]:=

"SpinorsDoc_773.gif"

Out[225]=

"SpinorsDoc_774.gif"

In[226]:=

"SpinorsDoc_775.gif"

Out[226]=

"SpinorsDoc_776.gif"

In[227]:=

"SpinorsDoc_777.gif"

Out[227]=

"SpinorsDoc_778.gif"

In[228]:=

"SpinorsDoc_779.gif"

Out[228]=

"SpinorsDoc_780.gif"

In[229]:=

"SpinorsDoc_781.gif"

Out[229]=

"SpinorsDoc_782.gif"

In[230]:=

"SpinorsDoc_783.gif"

Out[230]=

"SpinorsDoc_784.gif"

In[231]:=

"SpinorsDoc_785.gif"

Out[231]=

"SpinorsDoc_786.gif"

In[232]:=

"SpinorsDoc_787.gif"

In[233]:=

"SpinorsDoc_788.gif"

Out[233]=

"SpinorsDoc_789.gif"

6.3. Conformal Killing tensors

In[234]:=

"SpinorsDoc_790.gif"

"SpinorsDoc_791.gif"

In[235]:=

"SpinorsDoc_792.gif"

"SpinorsDoc_793.gif"

"SpinorsDoc_794.gif"

Consider the following quantity

In[236]:=

"SpinorsDoc_795.gif"

Out[236]=

"SpinorsDoc_796.gif"

In[237]:=

"SpinorsDoc_797.gif"

Out[237]=

"SpinorsDoc_798.gif"

We compute the tensor equivalent of this

In[238]:=

"SpinorsDoc_799.gif"

Out[238]=

"SpinorsDoc_800.gif"

In[239]:=

"SpinorsDoc_801.gif"

Out[239]=

"SpinorsDoc_802.gif"

In[240]:=

"SpinorsDoc_803.gif"

Out[240]=

"SpinorsDoc_804.gif"

In[241]:=

"SpinorsDoc_805.gif"

Out[241]=

"SpinorsDoc_806.gif"

In[242]:=

"SpinorsDoc_807.gif"

Out[242]=

"SpinorsDoc_808.gif"

In[243]:=

"SpinorsDoc_809.gif"

Out[243]=

"SpinorsDoc_810.gif"

In[244]:=

"SpinorsDoc_811.gif"

We check next that "SpinorsDoc_812.gif" is indeed a conformal Killing tensor.

In[245]:=

"SpinorsDoc_813.gif"

Out[245]=

"SpinorsDoc_814.gif"

In[246]:=

"SpinorsDoc_815.gif"

Out[246]=

"SpinorsDoc_816.gif"

In[247]:=

"SpinorsDoc_817.gif"

Out[247]=

"SpinorsDoc_818.gif"

In[248]:=

"SpinorsDoc_819.gif"

Out[248]=

"SpinorsDoc_820.gif"

In[249]:=

"SpinorsDoc_821.gif"

Out[249]=

"SpinorsDoc_822.gif"

In[250]:=

"SpinorsDoc_823.gif"

Out[250]=

"SpinorsDoc_824.gif"

In[251]:=

"SpinorsDoc_825.gif"

Out[251]=

"SpinorsDoc_826.gif"

In[252]:=

"SpinorsDoc_827.gif"

Out[252]=

"SpinorsDoc_828.gif"

In[253]:=

"SpinorsDoc_829.gif"

Out[253]=

"SpinorsDoc_830.gif"

In[254]:=

"SpinorsDoc_831.gif"

Out[254]=

"SpinorsDoc_832.gif"

In[255]:=

"SpinorsDoc_833.gif"

Out[255]=

"SpinorsDoc_834.gif"

By looking at this expression we realize that "SpinorsDoc_835.gif" is the trace-free part of a Killing tensor if and only if

7. Example: the Dirac equation

7.1. The Dirac Bundle

We define the vector bundle which will contain the Dirac spinors. This is a direct sum of the vector bundles Spin and Spin†.

In[256]:=

"SpinorsDoc_836.gif"

"SpinorsDoc_837.gif"

"SpinorsDoc_838.gif"

Extension of the Levi-Civita covariant derivative to the bundle SpinD.

In[257]:=

"SpinorsDoc_839.gif"

"SpinorsDoc_840.gif"

"SpinorsDoc_841.gif"

"SpinorsDoc_842.gif"

"SpinorsDoc_843.gif"

"SpinorsDoc_844.gif"

Definition of the Clifford algebra elements (gamma matrices)

In[258]:=

"SpinorsDoc_845.gif"

"SpinorsDoc_846.gif"

"SpinorsDoc_847.gif"

The Clifford relation is

In[259]:=

"SpinorsDoc_848.gif"

Out[259]=

"SpinorsDoc_849.gif"

The representation of of the Clifford algebra on SpinD is reducible, Spin and Spin†  being invariant subspaces. This entails the relations

In[260]:=

"SpinorsDoc_850.gif"

"SpinorsDoc_851.gif"

In[261]:=

"SpinorsDoc_852.gif"

"SpinorsDoc_853.gif"

In[262]:=

"SpinorsDoc_854.gif"

In[263]:=

"SpinorsDoc_855.gif"

"SpinorsDoc_856.gif"

In[264]:=

"SpinorsDoc_857.gif"

"SpinorsDoc_858.gif"

In[265]:=

"SpinorsDoc_859.gif"

Using previous relations, the Clifford relation can be split in two equations in the following way

In[266]:=

"SpinorsDoc_860.gif"

Out[266]=

"SpinorsDoc_861.gif"

In[267]:=

"SpinorsDoc_862.gif"

Out[267]=

"SpinorsDoc_863.gif"

In[268]:=

"SpinorsDoc_864.gif"

Out[268]=

"SpinorsDoc_865.gif"

In[269]:=

"SpinorsDoc_866.gif"

Out[269]=

"SpinorsDoc_867.gif"

We compare these equations with the following algebraic properties fulfilled by the soldering form

In[270]:=

"SpinorsDoc_868.gif"

Out[270]=

"SpinorsDoc_869.gif"

Therefore, we conclude the rules

In[271]:=

"SpinorsDoc_870.gif"

Out[271]=

"SpinorsDoc_871.gif"

We turn these relations into automatic rules.

In[272]:=

"SpinorsDoc_872.gif"

"SpinorsDoc_873.gif"

In[273]:=

"SpinorsDoc_874.gif"

"SpinorsDoc_875.gif"

7.2. The Dirac equation

We define the Dirac spinor (fermion).

In[274]:=

"SpinorsDoc_876.gif"

"SpinorsDoc_877.gif"

"SpinorsDoc_878.gif"

We define the fermion mass

In[275]:=

"SpinorsDoc_879.gif"

"SpinorsDoc_880.gif"

This is the Dirac equation as it is usually presented in textbooks.

In[276]:=

"SpinorsDoc_881.gif"

Out[276]=

"SpinorsDoc_882.gif"

We wish to write this equation in terms of spinors defined in Spin and Spin†.

In[277]:=

"SpinorsDoc_883.gif"

Out[277]=

"SpinorsDoc_884.gif"

In[278]:=

"SpinorsDoc_885.gif"

Out[278]=

"SpinorsDoc_886.gif"

The covariant derivative CDd acts now on quantities belonging to Spin and Spin†. Therefore it must be replaced by CDe.

In[279]:=

"SpinorsDoc_887.gif"

Out[279]=

"SpinorsDoc_888.gif"

In[280]:=

"SpinorsDoc_889.gif"

Out[280]=

"SpinorsDoc_890.gif"

We cancel the factor "SpinorsDoc_891.gif" on each side.

In[281]:=

"SpinorsDoc_892.gif"

Out[281]=

"SpinorsDoc_893.gif"

In[282]:=

"SpinorsDoc_894.gif"

It is convenient to introduce two new spinors to represent "SpinorsDoc_895.gif"  and "SpinorsDoc_896.gif"

In[283]:=

"SpinorsDoc_897.gif"

"SpinorsDoc_898.gif"

"SpinorsDoc_899.gif"

In[284]:=

"SpinorsDoc_900.gif"

In[285]:=

"SpinorsDoc_901.gif"

"SpinorsDoc_902.gif"

"SpinorsDoc_903.gif"

In[286]:=

"SpinorsDoc_904.gif"

By definition

In[287]:=

"SpinorsDoc_905.gif"

Out[287]=

"SpinorsDoc_906.gif"

We turn these definitions into automatic rules.

In[288]:=

"SpinorsDoc_907.gif"

"SpinorsDoc_908.gif"

In[289]:=

"SpinorsDoc_909.gif"

"SpinorsDoc_910.gif"

Hence

In[290]:=

"SpinorsDoc_911.gif"

Out[290]=

"SpinorsDoc_912.gif"

Compare this with eq. (4.4.66) of Penrose & Rindler Vol. 1.

7.3. Traces of products of gamma matrices

Traces of an odd number of gamma's are zero:

In[291]:=

"SpinorsDoc_913.gif"

Out[291]=

"SpinorsDoc_914.gif"

In[292]:=

"SpinorsDoc_915.gif"

Out[292]=

"SpinorsDoc_916.gif"

But not traces of an even number :

In[293]:=

"SpinorsDoc_917.gif"

Out[293]=

"SpinorsDoc_918.gif"

In[294]:=

"SpinorsDoc_919.gif"

Out[294]=

"SpinorsDoc_920.gif"

In[295]:=

"SpinorsDoc_921.gif"

Out[295]=

"SpinorsDoc_922.gif"

In[296]:=

"SpinorsDoc_923.gif"

Out[296]=

"SpinorsDoc_924.gif"

In[297]:=

"SpinorsDoc_925.gif"

Out[297]=

"SpinorsDoc_926.gif"

Notes

In[298]:=

"SpinorsDoc_927.gif"

Out[298]=

"SpinorsDoc_928.gif"

In[299]:=

"SpinorsDoc_929.gif"

Out[299]=

"SpinorsDoc_930.gif"

Note: For further information about Spinors`, and to be kept informed about new releases, you may contact the authors electronically at algar@mai.liu.se, garcia@iap.fr. This is SpinorsDoc.nb, the docfile of Spinors`, currently in version 0.9.2.    

In[300]:=

"SpinorsDoc_931.gif"

"SpinorsDoc_932.gif"

Spikey Created with Wolfram Mathematica 7.0